cnhis-design-vue 3.2.19-beta.1 → 3.2.19-beta.3

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 (100) hide show
  1. package/es/components/ai-chat/index.d.ts +17 -144
  2. package/es/components/ai-chat/src/Index.vue.d.ts +17 -144
  3. package/es/components/ai-chat/src/Index.vue2.js +1 -1
  4. package/es/components/ai-chat/src/components/ChatBI.vue.d.ts +2 -2
  5. package/es/components/ai-chat/src/components/ChatBI.vue2.js +1 -1
  6. package/es/components/ai-chat/src/components/ChatCard.js +1 -1
  7. package/es/components/ai-chat/src/components/ChatFooter.vue.d.ts +2 -52
  8. package/es/components/ai-chat/src/components/ChatFooter.vue2.js +1 -1
  9. package/es/components/ai-chat/src/components/ChatMain.d.ts +7 -1
  10. package/es/components/ai-chat/src/components/ChatMain.js +1 -1
  11. package/es/components/ai-chat/src/utils/index.d.ts +0 -1
  12. package/es/components/ai-chat/src/utils/index.js +1 -1
  13. package/es/components/ai-chat/style/index.css +1 -1
  14. package/es/components/audio-sdk/src/audioSDK.d.ts +7 -6
  15. package/es/components/audio-sdk/src/audioSDK.js +1 -1
  16. package/es/components/audio-sdk/src/utils/recordingModal.d.ts +1 -2
  17. package/es/components/audio-sdk/src/utils/recordingModal.js +1 -1
  18. package/es/components/{template-render → card-render}/index.d.ts +2 -2
  19. package/es/components/card-render/index.js +1 -0
  20. package/es/components/card-render/src/CardRender.vue.js +1 -0
  21. package/es/components/card-render/src/CardRender.vue2.js +1 -0
  22. package/es/components/{template-render → card-render}/src/components/Button.vue2.js +1 -1
  23. package/es/components/card-render/src/components/Field.vue2.js +1 -0
  24. package/es/components/{template-render → card-render}/src/components/FieldGroup.vue2.js +1 -1
  25. package/es/components/{template-render → card-render}/src/components/Label.vue2.js +1 -1
  26. package/es/components/card-render/src/components/Row.vue2.js +1 -0
  27. package/es/components/card-render/src/components/Text.vue2.js +1 -0
  28. package/es/components/card-render/style/index.css +1 -0
  29. package/es/components/editor/src/Editor.js +1 -1
  30. package/es/components/editor/style/index.css +0 -1
  31. package/es/components/form-render/src/components/renderer/combination/jsonCombination.js +1 -1
  32. package/es/components/index.css +1 -1
  33. package/es/components/index.d.ts +2 -2
  34. package/es/components/index.js +1 -1
  35. package/es/components/shortcut-provider/src/hooks/useShortcuts.js +1 -1
  36. package/es/components/shortcut-provider/src/types/index.d.ts +2 -0
  37. package/es/components/shortcut-provider/src/utils/index.d.ts +1 -1
  38. package/es/components/shortcut-provider/src/utils/index.js +1 -1
  39. package/es/shared/package.json.js +1 -1
  40. package/package.json +2 -2
  41. package/es/components/ai-chat/src/api/index.d.ts +0 -6
  42. package/es/components/ai-chat/src/api/index.js +0 -1
  43. package/es/components/ai-chat/src/components/ChatAudio.vue.d.ts +0 -40
  44. package/es/components/ai-chat/src/components/ChatAudio.vue.js +0 -1
  45. package/es/components/ai-chat/src/components/ChatAudio.vue2.js +0 -1
  46. package/es/components/ai-chat/src/components/ChatMainInner.d.ts +0 -2
  47. package/es/components/ai-chat/src/components/ChatMainInner.js +0 -1
  48. package/es/components/ai-chat/src/components/ChatRight.vue.d.ts +0 -56
  49. package/es/components/ai-chat/src/components/ChatRight.vue.js +0 -1
  50. package/es/components/ai-chat/src/components/ChatRight.vue2.js +0 -1
  51. package/es/components/ai-chat/src/components/card/JsonCard.d.ts +0 -25
  52. package/es/components/ai-chat/src/components/card/JsonCard.js +0 -1
  53. package/es/components/ai-chat/src/components/card/SelectIcon.d.ts +0 -14
  54. package/es/components/ai-chat/src/components/card/SelectIcon.js +0 -1
  55. package/es/components/ai-chat/src/hooks/useProgram.d.ts +0 -6
  56. package/es/components/ai-chat/src/hooks/useProgram.js +0 -1
  57. package/es/components/ai-chat/src/hooks/useWebsocket.d.ts +0 -2
  58. package/es/components/ai-chat/src/hooks/useWebsocket.js +0 -1
  59. package/es/components/template-render/index.js +0 -1
  60. package/es/components/template-render/src/TemplateRender.vue.js +0 -1
  61. package/es/components/template-render/src/TemplateRender.vue2.js +0 -1
  62. package/es/components/template-render/src/components/Field.vue2.js +0 -1
  63. package/es/components/template-render/src/components/Row.vue2.js +0 -1
  64. package/es/components/template-render/src/components/Text.vue2.js +0 -1
  65. package/es/components/template-render/style/index.css +0 -1
  66. package/es/shared/assets/img/file-emr.png.js +0 -1
  67. package/es/shared/assets/img/file.png.js +0 -1
  68. package/es/shared/assets/img/use.png.js +0 -1
  69. /package/es/components/{template-render/src/TemplateRender.vue.d.ts → card-render/src/CardRender.vue.d.ts} +0 -0
  70. /package/es/components/{template-render → card-render}/src/components/Box.vue.d.ts +0 -0
  71. /package/es/components/{template-render → card-render}/src/components/Box.vue.js +0 -0
  72. /package/es/components/{template-render → card-render}/src/components/Box.vue2.js +0 -0
  73. /package/es/components/{template-render → card-render}/src/components/Button.vue.d.ts +0 -0
  74. /package/es/components/{template-render → card-render}/src/components/Button.vue.js +0 -0
  75. /package/es/components/{template-render → card-render}/src/components/Divider.vue.d.ts +0 -0
  76. /package/es/components/{template-render → card-render}/src/components/Divider.vue.js +0 -0
  77. /package/es/components/{template-render → card-render}/src/components/Divider.vue2.js +0 -0
  78. /package/es/components/{template-render → card-render}/src/components/Field.vue.d.ts +0 -0
  79. /package/es/components/{template-render → card-render}/src/components/Field.vue.js +0 -0
  80. /package/es/components/{template-render → card-render}/src/components/FieldGroup.vue.d.ts +0 -0
  81. /package/es/components/{template-render → card-render}/src/components/FieldGroup.vue.js +0 -0
  82. /package/es/components/{template-render → card-render}/src/components/Image.vue.d.ts +0 -0
  83. /package/es/components/{template-render → card-render}/src/components/Image.vue.js +0 -0
  84. /package/es/components/{template-render → card-render}/src/components/Image.vue2.js +0 -0
  85. /package/es/components/{template-render → card-render}/src/components/Label.vue.d.ts +0 -0
  86. /package/es/components/{template-render → card-render}/src/components/Label.vue.js +0 -0
  87. /package/es/components/{template-render → card-render}/src/components/Row.vue.d.ts +0 -0
  88. /package/es/components/{template-render → card-render}/src/components/Row.vue.js +0 -0
  89. /package/es/components/{template-render → card-render}/src/components/Slot.d.ts +0 -0
  90. /package/es/components/{template-render → card-render}/src/components/Slot.js +0 -0
  91. /package/es/components/{template-render → card-render}/src/components/Text.vue.d.ts +0 -0
  92. /package/es/components/{template-render → card-render}/src/components/Text.vue.js +0 -0
  93. /package/es/components/{template-render → card-render}/src/components/index.d.ts +0 -0
  94. /package/es/components/{template-render → card-render}/src/components/index.js +0 -0
  95. /package/es/components/{template-render → card-render}/src/constants/index.d.ts +0 -0
  96. /package/es/components/{template-render → card-render}/src/constants/index.js +0 -0
  97. /package/es/components/{template-render → card-render}/src/hooks/useCommon.d.ts +0 -0
  98. /package/es/components/{template-render → card-render}/src/hooks/useCommon.js +0 -0
  99. /package/es/components/{template-render → card-render}/src/utils/index.d.ts +0 -0
  100. /package/es/components/{template-render → card-render}/src/utils/index.js +0 -0
@@ -15,16 +15,17 @@ declare const AiChat: SFCWithInstall<import("vue").DefineComponent<{
15
15
  };
16
16
  queryData: {
17
17
  type: import("vue").PropType<import("./src/types").QueryData>;
18
+ reuired: boolean;
18
19
  };
19
20
  queryRecord: {
20
21
  type: import("vue").PropType<import("./src/types").QueryRecord>;
22
+ reuired: boolean;
21
23
  };
22
24
  hideInput: {
23
25
  type: BooleanConstructor;
24
26
  };
25
27
  uiStyle: {
26
28
  type: StringConstructor;
27
- default: string;
28
29
  };
29
30
  audioTimed: {
30
31
  type: NumberConstructor;
@@ -48,16 +49,6 @@ declare const AiChat: SFCWithInstall<import("vue").DefineComponent<{
48
49
  appId: {
49
50
  type: StringConstructor;
50
51
  };
51
- orgId: {
52
- type: StringConstructor;
53
- };
54
- userId: {
55
- type: StringConstructor;
56
- };
57
- immediatelyRecording: {
58
- type: BooleanConstructor;
59
- default: boolean;
60
- };
61
52
  }, {
62
53
  cssVars: import("vue").ComputedRef<import("../../shared/types").AnyObject>;
63
54
  props: Readonly<import("@vue/shared").LooseRequired<Readonly<import("vue").ExtractPropTypes<{
@@ -76,16 +67,17 @@ declare const AiChat: SFCWithInstall<import("vue").DefineComponent<{
76
67
  };
77
68
  queryData: {
78
69
  type: import("vue").PropType<import("./src/types").QueryData>;
70
+ reuired: boolean;
79
71
  };
80
72
  queryRecord: {
81
73
  type: import("vue").PropType<import("./src/types").QueryRecord>;
74
+ reuired: boolean;
82
75
  };
83
76
  hideInput: {
84
77
  type: BooleanConstructor;
85
78
  };
86
79
  uiStyle: {
87
80
  type: StringConstructor;
88
- default: string;
89
81
  };
90
82
  audioTimed: {
91
83
  type: NumberConstructor;
@@ -109,30 +101,21 @@ declare const AiChat: SFCWithInstall<import("vue").DefineComponent<{
109
101
  appId: {
110
102
  type: StringConstructor;
111
103
  };
112
- orgId: {
113
- type: StringConstructor;
114
- };
115
- userId: {
116
- type: StringConstructor;
117
- };
118
- immediatelyRecording: {
119
- type: BooleanConstructor;
120
- default: boolean;
121
- };
122
104
  }>> & {
123
105
  "onButton-click"?: ((...args: any[]) => any) | undefined;
124
106
  }>>;
107
+ axiosInstance: import("axios").AxiosInstance;
125
108
  emit: (event: "button-click", ...args: any[]) => void;
126
- showSmallStyle: import("vue").ComputedRef<boolean>;
127
109
  state: import("../../shared/types").AnyObject;
128
- ChatMain: import("vue").DefineComponent<{}, () => JSX.Element[], {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{}>>, {}>;
110
+ NMessageProvider: any;
111
+ ChatMain: import("vue").DefineComponent<Readonly<import("vue").ComponentPropsOptions<{
112
+ [x: string]: unknown;
113
+ }>>, () => JSX.Element[], unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, never[], never, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<readonly string[] | import("vue").ExtractPropTypes<Readonly<import("vue").ComponentObjectPropsOptions<{
114
+ [x: string]: unknown;
115
+ }>>>> & {}, {
116
+ readonly [x: number]: string;
117
+ } | {}>;
129
118
  ChatFooter: import("vue").DefineComponent<{}, {
130
- innerDefaultShortcutList: {
131
- key: string;
132
- value: string;
133
- }[];
134
- programMethod: (bpmnProcessId: string, params: import("../../shared/types").AnyObject) => Promise<any>;
135
- MedicalOrderId: string;
136
119
  cssVars: import("vue").ComputedRef<import("../../shared/types").AnyObject>;
137
120
  audioSdk: import("..").CAudioSDK;
138
121
  emit: (event: string, ...args: any[]) => void;
@@ -141,9 +124,6 @@ declare const AiChat: SFCWithInstall<import("vue").DefineComponent<{
141
124
  isSmall: any;
142
125
  audioTimed: any;
143
126
  commandList: any;
144
- isInner: any;
145
- patientInfo: any;
146
- immediatelyRecording: any;
147
127
  inputRef: import("vue").Ref<any>;
148
128
  showPopover: import("vue").Ref<boolean>;
149
129
  breadcrumb: import("vue").Ref<{
@@ -163,16 +143,13 @@ declare const AiChat: SFCWithInstall<import("vue").DefineComponent<{
163
143
  showPrompt: import("vue").Ref<boolean>;
164
144
  currentShortcutId: import("vue").Ref<string>;
165
145
  showPatient: import("vue").Ref<boolean>;
166
- showAudio: any;
167
- placeholder: import("vue").ComputedRef<"请向我提问,Shift+Enter换行" | "请向我提问或输入\"/\"查看指令" | "请向我提问或输入\"/\"查看指令,Shift+Enter换行">;
146
+ placeholder: import("vue").ComputedRef<"请向我提问或输入\"/\"查看指令" | "请向我提问或输入\"/\"查看指令,Shift+Enter换行">;
168
147
  btnDisabled: import("vue").ComputedRef<any>;
169
148
  showMagicWand: import("vue").ComputedRef<boolean>;
170
149
  patient: import("vue").ComputedRef<string>;
171
- currentShortcutList: import("vue").ComputedRef<any>;
172
- isAllDisabled: import("vue").ComputedRef<any>;
173
150
  recorderStart: () => Promise<void>;
174
151
  getShortcutName: (item: string | import("../../shared/types").AnyObject) => any;
175
- handleShortcut: (item: string | import("../../shared/types").AnyObject) => Promise<void>;
152
+ handleShortcut: (item: string | import("../../shared/types").AnyObject) => void;
176
153
  resetCurrentCommand: () => void;
177
154
  handleKeyDown: (event: KeyboardEvent) => void;
178
155
  isWrap: (event: KeyboardEvent) => boolean;
@@ -292,99 +269,6 @@ declare const AiChat: SFCWithInstall<import("vue").DefineComponent<{
292
269
  }, {
293
270
  show: boolean;
294
271
  }>;
295
- ChatAudio: import("vue").DefineComponent<{
296
- show: {
297
- type: BooleanConstructor;
298
- };
299
- }, {
300
- audioSdk: import("..").CAudioSDK;
301
- props: Readonly<import("@vue/shared").LooseRequired<Readonly<import("vue").ExtractPropTypes<{
302
- show: {
303
- type: BooleanConstructor;
304
- };
305
- }>> & {
306
- "onUpdate:show"?: ((...args: any[]) => any) | undefined;
307
- }>>;
308
- emit: (event: "update:show", ...args: any[]) => void;
309
- state: any;
310
- time: import("vue").Ref<number>;
311
- pause: import("@vueuse/shared").Fn;
312
- resume: import("@vueuse/shared").Fn;
313
- isActive: import("vue").Ref<boolean>;
314
- tip: import("vue").ComputedRef<"正在录音中..." | "录音已暂停">;
315
- formattedTime: import("vue").ComputedRef<string>;
316
- start: () => Promise<void>;
317
- handlePause: () => void;
318
- handlePlay: () => void;
319
- handleEnd: () => Promise<void>;
320
- NSpace: any;
321
- NButton: any;
322
- NIcon: any;
323
- StopCircleOutline: 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<{}>>, {}>;
324
- }, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, "update:show"[], "update:show", import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
325
- show: {
326
- type: BooleanConstructor;
327
- };
328
- }>> & {
329
- "onUpdate:show"?: ((...args: any[]) => any) | undefined;
330
- }, {
331
- show: boolean;
332
- }>;
333
- }, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{}>>, {}>;
334
- ChatMainInner: import("vue").DefineComponent<{}, () => JSX.Element[], {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{}>>, {}>;
335
- ChatRight: import("vue").DefineComponent<{}, {
336
- medicalLabel: {
337
- key: string;
338
- title: string;
339
- }[];
340
- state: any;
341
- patientInfo: any;
342
- toolbarConfig: {
343
- toolbarKeys: never[];
344
- };
345
- content: import("vue").Ref<string>;
346
- key: import("vue").Ref<string>;
347
- handleSave: () => Promise<void>;
348
- createMedicalRecord: () => void;
349
- extractContentByTitle: () => import("../../shared/types").AnyObject;
350
- NIcon: any;
351
- NSpace: any;
352
- NButton: any;
353
- Editor: SFCWithInstall<import("vue").DefineComponent<{
354
- editorConfig: {
355
- type: ObjectConstructor;
356
- };
357
- toolbarConfig: {
358
- type: ObjectConstructor;
359
- };
360
- uploadImgUrl: {
361
- type: StringConstructor;
362
- };
363
- isDisabled: {
364
- type: BooleanConstructor;
365
- default: boolean;
366
- };
367
- }, {
368
- editorRef: import("vue").ShallowRef<any>;
369
- renderVN: () => JSX.Element;
370
- }, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, never[], never, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
371
- editorConfig: {
372
- type: ObjectConstructor;
373
- };
374
- toolbarConfig: {
375
- type: ObjectConstructor;
376
- };
377
- uploadImgUrl: {
378
- type: StringConstructor;
379
- };
380
- isDisabled: {
381
- type: BooleanConstructor;
382
- default: boolean;
383
- };
384
- }>> & {}, {
385
- isDisabled: boolean;
386
- }>>;
387
- CloseOutline: 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<{}>>, {}>;
388
272
  }, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{}>>, {}>;
389
273
  }, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, "button-click"[], "button-click", import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
390
274
  token: {
@@ -402,16 +286,17 @@ declare const AiChat: SFCWithInstall<import("vue").DefineComponent<{
402
286
  };
403
287
  queryData: {
404
288
  type: import("vue").PropType<import("./src/types").QueryData>;
289
+ reuired: boolean;
405
290
  };
406
291
  queryRecord: {
407
292
  type: import("vue").PropType<import("./src/types").QueryRecord>;
293
+ reuired: boolean;
408
294
  };
409
295
  hideInput: {
410
296
  type: BooleanConstructor;
411
297
  };
412
298
  uiStyle: {
413
299
  type: StringConstructor;
414
- default: string;
415
300
  };
416
301
  audioTimed: {
417
302
  type: NumberConstructor;
@@ -435,22 +320,10 @@ declare const AiChat: SFCWithInstall<import("vue").DefineComponent<{
435
320
  appId: {
436
321
  type: StringConstructor;
437
322
  };
438
- orgId: {
439
- type: StringConstructor;
440
- };
441
- userId: {
442
- type: StringConstructor;
443
- };
444
- immediatelyRecording: {
445
- type: BooleanConstructor;
446
- default: boolean;
447
- };
448
323
  }>> & {
449
324
  "onButton-click"?: ((...args: any[]) => any) | undefined;
450
325
  }, {
451
326
  hideInput: boolean;
452
- uiStyle: string;
453
327
  audioTimed: number;
454
- immediatelyRecording: boolean;
455
328
  }>>;
456
329
  export default AiChat;
@@ -17,16 +17,17 @@ declare const _default: import("vue").DefineComponent<{
17
17
  };
18
18
  queryData: {
19
19
  type: PropType<QueryData>;
20
+ reuired: boolean;
20
21
  };
21
22
  queryRecord: {
22
23
  type: PropType<QueryRecord>;
24
+ reuired: boolean;
23
25
  };
24
26
  hideInput: {
25
27
  type: BooleanConstructor;
26
28
  };
27
29
  uiStyle: {
28
30
  type: StringConstructor;
29
- default: string;
30
31
  };
31
32
  audioTimed: {
32
33
  type: NumberConstructor;
@@ -50,16 +51,6 @@ declare const _default: import("vue").DefineComponent<{
50
51
  appId: {
51
52
  type: StringConstructor;
52
53
  };
53
- orgId: {
54
- type: StringConstructor;
55
- };
56
- userId: {
57
- type: StringConstructor;
58
- };
59
- immediatelyRecording: {
60
- type: BooleanConstructor;
61
- default: boolean;
62
- };
63
54
  }, {
64
55
  cssVars: import("vue").ComputedRef<AnyObject>;
65
56
  props: Readonly<import("@vue/shared").LooseRequired<Readonly<import("vue").ExtractPropTypes<{
@@ -78,16 +69,17 @@ declare const _default: import("vue").DefineComponent<{
78
69
  };
79
70
  queryData: {
80
71
  type: PropType<QueryData>;
72
+ reuired: boolean;
81
73
  };
82
74
  queryRecord: {
83
75
  type: PropType<QueryRecord>;
76
+ reuired: boolean;
84
77
  };
85
78
  hideInput: {
86
79
  type: BooleanConstructor;
87
80
  };
88
81
  uiStyle: {
89
82
  type: StringConstructor;
90
- default: string;
91
83
  };
92
84
  audioTimed: {
93
85
  type: NumberConstructor;
@@ -111,30 +103,21 @@ declare const _default: import("vue").DefineComponent<{
111
103
  appId: {
112
104
  type: StringConstructor;
113
105
  };
114
- orgId: {
115
- type: StringConstructor;
116
- };
117
- userId: {
118
- type: StringConstructor;
119
- };
120
- immediatelyRecording: {
121
- type: BooleanConstructor;
122
- default: boolean;
123
- };
124
106
  }>> & {
125
107
  "onButton-click"?: ((...args: any[]) => any) | undefined;
126
108
  }>>;
109
+ axiosInstance: import("axios").AxiosInstance;
127
110
  emit: (event: "button-click", ...args: any[]) => void;
128
- showSmallStyle: import("vue").ComputedRef<boolean>;
129
111
  state: AnyObject;
130
- ChatMain: import("vue").DefineComponent<{}, () => JSX.Element[], {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{}>>, {}>;
112
+ NMessageProvider: any;
113
+ ChatMain: import("vue").DefineComponent<Readonly<import("vue").ComponentPropsOptions<{
114
+ [x: string]: unknown;
115
+ }>>, () => JSX.Element[], unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, never[], never, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<readonly string[] | import("vue").ExtractPropTypes<Readonly<import("vue").ComponentObjectPropsOptions<{
116
+ [x: string]: unknown;
117
+ }>>>> & {}, {
118
+ readonly [x: number]: string;
119
+ } | {}>;
131
120
  ChatFooter: import("vue").DefineComponent<{}, {
132
- innerDefaultShortcutList: {
133
- key: string;
134
- value: string;
135
- }[];
136
- programMethod: (bpmnProcessId: string, params: AnyObject) => Promise<any>;
137
- MedicalOrderId: string;
138
121
  cssVars: import("vue").ComputedRef<AnyObject>;
139
122
  audioSdk: import("../..").CAudioSDK;
140
123
  emit: (event: string, ...args: any[]) => void;
@@ -143,9 +126,6 @@ declare const _default: import("vue").DefineComponent<{
143
126
  isSmall: any;
144
127
  audioTimed: any;
145
128
  commandList: any;
146
- isInner: any;
147
- patientInfo: any;
148
- immediatelyRecording: any;
149
129
  inputRef: import("vue").Ref<any>;
150
130
  showPopover: import("vue").Ref<boolean>;
151
131
  breadcrumb: import("vue").Ref<{
@@ -165,16 +145,13 @@ declare const _default: import("vue").DefineComponent<{
165
145
  showPrompt: import("vue").Ref<boolean>;
166
146
  currentShortcutId: import("vue").Ref<string>;
167
147
  showPatient: import("vue").Ref<boolean>;
168
- showAudio: any;
169
- placeholder: import("vue").ComputedRef<"请向我提问,Shift+Enter换行" | "请向我提问或输入\"/\"查看指令" | "请向我提问或输入\"/\"查看指令,Shift+Enter换行">;
148
+ placeholder: import("vue").ComputedRef<"请向我提问或输入\"/\"查看指令" | "请向我提问或输入\"/\"查看指令,Shift+Enter换行">;
170
149
  btnDisabled: import("vue").ComputedRef<any>;
171
150
  showMagicWand: import("vue").ComputedRef<boolean>;
172
151
  patient: import("vue").ComputedRef<string>;
173
- currentShortcutList: import("vue").ComputedRef<any>;
174
- isAllDisabled: import("vue").ComputedRef<any>;
175
152
  recorderStart: () => Promise<void>;
176
153
  getShortcutName: (item: string | AnyObject) => any;
177
- handleShortcut: (item: string | AnyObject) => Promise<void>;
154
+ handleShortcut: (item: string | AnyObject) => void;
178
155
  resetCurrentCommand: () => void;
179
156
  handleKeyDown: (event: KeyboardEvent) => void;
180
157
  isWrap: (event: KeyboardEvent) => boolean;
@@ -294,99 +271,6 @@ declare const _default: import("vue").DefineComponent<{
294
271
  }, {
295
272
  show: boolean;
296
273
  }>;
297
- ChatAudio: import("vue").DefineComponent<{
298
- show: {
299
- type: BooleanConstructor;
300
- };
301
- }, {
302
- audioSdk: import("../..").CAudioSDK;
303
- props: Readonly<import("@vue/shared").LooseRequired<Readonly<import("vue").ExtractPropTypes<{
304
- show: {
305
- type: BooleanConstructor;
306
- };
307
- }>> & {
308
- "onUpdate:show"?: ((...args: any[]) => any) | undefined;
309
- }>>;
310
- emit: (event: "update:show", ...args: any[]) => void;
311
- state: any;
312
- time: import("vue").Ref<number>;
313
- pause: import("@vueuse/shared").Fn;
314
- resume: import("@vueuse/shared").Fn;
315
- isActive: import("vue").Ref<boolean>;
316
- tip: import("vue").ComputedRef<"正在录音中..." | "录音已暂停">;
317
- formattedTime: import("vue").ComputedRef<string>;
318
- start: () => Promise<void>;
319
- handlePause: () => void;
320
- handlePlay: () => void;
321
- handleEnd: () => Promise<void>;
322
- NSpace: any;
323
- NButton: any;
324
- NIcon: any;
325
- StopCircleOutline: 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<{}>>, {}>;
326
- }, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, "update:show"[], "update:show", import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
327
- show: {
328
- type: BooleanConstructor;
329
- };
330
- }>> & {
331
- "onUpdate:show"?: ((...args: any[]) => any) | undefined;
332
- }, {
333
- show: boolean;
334
- }>;
335
- }, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{}>>, {}>;
336
- ChatMainInner: import("vue").DefineComponent<{}, () => JSX.Element[], {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{}>>, {}>;
337
- ChatRight: import("vue").DefineComponent<{}, {
338
- medicalLabel: {
339
- key: string;
340
- title: string;
341
- }[];
342
- state: any;
343
- patientInfo: any;
344
- toolbarConfig: {
345
- toolbarKeys: never[];
346
- };
347
- content: import("vue").Ref<string>;
348
- key: import("vue").Ref<string>;
349
- handleSave: () => Promise<void>;
350
- createMedicalRecord: () => void;
351
- extractContentByTitle: () => AnyObject;
352
- NIcon: any;
353
- NSpace: any;
354
- NButton: any;
355
- Editor: import("../../../shared/types").SFCWithInstall<import("vue").DefineComponent<{
356
- editorConfig: {
357
- type: ObjectConstructor;
358
- };
359
- toolbarConfig: {
360
- type: ObjectConstructor;
361
- };
362
- uploadImgUrl: {
363
- type: StringConstructor;
364
- };
365
- isDisabled: {
366
- type: BooleanConstructor;
367
- default: boolean;
368
- };
369
- }, {
370
- editorRef: import("vue").ShallowRef<any>;
371
- renderVN: () => JSX.Element;
372
- }, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, never[], never, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
373
- editorConfig: {
374
- type: ObjectConstructor;
375
- };
376
- toolbarConfig: {
377
- type: ObjectConstructor;
378
- };
379
- uploadImgUrl: {
380
- type: StringConstructor;
381
- };
382
- isDisabled: {
383
- type: BooleanConstructor;
384
- default: boolean;
385
- };
386
- }>> & {}, {
387
- isDisabled: boolean;
388
- }>>;
389
- CloseOutline: 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<{}>>, {}>;
390
274
  }, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{}>>, {}>;
391
275
  }, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, "button-click"[], "button-click", import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
392
276
  token: {
@@ -404,16 +288,17 @@ declare const _default: import("vue").DefineComponent<{
404
288
  };
405
289
  queryData: {
406
290
  type: PropType<QueryData>;
291
+ reuired: boolean;
407
292
  };
408
293
  queryRecord: {
409
294
  type: PropType<QueryRecord>;
295
+ reuired: boolean;
410
296
  };
411
297
  hideInput: {
412
298
  type: BooleanConstructor;
413
299
  };
414
300
  uiStyle: {
415
301
  type: StringConstructor;
416
- default: string;
417
302
  };
418
303
  audioTimed: {
419
304
  type: NumberConstructor;
@@ -437,22 +322,10 @@ declare const _default: import("vue").DefineComponent<{
437
322
  appId: {
438
323
  type: StringConstructor;
439
324
  };
440
- orgId: {
441
- type: StringConstructor;
442
- };
443
- userId: {
444
- type: StringConstructor;
445
- };
446
- immediatelyRecording: {
447
- type: BooleanConstructor;
448
- default: boolean;
449
- };
450
325
  }>> & {
451
326
  "onButton-click"?: ((...args: any[]) => any) | undefined;
452
327
  }, {
453
328
  hideInput: boolean;
454
- uiStyle: string;
455
329
  audioTimed: number;
456
- immediatelyRecording: boolean;
457
330
  }>;
458
331
  export default _default;
@@ -1 +1 @@
1
- import{defineComponent as e,computed as t,reactive as i,provide as n,toRefs as o,openBlock as r,createElementBlock as s,normalizeStyle as a,unref as u,createElementVNode as l,normalizeClass as p,createBlock as m,createCommentVNode as d}from"vue";import c from"./components/ChatMain.js";import y from"./components/ChatFooter.vue.js";import h from"./components/ChatMainInner.js";import f from"./components/ChatRight.vue.js";import{useTheme as S}from"../../../shared/hooks/useTheme.js";import"@vueuse/core";import"date-fns";import"lodash-es";import"@vue/shared";import{uuidGenerator as v}from"../../../shared/utils/index.js";import"@vueuse/shared";import"../../../shared/hooks/selectHooks/useSearchContent.js";import"@vicons/ionicons5";import"naive-ui";import"../../../shared/hooks/useScrollLoading.js";import{InjectionAIChat as g,InjectionAIChatEmits as k}from"./types/index.js";import{instanceAxios as j}from"./api/index.js";import{useWebsocket as I}from"./hooks/useWebsocket.js";const C=["id"];var x=e({__name:"Index",props:{token:{type:String,required:!0},userAvatar:{type:String},defaultShortcutList:{type:Array},shortcutList:{type:Array},queryData:{type:Function},queryRecord:{type:Function},hideInput:{type:Boolean},uiStyle:{type:String,default:"big"},audioTimed:{type:Number,default:10},commandList:{type:Array},queryPrompt:{type:Function},patientInfo:{type:Object},appId:{type:String},orgId:{type:String},userId:{type:String},immediatelyRecording:{type:Boolean,default:!1}},emits:["button-click"],setup(e,{expose:x,emit:P}){const _=e,b=S();j.defaults.headers.Authorization="bearer "+_.token,"inner"!==_.uiStyle&&(j.defaults.timeout=5e3,j.interceptors.response.use((e=>{var t;return(null==(t=e.data)?void 0:t.success)?e.data:{success:!1,data:[]}})));const A=t((()=>["small","inner"].includes(_.uiStyle))),F=i({id:"ai-chat-"+v(),loading:!1,sending:!1,sendContent:"",selectedCommand:null,selectedPrompt:null,externalData:null,selectedPatient:null,selectedPatientLabel:"",selectedPatientForm:null,showPatient:!1,showRight:!1,consultationContent:null,params:{},reportContent:null,refreshMedical:!1});return n(g,{...o(_),state:F,isSmall:t((()=>"small"===_.uiStyle)),isInner:t((()=>"inner"===_.uiStyle))}),n(k,P),"inner"===_.uiStyle&&I(_,F),x({pushMessage:e=>{F.externalData=e},updatePatientInfo:e=>{F.selectedPatient=e}}),(t,i)=>(r(),s("div",{class:"ai-chat",style:a(u(b))},[l("div",{id:F.id,class:p(["ai-chat__main",u(A)?"ai-chat__main--small":"","inner"===e.uiStyle?"ai-chat__main--inner":""])},["inner"===e.uiStyle?(r(),m(u(h),{key:0})):(r(),m(u(c),{key:1})),e.hideInput?d("v-if",!0):(r(),m(y,{key:2}))],10,C),"inner"===e.uiStyle?(r(),m(f,{key:0})):d("v-if",!0)],4))}});export{x as default};
1
+ import{defineComponent as e,reactive as t,provide as o,toRefs as r,computed as s,openBlock as a,createElementBlock as i,normalizeClass as n,normalizeStyle as u,unref as l,createVNode as p,withCtx as d,createBlock as m,createCommentVNode as c}from"vue";import{NMessageProvider as h}from"naive-ui";import y from"./components/ChatMain.js";import f from"./components/ChatFooter.vue.js";import{useTheme as v}from"../../../shared/hooks/useTheme.js";import"@vueuse/core";import"date-fns";import"lodash-es";import"@vue/shared";import{uuidGenerator as S}from"../../../shared/utils/index.js";import"@vueuse/shared";import"../../../shared/hooks/selectHooks/useSearchContent.js";import"@vicons/ionicons5";import"../../../shared/hooks/useScrollLoading.js";import{InjectionAIChat as x,InjectionAIChatEmits as g}from"./types/index.js";import j from"axios";const k=["id"];var P=e({__name:"Index",props:{token:{type:String,required:!0},userAvatar:{type:String},defaultShortcutList:{type:Array},shortcutList:{type:Array},queryData:{type:Function,reuired:!0},queryRecord:{type:Function,reuired:!0},hideInput:{type:Boolean},uiStyle:{type:String},audioTimed:{type:Number,default:10},commandList:{type:Array},queryPrompt:{type:Function},patientInfo:{type:Object},appId:{type:String}},emits:["button-click"],setup(e,{expose:P,emit:I}){const b=e,A=v(),C=j.create({headers:{Authorization:"bearer "+b.token}});C.interceptors.response.use((e=>{var t;return(null==(t=e.data)?void 0:t.success)?e.data:{success:!1,data:[]}}));const F=t({id:"ai-chat-"+S(),loading:!1,sending:!1,sendContent:"",selectedCommand:null,selectedPrompt:null,externalData:null,selectedPatient:null,selectedPatientLabel:"",selectedPatientForm:null,showPatient:!1});return o(x,{...r(b),state:F,isSmall:s((()=>"small"===b.uiStyle)),axiosInstance:C}),o(g,I),P({pushMessage:e=>{F.externalData=e},updatePatientInfo:e=>{F.selectedPatient=e}}),(t,o)=>(a(),i("div",{id:F.id,class:n(["ai-chat","small"===e.uiStyle?"ai-chat--small":""]),style:u(l(A))},[p(l(h),null,{default:d((()=>[p(l(y)),e.hideInput?c("v-if",!0):(a(),m(f,{key:0}))])),_:1})],14,k))}});export{P as default};
@@ -28,7 +28,7 @@ declare const _default: import("vue").DefineComponent<{
28
28
  handleModuleClick: (param: AnyObject) => void;
29
29
  NDrawer: any;
30
30
  NDrawerContent: any;
31
- CTemplateRender: import("../../../../shared/types").SFCWithInstall<import("vue").DefineComponent<{
31
+ CCardRender: import("../../../../shared/types").SFCWithInstall<import("vue").DefineComponent<{
32
32
  config: {
33
33
  type: PropType<{
34
34
  templateStyle?: import("vue").CSSProperties | undefined;
@@ -65,7 +65,7 @@ declare const _default: import("vue").DefineComponent<{
65
65
  emit: (event: "button-click" | "module-click", ...args: any[]) => void;
66
66
  style: import("vue").ComputedRef<any>;
67
67
  componentsFieldList: import("vue").ComputedRef<AnyObject[]>;
68
- getComponent: typeof import("../../../template-render/src/components").getComponent;
68
+ getComponent: typeof import("../../../card-render/src/components").getComponent;
69
69
  }, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, ("button-click" | "module-click")[], "button-click" | "module-click", import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
70
70
  config: {
71
71
  type: PropType<{
@@ -1 +1 @@
1
- import{defineComponent as t,inject as e,computed as o,openBlock as n,createBlock as a,unref as s,withCtx as i,createVNode as d,mergeProps as l,createCommentVNode as r}from"vue";import{NDrawer as u,NDrawerContent as m}from"naive-ui";import{InjectionAIChatEmits as p,InjectionAIChat as c}from"../types/index.js";import"../../../index.js";import{isValidJSON as f}from"../utils/index.js";import h from"../../../template-render/index.js";var v=t({__name:"ChatBI",props:{show:{type:Boolean},data:{type:Object}},emits:["update:show"],setup(t,{emit:v}){const g=t,w=e(p),{state:j}=e(c),k=o((()=>{var t,e,o;const{content:n={}}=(null==(t=g.data)?void 0:t.msgItem)||{};return{config:f(null==(e=n.settings)?void 0:e.setting)?JSON.parse(null==(o=n.settings)?void 0:o.setting):null,data:n.data}}));function x(t){const{eventName:e,data:o}=t;v("update:show",!1),e&&w("button-click",{buttonInfo:o,isBI:!0,...g.data})}return(e,o)=>(n(),a(s(u),{placement:"bottom",height:"80%","trap-focus":!1,to:"#"+s(j).id,show:t.show,onMaskClick:o[0]||(o[0]=()=>v("update:show",!1))},{default:i((()=>[d(s(m),null,{default:i((()=>[t.data?(n(),a(s(h),l({key:0},s(k),{onModuleClick:x}),null,16)):r("v-if",!0)])),_:1})])),_:1},8,["to","show"]))}});export{v as default};
1
+ import{defineComponent as t,inject as e,computed as o,openBlock as n,createBlock as a,unref as s,withCtx as i,createVNode as d,mergeProps as r,createCommentVNode as u}from"vue";import{NDrawer as l,NDrawerContent as m}from"naive-ui";import{InjectionAIChatEmits as p,InjectionAIChat as c}from"../types/index.js";import"../../../index.js";import{isValidJSON as f}from"../utils/index.js";import h from"../../../card-render/index.js";var v=t({__name:"ChatBI",props:{show:{type:Boolean},data:{type:Object}},emits:["update:show"],setup(t,{emit:v}){const g=t,w=e(p),{state:j}=e(c),k=o((()=>{var t,e,o;const{content:n={}}=(null==(t=g.data)?void 0:t.msgItem)||{};return{config:f(null==(e=n.settings)?void 0:e.setting)?JSON.parse(null==(o=n.settings)?void 0:o.setting):null,data:n.data}}));function x(t){const{eventName:e,data:o}=t;v("update:show",!1),e&&w("button-click",{buttonInfo:o,isBI:!0,...g.data})}return(e,o)=>(n(),a(s(l),{placement:"bottom",height:"80%","trap-focus":!1,to:"#"+s(j).id,show:t.show,onMaskClick:o[0]||(o[0]=()=>v("update:show",!1))},{default:i((()=>[d(s(m),null,{default:i((()=>[t.data?(n(),a(s(h),r({key:0},s(k),{onModuleClick:x}),null,16)):u("v-if",!0)])),_:1})])),_:1},8,["to","show"]))}});export{v as default};
@@ -1 +1 @@
1
- import{defineComponent as e,inject as t,ref as a,reactive as l,computed as n,watch as o,createVNode as i}from"vue";import{NForm as s,NFormItem as r,NInput as u,NIcon as d,NButton as c}from"naive-ui";import{InjectionAIChat as v}from"../types/index.js";import"../../../index.js";import{cloneDeep as p,isArray as m,omit as f}from"lodash-es";import{isValidJSON as g}from"../utils/index.js";import{ChevronDown as b,ChevronForward as h}from"@vicons/ionicons5";import{useTheme as y}from"../../../../shared/hooks/useTheme.js";import"@vueuse/core";import"date-fns";import"@vue/shared";import"../../../../shared/utils/index.js";import"@vueuse/shared";import"../../../../shared/hooks/selectHooks/useSearchContent.js";import"../../../../shared/hooks/useScrollLoading.js";import{instanceAxios as E}from"../api/index.js";import I from"../../../form-render/index.js";import k from"../../../template-render/index.js";var x=e({name:"ChatCard",inheritAttrs:!1,props:{msgItem:{type:Object,default:()=>({})},selectParams:{type:Object},configs:{type:Object},msgId:{type:String}},emits:["button-click"],setup(e,{attrs:x,slots:_,emit:C}){const T={TEXT:"INPUT",NUMBER:"INPUT_NUMBER",DATETIME:"DATE",MULTI_SELECT:"REMOTE_SEARCH",SELECT:"REMOTE_SEARCH"},P=y(),{patientInfo:w,state:O,isSmall:S,appId:j}=t(v),M=a([]),R=a(),L=a(),N=l({vaa05:""}),q=a(),A=n((()=>{var t,a;return!!(null==(a=null==(t=e.msgItem)?void 0:t.content)?void 0:a.body)})),F=e.msgItem.content,H={},B=l(p(F.data||{})),K={beforeRequest(e,t,a){(null==t?void 0:t.params)&&(t.params.vaa05=L.value.selectedPatient.vaa01),t&&Reflect.has(t,"configs")&&(t.configs=L.value.selectedPatient)}};function U(e){const{eventName:t,data:a}=e;t&&C("button-click",{buttonInfo:a,isBI:!0})}function D(e){B[e.button.id+"Disabled"]="1",C("button-click",{buttonInfo:{...f(e.button,["props"]),data:e.data}})}if(A.value){const t=F.body.items||[],a=t.some((e=>"vaa05"===e.code));M.value=t.filter((e=>e.showFlag)).map((t=>{var l,n,o;if("vaa05"===t.code&&!S.value)return L.value={...t},t._value?N.vaa05=t._value:(null==(l=t.options)?void 0:l.length)&&t.value&&(N.vaa05=null==(n=t.options.find((e=>e.value===t.value)))?void 0:n.label,L.value.selectedPatient=e.configs),null;const i={html_type:T[t.type]||t.type,val_key:t.code,name:t.name,elem_width:12,default_val:t.value,lazyRequest:!0,requestCache:!0,urlConfig:{nameKey:null!=(o=t.labelField)?o:"label"},option:[],is_null:t.required?"0":"1",is_edit:e.msgItem.disabled?"0":"1",componentProps:{},multi_select:"MULTI_SELECT"===t.type?"0":"1"};if("DATETIME"===t.type&&(i.date_format="yyyy-MM-dd HH:mm:ss"),"REMOTE_SEARCH"===i.html_type){if(i.componentProps={fallbackOption:!1},i.option=t.options||[],i.default_val=null,t.value&&m(t.options)&&t.options.length>0){t.options.find((e=>(null==e?void 0:e.value)===t.value))&&(i.default_val=t.value)}if(Object.assign(i.urlConfig,{url:"/flow/api/instruction/parameter/getOptionsValues",method:"post",params:{...e.selectParams,code:t.code,source:S.value?"inner":"global",...S.value?{appId:j.value}:{}},dependKey:[]}),a&&(i.urlConfig.params.configs=w.value.info||O.selectedPatient),t.dependencies){const e=t.dependencies.split(",");i.urlConfig.dependKey=e,e.includes("vaa05")&&(i.urlConfig.params.params={vaa05:""})}}return i})).filter((e=>!!e))}function J(){var t;if(!L.value)return null;function a(){e.msgItem.disabled||(O.showPatient=!0)}return i(s,{class:"form-render",ref:q,"require-mark-placement":"left",disabled:e.msgItem.disabled,model:N,rules:{vaa05:{required:L.value.required,message:L.value.name+((null==(t=window.getLanguageByCode)?void 0:t.call(window,"10010.1.146"))||"为必填"),trigger:["input"]}}},{default:()=>[i(r,{label:L.value.name,path:"vaa05",class:"form-render__formItem",style:"--n-feedback-height: 16px; --n-feedback-padding: 0px; --n-feedback-font-size: 12px"},{default:()=>{var e;return[i(u,{style:"--n-text-color-disabled: #000; --n-placeholder-color-disabled: #000;--n-padding-left: 8px; --n-padding-right: 8px",readonly:!0,value:N.vaa05,placeholder:(null==(e=window.getLanguageByCode)?void 0:e.call(window,"10010.1.147"))||"请选择",onClick:a},{suffix:()=>i(d,{color:"#c2c2c2",component:b},null)})]}})]})}async function z(t,a){var l,n;try{const o=a||R.value.getFormValues();await(null==(l=R.value)?void 0:l.validate()),F.body.items.forEach((e=>{var t;"vaa05"===e.code?(e._value=O.selectedPatientLabel,e.value=L.value.selectedPatient.vaa01||e.value):o[e.code]&&(e.value=o[e.code]),e.showFlag||(o[e.code]=e.value),(null==(t=H[e.code])?void 0:t[0])&&(e.options=H[e.code])})),O.loading=!0,C("button-click",{values:o,buttonInfo:t,patient:(null==(n=L.value)?void 0:n.selectedPatient)||e.configs,isForm:!0})}catch(e){O.loading=!1}}function V(e){const{fieldInstance:t,context:a,value:l,fieldKey:n}=e;"REMOTE_SEARCH"===t.componentType&&(null==l?void 0:l.length)&&(H[n]=[null==a?void 0:a.currentOption])}function X(){C("button-click",{showMore:!0})}function G(){var e;if("1834043761964638208"!==(null==(e=F.settings)?void 0:e.id)||!F.data)return null;const t=JSON.parse(F.settings.setting),a=e=>{var t;let l="";for(let n=0;n<e.length;n++){const o=e[n];if(o.setting.scopeKey){l=o.setting.scopeKey;break}if((null==(t=o.childrens)?void 0:t.length)&&(l=a(o.childrens),l))break}return l},l=a(t.templates);return!l||!g(F.data[l])||JSON.parse(F.data[l]).length<=5?null:(g(B[l])&&(B[l]=JSON.parse(B[l]).slice(0,5)),i(c,{block:!0,text:!0,"icon-placement":"right",color:P.value["--c-primary-color"],style:"margin-top: 10px",onClick:X},{icon:()=>i(d,{component:h},null),default:()=>"查看更多"}))}return o((()=>O.showPatient),(t=>{!e.msgItem.disabled&&A.value&&!t&&O.selectedPatientLabel&&L.value&&(N.vaa05=O.selectedPatientLabel,L.value.selectedPatient={...O.selectedPatientForm})})),()=>{var t;return i("div",{class:"card"},[A.value?[i("p",null,[F.title||F.header.title]),i("div",{class:"form-box"},[[J(),i(I,{"request-instance":{get:E.get,post:E.post},"life-cycle":K,column:12,ref:R,"field-list":M.value,onFormChange:V},null)]]),F.footer.buttons.map((t=>function(t){const a={width:"100%","--n-height":"36px",fontSize:"15px",marginTop:"10px"},l=A.value?{...a,marginTop:"0"}:a;return i(c,{id:e.msgId,style:l,secondary:!0,class:"gradient",disabled:e.msgItem.disabled,onClick:async function(){var e;if(A.value){if(!R.value)return;try{L.value?null==(e=q.value)||e.validate((async e=>{var a,l;if(!e){const e=null==(l=(a=R.value).getFormValues)?void 0:l.call(a);Object.assign(e,{vaa05:L.value.selectedPatient.vaa01}),await z(t,e)}})):await z(t)}catch(e){}}else C("button-click")}},{default:()=>[A.value?null==t?void 0:t.text:F.buttonName]})}(t)))]:[i(k,{config:g(null==(t=F.settings)?void 0:t.setting)?JSON.parse(F.settings.setting):null,data:B,"onModule-click":U,"onButton-click":D},null),G()]])}}});export{x as default};
1
+ import{defineComponent as e,inject as t,ref as a,reactive as l,computed as n,watch as o,createVNode as i}from"vue";import{NForm as s,NFormItem as r,NInput as u,NIcon as d,NButton as c}from"naive-ui";import{InjectionAIChat as v}from"../types/index.js";import"../../../index.js";import{cloneDeep as p,isArray as m,omit as f}from"lodash-es";import{isValidJSON as g}from"../utils/index.js";import{ChevronDown as b,ChevronForward as h}from"@vicons/ionicons5";import{useTheme as y}from"../../../../shared/hooks/useTheme.js";import"@vueuse/core";import"date-fns";import"@vue/shared";import"../../../../shared/utils/index.js";import"@vueuse/shared";import"../../../../shared/hooks/selectHooks/useSearchContent.js";import"../../../../shared/hooks/useScrollLoading.js";import E from"../../../form-render/index.js";import I from"../../../card-render/index.js";var k=e({name:"ChatCard",inheritAttrs:!1,props:{msgItem:{type:Object,default:()=>({})},selectParams:{type:Object},configs:{type:Object},msgId:{type:String}},emits:["button-click"],setup(e,{attrs:k,slots:x,emit:_}){const C={TEXT:"INPUT",NUMBER:"INPUT_NUMBER",DATETIME:"DATE",MULTI_SELECT:"REMOTE_SEARCH",SELECT:"REMOTE_SEARCH"},T=y(),{patientInfo:P,state:w,axiosInstance:O,isSmall:S,appId:j}=t(v),M=a([]),R=a(),L=a(),N=l({vaa05:""}),q=a(),A=n((()=>{var t,a;return!!(null==(a=null==(t=e.msgItem)?void 0:t.content)?void 0:a.body)})),F=e.msgItem.content,H={},B=l(p(F.data||{})),K={beforeRequest(e,t,a){(null==t?void 0:t.params)&&(t.params.vaa05=L.value.selectedPatient.vaa01),t&&Reflect.has(t,"configs")&&(t.configs=L.value.selectedPatient)}};function U(e){const{eventName:t,data:a}=e;t&&_("button-click",{buttonInfo:a,isBI:!0})}function D(e){B[e.button.id+"Disabled"]="1",_("button-click",{buttonInfo:{...f(e.button,["props"]),data:e.data}})}if(A.value){const t=F.body.items||[],a=t.some((e=>"vaa05"===e.code));M.value=t.filter((e=>e.showFlag)).map((t=>{var l,n,o;if("vaa05"===t.code&&!S.value)return L.value={...t},t._value?N.vaa05=t._value:(null==(l=t.options)?void 0:l.length)&&t.value&&(N.vaa05=null==(n=t.options.find((e=>e.value===t.value)))?void 0:n.label,L.value.selectedPatient=e.configs),null;const i={html_type:C[t.type]||t.type,val_key:t.code,name:t.name,elem_width:12,default_val:t.value,lazyRequest:!0,requestCache:!0,urlConfig:{nameKey:null!=(o=t.labelField)?o:"label"},option:[],is_null:t.required?"0":"1",is_edit:e.msgItem.disabled?"0":"1",componentProps:{},multi_select:"MULTI_SELECT"===t.type?"0":"1"};if("DATETIME"===t.type&&(i.date_format="yyyy-MM-dd HH:mm:ss"),"REMOTE_SEARCH"===i.html_type){if(i.componentProps={fallbackOption:!1},i.option=t.options||[],i.default_val=null,t.value&&m(t.options)&&t.options.length>0){t.options.find((e=>(null==e?void 0:e.value)===t.value))&&(i.default_val=t.value)}if(Object.assign(i.urlConfig,{url:"/flow/api/instruction/parameter/getOptionsValues",method:"post",params:{...e.selectParams,code:t.code,source:S.value?"inner":"global",...S.value?{appId:j.value}:{}},dependKey:[]}),a&&(i.urlConfig.params.configs=P.value.info||w.selectedPatient),t.dependencies){const e=t.dependencies.split(",");i.urlConfig.dependKey=e,e.includes("vaa05")&&(i.urlConfig.params.params={vaa05:""})}}return i})).filter((e=>!!e))}function J(){var t;if(!L.value)return null;function a(){e.msgItem.disabled||(w.showPatient=!0)}return i(s,{class:"form-render",ref:q,"require-mark-placement":"left",disabled:e.msgItem.disabled,model:N,rules:{vaa05:{required:L.value.required,message:L.value.name+((null==(t=window.getLanguageByCode)?void 0:t.call(window,"10010.1.146"))||"为必填"),trigger:["input"]}}},{default:()=>[i(r,{label:L.value.name,path:"vaa05",class:"form-render__formItem",style:"--n-feedback-height: 16px; --n-feedback-padding: 0px; --n-feedback-font-size: 12px"},{default:()=>{var e;return[i(u,{style:"--n-text-color-disabled: #000; --n-placeholder-color-disabled: #000;--n-padding-left: 8px; --n-padding-right: 8px",readonly:!0,value:N.vaa05,placeholder:(null==(e=window.getLanguageByCode)?void 0:e.call(window,"10010.1.147"))||"请选择",onClick:a},{suffix:()=>i(d,{color:"#c2c2c2",component:b},null)})]}})]})}async function z(t,a){var l,n;try{const o=a||R.value.getFormValues();await(null==(l=R.value)?void 0:l.validate()),F.body.items.forEach((e=>{var t;"vaa05"===e.code?(e._value=w.selectedPatientLabel,e.value=L.value.selectedPatient.vaa01||e.value):o[e.code]&&(e.value=o[e.code]),e.showFlag||(o[e.code]=e.value),(null==(t=H[e.code])?void 0:t[0])&&(e.options=H[e.code])})),w.loading=!0,_("button-click",{values:o,buttonInfo:t,patient:(null==(n=L.value)?void 0:n.selectedPatient)||e.configs,isForm:!0})}catch(e){w.loading=!1}}function V(e){const{fieldInstance:t,context:a,value:l,fieldKey:n}=e;"REMOTE_SEARCH"===t.componentType&&(null==l?void 0:l.length)&&(H[n]=[null==a?void 0:a.currentOption])}function X(){_("button-click",{showMore:!0})}function G(){var e;if("1834043761964638208"!==(null==(e=F.settings)?void 0:e.id)||!F.data)return null;const t=JSON.parse(F.settings.setting),a=e=>{var t;let l="";for(let n=0;n<e.length;n++){const o=e[n];if(o.setting.scopeKey){l=o.setting.scopeKey;break}if((null==(t=o.childrens)?void 0:t.length)&&(l=a(o.childrens),l))break}return l},l=a(t.templates);return!l||!g(F.data[l])||JSON.parse(F.data[l]).length<=5?null:(g(B[l])&&(B[l]=JSON.parse(B[l]).slice(0,5)),i(c,{block:!0,text:!0,"icon-placement":"right",color:T.value["--c-primary-color"],style:"margin-top: 10px",onClick:X},{icon:()=>i(d,{component:h},null),default:()=>"查看更多"}))}return o((()=>w.showPatient),(t=>{!e.msgItem.disabled&&A.value&&!t&&w.selectedPatientLabel&&L.value&&(N.vaa05=w.selectedPatientLabel,L.value.selectedPatient={...w.selectedPatientForm})})),()=>{var t;return i("div",{class:"card"},[A.value?[i("p",null,[F.title||F.header.title]),i("div",{class:"form-box"},[[J(),i(E,{"request-instance":{get:O.get,post:O.post},"life-cycle":K,column:12,ref:R,"field-list":M.value,onFormChange:V},null)]]),F.footer.buttons.map((t=>function(t){const a={width:"100%","--n-height":"36px",fontSize:"15px",marginTop:"10px"},l=A.value?{...a,marginTop:"0"}:a;return i(c,{id:e.msgId,style:l,secondary:!0,class:"gradient",disabled:e.msgItem.disabled,onClick:async function(){var e;if(A.value){if(!R.value)return;try{L.value?null==(e=q.value)||e.validate((async e=>{var a,l;if(!e){const e=null==(l=(a=R.value).getFormValues)?void 0:l.call(a);Object.assign(e,{vaa05:L.value.selectedPatient.vaa01}),await z(t,e)}})):await z(t)}catch(e){}}else _("button-click")}},{default:()=>[A.value?null==t?void 0:t.text:F.buttonName]})}(t)))]:[i(I,{config:g(null==(t=F.settings)?void 0:t.setting)?JSON.parse(F.settings.setting):null,data:B,"onModule-click":U,"onButton-click":D},null),G()]])}}});export{k as default};