cnhis-design-vue 3.3.3-release.8 → 3.3.3-release.9

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 (75) hide show
  1. package/README.md +87 -87
  2. package/es/components/audio-sdk/src/utils/recorder/fft.d.ts +4 -0
  3. package/es/components/audio-sdk/src/utils/recorder/mp3-engine.d.ts +4 -0
  4. package/es/components/audio-sdk/src/utils/recorder/mp3.d.ts +4 -0
  5. package/es/components/audio-sdk/src/utils/recorder/recorder.d.ts +4 -0
  6. package/es/components/audio-sdk/src/utils/recorder/wave.d.ts +4 -0
  7. package/es/components/bpmn-workflow/src/BpmnWorkflow.d.ts +0 -0
  8. package/es/components/bpmn-workflow/types/BpmnViewer.d.ts +1 -0
  9. package/es/components/bpmn-workflow/types/ModelingModule.d.ts +1 -0
  10. package/es/components/bpmn-workflow/types/MoveCanvasModule.d.ts +1 -0
  11. package/es/components/button-print/src/components/OldPrintComponent.vue2.js +1 -1
  12. package/es/components/card-render/src/components/index.d.ts +23 -23
  13. package/es/components/classification/src/components/table-modal/index.vue.d.ts +0 -3
  14. package/es/components/date-picker/src/DatePicker.vue2.js +8 -1
  15. package/es/components/field-set/src/FieldColor.vue.d.ts +4 -4
  16. package/es/components/field-set/src/FieldFilter.vue.d.ts +4 -4
  17. package/es/components/field-set/src/FieldSet.vue.d.ts +5 -5
  18. package/es/components/field-set/src/components/table-row.vue.d.ts +4 -4
  19. package/es/components/form-config/src/components/FormConfigEventSetting.vue2.js +1 -1
  20. package/es/components/form-render/src/components/renderer/searchCascade.js +3 -0
  21. package/es/components/form-render/src/hooks/useLowCodeReactions.js +2 -1
  22. package/es/components/iho-chat/index.d.ts +4 -4
  23. package/es/components/iho-chat/src/Index.vue.d.ts +4 -4
  24. package/es/components/iho-chat/src/components/ChatFile.vue.d.ts +2 -2
  25. package/es/components/iho-chat/src/components/ChatFile.vue2.js +5 -15
  26. package/es/components/iho-chat/src/components/ChatFooter.vue2.js +1 -1
  27. package/es/components/iho-chat/src/components/ChatHeader.vue.d.ts +2 -2
  28. package/es/components/iho-chat/src/components/ChatMain.vue.d.ts +3 -3
  29. package/es/components/iho-chat/src/components/ChatMain.vue2.js +7 -15
  30. package/es/components/iho-chat/src/components/ChatRecord.vue.d.ts +2 -2
  31. package/es/components/iho-chat/src/components/ChatRecord.vue2.js +3 -3
  32. package/es/components/iho-chat/src/components/ContextMenu.js +3 -11
  33. package/es/components/iho-chat/src/components/MessageMergeForward.vue.d.ts +2 -2
  34. package/es/components/iho-chat/src/components/MessageMergeForward.vue2.js +3 -3
  35. package/es/components/iho-chat/src/components/PersonProfile.vue2.js +1 -1
  36. package/es/components/iho-chat/src/hooks/useData.js +2 -7
  37. package/es/components/iho-chat/src/utils/index.d.ts +2 -3
  38. package/es/components/iho-chat/src/utils/index.js +20 -39
  39. package/es/components/iho-table/src/plugins/filterRenderPlugin/filter.vue2.js +8 -1
  40. package/es/components/iho-table/src/plugins/headerPlugin/index.js +5 -2
  41. package/es/components/iho-table/src/plugins/highLightSetPlugin.js +2 -1
  42. package/es/components/select-person/src/SelectPerson.vue2.js +1 -1
  43. package/es/env.d.ts +25 -25
  44. package/es/shared/assets/img/defaultCover/10review_successful.png.js +1 -1
  45. package/es/shared/assets/img/defaultCover/11review_fail.png.js +1 -1
  46. package/es/shared/assets/img/defaultCover/12no_setting.png.js +1 -1
  47. package/es/shared/assets/img/defaultCover/13no_menu_setting.png.js +1 -1
  48. package/es/shared/assets/img/defaultCover/14no_call_setting.png.js +1 -1
  49. package/es/shared/assets/img/defaultCover/15no_use_tag.png.js +1 -1
  50. package/es/shared/assets/img/defaultCover/16no_table_data.png.js +1 -1
  51. package/es/shared/assets/img/defaultCover/1location.png.js +1 -1
  52. package/es/shared/assets/img/defaultCover/2notfound.png.js +1 -1
  53. package/es/shared/assets/img/defaultCover/3loading.png.js +1 -1
  54. package/es/shared/assets/img/defaultCover/4no_permission.png.js +1 -1
  55. package/es/shared/assets/img/defaultCover/5no_data.png.js +1 -1
  56. package/es/shared/assets/img/defaultCover/6no_network.png.js +1 -1
  57. package/es/shared/assets/img/defaultCover/7no_doctor.png.js +1 -1
  58. package/es/shared/assets/img/defaultCover/8system_error.png.js +1 -1
  59. package/es/shared/assets/img/defaultCover/9system_upgrade.png.js +1 -1
  60. package/es/shared/assets/img/failure.png.js +1 -1
  61. package/es/shared/assets/img/no-permission.png.js +1 -1
  62. package/es/shared/assets/img/nodata.png.js +1 -1
  63. package/es/shared/assets/img/notfound.png.js +1 -1
  64. package/es/shared/assets/img/qr.png.js +1 -1
  65. package/es/shared/assets/img/success.png.js +1 -1
  66. package/es/shared/assets/img/table_style_2.png.js +1 -1
  67. package/es/shared/assets/img/video.png.js +1 -1
  68. package/es/shared/assets/img/video_default_cover.png.js +1 -1
  69. package/es/shared/assets/img/xb_big.png.js +1 -1
  70. package/es/shared/assets/img/xb_small.png.js +1 -1
  71. package/es/shared/components/VueDraggable/src/vuedraggable.d.ts +86 -0
  72. package/es/shared/package.json.js +1 -1
  73. package/es/shared/utils/fabricjs/index.d.ts +6823 -0
  74. package/es/shared/utils/tapable/index.d.ts +139 -0
  75. package/package.json +3 -3
@@ -1,7 +1,7 @@
1
1
  import { CSSProperties } from 'vue';
2
2
  import { ImageRenderToolbarProps } from 'naive-ui';
3
3
  import { AnyObject } from '../../../../shared/types';
4
- import { simplifyMessage, isAudioOrVideoMessage, getAVTime, getForwardTitle } from '../utils';
4
+ import { simplifyMessage, isAudioOrVideoMessage, getAVTime, getForwardTitle, formatJsonstr } from '../utils';
5
5
  import { MESSAGE_TYPE } from '../constants';
6
6
  declare const _default: import("vue").DefineComponent<{}, {
7
7
  chatMainRef: import("vue").Ref<HTMLElement | undefined>;
@@ -71,7 +71,6 @@ declare const _default: import("vue").DefineComponent<{}, {
71
71
  renderToolbar: ({ nodes }: ImageRenderToolbarProps) => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
72
72
  [key: string]: any;
73
73
  }>[];
74
- formatImage: (obj: AnyObject | string, type: string) => any;
75
74
  getHistoryRecord: () => Promise<void>;
76
75
  handleSelectLabel: (event: MouseEvent, msgId: string) => void;
77
76
  handleContextmenu: (event: MouseEvent, msgId: string) => Promise<void>;
@@ -290,7 +289,7 @@ declare const _default: import("vue").DefineComponent<{}, {
290
289
  getForwardTitle: typeof getForwardTitle;
291
290
  isDoctorRole: typeof import("../utils").isDoctorRole;
292
291
  getRoleName: typeof import("../utils").getRoleName;
293
- getFileDetails: typeof import("../utils").getFileDetails;
292
+ formatJsonstr: typeof formatJsonstr;
294
293
  getFileType: typeof import("../utils").getFileType;
295
294
  getDetail: typeof import("../utils").getDetail;
296
295
  showAudioAndVideoRecord: typeof import("../utils").showAudioAndVideoRecord;
@@ -653,6 +652,7 @@ declare const _default: import("vue").DefineComponent<{}, {
653
652
  isAudioOrVideoMessage: typeof isAudioOrVideoMessage;
654
653
  getAVTime: typeof getAVTime;
655
654
  getForwardTitle: typeof getForwardTitle;
655
+ formatJsonstr: typeof formatJsonstr;
656
656
  MESSAGE_TYPE: typeof MESSAGE_TYPE;
657
657
  ChatbubbleEllipsesOutline: import("vue").DefineComponent<{}, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, import("vue").EmitsOptions, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{}>>, {}>;
658
658
  EllipsisHorizontal: import("vue").DefineComponent<{}, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, import("vue").EmitsOptions, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{}>>, {}>;
@@ -6,7 +6,7 @@ import { useData } from '../hooks/useData.js';
6
6
  import 'stompjs';
7
7
  import 'sockjs-client/dist/sockjs.min.js';
8
8
  import { MESSAGE_TYPE } from '../constants/index.js';
9
- import { isAudioOrVideoMessage, simplifyMessage, getForwardTitle, getAVTime, downloadFile } from '../utils/index.js';
9
+ import { isAudioOrVideoMessage, simplifyMessage, getForwardTitle, formatJsonstr, getAVTime, downloadFile } from '../utils/index.js';
10
10
  import { first, last, isArray, toString } from 'lodash-es';
11
11
  import 'trtc-sdk-v5';
12
12
  import MessageTemplate from './MessageTemplate.vue.js';
@@ -130,7 +130,10 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
130
130
  "color": "rgba(255, 255, 255, 0.75",
131
131
  "size": 24,
132
132
  "component": ArrowDownSharp,
133
- "onClick": () => src && downloadFile(src, "img")
133
+ "onClick": () => src && downloadFile(JSON.stringify({
134
+ fileUrl: src,
135
+ fileName: "image"
136
+ }))
134
137
  }, null),
135
138
  default: () => function() {
136
139
  var _a2, _b2, _c;
@@ -142,17 +145,6 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
142
145
  }()
143
146
  }), nodes.close];
144
147
  }
145
- function formatImage(obj, type) {
146
- try {
147
- if (typeof obj === "string") {
148
- const objParse = JSON.parse(obj);
149
- return objParse[type];
150
- }
151
- return obj[type];
152
- } catch (error) {
153
- return obj;
154
- }
155
- }
156
148
  async function getHistoryRecord() {
157
149
  try {
158
150
  if (!pageInfo.hasMore)
@@ -490,7 +482,7 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
490
482
  }), 128))])], 8, _hoisted_14)) : createCommentVNode("v-if", true), item.content.chatMessageType === unref(MESSAGE_TYPE).IMAGE ? (openBlock(), createBlock(unref(NImage), {
491
483
  key: 4,
492
484
  width: "240",
493
- src: formatImage(item.__content, "fileUrl"),
485
+ src: unref(formatJsonstr)(item.__content, "fileUrl"),
494
486
  onClick: _cache[0] || (_cache[0] = (event) => event.stopPropagation())
495
487
  }, null, 8, ["src"])) : createCommentVNode("v-if", true), unref(isAudioOrVideoMessage)(item.content) ? (openBlock(), createElementBlock(Fragment, {
496
488
  key: 5
@@ -515,7 +507,7 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
515
507
  "row-gap": "0"
516
508
  }
517
509
  }, {
518
- default: withCtx(() => [createElementVNode("span", null, toDisplayString(formatImage(item.__content, "fileName")), 1), createElementVNode("span", _hoisted_19, toDisplayString(item.__size), 1)]),
510
+ default: withCtx(() => [createElementVNode("span", null, toDisplayString(unref(formatJsonstr)(item.__content, "fileName")), 1), createElementVNode("span", _hoisted_19, toDisplayString(unref(formatJsonstr)(item.__content, "fileSize")), 1)]),
519
511
  _: 2
520
512
  }, 1024)]),
521
513
  _: 2
@@ -1,6 +1,6 @@
1
1
  import { PropType } from 'vue';
2
2
  import { AnyObject } from '../../../../shared/types';
3
- import { formatTime, isDoctorRole, getRoleName, getFileDetails, getFileType, getDetail, showAudioAndVideoRecord, getForwardTitle, simplifyMessage } from '../utils';
3
+ import { formatTime, isDoctorRole, getRoleName, formatJsonstr, getFileType, getDetail, showAudioAndVideoRecord, getForwardTitle, simplifyMessage } from '../utils';
4
4
  import { MESSAGE_TYPE } from '../constants';
5
5
  declare const _default: import("vue").DefineComponent<{
6
6
  visible: {
@@ -213,7 +213,7 @@ declare const _default: import("vue").DefineComponent<{
213
213
  formatTime: typeof formatTime;
214
214
  isDoctorRole: typeof isDoctorRole;
215
215
  getRoleName: typeof getRoleName;
216
- getFileDetails: typeof getFileDetails;
216
+ formatJsonstr: typeof formatJsonstr;
217
217
  getFileType: typeof getFileType;
218
218
  getDetail: typeof getDetail;
219
219
  showAudioAndVideoRecord: typeof showAudioAndVideoRecord;
@@ -6,7 +6,7 @@ import 'stompjs';
6
6
  import 'sockjs-client/dist/sockjs.min.js';
7
7
  import { MESSAGE_TYPE } from '../constants/index.js';
8
8
  import { searchChatRecordApi } from '../api/index.js';
9
- import { transformMessage, isDoctorRole, getRoleName, formatTime, getFileDetails, getFileType, getDetail, showAudioAndVideoRecord, getForwardTitle, simplifyMessage } from '../utils/index.js';
9
+ import { transformMessage, isDoctorRole, getRoleName, formatTime, formatJsonstr, getFileType, getDetail, showAudioAndVideoRecord, getForwardTitle, simplifyMessage } from '../utils/index.js';
10
10
  import { last, isArray } from 'lodash-es';
11
11
  import 'trtc-sdk-v5';
12
12
  import DatePicker from '../../../date-picker/index.js';
@@ -369,10 +369,10 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
369
369
  class: normalizeClass(["iho-chatRole", unref(isDoctorRole)(item.roleInfo) ? "isDoctor" : ""])
370
370
  }, toDisplayString(unref(getRoleName)(item.roleInfo)), 3), [[vShow, unref(getRoleName)(item.roleInfo)]])]), createElementVNode("span", _hoisted_9, toDisplayString(unref(formatTime)(item.sendTime).recordTime), 1)]), createElementVNode("div", _hoisted_10, [item.content.chatMessageType === unref(MESSAGE_TYPE).IMAGE ? (openBlock(), createElementBlock("img", {
371
371
  key: 0,
372
- src: unref(getFileDetails)(item.__content, "fileUrl")
372
+ src: unref(formatJsonstr)(item.__content, "fileUrl")
373
373
  }, null, 8, _hoisted_11)) : item.content.chatMessageType === unref(MESSAGE_TYPE).FILE ? (openBlock(), createElementBlock(Fragment, {
374
374
  key: 1
375
- }, [createElementVNode("span", _hoisted_12, toDisplayString(unref(getFileType)(item.__content)), 1), createElementVNode("div", _hoisted_13, [createElementVNode("span", _hoisted_14, toDisplayString(unref(getFileDetails)(item.__content, "fileName")), 1), createElementVNode("span", _hoisted_15, toDisplayString(unref(getDetail)(item)), 1)])], 64)) : item.content.chatMessageType === unref(MESSAGE_TYPE).EMOJI ? (openBlock(), createElementBlock("img", {
375
+ }, [createElementVNode("span", _hoisted_12, toDisplayString(unref(getFileType)(item.__content)), 1), createElementVNode("div", _hoisted_13, [createElementVNode("span", _hoisted_14, toDisplayString(unref(formatJsonstr)(item.__content, "fileName")), 1), createElementVNode("span", _hoisted_15, toDisplayString(unref(getDetail)(item)), 1)])], 64)) : item.content.chatMessageType === unref(MESSAGE_TYPE).EMOJI ? (openBlock(), createElementBlock("img", {
376
376
  key: 2,
377
377
  class: "emoji",
378
378
  src: unref(emojis).findEmoji(item.__content)
@@ -7,7 +7,7 @@ import 'stompjs';
7
7
  import 'sockjs-client/dist/sockjs.min.js';
8
8
  import { STATUS, MESSAGE_TYPE } from '../constants/index.js';
9
9
  import { recallMessageApi } from '../api/index.js';
10
- import { isAudioOrVideoMessage, $message, downloadFile, getFileDetails } from '../utils/index.js';
10
+ import { isAudioOrVideoMessage, $message, downloadFile, formatJsonstr } from '../utils/index.js';
11
11
  import 'lodash-es';
12
12
  import 'trtc-sdk-v5';
13
13
  import { emojis } from '../utils/emoji.js';
@@ -192,7 +192,7 @@ var ContextMenu = /* @__PURE__ */ defineComponent({
192
192
  } else {
193
193
  let data;
194
194
  if ([MESSAGE_TYPE.EMOJI, MESSAGE_TYPE.IMAGE].includes(chatMessageType)) {
195
- const url = chatMessageType === MESSAGE_TYPE.EMOJI ? emojis.findEmoji(content.msg) : getFileDetails(content.msg, "fileUrl");
195
+ const url = chatMessageType === MESSAGE_TYPE.EMOJI ? emojis.findEmoji(content.msg) : formatJsonstr(content.msg, "fileUrl");
196
196
  data = `<img data-msg=${chatMessageType === MESSAGE_TYPE.EMOJI ? content.msg : ""} data-type=${chatMessageType} class=${chatMessageType === MESSAGE_TYPE.EMOJI ? "emoji--min" : "chat-image-copy"} src=${url} />`;
197
197
  } else if (chatMessageType === MESSAGE_TYPE.BLEND) {
198
198
  data = __content;
@@ -211,15 +211,7 @@ var ContextMenu = /* @__PURE__ */ defineComponent({
211
211
  }
212
212
  return;
213
213
  case "download": {
214
- let {
215
- fileUrl: url,
216
- msg: fileName
217
- } = content;
218
- if (chatMessageType === MESSAGE_TYPE.IMAGE) {
219
- url = fileName;
220
- fileName = fileName.match(/\/([^\/?#]+)$/)[1];
221
- }
222
- downloadFile(url, fileName);
214
+ downloadFile(__content);
223
215
  return;
224
216
  }
225
217
  case "withdraw": {
@@ -1,5 +1,5 @@
1
1
  import { AnyObject } from '../../../../shared/types';
2
- import { formatTime, getForwardTitle, isDoctorRole, getRoleName, getFileDetails, getFileType, getDetail, showAudioAndVideoRecord, simplifyMessage } from '../utils';
2
+ import { formatTime, getForwardTitle, isDoctorRole, getRoleName, formatJsonstr, getFileType, getDetail, showAudioAndVideoRecord, simplifyMessage } from '../utils';
3
3
  import { MESSAGE_TYPE } from '../constants';
4
4
  declare const _default: import("vue").DefineComponent<{
5
5
  id: {
@@ -54,7 +54,7 @@ declare const _default: import("vue").DefineComponent<{
54
54
  getForwardTitle: typeof getForwardTitle;
55
55
  isDoctorRole: typeof isDoctorRole;
56
56
  getRoleName: typeof getRoleName;
57
- getFileDetails: typeof getFileDetails;
57
+ formatJsonstr: typeof formatJsonstr;
58
58
  getFileType: typeof getFileType;
59
59
  getDetail: typeof getDetail;
60
60
  showAudioAndVideoRecord: typeof showAudioAndVideoRecord;
@@ -5,7 +5,7 @@ import 'stompjs';
5
5
  import 'sockjs-client/dist/sockjs.min.js';
6
6
  import { MESSAGE_TYPE } from '../constants/index.js';
7
7
  import '../api/index.js';
8
- import { transformMessage, getForwardTitle, isDoctorRole, getRoleName, formatTime, getFileDetails, getFileType, getDetail, showAudioAndVideoRecord, simplifyMessage } from '../utils/index.js';
8
+ import { transformMessage, getForwardTitle, isDoctorRole, getRoleName, formatTime, formatJsonstr, getFileType, getDetail, showAudioAndVideoRecord, simplifyMessage } from '../utils/index.js';
9
9
  import { isArray } from 'lodash-es';
10
10
  import 'trtc-sdk-v5';
11
11
  import { emojis } from '../utils/emoji.js';
@@ -116,10 +116,10 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
116
116
  }
117
117
  }, toDisplayString(unref(getRoleName)(item.roleInfo)), 3), [[vShow, unref(getRoleName)(item.roleInfo)]])]), createElementVNode("span", null, toDisplayString(unref(formatTime)(item.sendTime).recordTime), 1)]), createElementVNode("div", _hoisted_5, [item.content.chatMessageType === unref(MESSAGE_TYPE).IMAGE ? (openBlock(), createElementBlock("img", {
118
118
  key: 0,
119
- src: unref(getFileDetails)(item.__content, "fileUrl")
119
+ src: unref(formatJsonstr)(item.__content, "fileUrl")
120
120
  }, null, 8, _hoisted_6)) : item.content.chatMessageType === unref(MESSAGE_TYPE).FILE ? (openBlock(), createElementBlock(Fragment, {
121
121
  key: 1
122
- }, [createElementVNode("span", _hoisted_7, toDisplayString(unref(getFileType)(item.__content)), 1), createElementVNode("div", _hoisted_8, [createElementVNode("span", _hoisted_9, toDisplayString(unref(getFileDetails)(item.__content, "fileName")), 1), createElementVNode("span", _hoisted_10, toDisplayString(unref(getDetail)(item)), 1)])], 64)) : item.content.chatMessageType === unref(MESSAGE_TYPE).EMOJI ? (openBlock(), createElementBlock("img", {
122
+ }, [createElementVNode("span", _hoisted_7, toDisplayString(unref(getFileType)(item.__content)), 1), createElementVNode("div", _hoisted_8, [createElementVNode("span", _hoisted_9, toDisplayString(unref(formatJsonstr)(item.__content, "fileName")), 1), createElementVNode("span", _hoisted_10, toDisplayString(unref(getDetail)(item)), 1)])], 64)) : item.content.chatMessageType === unref(MESSAGE_TYPE).EMOJI ? (openBlock(), createElementBlock("img", {
123
123
  key: 2,
124
124
  class: "emoji",
125
125
  src: unref(emojis).findEmoji(item.__content)
@@ -225,7 +225,7 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
225
225
  round: "",
226
226
  size: 100,
227
227
  onClickCapture: _cache[0] || (_cache[0] = ($event) => showLargeAvatar.value = true)
228
- }, null, 8, ["src"]), createCommentVNode(' <n-upload abstract accept="image/*" @change="onChange">\r\n <n-upload-trigger #="{ handleClick }" abstract>\r\n <n-button\r\n circle\r\n secondary\r\n class="edit-avatar"\r\n v-show="userDetail.id === state.userInfo.id"\r\n @click="handleClick"\r\n >\r\n <template #icon>\r\n <n-icon size="16" color="#666666" :component="Camera" />\r\n </template>\r\n </n-button>\r\n </n-upload-trigger>\r\n </n-upload> '), createElementVNode("div", _hoisted_4, [createElementVNode("h4", null, [createElementVNode("label", _hoisted_5, toDisplayString(userDetail.name), 1), withDirectives(createElementVNode("label", {
228
+ }, null, 8, ["src"]), createCommentVNode(' <n-upload abstract accept="image/*" @change="onChange">\n <n-upload-trigger #="{ handleClick }" abstract>\n <n-button\n circle\n secondary\n class="edit-avatar"\n v-show="userDetail.id === state.userInfo.id"\n @click="handleClick"\n >\n <template #icon>\n <n-icon size="16" color="#666666" :component="Camera" />\n </template>\n </n-button>\n </n-upload-trigger>\n </n-upload> '), createElementVNode("div", _hoisted_4, [createElementVNode("h4", null, [createElementVNode("label", _hoisted_5, toDisplayString(userDetail.name), 1), withDirectives(createElementVNode("label", {
229
229
  class: normalizeClass(["iho-chatRole", unref(isDoctorRole)(userDetail.roleInfo) ? "isDoctor" : ""])
230
230
  }, toDisplayString(unref(getRoleName)(userDetail.roleInfo)), 3), [[vShow, unref(getRoleName)(userDetail.roleInfo)]])]), createElementVNode("p", null, toDisplayString(userDetail.orgName), 1)]), createVNode(unref(NButton), {
231
231
  strong: "",
@@ -1,9 +1,9 @@
1
1
  import { ref, reactive, computed, watch, toRef, inject, toRaw } from 'vue';
2
2
  import { openSessionApi, updateStatusApi, groupUserApi } from '../api/index.js';
3
3
  import { promiseTimeout, useIntervalFn } from '@vueuse/core';
4
- import { isGroup, listSort, formatTime, transformMessage, getFileSize, $message, simplifyMessage } from '../utils/index.js';
4
+ import { isGroup, listSort, formatTime, transformMessage, $message, simplifyMessage } from '../utils/index.js';
5
5
  import { cloneDeep, remove, isArray, uniqBy } from 'lodash-es';
6
- import { STATUS, MESSAGE_TYPE, CHAT_TYPE } from '../constants/index.js';
6
+ import { STATUS, CHAT_TYPE, MESSAGE_TYPE } from '../constants/index.js';
7
7
  import { useTheme } from '../../../../shared/hooks/useTheme.js';
8
8
  import 'date-fns';
9
9
  import '@vue/shared';
@@ -139,11 +139,6 @@ function initData(props, emit) {
139
139
  __content: transformMessage(item.content),
140
140
  __sendTime: formatTime(item.sendTime).recordTime
141
141
  });
142
- if (item.content.chatMessageType === MESSAGE_TYPE.FILE && !item.__size) {
143
- getFileSize(item.content.fileUrl).then((size) => {
144
- item.__size = size;
145
- });
146
- }
147
142
  });
148
143
  if (needUpdateTime()) {
149
144
  resume();
@@ -9,8 +9,7 @@ export declare function listSort(list: AnyObject[]): AnyObject[];
9
9
  export declare function transformMessage(content: AnyObject): any;
10
10
  export declare function getAVTime(msg: string): string;
11
11
  export declare function simplifyMessage(lastMessage: AnyObject): any;
12
- export declare function downloadFile(url: string, filename: string): void;
13
- export declare function getFileSize(url: string): Promise<unknown>;
12
+ export declare function downloadFile(msg: string): void;
14
13
  export declare function base64ToFile(base64: string): Promise<File | undefined>;
15
14
  export declare function isAudioOrVideoMessage(message: AnyObject): boolean;
16
15
  export declare function formatSeconds(seconds: number): string;
@@ -18,7 +17,7 @@ export declare function isGroup(session: AnyObject): boolean;
18
17
  export declare function getForwardTitle(content: AnyObject): string | undefined;
19
18
  export declare function isDoctorRole(type: string): boolean;
20
19
  export declare function getRoleName(type: string): string;
21
- export declare function getFileDetails(msg: string, type: string): any;
22
20
  export declare function getFileType(msg: string): string;
23
21
  export declare function getDetail(item: AnyObject, isShowSize?: boolean): string;
24
22
  export declare function showAudioAndVideoRecord(chatMessageType: string): "语音通话" | "视频通话";
23
+ export declare function formatJsonstr(obj: AnyObject | string, type: string): any;
@@ -177,44 +177,24 @@ function simplifyMessage(lastMessage) {
177
177
  return "[\u6D88\u606F]";
178
178
  }
179
179
  }
180
- function downloadFile(url, filename) {
180
+ function downloadFile(msg) {
181
+ const fileName = formatJsonstr(msg, "fileName");
182
+ const fileUrl = formatJsonstr(msg, "fileUrl");
181
183
  const x = new XMLHttpRequest();
182
- x.open("GET", url, true);
184
+ x.open("GET", fileUrl, true);
183
185
  x.responseType = "blob";
184
186
  x.onload = function(e) {
185
187
  if (x.status === 200) {
186
188
  const _url = window.URL.createObjectURL(x.response);
187
189
  const a = document.createElement("a");
188
190
  a.href = _url;
189
- a.download = filename;
191
+ a.download = fileName;
190
192
  a.dispatchEvent(new MouseEvent("click"));
191
193
  window.URL.revokeObjectURL(_url);
192
194
  }
193
195
  };
194
196
  x.send();
195
197
  }
196
- function getFileSize(url) {
197
- return new Promise((resolve, reject) => {
198
- const x = new XMLHttpRequest();
199
- x.open("HEAD", url, true);
200
- x.onreadystatechange = () => {
201
- var _a;
202
- if (x.readyState === 4 && x.status === 200) {
203
- let size = (_a = x.getResponseHeader("Content-Length")) != null ? _a : 0;
204
- const _size = +size;
205
- if (_size > 1024 * 1024) {
206
- size = (_size / (1024 * 1024)).toFixed(2) + "M";
207
- } else if (_size > 1024) {
208
- size = (_size / 1024).toFixed(2) + "K";
209
- } else {
210
- size = size + "B";
211
- }
212
- resolve(size);
213
- }
214
- };
215
- x.send();
216
- });
217
- }
218
198
  async function base64ToFile(base64) {
219
199
  try {
220
200
  const res = await fetch(base64);
@@ -272,17 +252,6 @@ function getRoleName(type) {
272
252
  }
273
253
  return roleName;
274
254
  }
275
- function getFileDetails(msg, type) {
276
- try {
277
- const parseMsg = JSON.parse(msg);
278
- if (parseMsg) {
279
- return parseMsg[type];
280
- }
281
- return "";
282
- } catch (error) {
283
- return msg || "";
284
- }
285
- }
286
255
  function getFileType(msg) {
287
256
  const dotIndex = msg.lastIndexOf(".");
288
257
  if (dotIndex !== -1) {
@@ -293,13 +262,14 @@ function getFileType(msg) {
293
262
  }
294
263
  function getDetail(item, isShowSize) {
295
264
  const {
296
- size,
265
+ content = {},
297
266
  sendTime,
298
267
  senderName
299
268
  } = item;
300
269
  const details = `${format(new Date(sendTime), "yyyy/MM/dd HH:mm")} ${senderName}`;
301
270
  if (isShowSize) {
302
- return `${size} \xB7 ${details}`;
271
+ const fileSize = formatJsonstr(content.msg, "fileSize");
272
+ return `${fileSize} \xB7 ${details}`;
303
273
  }
304
274
  return details;
305
275
  }
@@ -320,5 +290,16 @@ function showAudioAndVideoRecord(chatMessageType) {
320
290
  }
321
291
  }();
322
292
  }
293
+ function formatJsonstr(obj, type) {
294
+ try {
295
+ if (typeof obj === "string") {
296
+ const objParse = JSON.parse(obj);
297
+ return objParse[type];
298
+ }
299
+ return obj[type];
300
+ } catch (error) {
301
+ return obj;
302
+ }
303
+ }
323
304
 
324
- export { $message, base64ToFile, downloadFile, formatSeconds, formatTime, getAVTime, getDetail, getFileDetails, getFileSize, getFileType, getForwardTitle, getRoleName, isAudioOrVideoMessage, isDoctorRole, isGroup, listSort, showAudioAndVideoRecord, simplifyMessage, transformMessage };
305
+ export { $message, base64ToFile, downloadFile, formatJsonstr, formatSeconds, formatTime, getAVTime, getDetail, getFileType, getForwardTitle, getRoleName, isAudioOrVideoMessage, isDoctorRole, isGroup, listSort, showAudioAndVideoRecord, simplifyMessage, transformMessage };
@@ -188,7 +188,14 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
188
188
  "onUpdate:checked": _cache[1] || (_cache[1] = ($event) => isRef(partCheckAll) ? partCheckAll.value = $event : null),
189
189
  indeterminate: unref(partIndeterminate)
190
190
  }, {
191
- default: withCtx(() => [createTextVNode("\u5168\u9009\u5F53\u524D")]),
191
+ default: withCtx(() => [createTextVNode(function() {
192
+ var _a, _b, _c;
193
+ try {
194
+ return ((_a = window.getLanguageByCode) == null ? void 0 : _a.call(window, "10010.1.661")) || ((_c = (_b = window.top) == null ? void 0 : _b.getLanguageByCode) == null ? void 0 : _c.call(_b, "10010.1.661")) || "\u5168\u9009\u5F53\u524D";
195
+ } catch (e) {
196
+ return "\u5168\u9009\u5F53\u524D";
197
+ }
198
+ }())]),
192
199
  _: 1
193
200
  }, 8, ["checked", "indeterminate"])])) : createCommentVNode("v-if", true), createElementVNode("div", _hoisted_4, [createVNode(unref(NCheckbox), {
194
201
  checked: unref(checkAll),
@@ -65,8 +65,11 @@ function HeaderPlugin() {
65
65
  return attrs["annotation-shortcuts"] || attrs["annotationShortcuts"] || [];
66
66
  }
67
67
  function getOtherAttrs() {
68
- var _a2;
69
- const fieldDescribe = (_a2 = lowCodeField.settingObj) == null ? void 0 : _a2.fieldDescribe;
68
+ const {
69
+ fieldDescribe: fieldDescribe1,
70
+ feildDescribe: fieldDescribe2
71
+ } = lowCodeField.settingObj || {};
72
+ const fieldDescribe = fieldDescribe1 || fieldDescribe2;
70
73
  return fieldDescribe ? {
71
74
  title: `${column.title}
72
75
  ${fieldDescribe}`
@@ -15,6 +15,7 @@ function highLightSetPlugin() {
15
15
  name: pluginName,
16
16
  apply(hooks) {
17
17
  hooks.dataHooks.data.tapPromise(pluginName, async (row, config) => {
18
+ var _a, _b;
18
19
  if (!config.uuid || getItemFromUUID(config.uuid))
19
20
  return;
20
21
  let hasColor = false;
@@ -23,7 +24,7 @@ function highLightSetPlugin() {
23
24
  return;
24
25
  hasColor = true;
25
26
  stop();
26
- }, ["children", "childrenList"]);
27
+ }, ["childrenList", (_b = (_a = config.treeConfig) == null ? void 0 : _a.children) != null ? _b : "children"]);
27
28
  hasColor && setItemFromUUID(config.uuid, true);
28
29
  });
29
30
  hooks.dataHooks.dataEnd.tap(pluginName, (_, config) => {
@@ -372,7 +372,7 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
372
372
  stack.push(...node.children);
373
373
  }
374
374
  }
375
- return result;
375
+ return result == null ? void 0 : result.reverse();
376
376
  }
377
377
  if (!isRemote.value) {
378
378
  if (isSearch.value && !isShowGroupList.value) {
package/es/env.d.ts CHANGED
@@ -1,25 +1,25 @@
1
- /// <reference types="vite/client" />
2
-
3
- interface ImportMetaEnv {
4
- readonly VITE_APP_TYPE: string;
5
- // 更多环境变量...
6
- }
7
-
8
- interface ImportMeta {
9
- readonly env: ImportMetaEnv;
10
- }
11
-
12
- declare module '*.vue' {
13
- // @ts-ignore
14
- import type { App, defineComponent } from 'vue';
15
- // // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/ban-types
16
- // // const component: DefineComponent<{}, {}, any>
17
- const component: ReturnType<typeof defineComponent> & {
18
- install(app: App): void;
19
- };
20
- // @ts-ignore
21
- export default component;
22
- }
23
-
24
- declare module '*.js';
25
-
1
+ /// <reference types="vite/client" />
2
+
3
+ interface ImportMetaEnv {
4
+ readonly VITE_APP_TYPE: string;
5
+ // 更多环境变量...
6
+ }
7
+
8
+ interface ImportMeta {
9
+ readonly env: ImportMetaEnv;
10
+ }
11
+
12
+ declare module '*.vue' {
13
+ // @ts-ignore
14
+ import type { App, defineComponent } from 'vue';
15
+ // // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/ban-types
16
+ // // const component: DefineComponent<{}, {}, any>
17
+ const component: ReturnType<typeof defineComponent> & {
18
+ install(app: App): void;
19
+ };
20
+ // @ts-ignore
21
+ export default component;
22
+ }
23
+
24
+ declare module '*.js';
25
+
@@ -1,3 +1,3 @@
1
- var ReviewSuccessful = "";
1
+ var ReviewSuccessful = "";
2
2
 
3
3
  export { ReviewSuccessful as default };
@@ -1,3 +1,3 @@
1
- var ReviewFail = "";
1
+ var ReviewFail = "";
2
2
 
3
3
  export { ReviewFail as default };