tianheng-ui 0.1.10 → 0.1.12
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/lib/theme-chalk/styles/reset.scss +0 -2
- package/lib/tianheng-ui.js +13 -14
- package/package.json +1 -1
- package/packages/FormMaking/GenerateForm.vue +16 -11
- package/packages/FormMaking/GenerateFormItem.vue +73 -581
- package/packages/FormMaking/GenerateFormItemH5.vue +6 -6
- package/packages/FormMaking/Upload/index.vue +0 -1
- package/packages/FormMaking/WidgetConfig.vue +100 -77
- package/packages/FormMaking/WidgetForm.vue +7 -48
- package/packages/FormMaking/WidgetFormItem.vue +41 -65
- package/packages/FormMaking/WidgetSelect.vue +160 -0
- package/packages/FormMaking/WidgetTools.vue +538 -0
- package/packages/FormMaking/config/index.js +6 -0
- package/packages/FormMaking/custom/config.js +119 -87
- package/packages/FormMaking/custom/configs/button.vue +24 -25
- package/packages/FormMaking/custom/configs/cascader.vue +7 -7
- package/packages/FormMaking/custom/configs/checkbox.vue +23 -22
- package/packages/FormMaking/custom/configs/color.vue +3 -3
- package/packages/FormMaking/custom/configs/date.vue +3 -3
- package/packages/FormMaking/custom/configs/grid.vue +4 -4
- package/packages/FormMaking/custom/configs/input.vue +138 -31
- package/packages/FormMaking/custom/configs/number.vue +5 -5
- package/packages/FormMaking/custom/configs/radio.vue +23 -19
- package/packages/FormMaking/custom/configs/rate.vue +3 -3
- package/packages/FormMaking/custom/configs/select.vue +25 -20
- package/packages/FormMaking/custom/configs/slider.vue +3 -3
- package/packages/FormMaking/custom/configs/switch.vue +3 -3
- package/packages/FormMaking/custom/configs/table.vue +2 -2
- package/packages/FormMaking/custom/configs/{table_h5.vue → tableH5.vue} +2 -2
- package/packages/FormMaking/custom/configs/tabs.vue +18 -23
- package/packages/FormMaking/custom/configs/textarea.vue +124 -22
- package/packages/FormMaking/custom/configs/time.vue +3 -3
- package/packages/FormMaking/custom/configs/upload.vue +5 -5
- package/packages/FormMaking/custom/index.js +2 -4
- package/packages/FormMaking/custom/items/alliance.vue +30 -29
- package/packages/FormMaking/custom/items/blank_pro.vue +14 -0
- package/packages/FormMaking/custom/items/button.vue +36 -1
- package/packages/FormMaking/custom/items/cascader.vue +6 -2
- package/packages/FormMaking/custom/items/cell.vue +0 -2
- package/packages/FormMaking/custom/items/checkbox.vue +18 -8
- package/packages/FormMaking/custom/items/color.vue +1 -1
- package/packages/FormMaking/custom/items/date.vue +1 -1
- package/packages/FormMaking/custom/items/editor.vue +1 -1
- package/packages/FormMaking/custom/items/{grid.vue → grid_dev.vue} +16 -47
- package/packages/FormMaking/custom/items/grid_pro.vue +45 -0
- package/packages/FormMaking/custom/items/image.vue +0 -28
- package/packages/FormMaking/custom/items/input.vue +15 -9
- package/packages/FormMaking/custom/items/number.vue +4 -4
- package/packages/FormMaking/custom/items/radio.vue +17 -7
- package/packages/FormMaking/custom/items/rate.vue +1 -1
- package/packages/FormMaking/custom/items/select.vue +12 -6
- package/packages/FormMaking/custom/items/slider.vue +1 -1
- package/packages/FormMaking/custom/items/switch.vue +1 -1
- package/packages/FormMaking/custom/items/{table_h5.vue → tableH5_dev.vue} +44 -49
- package/packages/FormMaking/custom/items/tableH5_pro.vue +113 -0
- package/packages/FormMaking/custom/items/{table.vue → table_dev.vue} +21 -41
- package/packages/FormMaking/custom/items/table_pro.vue +114 -0
- package/packages/FormMaking/custom/items/tabs_dev.vue +101 -0
- package/packages/FormMaking/custom/items/tabs_pro.vue +50 -0
- package/packages/FormMaking/custom/items/text.vue +1 -1
- package/packages/FormMaking/custom/items/textarea.vue +4 -13
- package/packages/FormMaking/custom/items/time.vue +3 -3
- package/packages/FormMaking/custom/items/upload.vue +15 -14
- package/packages/FormMaking/custom/mixins/index.js +28 -6
- package/packages/FormMaking/custom/register.js +22 -11
- package/packages/FormMaking/index.vue +95 -468
- package/packages/FormMaking/styles/index.scss +235 -242
- package/packages/FormMaking/util/generateCode.js +3 -3
- package/packages/FormMaking/util/index.js +33 -23
- package/packages/FormMaking/util/request.js +9 -12
- package/packages/FormMaking/custom/items/tabs.vue +0 -145
- /package/packages/FormMaking/custom/items/{blank.vue → blank_dev.vue} +0 -0
@@ -30,7 +30,7 @@ export const basicComponents = [
|
|
30
30
|
onFocus: "",
|
31
31
|
onBlur: ""
|
32
32
|
},
|
33
|
-
rules: []
|
33
|
+
rules: [{}]
|
34
34
|
},
|
35
35
|
{
|
36
36
|
name: "多行文本",
|
@@ -60,7 +60,8 @@ export const basicComponents = [
|
|
60
60
|
onChange: "",
|
61
61
|
onFocus: "",
|
62
62
|
onBlur: ""
|
63
|
-
}
|
63
|
+
},
|
64
|
+
rules: [{}]
|
64
65
|
},
|
65
66
|
{
|
66
67
|
name: "单元格",
|
@@ -79,7 +80,8 @@ export const basicComponents = [
|
|
79
80
|
textAlign: "right",
|
80
81
|
hidden: false,
|
81
82
|
hideLabel: false
|
82
|
-
}
|
83
|
+
},
|
84
|
+
rules: []
|
83
85
|
},
|
84
86
|
{
|
85
87
|
name: "文字",
|
@@ -95,7 +97,8 @@ export const basicComponents = [
|
|
95
97
|
textAlign: "left",
|
96
98
|
hidden: false,
|
97
99
|
hideLabel: false
|
98
|
-
}
|
100
|
+
},
|
101
|
+
rules: []
|
99
102
|
},
|
100
103
|
{
|
101
104
|
name: "单选框组",
|
@@ -110,16 +113,16 @@ export const basicComponents = [
|
|
110
113
|
showLabel: false,
|
111
114
|
options: [
|
112
115
|
{
|
113
|
-
value: "
|
114
|
-
label: "
|
116
|
+
value: "选值 1",
|
117
|
+
label: "选项 1"
|
115
118
|
},
|
116
119
|
{
|
117
|
-
value: "
|
118
|
-
label: "
|
120
|
+
value: "选值 2",
|
121
|
+
label: "选项 2"
|
119
122
|
},
|
120
123
|
{
|
121
|
-
value: "
|
122
|
-
label: "
|
124
|
+
value: "选值 3",
|
125
|
+
label: "选项 3"
|
123
126
|
}
|
124
127
|
],
|
125
128
|
required: false,
|
@@ -137,7 +140,8 @@ export const basicComponents = [
|
|
137
140
|
},
|
138
141
|
events: {
|
139
142
|
onChange: ""
|
140
|
-
}
|
143
|
+
},
|
144
|
+
rules: []
|
141
145
|
},
|
142
146
|
{
|
143
147
|
name: "多选框组",
|
@@ -152,13 +156,16 @@ export const basicComponents = [
|
|
152
156
|
showLabel: false,
|
153
157
|
options: [
|
154
158
|
{
|
155
|
-
value: "
|
159
|
+
value: "选值 1",
|
160
|
+
label: "选项 1"
|
156
161
|
},
|
157
162
|
{
|
158
|
-
value: "
|
163
|
+
value: "选值 2",
|
164
|
+
label: "选项 2"
|
159
165
|
},
|
160
166
|
{
|
161
|
-
value: "
|
167
|
+
value: "选值 3",
|
168
|
+
label: "选项 3"
|
162
169
|
}
|
163
170
|
],
|
164
171
|
required: false,
|
@@ -180,7 +187,8 @@ export const basicComponents = [
|
|
180
187
|
},
|
181
188
|
events: {
|
182
189
|
onChange: ""
|
183
|
-
}
|
190
|
+
},
|
191
|
+
rules: []
|
184
192
|
},
|
185
193
|
{
|
186
194
|
name: "时间选择器",
|
@@ -210,7 +218,8 @@ export const basicComponents = [
|
|
210
218
|
onChange: "",
|
211
219
|
onFocus: "",
|
212
220
|
onBlur: ""
|
213
|
-
}
|
221
|
+
},
|
222
|
+
rules: []
|
214
223
|
},
|
215
224
|
{
|
216
225
|
name: "日期选择器",
|
@@ -237,7 +246,8 @@ export const basicComponents = [
|
|
237
246
|
onChange: "",
|
238
247
|
onFocus: "",
|
239
248
|
onBlur: ""
|
240
|
-
}
|
249
|
+
},
|
250
|
+
rules: []
|
241
251
|
},
|
242
252
|
{
|
243
253
|
name: "下拉选择框",
|
@@ -257,15 +267,9 @@ export const basicComponents = [
|
|
257
267
|
collapseTags: false,
|
258
268
|
allowCreate: false,
|
259
269
|
options: [
|
260
|
-
{
|
261
|
-
|
262
|
-
}
|
263
|
-
{
|
264
|
-
value: "Option 2"
|
265
|
-
},
|
266
|
-
{
|
267
|
-
value: "Option 3"
|
268
|
-
}
|
270
|
+
{ value: "选值 1", label: "选项 1" },
|
271
|
+
{ value: "选值 2", label: "选项 2" },
|
272
|
+
{ value: "选值 3", label: "选项 3" }
|
269
273
|
],
|
270
274
|
filterable: false,
|
271
275
|
props: {
|
@@ -283,7 +287,8 @@ export const basicComponents = [
|
|
283
287
|
onChange: "",
|
284
288
|
onFocus: "",
|
285
289
|
onBlur: ""
|
286
|
-
}
|
290
|
+
},
|
291
|
+
rules: []
|
287
292
|
},
|
288
293
|
{
|
289
294
|
name: "颜色选择器",
|
@@ -312,7 +317,8 @@ export const basicComponents = [
|
|
312
317
|
},
|
313
318
|
events: {
|
314
319
|
onChange: ""
|
315
|
-
}
|
320
|
+
},
|
321
|
+
rules: []
|
316
322
|
},
|
317
323
|
{
|
318
324
|
name: "开关",
|
@@ -334,7 +340,8 @@ export const basicComponents = [
|
|
334
340
|
},
|
335
341
|
events: {
|
336
342
|
onChange: ""
|
337
|
-
}
|
343
|
+
},
|
344
|
+
rules: []
|
338
345
|
},
|
339
346
|
{
|
340
347
|
name: "按钮",
|
@@ -377,13 +384,12 @@ export const basicComponents = [
|
|
377
384
|
isLabelWidth: false,
|
378
385
|
required: false,
|
379
386
|
defaultValue: 0,
|
380
|
-
min:
|
381
|
-
max:
|
382
|
-
step: 1,
|
387
|
+
min: 0,
|
388
|
+
max: -1,
|
389
|
+
step: 1, //递增递减步数
|
390
|
+
precision: 0, //精度
|
383
391
|
disabled: false,
|
384
392
|
controlsPosition: false,
|
385
|
-
step: 1, //递增递减步数
|
386
|
-
precision: 1, //精度
|
387
393
|
hidden: false,
|
388
394
|
hideLabel: false
|
389
395
|
},
|
@@ -391,7 +397,8 @@ export const basicComponents = [
|
|
391
397
|
onChange: "",
|
392
398
|
onFocus: "",
|
393
399
|
onBlur: ""
|
394
|
-
}
|
400
|
+
},
|
401
|
+
rules: []
|
395
402
|
},
|
396
403
|
{
|
397
404
|
name: "滑块",
|
@@ -419,7 +426,8 @@ export const basicComponents = [
|
|
419
426
|
},
|
420
427
|
events: {
|
421
428
|
onChange: ""
|
422
|
-
}
|
429
|
+
},
|
430
|
+
rules: []
|
423
431
|
},
|
424
432
|
{
|
425
433
|
name: "评分",
|
@@ -440,7 +448,8 @@ export const basicComponents = [
|
|
440
448
|
},
|
441
449
|
events: {
|
442
450
|
onChange: ""
|
443
|
-
}
|
451
|
+
},
|
452
|
+
rules: []
|
444
453
|
},
|
445
454
|
{
|
446
455
|
name: "图片",
|
@@ -471,7 +480,9 @@ export const basicComponents = [
|
|
471
480
|
hidden: false,
|
472
481
|
hideLabel: false,
|
473
482
|
isLazy: true
|
474
|
-
}
|
483
|
+
},
|
484
|
+
events: {},
|
485
|
+
rules: []
|
475
486
|
},
|
476
487
|
{
|
477
488
|
name: "文件",
|
@@ -505,7 +516,9 @@ export const basicComponents = [
|
|
505
516
|
elUploadTip: "",
|
506
517
|
listType: "default", //展示方式
|
507
518
|
drag: false //拖拽上传
|
508
|
-
}
|
519
|
+
},
|
520
|
+
events: {},
|
521
|
+
rules: []
|
509
522
|
},
|
510
523
|
{
|
511
524
|
name: "编辑器",
|
@@ -521,7 +534,9 @@ export const basicComponents = [
|
|
521
534
|
required: false,
|
522
535
|
hidden: false,
|
523
536
|
hideLabel: false
|
524
|
-
}
|
537
|
+
},
|
538
|
+
events: {},
|
539
|
+
rules: []
|
525
540
|
},
|
526
541
|
{
|
527
542
|
name: "级联选择器",
|
@@ -557,7 +572,8 @@ export const basicComponents = [
|
|
557
572
|
},
|
558
573
|
events: {
|
559
574
|
onChange: ""
|
560
|
-
}
|
575
|
+
},
|
576
|
+
rules: []
|
561
577
|
}
|
562
578
|
];
|
563
579
|
|
@@ -569,6 +585,7 @@ export const advanceComponents = [
|
|
569
585
|
options: {
|
570
586
|
height: "",
|
571
587
|
defaultValue: "",
|
588
|
+
columns: [],
|
572
589
|
customClass: "",
|
573
590
|
labelWidth: 100,
|
574
591
|
isLabelWidth: false,
|
@@ -590,14 +607,16 @@ export const advanceComponents = [
|
|
590
607
|
showHeader: true, // 是否显示表头
|
591
608
|
highlightCurrentRow: false // 是否高亮当前行
|
592
609
|
},
|
593
|
-
|
610
|
+
events: {},
|
611
|
+
rules: []
|
594
612
|
},
|
595
613
|
{
|
596
614
|
name: "子表单H5",
|
597
|
-
type: "
|
615
|
+
type: "tableH5",
|
598
616
|
icon: "icon-table",
|
599
617
|
options: {
|
600
618
|
defaultValue: "",
|
619
|
+
columns: [],
|
601
620
|
customClass: "",
|
602
621
|
labelWidth: 100,
|
603
622
|
isLabelWidth: false,
|
@@ -617,29 +636,30 @@ export const advanceComponents = [
|
|
617
636
|
deleteButtonText: "删除",
|
618
637
|
deleteIndex: 0 // 可删除的最小索引
|
619
638
|
},
|
620
|
-
|
639
|
+
events: {},
|
640
|
+
rules: []
|
621
641
|
},
|
622
642
|
{
|
623
643
|
name: "标签页",
|
624
644
|
type: "tabs",
|
625
645
|
icon: "icon-tabs",
|
626
|
-
tabs: [
|
627
|
-
{
|
628
|
-
label: "选项1",
|
629
|
-
value: "tab1",
|
630
|
-
list: []
|
631
|
-
},
|
632
|
-
{
|
633
|
-
label: "选项2",
|
634
|
-
value: "tab2",
|
635
|
-
list: []
|
636
|
-
}
|
637
|
-
],
|
638
646
|
options: {
|
639
647
|
defaultValue: "tab1",
|
640
648
|
type: "",
|
641
649
|
tabPosition: "top",
|
642
650
|
customClass: "",
|
651
|
+
columns: [
|
652
|
+
{
|
653
|
+
label: "选项1",
|
654
|
+
value: "tab1",
|
655
|
+
list: []
|
656
|
+
},
|
657
|
+
{
|
658
|
+
label: "选项2",
|
659
|
+
value: "tab2",
|
660
|
+
list: []
|
661
|
+
}
|
662
|
+
],
|
643
663
|
hidden: false,
|
644
664
|
labelWidth: 100,
|
645
665
|
isLabelWidth: false,
|
@@ -649,6 +669,7 @@ export const advanceComponents = [
|
|
649
669
|
remoteOption: [],
|
650
670
|
tableColumn: false
|
651
671
|
},
|
672
|
+
events: {},
|
652
673
|
rules: []
|
653
674
|
},
|
654
675
|
{
|
@@ -658,7 +679,9 @@ export const advanceComponents = [
|
|
658
679
|
options: {
|
659
680
|
defaultType: "String",
|
660
681
|
required: false
|
661
|
-
}
|
682
|
+
},
|
683
|
+
events: {},
|
684
|
+
rules: []
|
662
685
|
}
|
663
686
|
];
|
664
687
|
|
@@ -667,43 +690,47 @@ export const layoutComponents = [
|
|
667
690
|
name: "栅格布局",
|
668
691
|
type: "grid",
|
669
692
|
icon: "icon-grid-",
|
670
|
-
columns: [
|
671
|
-
{
|
672
|
-
span: 12,
|
673
|
-
list: []
|
674
|
-
},
|
675
|
-
{
|
676
|
-
span: 12,
|
677
|
-
list: []
|
678
|
-
}
|
679
|
-
],
|
680
693
|
options: {
|
681
694
|
gutter: 0,
|
682
695
|
justify: "start",
|
683
696
|
align: "top",
|
697
|
+
columns: [
|
698
|
+
{
|
699
|
+
span: 12,
|
700
|
+
list: []
|
701
|
+
},
|
702
|
+
{
|
703
|
+
span: 12,
|
704
|
+
list: []
|
705
|
+
}
|
706
|
+
],
|
684
707
|
hideLabel: true
|
685
|
-
}
|
708
|
+
},
|
709
|
+
events: {},
|
710
|
+
rules: []
|
686
711
|
},
|
687
712
|
{
|
688
713
|
name: "浮动布局",
|
689
714
|
type: "alliance",
|
690
715
|
icon: "icon-grid-",
|
691
|
-
columns: [
|
692
|
-
{
|
693
|
-
span: 12,
|
694
|
-
list: []
|
695
|
-
},
|
696
|
-
{
|
697
|
-
span: 12,
|
698
|
-
list: []
|
699
|
-
}
|
700
|
-
],
|
701
716
|
options: {
|
702
717
|
gutter: 0,
|
703
718
|
justify: "start",
|
704
719
|
align: "top",
|
720
|
+
columns: [
|
721
|
+
{
|
722
|
+
span: 12,
|
723
|
+
list: []
|
724
|
+
},
|
725
|
+
{
|
726
|
+
span: 12,
|
727
|
+
list: []
|
728
|
+
}
|
729
|
+
],
|
705
730
|
hideLabel: true
|
706
|
-
}
|
731
|
+
},
|
732
|
+
events: {},
|
733
|
+
rules: []
|
707
734
|
},
|
708
735
|
{
|
709
736
|
name: "填充物",
|
@@ -716,8 +743,10 @@ export const layoutComponents = [
|
|
716
743
|
labelWidth: 100,
|
717
744
|
isLabelWidth: false,
|
718
745
|
hideLabel: true,
|
719
|
-
hidden: false
|
720
|
-
}
|
746
|
+
hidden: false
|
747
|
+
},
|
748
|
+
events: {},
|
749
|
+
rules: []
|
721
750
|
},
|
722
751
|
{
|
723
752
|
name: "分割线",
|
@@ -733,10 +762,13 @@ export const layoutComponents = [
|
|
733
762
|
contentPosition: "left",
|
734
763
|
tableColumn: false
|
735
764
|
},
|
765
|
+
events: {},
|
736
766
|
rules: []
|
737
767
|
}
|
738
768
|
];
|
739
769
|
|
770
|
+
export const templateComponents = [];
|
771
|
+
|
740
772
|
export const baseConfig = {
|
741
773
|
ui: "element",
|
742
774
|
title: "",
|
@@ -749,14 +781,14 @@ export const baseConfig = {
|
|
749
781
|
hideLabel: false,
|
750
782
|
eventScript: [
|
751
783
|
{
|
752
|
-
|
753
|
-
|
754
|
-
|
784
|
+
id: "mounted",
|
785
|
+
label: "mounted",
|
786
|
+
value: ""
|
755
787
|
},
|
756
788
|
{
|
757
|
-
|
758
|
-
|
759
|
-
|
789
|
+
id: "refresh",
|
790
|
+
label: "refresh",
|
791
|
+
value: ""
|
760
792
|
}
|
761
793
|
]
|
762
794
|
};
|
@@ -82,12 +82,7 @@
|
|
82
82
|
</el-checkbox>
|
83
83
|
</el-form-item>
|
84
84
|
|
85
|
-
<el-form-item>
|
86
|
-
<div class="config-header" slot="label">
|
87
|
-
<span class="title">动作设置</span>
|
88
|
-
<span class="value" @click="handleEventsShow">配置</span>
|
89
|
-
</div>
|
90
|
-
|
85
|
+
<el-form-item label="提交接口">
|
91
86
|
<!-- <el-radio-group
|
92
87
|
style="margin-bottom:10px;"
|
93
88
|
v-model="widget.options.remote"
|
@@ -96,23 +91,27 @@
|
|
96
91
|
<el-radio-button :label="false">自定义事件</el-radio-button>
|
97
92
|
<el-radio-button :label="true">绑定接口</el-radio-button>
|
98
93
|
</el-radio-group> -->
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
94
|
+
<el-select
|
95
|
+
style="width:100%"
|
96
|
+
v-model="widget.options.remoteFunc"
|
97
|
+
value-key="id"
|
98
|
+
placeholder="请选择提交方法"
|
99
|
+
clearable
|
100
|
+
>
|
101
|
+
<el-option
|
102
|
+
v-for="item in config.remoteFuncs"
|
103
|
+
:key="item.id"
|
104
|
+
:label="item.label"
|
105
|
+
:value="item"
|
107
106
|
>
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
107
|
+
</el-option>
|
108
|
+
</el-select>
|
109
|
+
</el-form-item>
|
110
|
+
|
111
|
+
<el-form-item>
|
112
|
+
<div class="config-header" slot="label">
|
113
|
+
<span class="title">动作设置</span>
|
114
|
+
<span class="value" @click="handleEventsShow">配置</span>
|
116
115
|
</div>
|
117
116
|
|
118
117
|
<el-collapse v-show="!widget.options.remote" class="eventsCollapse">
|
@@ -131,9 +130,9 @@
|
|
131
130
|
>
|
132
131
|
<el-option
|
133
132
|
v-for="item in config.eventScript"
|
134
|
-
:key="item.
|
135
|
-
:label="item.
|
136
|
-
:value="item.
|
133
|
+
:key="item.id"
|
134
|
+
:label="item.label"
|
135
|
+
:value="item.id"
|
137
136
|
>
|
138
137
|
</el-option>
|
139
138
|
</el-select>
|
@@ -64,14 +64,14 @@
|
|
64
64
|
<el-select
|
65
65
|
style="width:100%"
|
66
66
|
v-model="widget.options.remoteFunc"
|
67
|
-
value-key="
|
67
|
+
value-key="id"
|
68
68
|
placeholder="请选择远端方法"
|
69
69
|
clearable
|
70
70
|
>
|
71
71
|
<el-option
|
72
|
-
v-for="item in
|
73
|
-
:key="item.
|
74
|
-
:label="item.
|
72
|
+
v-for="item in config.remoteFuncs"
|
73
|
+
:key="item.id"
|
74
|
+
:label="item.label"
|
75
75
|
:value="item"
|
76
76
|
>
|
77
77
|
</el-option>
|
@@ -137,9 +137,9 @@
|
|
137
137
|
>
|
138
138
|
<el-option
|
139
139
|
v-for="item in config.eventScript"
|
140
|
-
:key="item.
|
141
|
-
:label="item.
|
142
|
-
:value="item.
|
140
|
+
:key="item.id"
|
141
|
+
:label="item.label"
|
142
|
+
:value="item.id"
|
143
143
|
>
|
144
144
|
</el-option>
|
145
145
|
</el-select>
|
@@ -43,40 +43,35 @@
|
|
43
43
|
</div>
|
44
44
|
<div style="display: flex;">
|
45
45
|
<div style="flex:1;">最大勾选:</div>
|
46
|
-
<el-input-number
|
47
|
-
v-model="widget.options.max"
|
48
|
-
:min="widget.options.min || 1"
|
49
|
-
>
|
46
|
+
<el-input-number v-model="widget.options.max" :min="0">
|
50
47
|
</el-input-number>
|
51
48
|
</div>
|
52
49
|
</el-form-item>
|
53
50
|
|
54
51
|
<el-form-item label="选项">
|
55
|
-
<div
|
56
|
-
|
57
|
-
|
58
|
-
|
52
|
+
<div class="config-header" slot="label">
|
53
|
+
<span class="title">选项</span>
|
54
|
+
<el-radio-group
|
55
|
+
class="value"
|
56
|
+
v-model="widget.options.remote"
|
57
|
+
size="mini"
|
58
|
+
>
|
59
59
|
<el-radio-button :label="false">静态数据</el-radio-button>
|
60
60
|
<el-radio-button :label="true">远端数据</el-radio-button>
|
61
61
|
</el-radio-group>
|
62
|
-
|
63
|
-
<div v-if="!widget.options.remote">
|
64
|
-
<span>显示标签</span>
|
65
|
-
<el-switch v-model="widget.options.showLabel"> </el-switch>
|
66
|
-
</div>
|
67
62
|
</div>
|
68
63
|
<template v-if="widget.options.remote">
|
69
64
|
<el-select
|
70
65
|
style="width:100%"
|
71
66
|
v-model="widget.options.remoteFunc"
|
72
|
-
value-key="
|
67
|
+
:value-key="config.remoteFuncs.props.key"
|
73
68
|
placeholder="请选择远端方法"
|
74
69
|
clearable
|
75
70
|
>
|
76
71
|
<el-option
|
77
|
-
v-for="item in
|
78
|
-
:key="item.
|
79
|
-
:label="item.
|
72
|
+
v-for="item in config.remoteFuncs.options"
|
73
|
+
:key="item[config.remoteFuncs.props.key]"
|
74
|
+
:label="item[config.remoteFuncs.props.label]"
|
80
75
|
:value="item"
|
81
76
|
>
|
82
77
|
</el-option>
|
@@ -93,6 +88,12 @@
|
|
93
88
|
</el-input>
|
94
89
|
</template>
|
95
90
|
<template v-else>
|
91
|
+
<el-switch
|
92
|
+
v-model="widget.options.showLabel"
|
93
|
+
active-text="显示标签"
|
94
|
+
inactive-text="隐藏标签"
|
95
|
+
>
|
96
|
+
</el-switch>
|
96
97
|
<el-checkbox-group v-model="widget.options.defaultValue">
|
97
98
|
<draggable
|
98
99
|
tag="ul"
|
@@ -188,9 +189,9 @@
|
|
188
189
|
>
|
189
190
|
<el-option
|
190
191
|
v-for="item in config.eventScript"
|
191
|
-
:key="item.
|
192
|
-
:label="item.
|
193
|
-
:value="item.
|
192
|
+
:key="item.id"
|
193
|
+
:label="item.label"
|
194
|
+
:value="item.id"
|
194
195
|
>
|
195
196
|
</el-option>
|
196
197
|
</el-select>
|
@@ -220,8 +221,8 @@ export default {
|
|
220
221
|
methods: {
|
221
222
|
handleAddOption() {
|
222
223
|
this.widget.options.options.push({
|
223
|
-
value:
|
224
|
-
label:
|
224
|
+
value: `选值 ${this.widget.options.options.length + 1}`,
|
225
|
+
label: `选项 ${this.widget.options.options.length + 1}`
|
225
226
|
});
|
226
227
|
},
|
227
228
|
handleOptionsRemove(index) {
|