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.
- package/README.md +87 -87
- package/es/components/audio-sdk/src/utils/recorder/fft.d.ts +4 -0
- package/es/components/audio-sdk/src/utils/recorder/mp3-engine.d.ts +4 -0
- package/es/components/audio-sdk/src/utils/recorder/mp3.d.ts +4 -0
- package/es/components/audio-sdk/src/utils/recorder/recorder.d.ts +4 -0
- package/es/components/audio-sdk/src/utils/recorder/wave.d.ts +4 -0
- package/es/components/bpmn-workflow/src/BpmnWorkflow.d.ts +0 -0
- package/es/components/bpmn-workflow/types/BpmnViewer.d.ts +1 -0
- package/es/components/bpmn-workflow/types/ModelingModule.d.ts +1 -0
- package/es/components/bpmn-workflow/types/MoveCanvasModule.d.ts +1 -0
- package/es/components/card-render/src/components/index.d.ts +23 -23
- package/es/components/fabric-chart/src/hooks/temperature/useOther.js +4 -2
- package/es/components/field-set/src/FieldColor.vue.d.ts +1 -1
- package/es/components/field-set/src/FieldFilter.vue.d.ts +1 -1
- package/es/components/field-set/src/FieldSet.vue.d.ts +1 -1
- package/es/components/field-set/src/components/table-row.vue.d.ts +1 -1
- package/es/components/form-render/src/components/renderer/formItem.js +2 -2
- package/es/components/form-render/src/hooks/useNewLowCodeReactions.js +1 -1
- package/es/components/iho-chat/src/components/ChatMain.vue2.js +1 -1
- package/es/components/iho-chat/src/components/PersonProfile.vue2.js +1 -1
- package/es/components/scale-view/src/components/formitem/r-input.js +75 -10
- package/es/env.d.ts +25 -25
- package/es/shared/assets/img/defaultCover/10review_successful.png.js +1 -1
- package/es/shared/assets/img/defaultCover/11review_fail.png.js +1 -1
- package/es/shared/assets/img/defaultCover/12no_setting.png.js +1 -1
- package/es/shared/assets/img/defaultCover/13no_menu_setting.png.js +1 -1
- package/es/shared/assets/img/defaultCover/14no_call_setting.png.js +1 -1
- package/es/shared/assets/img/defaultCover/15no_use_tag.png.js +1 -1
- package/es/shared/assets/img/defaultCover/16no_table_data.png.js +1 -1
- package/es/shared/assets/img/defaultCover/1location.png.js +1 -1
- package/es/shared/assets/img/defaultCover/2notfound.png.js +1 -1
- package/es/shared/assets/img/defaultCover/3loading.png.js +1 -1
- package/es/shared/assets/img/defaultCover/4no_permission.png.js +1 -1
- package/es/shared/assets/img/defaultCover/5no_data.png.js +1 -1
- package/es/shared/assets/img/defaultCover/6no_network.png.js +1 -1
- package/es/shared/assets/img/defaultCover/7no_doctor.png.js +1 -1
- package/es/shared/assets/img/defaultCover/8system_error.png.js +1 -1
- package/es/shared/assets/img/defaultCover/9system_upgrade.png.js +1 -1
- package/es/shared/assets/img/failure.png.js +1 -1
- package/es/shared/assets/img/no-permission.png.js +1 -1
- package/es/shared/assets/img/nodata.png.js +1 -1
- package/es/shared/assets/img/notfound.png.js +1 -1
- package/es/shared/assets/img/qr.png.js +1 -1
- package/es/shared/assets/img/success.png.js +1 -1
- package/es/shared/assets/img/table_style_2.png.js +1 -1
- package/es/shared/assets/img/video.png.js +1 -1
- package/es/shared/assets/img/video_default_cover.png.js +1 -1
- package/es/shared/assets/img/xb_big.png.js +1 -1
- package/es/shared/assets/img/xb_small.png.js +1 -1
- package/es/shared/components/VueDraggable/src/vuedraggable.d.ts +86 -0
- package/es/shared/package.json.js +1 -1
- package/es/shared/utils/fabricjs/index.d.ts +6823 -0
- package/es/shared/utils/tapable/index.d.ts +139 -0
- package/package.json +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
|
+
```
|
|
File without changes
|
|
@@ -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
|
|
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 &&
|
|
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
|
|
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\
|
|
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">\
|
|
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
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
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 (
|
|
70
|
-
|
|
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
|
-
|
|
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 };
|