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.
- package/README.md +87 -87
- package/es/components/audio-sdk/src/utils/recorder/fft.d.ts +4 -0
- package/es/components/audio-sdk/src/utils/recorder/mp3-engine.d.ts +4 -0
- package/es/components/audio-sdk/src/utils/recorder/mp3.d.ts +4 -0
- package/es/components/audio-sdk/src/utils/recorder/recorder.d.ts +4 -0
- package/es/components/audio-sdk/src/utils/recorder/wave.d.ts +4 -0
- package/es/components/bpmn-workflow/src/BpmnWorkflow.d.ts +0 -0
- package/es/components/bpmn-workflow/types/BpmnViewer.d.ts +1 -0
- package/es/components/bpmn-workflow/types/ModelingModule.d.ts +1 -0
- package/es/components/bpmn-workflow/types/MoveCanvasModule.d.ts +1 -0
- package/es/components/button-print/src/components/OldPrintComponent.vue2.js +1 -1
- package/es/components/card-render/src/components/index.d.ts +23 -23
- package/es/components/classification/src/components/table-modal/index.vue.d.ts +0 -3
- package/es/components/date-picker/src/DatePicker.vue2.js +8 -1
- package/es/components/field-set/src/FieldColor.vue.d.ts +4 -4
- package/es/components/field-set/src/FieldFilter.vue.d.ts +4 -4
- package/es/components/field-set/src/FieldSet.vue.d.ts +5 -5
- package/es/components/field-set/src/components/table-row.vue.d.ts +4 -4
- package/es/components/form-config/src/components/FormConfigEventSetting.vue2.js +1 -1
- package/es/components/form-render/src/components/renderer/searchCascade.js +3 -0
- package/es/components/form-render/src/hooks/useLowCodeReactions.js +2 -1
- package/es/components/iho-chat/index.d.ts +4 -4
- package/es/components/iho-chat/src/Index.vue.d.ts +4 -4
- package/es/components/iho-chat/src/components/ChatFile.vue.d.ts +2 -2
- package/es/components/iho-chat/src/components/ChatFile.vue2.js +5 -15
- package/es/components/iho-chat/src/components/ChatFooter.vue2.js +1 -1
- package/es/components/iho-chat/src/components/ChatHeader.vue.d.ts +2 -2
- package/es/components/iho-chat/src/components/ChatMain.vue.d.ts +3 -3
- package/es/components/iho-chat/src/components/ChatMain.vue2.js +7 -15
- package/es/components/iho-chat/src/components/ChatRecord.vue.d.ts +2 -2
- package/es/components/iho-chat/src/components/ChatRecord.vue2.js +3 -3
- package/es/components/iho-chat/src/components/ContextMenu.js +3 -11
- package/es/components/iho-chat/src/components/MessageMergeForward.vue.d.ts +2 -2
- package/es/components/iho-chat/src/components/MessageMergeForward.vue2.js +3 -3
- package/es/components/iho-chat/src/components/PersonProfile.vue2.js +1 -1
- package/es/components/iho-chat/src/hooks/useData.js +2 -7
- package/es/components/iho-chat/src/utils/index.d.ts +2 -3
- package/es/components/iho-chat/src/utils/index.js +20 -39
- package/es/components/iho-table/src/plugins/filterRenderPlugin/filter.vue2.js +8 -1
- package/es/components/iho-table/src/plugins/headerPlugin/index.js +5 -2
- package/es/components/iho-table/src/plugins/highLightSetPlugin.js +2 -1
- package/es/components/select-person/src/SelectPerson.vue2.js +1 -1
- package/es/env.d.ts +25 -25
- package/es/shared/assets/img/defaultCover/10review_successful.png.js +1 -1
- package/es/shared/assets/img/defaultCover/11review_fail.png.js +1 -1
- package/es/shared/assets/img/defaultCover/12no_setting.png.js +1 -1
- package/es/shared/assets/img/defaultCover/13no_menu_setting.png.js +1 -1
- package/es/shared/assets/img/defaultCover/14no_call_setting.png.js +1 -1
- package/es/shared/assets/img/defaultCover/15no_use_tag.png.js +1 -1
- package/es/shared/assets/img/defaultCover/16no_table_data.png.js +1 -1
- package/es/shared/assets/img/defaultCover/1location.png.js +1 -1
- package/es/shared/assets/img/defaultCover/2notfound.png.js +1 -1
- package/es/shared/assets/img/defaultCover/3loading.png.js +1 -1
- package/es/shared/assets/img/defaultCover/4no_permission.png.js +1 -1
- package/es/shared/assets/img/defaultCover/5no_data.png.js +1 -1
- package/es/shared/assets/img/defaultCover/6no_network.png.js +1 -1
- package/es/shared/assets/img/defaultCover/7no_doctor.png.js +1 -1
- package/es/shared/assets/img/defaultCover/8system_error.png.js +1 -1
- package/es/shared/assets/img/defaultCover/9system_upgrade.png.js +1 -1
- package/es/shared/assets/img/failure.png.js +1 -1
- package/es/shared/assets/img/no-permission.png.js +1 -1
- package/es/shared/assets/img/nodata.png.js +1 -1
- package/es/shared/assets/img/notfound.png.js +1 -1
- package/es/shared/assets/img/qr.png.js +1 -1
- package/es/shared/assets/img/success.png.js +1 -1
- package/es/shared/assets/img/table_style_2.png.js +1 -1
- package/es/shared/assets/img/video.png.js +1 -1
- package/es/shared/assets/img/video_default_cover.png.js +1 -1
- package/es/shared/assets/img/xb_big.png.js +1 -1
- package/es/shared/assets/img/xb_small.png.js +1 -1
- package/es/shared/components/VueDraggable/src/vuedraggable.d.ts +86 -0
- package/es/shared/package.json.js +1 -1
- package/es/shared/utils/fabricjs/index.d.ts +6823 -0
- package/es/shared/utils/tapable/index.d.ts +139 -0
- 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
|
-
|
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(
|
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:
|
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(
|
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,
|
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
|
-
|
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,
|
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(
|
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(
|
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,
|
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) :
|
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
|
-
|
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,
|
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
|
-
|
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,
|
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(
|
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(
|
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">\
|
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,
|
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,
|
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(
|
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(
|
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",
|
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 =
|
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
|
-
|
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
|
-
|
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,
|
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(
|
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
|
-
|
69
|
-
|
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
|
-
}, ["
|
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 };
|