cnhis-design-vue 3.4.0-beta.77 → 3.4.0-beta.79

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 (49) 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/card-render/src/components/index.d.ts +23 -23
  12. package/es/components/form-render/src/components/renderer/formItem.js +2 -2
  13. package/es/components/form-render/src/hooks/useNewLowCodeReactions.js +1 -1
  14. package/es/components/iho-chat/src/components/ChatMain.vue2.js +1 -1
  15. package/es/components/iho-chat/src/components/PersonProfile.vue2.js +1 -1
  16. package/es/components/scale-view/src/components/formitem/r-input.js +75 -10
  17. package/es/env.d.ts +25 -25
  18. package/es/shared/assets/img/defaultCover/10review_successful.png.js +1 -1
  19. package/es/shared/assets/img/defaultCover/11review_fail.png.js +1 -1
  20. package/es/shared/assets/img/defaultCover/12no_setting.png.js +1 -1
  21. package/es/shared/assets/img/defaultCover/13no_menu_setting.png.js +1 -1
  22. package/es/shared/assets/img/defaultCover/14no_call_setting.png.js +1 -1
  23. package/es/shared/assets/img/defaultCover/15no_use_tag.png.js +1 -1
  24. package/es/shared/assets/img/defaultCover/16no_table_data.png.js +1 -1
  25. package/es/shared/assets/img/defaultCover/1location.png.js +1 -1
  26. package/es/shared/assets/img/defaultCover/2notfound.png.js +1 -1
  27. package/es/shared/assets/img/defaultCover/3loading.png.js +1 -1
  28. package/es/shared/assets/img/defaultCover/4no_permission.png.js +1 -1
  29. package/es/shared/assets/img/defaultCover/5no_data.png.js +1 -1
  30. package/es/shared/assets/img/defaultCover/6no_network.png.js +1 -1
  31. package/es/shared/assets/img/defaultCover/7no_doctor.png.js +1 -1
  32. package/es/shared/assets/img/defaultCover/8system_error.png.js +1 -1
  33. package/es/shared/assets/img/defaultCover/9system_upgrade.png.js +1 -1
  34. package/es/shared/assets/img/failure.png.js +1 -1
  35. package/es/shared/assets/img/no-permission.png.js +1 -1
  36. package/es/shared/assets/img/nodata.png.js +1 -1
  37. package/es/shared/assets/img/notfound.png.js +1 -1
  38. package/es/shared/assets/img/qr.png.js +1 -1
  39. package/es/shared/assets/img/success.png.js +1 -1
  40. package/es/shared/assets/img/table_style_2.png.js +1 -1
  41. package/es/shared/assets/img/video.png.js +1 -1
  42. package/es/shared/assets/img/video_default_cover.png.js +1 -1
  43. package/es/shared/assets/img/xb_big.png.js +1 -1
  44. package/es/shared/assets/img/xb_small.png.js +1 -1
  45. package/es/shared/components/VueDraggable/src/vuedraggable.d.ts +86 -0
  46. package/es/shared/package.json.js +1 -1
  47. package/es/shared/utils/fabricjs/index.d.ts +6823 -0
  48. package/es/shared/utils/tapable/index.d.ts +139 -0
  49. package/package.json +2 -2
package/README.md CHANGED
@@ -1,87 +1,87 @@
1
- # 安装
2
-
3
- ```shell
4
- npm i cnhis-design-vue@[版本号]
5
- # or
6
- yarn add cnhis-design-vue@[版本号] #推荐
7
- ```
8
-
9
- ## 1.全局引入
10
-
11
- ```typescript
12
- // main.ts
13
- import { createApp } from 'vue';
14
- import App from './App.vue';
15
- import 'cnhis-design-vue/es/packages/index.css';
16
- import cui from 'cnhis-design-vue';
17
-
18
- const app = createApp(App);
19
- app.use(cui).mount('#app');
20
- ```
21
-
22
- ## 2. 按需引入
23
-
24
- 组件现在支持了自动按需引入, 但是样式文件需要额外的处理
25
-
26
- ### 2.1 样式处理方式1 (按需引入样式)
27
-
28
- ```shell
29
- # 安装自动导入样式的插件
30
- npm i -d vite-plugin-style-import
31
- ```
32
-
33
- ```typescript
34
- // vite.config.ts
35
- import { defineConfig } from 'vite';
36
- import { createStyleImportPlugin } from 'vite-plugin-style-import';
37
-
38
- export default defineConfig({
39
- plugins: [
40
- // ...otherPlugins
41
- createStyleImportPlugin({
42
- libs: [
43
- {
44
- libraryName: 'cnhis-design-vue',
45
- esModule: true,
46
- ensureStyleFile: true,
47
- resolveStyle: name => {
48
- return `cnhis-design-vue/es/components/${ name.slice(2) }/style/index.css`;
49
- }
50
- }
51
- ]
52
- })
53
- ]
54
- });
55
- ```
56
-
57
- ### 2.2 样式处理方式2 (全局引入样式)
58
-
59
- ```typescript
60
- // main.ts
61
- import 'cnhis-design-vue/es/components/index.css';
62
- ```
63
-
64
- ## 3.FAQ
65
-
66
- ### 3.1 项目打包后样式丢失
67
-
68
- 处理方法, 将 cnhis-design-vue 从 vendor 包中移除 (没有出现此问题则不需要)
69
-
70
- ```typescript
71
- // vite.config.ts
72
- import { defineConfig } from 'vite';
73
-
74
- export default defineConfig({
75
- build: {
76
- rollupOptions: {
77
- // ..otherOptions
78
- output: {
79
- dir: './dist',
80
- manualChunks: {
81
- 'cnhis-vendor': ['cnhis-design-vue']
82
- }
83
- }
84
- }
85
- }
86
- });
87
- ```
1
+ # 安装
2
+
3
+ ```shell
4
+ npm i cnhis-design-vue@[版本号]
5
+ # or
6
+ yarn add cnhis-design-vue@[版本号] #推荐
7
+ ```
8
+
9
+ ## 1.全局引入
10
+
11
+ ```typescript
12
+ // main.ts
13
+ import { createApp } from 'vue';
14
+ import App from './App.vue';
15
+ import 'cnhis-design-vue/es/packages/index.css';
16
+ import cui from 'cnhis-design-vue';
17
+
18
+ const app = createApp(App);
19
+ app.use(cui).mount('#app');
20
+ ```
21
+
22
+ ## 2. 按需引入
23
+
24
+ 组件现在支持了自动按需引入, 但是样式文件需要额外的处理
25
+
26
+ ### 2.1 样式处理方式1 (按需引入样式)
27
+
28
+ ```shell
29
+ # 安装自动导入样式的插件
30
+ npm i -d vite-plugin-style-import
31
+ ```
32
+
33
+ ```typescript
34
+ // vite.config.ts
35
+ import { defineConfig } from 'vite';
36
+ import { createStyleImportPlugin } from 'vite-plugin-style-import';
37
+
38
+ export default defineConfig({
39
+ plugins: [
40
+ // ...otherPlugins
41
+ createStyleImportPlugin({
42
+ libs: [
43
+ {
44
+ libraryName: 'cnhis-design-vue',
45
+ esModule: true,
46
+ ensureStyleFile: true,
47
+ resolveStyle: name => {
48
+ return `cnhis-design-vue/es/components/${ name.slice(2) }/style/index.css`;
49
+ }
50
+ }
51
+ ]
52
+ })
53
+ ]
54
+ });
55
+ ```
56
+
57
+ ### 2.2 样式处理方式2 (全局引入样式)
58
+
59
+ ```typescript
60
+ // main.ts
61
+ import 'cnhis-design-vue/es/components/index.css';
62
+ ```
63
+
64
+ ## 3.FAQ
65
+
66
+ ### 3.1 项目打包后样式丢失
67
+
68
+ 处理方法, 将 cnhis-design-vue 从 vendor 包中移除 (没有出现此问题则不需要)
69
+
70
+ ```typescript
71
+ // vite.config.ts
72
+ import { defineConfig } from 'vite';
73
+
74
+ export default defineConfig({
75
+ build: {
76
+ rollupOptions: {
77
+ // ..otherOptions
78
+ output: {
79
+ dir: './dist',
80
+ manualChunks: {
81
+ 'cnhis-vendor': ['cnhis-design-vue']
82
+ }
83
+ }
84
+ }
85
+ }
86
+ });
87
+ ```
@@ -0,0 +1,4 @@
1
+ import { AnyFn } from '../../../../../cnhis-design-vue/es/shared/types';
2
+
3
+ declare const useFFT: AnyFn;
4
+ export { useFFT };
@@ -0,0 +1,4 @@
1
+ import { AnyFn } from '../../../../../cnhis-design-vue/es/shared/types';
2
+
3
+ declare const useMP3Engine: AnyFn;
4
+ export { useMP3Engine };
@@ -0,0 +1,4 @@
1
+ import { AnyFn } from '../../../../../cnhis-design-vue/es/shared/types';
2
+
3
+ declare const useMP3: AnyFn;
4
+ export { useMP3 };
@@ -0,0 +1,4 @@
1
+ import { AnyFn } from '../../../../../cnhis-design-vue/es/shared/types';
2
+
3
+ declare const Recorder: AnyFn & { FrequencyHistogramView: any };
4
+ export default Recorder;
@@ -0,0 +1,4 @@
1
+ import { AnyFn } from '../../../../../cnhis-design-vue/es/shared/types';
2
+
3
+ declare const useWave: AnyFn;
4
+ export { useWave };
@@ -0,0 +1 @@
1
+ declare module 'bpmn-js/lib/Viewer';
@@ -0,0 +1 @@
1
+ declare module 'bpmn-js/lib/features/modeling';
@@ -0,0 +1 @@
1
+ declare module 'diagram-js/lib/navigation/movecanvas';
@@ -143,6 +143,29 @@ declare function getComponent(type: COMPONENT_TYPE): import("vue").DefineCompone
143
143
  default: () => {};
144
144
  type: import("vue").PropType<import("../../../../shared/types").AnyObject>;
145
145
  };
146
+ }>, () => any, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, "button-click"[], "button-click", import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
147
+ config: {
148
+ default: () => {};
149
+ type: import("vue").PropType<import("../../../../shared/types").AnyObject>;
150
+ };
151
+ data: {
152
+ default: () => {};
153
+ type: import("vue").PropType<import("../../../../shared/types").AnyObject>;
154
+ };
155
+ }>> & Readonly<{
156
+ "onButton-click"?: ((...args: any[]) => any) | undefined;
157
+ }>, {
158
+ data: import("../../../../shared/types").AnyObject;
159
+ config: import("../../../../shared/types").AnyObject;
160
+ }, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any> | import("vue").DefineComponent<import("vue").ExtractPropTypes<{
161
+ config: {
162
+ default: () => {};
163
+ type: import("vue").PropType<import("../../../../shared/types").AnyObject>;
164
+ };
165
+ data: {
166
+ default: () => {};
167
+ type: import("vue").PropType<import("../../../../shared/types").AnyObject>;
168
+ };
146
169
  }>, {
147
170
  props: import("@vue/shared").LooseRequired<Readonly<import("vue").ExtractPropTypes<{
148
171
  config: {
@@ -468,29 +491,6 @@ declare function getComponent(type: COMPONENT_TYPE): import("vue").DefineCompone
468
491
  default: () => {};
469
492
  type: import("vue").PropType<import("../../../../shared/types").AnyObject>;
470
493
  };
471
- }>, () => any, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, "button-click"[], "button-click", import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
472
- config: {
473
- default: () => {};
474
- type: import("vue").PropType<import("../../../../shared/types").AnyObject>;
475
- };
476
- data: {
477
- default: () => {};
478
- type: import("vue").PropType<import("../../../../shared/types").AnyObject>;
479
- };
480
- }>> & Readonly<{
481
- "onButton-click"?: ((...args: any[]) => any) | undefined;
482
- }>, {
483
- data: import("../../../../shared/types").AnyObject;
484
- config: import("../../../../shared/types").AnyObject;
485
- }, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any> | import("vue").DefineComponent<import("vue").ExtractPropTypes<{
486
- config: {
487
- default: () => {};
488
- type: import("vue").PropType<import("../../../../shared/types").AnyObject>;
489
- };
490
- data: {
491
- default: () => {};
492
- type: import("vue").PropType<import("../../../../shared/types").AnyObject>;
493
- };
494
494
  }>, {
495
495
  props: import("@vue/shared").LooseRequired<Readonly<import("vue").ExtractPropTypes<{
496
496
  config: {
@@ -142,13 +142,13 @@ const script = /* @__PURE__ */ defineComponent({
142
142
  var _a, _b;
143
143
  return [createVNode("div", {
144
144
  "innerHTML": editorUnescape((_b = (_a = props.fieldItem) == null ? void 0 : _a.editor_title) != null ? _b : "")
145
- }, null), createVNode(NButton, {
145
+ }, null), props.fieldItem.editor_title_mode === "POPUP_ALERT" ? createVNode(NButton, {
146
146
  "text": true,
147
147
  "onClick": () => editorTitleShowRef.value = !editorTitleShowRef.value,
148
148
  "style": "position:absolute;right:2px;top:2px;line-height:1;height:12px;transform:scaleY(0.9)"
149
149
  }, {
150
150
  default: () => [createTextVNode("x")]
151
- })];
151
+ }) : null];
152
152
  }
153
153
  });
154
154
  }
@@ -45,7 +45,7 @@ function useNewLowCodeReactions(configListRef, formModel) {
45
45
  createFieldHandler((state, isPositive, { actionConfig: { value } = {} }) => {
46
46
  if (!isPositive)
47
47
  return;
48
- state.value = value === null ? "null" : value === void 0 ? "undefined" : value;
48
+ state.value = value == null ? null : value;
49
49
  })
50
50
  ]
51
51
  ]);
@@ -600,7 +600,7 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
600
600
  }, {
601
601
  default: withCtx(() => [!unref(isAudioOrVideoMessage)(item.content) ? (openBlock(), createElementBlock(Fragment, {
602
602
  key: 0
603
- }, [createCommentVNode(' <n-button\r\n quaternary\r\n size="tiny"\r\n @click="(event: MouseEvent) => handleSelectLabel(event, item.id)"\r\n >\r\n <template #icon>\r\n <n-icon size="17" :component="HappyOutline" />\r\n </template>\r\n </n-button> '), createVNode(unref(NButton), {
603
+ }, [createCommentVNode(' <n-button\n quaternary\n size="tiny"\n @click="(event: MouseEvent) => handleSelectLabel(event, item.id)"\n >\n <template #icon>\n <n-icon size="17" :component="HappyOutline" />\n </template>\n </n-button> '), createVNode(unref(NButton), {
604
604
  quaternary: "",
605
605
  size: "tiny",
606
606
  onClick: () => setReferenceMsg(item)
@@ -170,7 +170,7 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
170
170
  round: "",
171
171
  size: 100,
172
172
  onClickCapture: _cache[0] || (_cache[0] = ($event) => showLargeAvatar.value = true)
173
- }, 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", {
173
+ }, 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", {
174
174
  class: normalizeClass(["iho-chatRole", unref(isDoctorRole)(userDetail.roleInfo) ? "isDoctor" : ""])
175
175
  }, toDisplayString(unref(getRoleName)(userDetail.roleInfo)), 3), [[vShow, unref(getRoleName)(userDetail.roleInfo)]])]), createElementVNode("p", null, toDisplayString(userDetail.orgName), 1)]), createVNode(unref(NButton), {
176
176
  strong: "",
@@ -29,12 +29,18 @@ var RInput = /* @__PURE__ */ defineComponent({
29
29
  setup(props, {
30
30
  emit
31
31
  }) {
32
- var _a, _b, _c, _d, _e, _f;
32
+ var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j;
33
33
  const type = (_a = props.item) == null ? void 0 : _a.valueType;
34
34
  const eleType = ((_b = props.item) == null ? void 0 : _b.type) || "INPUT";
35
35
  const isTextarea = eleType == "INPUT" || eleType == "EVALUATE_INPUT";
36
36
  const row = ((_d = (_c = props.item) == null ? void 0 : _c.setting) == null ? void 0 : _d.inputRow) || 1;
37
37
  const defaultPlaceHolder = (_f = (_e = props.item) == null ? void 0 : _e.setting) == null ? void 0 : _f.defaultPlaceHolder;
38
+ const numberSeting = ((_g = props.item.scoreConfigs) == null ? void 0 : _g.numberSetting) || {};
39
+ const numberMax = (_h = numberSeting.max) != null ? _h : void 0;
40
+ const numberMin = (_i = numberSeting.min) != null ? _i : void 0;
41
+ const precision = !("enableDecimal" in numberSeting) ? void 0 : !numberSeting.enableDecimal ? 0 : numberSeting.decimal;
42
+ const allowDecimal = precision !== 0;
43
+ const unit = (_j = numberSeting.unit) != null ? _j : void 0;
38
44
  const {
39
45
  isGeneratePrintPdf
40
46
  } = toRefs(props);
@@ -49,29 +55,85 @@ var RInput = /* @__PURE__ */ defineComponent({
49
55
  maxRows: row || 1
50
56
  };
51
57
  });
58
+ const handleBlur = () => {
59
+ if (inputValue.value !== lastEmittedValue.value) {
60
+ lastEmittedValue.value = inputValue.value;
61
+ emit("scaleChange", inputValue.value, props.item);
62
+ }
63
+ };
52
64
  const keydown = (e) => {
53
65
  if (!isTextarea)
54
66
  return;
55
67
  const key = e.key;
56
- if (key === "e" || key === "E" || key === "+" || key === "-") {
57
- e.returnValue = false;
58
- } else {
59
- e.returnValue = true;
68
+ const target = e.target;
69
+ const cursorPosition = target.selectionStart || 0;
70
+ if (type === "number" && key === "-") {
71
+ if (cursorPosition !== 0 || target.value.includes("-")) {
72
+ e.preventDefault();
73
+ return;
74
+ }
75
+ return;
76
+ }
77
+ if (key === "e" || key === "E" || key === "+") {
78
+ e.preventDefault();
79
+ }
80
+ if (key === "Enter") {
81
+ handleBlur();
60
82
  }
61
83
  };
62
84
  const inputValue = ref(props.form[props.item.val_key]);
85
+ const lastEmittedValue = ref(props.form[props.item.val_key]);
63
86
  watch(() => props.form[props.item.val_key], (val) => {
64
87
  inputValue.value = val;
88
+ lastEmittedValue.value = val;
65
89
  }, {
66
90
  immediate: true
67
91
  });
68
92
  const handleUpdateValue = (val) => {
69
- if (isTextarea && val && type === "number") {
70
- inputValue.value = val.replace(/[^\d.]/gi, "");
93
+ if (val && type === "number") {
94
+ const hasNegativeSign = val.startsWith("-");
95
+ let filteredVal = val.replace(/[^\d.-]/gi, "");
96
+ if (hasNegativeSign) {
97
+ filteredVal = filteredVal.replace(/-/g, "");
98
+ filteredVal = "-" + filteredVal;
99
+ } else {
100
+ filteredVal = filteredVal.replace(/-/g, "");
101
+ }
102
+ const dotIndex = filteredVal.indexOf(".");
103
+ if (dotIndex !== -1) {
104
+ if (!allowDecimal) {
105
+ filteredVal = filteredVal.replace(/\./g, "");
106
+ } else {
107
+ filteredVal = filteredVal.substring(0, dotIndex + 1) + filteredVal.substring(dotIndex + 1).replace(/\./g, "");
108
+ }
109
+ }
110
+ if (allowDecimal && typeof precision === "number") {
111
+ const currentDotIndex = filteredVal.indexOf(".");
112
+ if (currentDotIndex !== -1) {
113
+ const decimalPart = filteredVal.substring(currentDotIndex + 1);
114
+ if (decimalPart.length > precision) {
115
+ filteredVal = filteredVal.substring(0, currentDotIndex + 1 + precision);
116
+ }
117
+ }
118
+ }
119
+ if (filteredVal === "-") {
120
+ if (numberMin !== void 0 && numberMin >= 0) {
121
+ filteredVal = "";
122
+ }
123
+ }
124
+ const numValue = filteredVal === "" || filteredVal === "." || filteredVal === "-" ? null : parseFloat(filteredVal);
125
+ if (numValue !== null && !isNaN(numValue)) {
126
+ if (numberMin !== void 0 && numValue < numberMin) {
127
+ filteredVal = numberMin.toString();
128
+ }
129
+ if (numberMax !== void 0 && numValue > numberMax) {
130
+ filteredVal = numberMax.toString();
131
+ }
132
+ }
133
+ inputValue.value = filteredVal;
71
134
  } else {
72
135
  inputValue.value = val;
73
136
  }
74
- emit("scaleChange", inputValue.value, props.item);
75
137
  };
76
138
  const renderPrintSpan = () => {
77
139
  const val = inputValue.value;
@@ -96,8 +158,11 @@ var RInput = /* @__PURE__ */ defineComponent({
96
158
  "placeholder": defaultPlaceHolder,
97
159
  "disabled": props.isLock,
98
160
  "onKeydown": keydown,
99
- "onUpdate:value": handleUpdateValue
100
- }, null);
161
+ "onUpdate:value": handleUpdateValue,
162
+ "onBlur": handleBlur
163
+ }, {
164
+ suffix: () => unit ? createVNode("span", null, [unit]) : null
165
+ });
101
166
  };
102
167
  return () => {
103
168
  return inputRender();
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 };