cnhis-design-vue 3.4.0-beta.76 → 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 (54) 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/fabric-chart/src/hooks/temperature/useOther.js +4 -2
  13. package/es/components/field-set/src/FieldColor.vue.d.ts +1 -1
  14. package/es/components/field-set/src/FieldFilter.vue.d.ts +1 -1
  15. package/es/components/field-set/src/FieldSet.vue.d.ts +1 -1
  16. package/es/components/field-set/src/components/table-row.vue.d.ts +1 -1
  17. package/es/components/form-render/src/components/renderer/formItem.js +2 -2
  18. package/es/components/form-render/src/hooks/useNewLowCodeReactions.js +1 -1
  19. package/es/components/iho-chat/src/components/ChatMain.vue2.js +1 -1
  20. package/es/components/iho-chat/src/components/PersonProfile.vue2.js +1 -1
  21. package/es/components/scale-view/src/components/formitem/r-input.js +75 -10
  22. package/es/env.d.ts +25 -25
  23. package/es/shared/assets/img/defaultCover/10review_successful.png.js +1 -1
  24. package/es/shared/assets/img/defaultCover/11review_fail.png.js +1 -1
  25. package/es/shared/assets/img/defaultCover/12no_setting.png.js +1 -1
  26. package/es/shared/assets/img/defaultCover/13no_menu_setting.png.js +1 -1
  27. package/es/shared/assets/img/defaultCover/14no_call_setting.png.js +1 -1
  28. package/es/shared/assets/img/defaultCover/15no_use_tag.png.js +1 -1
  29. package/es/shared/assets/img/defaultCover/16no_table_data.png.js +1 -1
  30. package/es/shared/assets/img/defaultCover/1location.png.js +1 -1
  31. package/es/shared/assets/img/defaultCover/2notfound.png.js +1 -1
  32. package/es/shared/assets/img/defaultCover/3loading.png.js +1 -1
  33. package/es/shared/assets/img/defaultCover/4no_permission.png.js +1 -1
  34. package/es/shared/assets/img/defaultCover/5no_data.png.js +1 -1
  35. package/es/shared/assets/img/defaultCover/6no_network.png.js +1 -1
  36. package/es/shared/assets/img/defaultCover/7no_doctor.png.js +1 -1
  37. package/es/shared/assets/img/defaultCover/8system_error.png.js +1 -1
  38. package/es/shared/assets/img/defaultCover/9system_upgrade.png.js +1 -1
  39. package/es/shared/assets/img/failure.png.js +1 -1
  40. package/es/shared/assets/img/no-permission.png.js +1 -1
  41. package/es/shared/assets/img/nodata.png.js +1 -1
  42. package/es/shared/assets/img/notfound.png.js +1 -1
  43. package/es/shared/assets/img/qr.png.js +1 -1
  44. package/es/shared/assets/img/success.png.js +1 -1
  45. package/es/shared/assets/img/table_style_2.png.js +1 -1
  46. package/es/shared/assets/img/video.png.js +1 -1
  47. package/es/shared/assets/img/video_default_cover.png.js +1 -1
  48. package/es/shared/assets/img/xb_big.png.js +1 -1
  49. package/es/shared/assets/img/xb_small.png.js +1 -1
  50. package/es/shared/components/VueDraggable/src/vuedraggable.d.ts +86 -0
  51. package/es/shared/package.json.js +1 -1
  52. package/es/shared/utils/fabricjs/index.d.ts +6823 -0
  53. package/es/shared/utils/tapable/index.d.ts +139 -0
  54. 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: {
@@ -37,17 +37,19 @@ function useOther(canvas, propItems, emits, computedX, computedY, fixedNoRisePoi
37
37
  }
38
38
  }
39
39
  function adjustEventsForCrossDay(eventList) {
40
+ var _a, _b;
40
41
  const currentColumnEvents = [...eventList];
41
42
  const sortedEvents = currentColumnEvents.sort((a, b) => (b.trueLeft || 0) - (a.trueLeft || 0));
42
43
  for (let i = 0; i < sortedEvents.length; i++) {
43
44
  const event = sortedEvents[i];
44
45
  const nextEvent = sortedEvents[i + 1];
45
- const prevLeft = event.trueLeft - xCellWidth;
46
+ const currentLeft = (_a = event.trueLeft) != null ? _a : 0;
47
+ const prevLeft = currentLeft - xCellWidth;
46
48
  if (prevLeft >= originX) {
47
49
  event.set("left", prevLeft);
48
50
  event.trueLeft = prevLeft;
49
51
  }
50
- if (nextEvent && (event.trueLeft || 0) - (nextEvent.trueLeft || 0) > xCellWidth + 1) {
52
+ if (nextEvent && currentLeft - ((_b = nextEvent.trueLeft) != null ? _b : 0) > xCellWidth + 1) {
51
53
  break;
52
54
  }
53
55
  }
@@ -553,9 +553,9 @@ declare const _default: import("vue").DefineComponent<import("vue").ExtractPropT
553
553
  hide: boolean;
554
554
  }>;
555
555
  draggable: boolean;
556
+ isHighlightRow: boolean;
556
557
  idx: number;
557
558
  isHighlight: boolean;
558
- isHighlightRow: boolean;
559
559
  isFieldSet: boolean;
560
560
  fieldDescribeMode: "column" | "tooltip";
561
561
  hideExpressionOption: AnyObject[];
@@ -594,9 +594,9 @@ declare const _default: import("vue").DefineComponent<import("vue").ExtractPropT
594
594
  hide: boolean;
595
595
  }>;
596
596
  draggable: boolean;
597
+ isHighlightRow: boolean;
597
598
  idx: number;
598
599
  isHighlight: boolean;
599
- isHighlightRow: boolean;
600
600
  isFieldSet: boolean;
601
601
  fieldDescribeMode: "column" | "tooltip";
602
602
  hideExpressionOption: AnyObject[];
@@ -773,9 +773,9 @@ declare const _default: import("vue").DefineComponent<import("vue").ExtractPropT
773
773
  hide: boolean;
774
774
  }>;
775
775
  draggable: boolean;
776
+ isHighlightRow: boolean;
776
777
  idx: number;
777
778
  isHighlight: boolean;
778
- isHighlightRow: boolean;
779
779
  isFieldSet: boolean;
780
780
  fieldDescribeMode: "column" | "tooltip";
781
781
  hideExpressionOption: AnyObject[];
@@ -384,9 +384,9 @@ declare const _default: import("vue").DefineComponent<import("vue").ExtractPropT
384
384
  hide: boolean;
385
385
  }>;
386
386
  draggable: boolean;
387
+ isHighlightRow: boolean;
387
388
  idx: number;
388
389
  isHighlight: boolean;
389
- isHighlightRow: boolean;
390
390
  isFieldSet: boolean;
391
391
  fieldDescribeMode: "column" | "tooltip";
392
392
  hideExpressionOption: AnyObject[];
@@ -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 };