vue2-client 1.22.3 → 1.22.4

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 (88) hide show
  1. package/.env.his +19 -19
  2. package/.idea/.name +1 -0
  3. package/.idea/MarsCodeWorkspaceAppSettings.xml +8 -0
  4. package/.idea/deployment.xml +14 -0
  5. package/.idea/gradle.xml +7 -0
  6. package/.idea/inspectionProfiles/Project_Default.xml +6 -0
  7. package/.idea/libraries/contour_plot.xml +9 -0
  8. package/.idea/material_theme_project_new.xml +18 -0
  9. package/.idea/misc.xml +87 -5
  10. package/package.json +1 -1
  11. package/src/base-client/components/common/HIS/HForm/HForm.vue +1186 -1186
  12. package/src/base-client/components/common/XMarkdownViewer/demo.vue +102 -102
  13. package/src/base-client/components/his/HAi/HAi.vue +1177 -1177
  14. package/src/base-client/components/his/XTransfer/index.md +327 -327
  15. package/src/base-client/plugins/GetLoginInfoService.js +4 -4
  16. package/src/utils/login.js +11 -11
  17. package/.history/.eslintrc_20260521171150.js +0 -74
  18. package/.history/.eslintrc_20260521171213.js +0 -74
  19. package/.history/src/base-client/components/common/HIS/HAddNativeForm/HAddNativeForm_20260601154443.vue +0 -726
  20. package/.history/src/base-client/components/common/HIS/HAddNativeForm/HAddNativeForm_20260601154700.vue +0 -478
  21. package/.history/src/base-client/components/common/HIS/HButtons/HButtons_20260512175435.vue +0 -706
  22. package/.history/src/base-client/components/common/HIS/HButtons/HButtons_20260512175450.vue +0 -694
  23. package/.history/src/base-client/components/common/HIS/HButtons/HButtons_20260611152602.vue +0 -755
  24. package/.history/src/base-client/components/common/HIS/HForm/HForm_20260513145941.vue +0 -524
  25. package/.history/src/base-client/components/common/HIS/HForm/HForm_20260513153133.vue +0 -731
  26. package/.history/src/base-client/components/common/HIS/HForm/HForm_20260513160316.vue +0 -525
  27. package/.history/src/base-client/components/common/HIS/HForm/HForm_20260601144150.vue +0 -1046
  28. package/.history/src/base-client/components/common/HIS/HFormTable/HFormTable_20260310142713.vue +0 -512
  29. package/.history/src/base-client/components/common/HIS/HFormTable/HFormTable_20260310145118.vue +0 -511
  30. package/.history/src/base-client/components/common/HIS/HFormTable/HFormTable_20260311094834.vue +0 -696
  31. package/.history/src/base-client/components/common/HIS/HFormTable/HFormTable_20260320143028.vue +0 -693
  32. package/.history/src/base-client/components/common/HIS/HFormTable/HFormTable_20260409101450.vue +0 -677
  33. package/.history/src/base-client/components/common/HIS/HTab/HTab_20260508164645.vue +0 -758
  34. package/.history/src/base-client/components/common/HIS/HTab/HTab_20260508164714.vue +0 -693
  35. package/.history/src/base-client/components/common/HIS/HTab/HTab_20260508171651.vue +0 -716
  36. package/.history/src/base-client/components/common/HIS/HTab/HTab_20260509133717.vue +0 -695
  37. package/.history/src/base-client/components/common/HIS/HTab/HTab_20260509171115.vue +0 -664
  38. package/.history/src/base-client/components/common/XAddNativeForm/XAddNativeForm_20260513140637.vue +0 -1455
  39. package/.history/src/base-client/components/common/XAddNativeForm/XAddNativeForm_20260513140935.vue +0 -1441
  40. package/.history/src/base-client/components/common/XAddNativeForm/XAddNativeForm_20260513150818.vue +0 -1441
  41. package/.history/src/base-client/components/common/XAddNativeForm/XAddNativeForm_20260513153119.vue +0 -1442
  42. package/.history/src/base-client/components/common/XAddNativeForm/XAddNativeForm_20260513153126.vue +0 -1486
  43. package/.history/src/base-client/components/common/XForm/XFormItem_20260513140854.vue +0 -1607
  44. package/.history/src/base-client/components/common/XMarkdownViewer/XMarkdownViewer_20260519140403.vue +0 -643
  45. package/.history/src/base-client/components/common/XMarkdownViewer/XMarkdownViewer_20260519140829.vue +0 -628
  46. package/.history/src/base-client/components/common/XMarkdownViewer/demo_20260519142824.vue +0 -104
  47. package/.history/src/base-client/components/common/XMarkdownViewer/demo_20260519143155.vue +0 -102
  48. package/.history/src/base-client/components/common/XReportGrid/XReport_20260309171231.vue +0 -1241
  49. package/.history/src/base-client/components/common/XReportGrid/XReport_20260309171441.vue +0 -1223
  50. package/.history/src/base-client/components/his/HAi/HAi_20260612174826.vue +0 -472
  51. package/.history/src/base-client/components/his/HAi/HAi_20260612175839.vue +0 -538
  52. package/.history/src/base-client/components/his/HAi/HAi_20260615103331.vue +0 -650
  53. package/.history/src/base-client/components/his/XHDescriptions/XHDescriptions_20260424134504.vue +0 -1469
  54. package/.history/src/base-client/components/his/XSidebar/XSidebar_20260610171133.vue +0 -788
  55. package/.history/src/base-client/components/his/XSidebar/XSidebar_20260610171151.vue +0 -780
  56. package/.history/src/base-client/components/his/XTransfer/XTransfer_20260511170841.vue +0 -585
  57. package/.history/src/base-client/components/his/XTransfer/XTransfer_20260511171138.vue +0 -787
  58. package/.history/src/base-client/components/his/XTransfer/XTransfer_20260512141830.vue +0 -739
  59. package/.history/src/components/STable/index_20260409155138.js +0 -806
  60. package/.history/src/components/STable/index_20260409155218.js +0 -814
  61. package/.history/src/expression/core/Expression_20260305164427.js +0 -1371
  62. package/.history/src/expression/core/Expression_20260305170258.js +0 -1358
  63. package/.history/src/expression/core/Program_20260305111830.js +0 -944
  64. package/.history/src/expression/core/Program_20260305112041.js +0 -931
  65. package/.history/src/logic/LogicRunner_20260304154306.js +0 -170
  66. package/.history/src/logic/LogicRunner_20260304155553.js +0 -112
  67. package/.history/src/logic/LogicRunner_20260305105834.js +0 -112
  68. package/.history/src/logic/LogicRunner_20260305112718.js +0 -129
  69. package/.history/src/logic/LogicRunner_20260305182436.js +0 -133
  70. package/.history/src/logic/LogicRunner_20260306151301.js +0 -213
  71. package/.history/src/logic/LogicRunner_20260306152419.js +0 -213
  72. package/.history/src/logic/plugins/common/DateTools_20260305154159.js +0 -61
  73. package/.history/src/logic/plugins/common/DateTools_20260305154217.js +0 -44
  74. package/.history/src/logic/plugins/common/DateTools_20260305161014.js +0 -44
  75. package/.history/src/logic/plugins/common/HttpTools_20260305164352.js +0 -80
  76. package/.history/src/logic/plugins/common/HttpTools_20260305170258.js +0 -75
  77. package/.history/src/logic/plugins/common/HttpTools_20260305171634.js +0 -75
  78. package/.history/src/logic/plugins/common/HttpTools_20260306152419.js +0 -72
  79. package/.history/src/services/api/restTools_20260427142149.js +0 -245
  80. package/.history/src/services/api/restTools_20260427142853.js +0 -230
  81. package/.history/src/services/api/restTools_20260519135558.js +0 -230
  82. package/.history/src/services/api/restTools_20260519140825.js +0 -230
  83. package/.history/src/services/api/restTools_20260519151223.js +0 -230
  84. package/.history/src/utils/indexedDB_20260306150918.js +0 -593
  85. package/.history/src/utils/indexedDB_20260306151301.js +0 -586
  86. package/.idea/codeStyles/Project.xml +0 -62
  87. package/.idea/codeStyles/codeStyleConfig.xml +0 -5
  88. package/preview-input-box.html +0 -180
@@ -1,524 +0,0 @@
1
- <script setup>
2
- import XAddNativeForm from '@vue2-client/base-client/components/common/XAddNativeForm/XAddNativeForm.vue'
3
- import { ref, computed, useAttrs } from 'vue'
4
-
5
- const xAddNativeFormRef = ref()
6
-
7
- const attrs = useAttrs()
8
- const props = defineProps({
9
- // 是否启用 horizontal 模式的自定义配置
10
- enableHorizontalCustom: {
11
- type: Boolean,
12
- default: false
13
- }
14
- })
15
- // 从 radio-style_1 属性值中获取 padding
16
- const radioPadding = computed(() => {
17
- const val = attrs['radio-style_1']
18
- if (val !== undefined && val !== '' && val !== null) {
19
- const num = Number(val)
20
- return isNaN(num) ? 9 : num
21
- }
22
- return 9
23
- })
24
-
25
- // 包装器样式对象
26
- const wrapperStyleObject = computed(() => {
27
- return {
28
- '--radio-padding': `${radioPadding.value}px`
29
- }
30
- })
31
-
32
- // 启动时间选择框弹出到body
33
- const enablePopupToBody = computed(() => {
34
- const a = attrs
35
- return a.enablePopupToBody === 'true' || a.enablePopupToBody === true
36
- })
37
- const wrapperClassObject = computed(() => {
38
- const a = attrs
39
- const classes = {}
40
-
41
- // 1) 多个布尔型样式开关(存在且为真则生效)
42
- const booleanStyleKeys = [
43
- 'query-conditions',
44
- 'padding-50',
45
- 'label-text-horizontal',
46
- 'label-text-justify',
47
- 'simple-inline',
48
- 'label-justify',
49
- 'charge-form',
50
- 'mini-form',
51
- 'content-right',
52
- 'label-font-style'
53
- ]
54
- // 只要属性存在就生效的样式开关
55
- const existStyleKeys = ['radio-style_1']
56
- for (const key of booleanStyleKeys) {
57
- const val = a[key]
58
- const truthy = val === true || val === '' || val === 'true'
59
- if (truthy) classes[`h-form-${key}`] = true
60
- }
61
- // 检查存在即生效的样式开关
62
- for (const key of existStyleKeys) {
63
- if (key in a) classes[`h-form-${key}`] = true
64
- }
65
-
66
- return classes
67
- })
68
-
69
- defineExpose({
70
- getXAddNativeFormInstance: () => xAddNativeFormRef.value,
71
- init: (params) => xAddNativeFormRef.value && xAddNativeFormRef.value.init && xAddNativeFormRef.value.init(params),
72
- asyncSubmit: () => xAddNativeFormRef.value && xAddNativeFormRef.value.asyncSubmit && xAddNativeFormRef.value.asyncSubmit(),
73
- validateForm: () => xAddNativeFormRef.value && xAddNativeFormRef.value.validateForm && xAddNativeFormRef.value.validateForm(),
74
- /** 等待配置结束的异步方法,委托给内部 XAddNativeForm */
75
- waitConfigEnd: () => xAddNativeFormRef.value?.waitConfigEnd?.() ?? Promise.resolve()
76
- })
77
-
78
- </script>
79
-
80
- <template>
81
- <div
82
- class="h-form-wrapper"
83
- :class="[
84
- wrapperClassObject
85
- ]"
86
- :style="wrapperStyleObject"
87
- >
88
-
89
- <x-add-native-form
90
- ref="xAddNativeFormRef"
91
- v-bind="$attrs"
92
- :enable-popup-to-body="enablePopupToBody"
93
- :enable-horizontal-custom="props.enableHorizontalCustom"
94
- @configEnd="$emit('configEnd')"
95
- v-on="$listeners"
96
- >
97
- <template v-for="(_, name) in $slots" #[name]="slotData">
98
- <slot :name="name" v-bind="slotData" />
99
- </template>
100
- </x-add-native-form>
101
- </div>
102
- </template>
103
-
104
- <style scoped lang="less">
105
- // 单选框 padding 变量
106
- @radio-padding: var(--radio-padding, 9px);
107
-
108
- .h-form-wrapper {
109
- // 基础样式
110
- :deep(.ant-form-item) {
111
- margin-bottom: 4px;
112
- }
113
- &.h-form-mini-form {
114
- :deep(.ant-form-inline) {
115
- .ant-row-flex {
116
- .ant-col {
117
- flex: auto !important;
118
- max-width: 250px !important;
119
- }
120
- }
121
- }
122
- :deep(.ant-form-item){
123
- margin-right: 0px !important;
124
- }
125
- }
126
-
127
- &.h-form-content-right {
128
- :deep(.ant-form-inline) {
129
- .ant-row-flex {
130
- justify-content: right;
131
- }
132
- }
133
- }
134
-
135
- // query-conditions 样式
136
- &.h-form-query-conditions {
137
- :deep(.ant-card-body) {
138
- padding: 0px;
139
- }
140
-
141
- :deep(.ant-row-flex) {
142
- .x-form-col-wrapper {
143
- .ant-form-item {
144
- display: flex !important;
145
- width: 100%;
146
- height: 100%;
147
- margin-bottom: 0px;
148
- justify-content: space-between;
149
-
150
- .ant-form-item-label {
151
- display: flex;
152
- align-items: center;
153
- height: 100%;
154
-
155
- label {
156
- height: auto;
157
- font-family: Source Han Sans;
158
- font-size: 16px;
159
- font-weight: normal;
160
- line-height: normal;
161
- color: #313131;
162
- display: block !important; // 保持 block 以支持两端对齐
163
- width: 100%;
164
- white-space: nowrap;
165
- margin: 0;
166
- text-align: justify;
167
- text-align-last: justify;
168
- text-justify: inter-ideograph;
169
- box-sizing: border-box;
170
- padding-right: 0 !important; // 移除冒号预留空间
171
-
172
- // 使用 line-height 实现垂直居中
173
- line-height: 40px; // 设置与容器高度相同的行高
174
- }
175
-
176
- & > label::after {
177
- display: none !important;
178
- }
179
- }
180
- }
181
- }
182
-
183
- .ant-col-24 {
184
- padding: 0px 4px !important;
185
- }
186
- }
187
- }
188
- // 单选框样式设计图中切换模式的样式
189
- &.h-form-radio-style_1{
190
- :deep(.ant-radio-button-wrapper) {
191
- padding: 0 @radio-padding;
192
- }
193
- :deep(.ant-radio-button-wrapper-checked){
194
- background-color: #0057FE;
195
- color: white;
196
- }
197
- }
198
-
199
- &.h-form-simple-inline {
200
- :deep(.ant-form-item-label){
201
- display: none !important;
202
- }
203
- :deep(.ant-form-item-control-wrapper){
204
- width: 100%;
205
- }
206
- }
207
-
208
- &.h-form-padding-50 {
209
- // ant-row-flex 样式
210
- :deep(.ant-row-flex) {
211
- padding-left: 50px;
212
- padding-right: 50px
213
- }
214
- }
215
-
216
- // 单选框样式设计图中切换模式的样式
217
- &.h-form-radio-style_1{
218
- :deep(.ant-radio-button-wrapper) {
219
- padding: 0 @radio-padding;
220
- }
221
- :deep(.ant-radio-button-wrapper-checked){
222
- background-color: #0057FE;
223
- color: white;
224
- }
225
- }
226
-
227
- // charge-form 样式
228
- &.h-form-charge-form {
229
- margin-top: 2px !important;
230
- // 定义变量
231
- @font-common: {
232
- font-family: 'Source Han Sans', sans-serif;
233
- font-size: 16px;
234
- font-weight: normal;
235
- letter-spacing: 0em;
236
- font-feature-settings: "kern" on;
237
- };
238
-
239
- @color-primary: #313131;
240
- @color-placeholder: #999999;
241
-
242
- // 定义混合宏
243
- .input-base() {
244
- width: 100%;
245
- height: 30px;
246
- line-height: 30px;
247
- vertical-align: top;
248
- margin: 0;
249
- text-align: left;
250
- color: @color-primary;
251
- opacity: 1;
252
- @font-common();
253
- }
254
-
255
- .placeholder-base() {
256
- color: @color-placeholder;
257
- opacity: 1;
258
- @font-common();
259
- }
260
-
261
- .option-group-base() {
262
- height: 30px;
263
- line-height: 30px;
264
- display: flex;
265
- align-items: center;
266
-
267
- .ant-radio-wrapper,
268
- .ant-checkbox-wrapper {
269
- height: 30px;
270
- line-height: 30px;
271
- margin-right: 16px;
272
- }
273
- }
274
-
275
- :deep(.ant-form-item) {
276
- margin-bottom: 16px;
277
- margin-top: 0;
278
- padding: 0;
279
- display: flex;
280
- align-items: center;
281
-
282
- .ant-form-item-label {
283
- text-align: left;
284
- margin: 0 11px 0 0 !important;
285
- width: 64px;
286
- min-width: 64px;
287
- max-width: 64px;
288
- flex-shrink: 0;
289
-
290
- label {
291
- height: 23px;
292
- opacity: 1;
293
- line-height: 23px;
294
- color: @color-primary;
295
- margin: 0;
296
- padding: 0;
297
- white-space: nowrap;
298
- display: block;
299
- @font-common();
300
-
301
- // 移除冒号
302
- &::after {
303
- content: '';
304
- }
305
- }
306
- }
307
-
308
- .ant-form-item-control-wrapper {
309
- margin: 0;
310
- padding: 0;
311
- flex: 1;
312
- min-width: 0;
313
- display: flex;
314
- align-items: center;
315
-
316
- .ant-form-item-control {
317
- margin: 0;
318
- padding: 0;
319
- width: 100%;
320
- text-align: left;
321
- line-height: 30px !important;
322
-
323
- // 输入框样式统一
324
- .ant-input,
325
- .ant-input-affix-wrapper,
326
- .ant-select,
327
- .ant-input-number,
328
- .ant-picker,
329
- .ant-radio-group,
330
- .ant-checkbox-group {
331
- .input-base();
332
- }
333
-
334
- // 选择器样式
335
- .ant-select {
336
- .ant-select-selector {
337
- .input-base();
338
- height: 30px;
339
- line-height: 30px;
340
-
341
- .ant-select-selection-item {
342
- .input-base();
343
- line-height: 30px;
344
- }
345
-
346
- .ant-select-selection-placeholder {
347
- .placeholder-base();
348
- line-height: 30px;
349
- color: #313131;
350
- }
351
- }
352
- }
353
-
354
- // 日期选择器样式
355
- .ant-picker {
356
- height: 30px;
357
-
358
- .ant-picker-input {
359
- height: 30px;
360
- line-height: 30px;
361
- .input-base();
362
-
363
- input {
364
- .input-base();
365
- height: 30px;
366
- line-height: 30px;
367
- }
368
- }
369
- }
370
-
371
- // 数字输入框样式
372
- .ant-input-number {
373
- height: 30px;
374
-
375
- .ant-input-number-input {
376
- .input-base();
377
- height: 30px;
378
- line-height: 30px;
379
- }
380
- }
381
-
382
- // 单选框组样式
383
- .ant-radio-group {
384
- .option-group-base();
385
- }
386
-
387
- // 复选框组样式
388
- .ant-checkbox-group {
389
- .option-group-base();
390
- }
391
- }
392
- }
393
- }
394
-
395
- // 重置可能的容器边距
396
- :deep(.ant-row) {
397
- margin: 0;
398
- padding: 0;
399
-
400
- .ant-col {
401
- margin: 0;
402
- padding: 0;
403
- }
404
- }
405
-
406
- // 强制重置所有可能的表单项样式
407
- :deep(.ant-form-item) {
408
- margin: 0 0 16px 0 !important;
409
-
410
- // 重置可能的内部边距
411
- .ant-form-item-control-input,
412
- .ant-form-item-control-input-content {
413
- margin: 0 !important;
414
- padding: 0 !important;
415
- }
416
- }
417
- }
418
-
419
- // label-text-horizontal 样式 - 只控制label文字从左到右排列
420
- &.h-form-label-text-horizontal {
421
- :deep(.ant-form-item-label) {
422
- text-align: left;
423
- direction: ltr;
424
-
425
- // 标签文字水平排列
426
- .ant-form-item-label-text {
427
- display: inline-block;
428
- text-align: left;
429
- direction: ltr;
430
- unicode-bidi: normal;
431
- }
432
-
433
- // 必填标识水平排列
434
- .ant-form-item-required::before {
435
- margin-right: 4px;
436
- margin-left: 0;
437
- }
438
- }
439
- }
440
-
441
- // label-text-justify 样式 - 标签文字两端对齐分散占满 必填*可能会有问题
442
- &.h-form-label-text-justify {
443
- :deep(.ant-form-item-label) {
444
- padding-left: 0;
445
- padding-right: 8px;
446
- label {
447
- position: relative;
448
- display: block;
449
- width: 100%;
450
- white-space: nowrap;
451
- margin: 0;
452
- text-indent: 0;
453
- text-align: justify;
454
- text-align-last: justify;
455
- text-justify: inter-ideograph;
456
- box-sizing: border-box;
457
- padding-right: 12px; // 给绝对定位的冒号留出空间
458
- }
459
- // 将冒号绝对定位到最右侧,避免参与两端对齐计算
460
- label::after {
461
- position: absolute;
462
- right: 0;
463
- }
464
- }
465
- }
466
-
467
- // label-justify 样式 - 两端对齐,应用指定字体样式
468
- &.h-form-label-justify {
469
- padding-left: 8px;
470
-
471
- :deep(.ant-form-item-label) {
472
- padding-left: 0;
473
- padding-right: 8px;
474
- // 限制label容器的宽度,强制两端对齐
475
- width: 80px !important;
476
- min-width: 80px;
477
- max-width: 80px;
478
- label {
479
- position: relative;
480
- display: block;
481
- width: 100%;
482
- white-space: nowrap;
483
- margin: 0;
484
- text-indent: 0;
485
- text-align: justify;
486
- text-align-last: justify;
487
- text-justify: inter-ideograph;
488
- box-sizing: border-box;
489
- padding-right: 12px; // 给绝对定位的冒号留出空间
490
-
491
- // 应用指定的字体样式
492
- height: 39px;
493
- opacity: 1;
494
- font-family: 'Source Han Sans', sans-serif;
495
- font-size: 16px;
496
- font-weight: normal;
497
- line-height: 39px;
498
- color: #313131;
499
- }
500
- // 去掉冒号
501
- label::after {
502
- content: '';
503
- }
504
- }
505
- }
506
-
507
- // label-font-style 样式 - 独立的label字体样式
508
- &.h-form-label-font-style {
509
- :deep(.ant-form-item-label) {
510
- label {
511
- height: 23px;
512
- opacity: 1;
513
- font-family: Source Han Sans;
514
- font-size: 16px;
515
- font-weight: normal;
516
- line-height: normal;
517
- letter-spacing: 0em;
518
- font-feature-settings: "kern" on;
519
- color: #313131;
520
- }
521
- }
522
- }
523
- }
524
- </style>