vue2-client 1.10.32 → 1.10.35

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 (27) hide show
  1. package/package.json +1 -1
  2. package/src/App.vue +196 -196
  3. package/src/base-client/components/common/XAddNativeForm/demo.vue +43 -43
  4. package/src/base-client/components/common/XAddReport/XAddReport.vue +1 -1
  5. package/src/base-client/components/common/XConversation/XConversation.vue +12 -0
  6. package/src/base-client/components/common/XDataCard/XDataCard.vue +17 -16
  7. package/src/base-client/components/common/XForm/XFormItem.vue +1248 -1286
  8. package/src/base-client/components/common/XFormCol/XFormCol.vue +157 -157
  9. package/src/base-client/components/common/XFormGroup/XFormGroup.vue +301 -301
  10. package/src/base-client/components/common/XFormTable/XFormTable.vue +12 -0
  11. package/src/base-client/components/common/XFormTable/demo.vue +2 -2
  12. package/src/base-client/components/common/XIntervalPicker/XIntervalPicker.vue +121 -0
  13. package/src/base-client/components/common/XReportDrawer/XReportDrawer.vue +1 -1
  14. package/src/base-client/components/common/XReportGrid/XReport.vue +1079 -1070
  15. package/src/base-client/components/common/XReportGrid/XReportDemo.vue +46 -47
  16. package/src/base-client/components/common/XReportGrid/XReportDesign.vue +628 -628
  17. package/src/base-client/components/common/XReportGrid/XReportJsonRender.vue +380 -380
  18. package/src/base-client/components/common/XReportGrid/XReportTrGroup.vue +1104 -1104
  19. package/src/base-client/components/common/XReportGrid/print.js +184 -184
  20. package/src/base-client/components/common/XTab/XTab.vue +57 -25
  21. package/src/components/cache/AKeepAlive.js +11 -4
  22. package/src/layouts/BlankView.vue +59 -3
  23. package/src/pages/ReportGrid/index.vue +76 -76
  24. package/src/router/async/router.map.js +95 -148
  25. package/src/router/guards.js +260 -263
  26. package/src/utils/microAppUtils.js +49 -40
  27. package/src/utils/routerUtil.js +526 -450
@@ -1,628 +1,628 @@
1
- <template>
2
- <div>
3
- <template v-if="this.activatedConfig.designMode === 'json'">
4
- <XReportJsonRender
5
- @updateImg="updateImg"
6
- @selectRow="selectRow"
7
- :img-prefix="imgPrefix"
8
- :server-name="serverName"
9
- :display-only="displayOnly"
10
- :show-title="showTitle"
11
- :no-padding="noPadding"
12
- :no-top-border="noTopBorder"
13
- :config="activatedConfig"/>
14
- </template>
15
- <template v-else-if="isWidget">
16
- <template v-for="(row, rowIndex) in activatedConfig.columns">
17
- <!-- 插槽展示 -->
18
- <template v-if="row[0].type === 'slot'">
19
- <x-report-tr-group
20
- @updateImg="updateImg"
21
- @selectRow="selectRow"
22
- :show-img-in-cell="showImgInCell"
23
- :img-prefix="imgPrefix"
24
- :server-name="serverName"
25
- :env="env"
26
- :use-oss-for-img="useOssForImg"
27
- :key="rowIndex"
28
- :columns="row"
29
- :no-top-border="noTopBorder"
30
- :config-data="activatedConfig.data"
31
- :config="activatedConfig"
32
- :display="true">
33
- </x-report-tr-group>
34
- </template>
35
- <!-- 普通行 -->
36
- <template v-else>
37
- <template v-if="!forDisplay">
38
- <x-report-tr-group
39
- @updateImg="updateImg"
40
- @selectRow="selectRow"
41
- :show-img-in-cell="showImgInCell"
42
- :img-prefix="imgPrefix"
43
- :server-name="serverName"
44
- :env="env"
45
- :use-oss-for-img="useOssForImg"
46
- :key="rowIndex"
47
- :columns="row"
48
- :no-top-border="noTopBorder"
49
- :config-data="activatedConfig.data"
50
- :config="activatedConfig">
51
- </x-report-tr-group>
52
- </template>
53
- <template v-else>
54
- <x-report-tr-group
55
- @updateImg="updateImg"
56
- @selectRow="selectRow"
57
- :show-img-in-cell="showImgInCell"
58
- :img-prefix="imgPrefix"
59
- :server-name="serverName"
60
- :env="env"
61
- :use-oss-for-img="useOssForImg"
62
- :config="activatedConfig"
63
- :key="rowIndex"
64
- :columns="row"
65
- :no-top-border="noTopBorder"
66
- :config-data="activatedConfig.data"
67
- :display="true">
68
- </x-report-tr-group>
69
- </template>
70
- </template>
71
- </template>
72
- </template>
73
- <template v-else>
74
- <div :class=" noPadding ? 'reportMainNoPadding' : 'reportMain'" :style="activatedConfig.width > 0 ? ('width:' + activatedConfig.width + 'px') : undefined">
75
- <!-- 大标题 -->
76
- <h2 class="reportTitle" v-if="showTitle && activatedConfig.title" v-html="activatedConfig.title"></h2>
77
- <!-- 小标题 / 介乎于标题与表格之间的内容 -->
78
- <div class="subTitle" v-if="activatedConfig.subTitle && activatedConfig.subTitle.length">
79
- <div class="subTitleItems" v-for="(item, itemIndex) in activatedConfig.subTitle" :key="itemIndex">
80
- <template v-if="item.type === 'column'">
81
- <span>{{ item.text }}</span>
82
- </template>
83
- <template v-else-if="item.type === 'inputs'">
84
- <div class="inputsDiv">
85
- <div class="inputsDivItem" v-for="(num, index) of calcFormatInputNum(item.format)" :key="index">
86
- <span class="inputsDivItemLabel">{{ displayFormatStartText(item.format) }}</span>
87
- <template v-if="!forDisplay">
88
- <template v-if="item.inputReadOnly === true">
89
- <a-input v-model="data[item.dataIndex][index]" :style="'width:' + (item.inputWidth ? item.inputWidth : '100') + '%'" :disabled="true"/>
90
- </template>
91
- <template v-else>
92
- <a-input v-model="data[item.dataIndex][index]" :style="'width:' + (item.inputWidth ? item.inputWidth : '100') + '%'"/>
93
- </template>
94
- </template>
95
- <template v-else>
96
- {{ activatedConfig.data[item.dataIndex][index] }}
97
- </template>
98
- <span class="inputsDivItemLabel">{{ displayFormatText(item.format, index) }}</span>
99
- </div>
100
- </div>
101
- </template>
102
- </div>
103
- </div>
104
- <!-- 主体表格 -->
105
- <table class="reportTable" v-if="render" :style="activatedConfig.style ? activatedConfig.style : undefined">
106
- <tbody class="reportTable">
107
- <template v-for="(row, rowIndex) in activatedConfig.columns">
108
- <!-- 插槽展示 -->
109
- <template v-if="row[0].type === 'slot'">
110
- <x-report-tr-group
111
- @updateImg="updateImg"
112
- @selectRow="selectRow"
113
- @slotRendered="slotRendered"
114
- :show-img-in-cell="showImgInCell"
115
- :img-prefix="imgPrefix"
116
- :server-name="serverName"
117
- :env="env"
118
- :use-oss-for-img="useOssForImg"
119
- :key="rowIndex"
120
- :columns="row"
121
- :no-top-border="noTopBorder"
122
- :config-data="activatedConfig.data"
123
- :config="activatedConfig"
124
- :display="true">
125
- </x-report-tr-group>
126
- </template>
127
- <!-- 列表 list -->
128
- <template v-else-if="row[0].type === 'list'" >
129
- <template v-for="(num, listIndex) in row[0].listLength + 1">
130
- <template v-if="!forDisplay">
131
- <x-report-tr-group
132
- @slotRendered="slotRendered"
133
- @updateImg="updateImg"
134
- @selectRow="selectRow"
135
- :show-img-in-cell="showImgInCell"
136
- :img-prefix="imgPrefix"
137
- :server-name="serverName"
138
- :env="env"
139
- :use-oss-for-img="useOssForImg"
140
- :config="activatedConfig"
141
- :key="rowIndex + listIndex"
142
- :columns="row"
143
- :no-top-border="noTopBorder"
144
- :config-data="activatedConfig.data"
145
- :list-index="listIndex">
146
- </x-report-tr-group>
147
- </template>
148
- <template v-else>
149
- <x-report-tr-group
150
- @slotRendered="slotRendered"
151
- @updateImg="updateImg"
152
- @selectRow="selectRow"
153
- :show-img-in-cell="showImgInCell"
154
- :img-prefix="imgPrefix"
155
- :server-name="serverName"
156
- :env="env"
157
- :use-oss-for-img="useOssForImg"
158
- :config="activatedConfig"
159
- :key="rowIndex + listIndex"
160
- :columns="row"
161
- :no-top-border="noTopBorder"
162
- :config-data="activatedConfig.data"
163
- :list-index="listIndex"
164
- :display="true">
165
- </x-report-tr-group>
166
- </template>
167
- </template>
168
- </template>
169
- <!-- 动态行 inputColumns -->
170
- <template v-else-if="row[0].type === 'inputColumns'">
171
- <template v-if="forDisplay">
172
- <x-report-tr-group
173
- @slotRendered="slotRendered"
174
- @updateImg="updateImg"
175
- @selectRow="selectRow"
176
- :show-img-in-cell="showImgInCell"
177
- :img-prefix="imgPrefix"
178
- :server-name="serverName"
179
- :env="env"
180
- :use-oss-for-img="useOssForImg"
181
- :config="activatedConfig"
182
- :columns="row[0].definition"
183
- :config-data="{arr: activatedConfig.data[row[0].dataIndex]}"
184
- :input-columns="true"
185
- :no-top-border="noTopBorder"
186
- v-for="(item, definitionIndex) in activatedConfig.data[row[0].dataIndex]"
187
- :input-columns-definition-index="definitionIndex"
188
- :display="true"
189
- :key="row[0].dataIndex + definitionIndex + rowIndex"></x-report-tr-group>
190
- </template>
191
- <template v-if="!forDisplay">
192
- <x-report-tr-group
193
- @slotRendered="slotRendered"
194
- @updateImg="updateImg"
195
- @selectRow="selectRow"
196
- :show-img-in-cell="showImgInCell"
197
- :img-prefix="imgPrefix"
198
- :server-name="serverName"
199
- :env="env"
200
- :use-oss-for-img="useOssForImg"
201
- :config="activatedConfig"
202
- :columns="row[0].definition"
203
- :config-data="{arr: activatedConfig.data[row[0].dataIndex]}"
204
- :input-columns="true"
205
- :no-top-border="noTopBorder"
206
- v-for="(item, definitionIndex) in activatedConfig.data[row[0].dataIndex]"
207
- :input-columns-definition-index="definitionIndex"
208
- :key="row[0].dataIndex + definitionIndex + rowIndex"></x-report-tr-group>
209
- <!-- 动态行交互按钮 -->
210
- <x-report-tr-group
211
- @slotRendered="slotRendered"
212
- @updateImg="updateImg"
213
- @selectRow="selectRow"
214
- :show-img-in-cell="showImgInCell"
215
- :img-prefix="imgPrefix"
216
- :server-name="serverName"
217
- :env="env"
218
- :use-oss-for-img="useOssForImg"
219
- :config="activatedConfig"
220
- :key="rowIndex"
221
- :columns="row"
222
- :no-top-border="noTopBorder"
223
- :config-data="activatedConfig.data"
224
- :input-columns-button="true"
225
- :input-columns="true">
226
- </x-report-tr-group>
227
- </template>
228
- </template>
229
- <!-- 普通行 -->
230
- <template v-else>
231
- <template v-if="!forDisplay">
232
- <x-report-tr-group
233
- @slotRendered="slotRendered"
234
- @updateImg="updateImg"
235
- @selectRow="selectRow"
236
- :show-img-in-cell="showImgInCell"
237
- :img-prefix="imgPrefix"
238
- :server-name="serverName"
239
- :env="env"
240
- :use-oss-for-img="useOssForImg"
241
- :key="rowIndex"
242
- :columns="row"
243
- :no-top-border="noTopBorder"
244
- :config-data="activatedConfig.data"
245
- :config="activatedConfig">
246
- </x-report-tr-group>
247
- </template>
248
- <template v-else>
249
- <x-report-tr-group
250
- @slotRendered="slotRendered"
251
- @updateImg="updateImg"
252
- @selectRow="selectRow"
253
- :show-img-in-cell="showImgInCell"
254
- :img-prefix="imgPrefix"
255
- :server-name="serverName"
256
- :env="env"
257
- :use-oss-for-img="useOssForImg"
258
- :config="activatedConfig"
259
- :key="rowIndex"
260
- :columns="row"
261
- :no-top-border="noTopBorder"
262
- :config-data="activatedConfig.data"
263
- :display="true">
264
- </x-report-tr-group>
265
- </template>
266
- </template>
267
- </template>
268
- </tbody>
269
- </table>
270
- <div v-if="showImages" style="margin-top: 5%; display: flex;margin-bottom: 5%">
271
- <p>图片:</p>
272
- <div :key="imgIndex" v-for="(img,imgIndex) in imageList" style="margin-left: 3%;width: 200px">
273
- <img :src="img.url" class="img" :alt="img.name"/>
274
- <p style="overflow: hidden;text-overflow: ellipsis;white-space: nowrap;width: 100%;">{{ img.name }}</p>
275
- </div>
276
- </div>
277
- </div>
278
- </template>
279
- </div>
280
- </template>
281
-
282
- <script>
283
- import XReportTrGroup from './XReportTrGroup.vue'
284
- import XReportJsonRender from './XReportJsonRender.vue'
285
- import { getConfigByName } from '@vue2-client/services/api/common'
286
- import XFormTable from '@vue2-client/base-client/components/common/XFormTable/XFormTable'
287
-
288
- export default {
289
- name: 'XReportDesign',
290
- props: {
291
- // 配置
292
- config: {
293
- type: Object,
294
- require: true,
295
- default: () => {}
296
- },
297
- showImgInCell: {
298
- type: Boolean,
299
- default: false
300
- },
301
- // 是否是展示用
302
- forDisplay: {
303
- type: Boolean,
304
- default: false
305
- },
306
- // 命名空间
307
- serverName: {
308
- type: String,
309
- default: 'af-system'
310
- },
311
- // 环境
312
- env: {
313
- type: String,
314
- default: 'prod'
315
- },
316
- // 是否只能展示不可编辑
317
- displayOnly: {
318
- type: Boolean,
319
- default: false
320
- },
321
- // 插槽名
322
- slotConfigName: {
323
- type: String,
324
- default: undefined
325
- },
326
- // 将图片全部展示在表格之后,挨个罗列
327
- showImages: {
328
- type: Boolean,
329
- default: false
330
- },
331
- // 图片罗列的数组
332
- imageList: {
333
- type: Array,
334
- default: undefined
335
- },
336
- // 表格没有边距
337
- noPadding: {
338
- type: Boolean,
339
- default: true
340
- },
341
- // 表格没有上边框,与noPadding搭配可以实现连续表格
342
- noTopBorder: {
343
- type: Boolean,
344
- default: false
345
- },
346
- // 是否展示标题
347
- showTitle: {
348
- type: Boolean,
349
- default: true
350
- },
351
- // 图片是否使用OSS来保存
352
- useOssForImg: {
353
- type: Boolean,
354
- default: true
355
- },
356
- // 图片上传后添加前缀
357
- imgPrefix: {
358
- type: String,
359
- default: undefined
360
- }
361
- },
362
- components: {
363
- XFormTable,
364
- XReportTrGroup,
365
- XReportJsonRender
366
- },
367
- inject: ['isWidget'],
368
- data () {
369
- return {
370
- // 表单的数据
371
- data: this.config.data,
372
- // 插槽配置
373
- slotConfig: undefined,
374
- // 控制是否渲染
375
- render: false,
376
- // 用于展示的配置
377
- activatedConfig: {}
378
- }
379
- },
380
- methods: {
381
- slotRendered () {
382
- this.$emit('slotRendered')
383
- },
384
- updateImg (data) {
385
- this.$emit('updateImg', data)
386
- },
387
- selectRow (selectedRowKeys, selectedRows) {
388
- this.table_selectedRowKeys = selectedRowKeys
389
- this.table_selectedRows = selectedRows
390
- console.log('XReportDesign')
391
- this.$emit('selectRow', selectedRowKeys, selectedRows)
392
- },
393
- // 根据format计算需要多少个输入框
394
- calcFormatInputNum (formatStr) {
395
- let count = 0
396
- for (let i = 0; i < formatStr.length; i++) {
397
- if (formatStr[i] == '{') {
398
- count++
399
- }
400
- }
401
- return count
402
- },
403
- // 根据format计算输入框之后的文字显示
404
- displayFormatText (formatStr, num) {
405
- let start = 0
406
- let count = 0
407
- num++
408
- for (let i = 0; i < formatStr.length; i++) {
409
- if (formatStr[i] === '}') {
410
- start = i
411
- count++
412
- }
413
- if (count === num) {
414
- for (let j = start + 1; j < formatStr.length; j++) {
415
- if (formatStr[j] === '{') {
416
- return formatStr.slice(start + 1, j)
417
- }
418
- if (j === formatStr.length - 1 && formatStr[j] !== '}') {
419
- return formatStr[j]
420
- }
421
- }
422
- }
423
- }
424
- },
425
- // 根据format计算输入框之前的文字显示
426
- displayFormatStartText (formatStr) {
427
- let count = 0
428
- for (let i = 0; i < formatStr.length; i++) {
429
- if (formatStr[i] === '{') {
430
- break
431
- } else {
432
- count++
433
- }
434
- }
435
- return formatStr.slice(0, count)
436
- },
437
- },
438
- created () {
439
- console.log('>>>> xreportdesign 渲染')
440
- if (this.slotConfigName) {
441
- getConfigByName(this.slotConfigName, undefined, res => {
442
- this.slotConfig = res
443
- res.data = { ...res.data, ...this.data }
444
- this.config.data = res.data
445
- this.activatedConfig = res
446
- this.render = true
447
- }, this.env === 'dev')
448
- } else {
449
- this.activatedConfig = this.config
450
- this.render = true
451
- }
452
- if (this.activatedConfig.designMode !== 'json') {
453
- this.activatedConfig.columns.forEach(row => {
454
- if (row[0] && row[0].type && row[0].type === 'list' && row[0].listLength === 1) {
455
- row.forEach(cell => {
456
- cell.listLength = this.activatedConfig.data[cell.dataIndex].length
457
- })
458
- }
459
- })
460
- }
461
- },
462
- mounted () {
463
- },
464
- watch: {
465
- config: {
466
- deep: true,
467
- handler (newVal) {
468
- }
469
- },
470
- activatedConfig: {
471
- handler (val) {
472
- console.log('>>>> activatedConfig: ', val)
473
- }
474
- }
475
- }
476
- }
477
- </script>
478
-
479
- <style lang="less" scoped>
480
- .img{
481
- width: 95%;
482
- height: 180px;
483
- object-fit: cover;
484
- }
485
- .reportMain {
486
- text-align: center;
487
- margin: 0 auto;
488
- font-size: 16px;
489
- color: #000;
490
- background-color: #fff;
491
- border-radius: 8px;
492
-
493
- .reportTitle {
494
- font-weight: bold;
495
- }
496
-
497
- .subTitle {
498
- display: flex;
499
- justify-content: space-between;
500
- margin-bottom: 1%;
501
-
502
- .subTitleItems {
503
- max-width: 30%;
504
- }
505
- }
506
-
507
- .inputsDiv {
508
- display: flex;
509
- justify-content: space-between;
510
- .inputsDivItem {
511
- display: flex;
512
- align-items: center;
513
- padding: 0 4px;
514
- white-space: nowrap;
515
- .inputsDivItemLabel {
516
- padding: 0 4px;
517
- }
518
- }
519
- }
520
-
521
- .reportTable {
522
- width: 100%;
523
- border-collapse: collapse;
524
- table-layout:fixed;
525
- word-break:break-all;
526
- }
527
- }
528
- .reportMainForDisplay {
529
- text-align: center;
530
- margin: 10% auto;
531
- font-size: 16px;
532
- color: #000;
533
- background-color: #fff;
534
- border-radius: 8px;
535
-
536
- .reportTitle {
537
- font-weight: bold;
538
- }
539
-
540
- .subTitle {
541
- display: flex;
542
- justify-content: space-between;
543
-
544
- .subTitleItems {
545
- max-width: 30%;
546
- }
547
- }
548
-
549
- .inputsDiv {
550
- display: flex;
551
- justify-content: space-around;
552
- .inputsDivItem {
553
- display: flex;
554
- align-items: center;
555
- padding: 0 4px;
556
- white-space: nowrap;
557
- .inputsDivItemLabel {
558
- padding: 0 4px;
559
- }
560
- }
561
- }
562
-
563
- .reportTable {
564
- width: 100%;
565
- border-collapse: collapse;
566
- table-layout:fixed;
567
- word-break:break-all;
568
- }
569
- }
570
- .reportMainNoPadding {
571
- // text-align: center;
572
- margin: 0 auto;
573
- font-size: 16px;
574
- color: #000;
575
- // background-color: #fff;
576
- border-radius: 8px;
577
- height: auto;
578
- min-height : 20vh;
579
- overflow-y: auto;
580
- overflow-x: hidden;
581
-
582
- .reportTitle {
583
- font-weight: bold;
584
- }
585
-
586
- .subTitle {
587
- display: flex;
588
- justify-content: space-between;
589
-
590
- .subTitleItems {
591
- max-width: 30%;
592
- }
593
- }
594
-
595
- .inputsDiv {
596
- display: flex;
597
- justify-content: space-between;
598
- .inputsDivItem {
599
- display: flex;
600
- align-items: center;
601
- padding: 0 4px;
602
- white-space: nowrap;
603
- .inputsDivItemLabel {
604
- padding: 0 4px;
605
- }
606
- }
607
- }
608
-
609
- .reportTable {
610
- width: 100%;
611
- border-collapse: collapse;
612
- table-layout:fixed;
613
- word-break:break-all;
614
- }
615
- }
616
- .tools{
617
- position: fixed;
618
- right: 2%;
619
- text-align: right;
620
- width: 60%;
621
- cursor: pointer;
622
- .toolsItem{
623
- width: 15%;
624
- margin-right: 3%;
625
- display: inline-block;
626
- }
627
- }
628
- </style>
1
+ <template>
2
+ <div>
3
+ <template v-if="this.activatedConfig.designMode === 'json'">
4
+ <XReportJsonRender
5
+ @updateImg="updateImg"
6
+ @selectRow="selectRow"
7
+ :img-prefix="imgPrefix"
8
+ :server-name="serverName"
9
+ :display-only="displayOnly"
10
+ :show-title="showTitle"
11
+ :no-padding="noPadding"
12
+ :no-top-border="noTopBorder"
13
+ :config="activatedConfig"/>
14
+ </template>
15
+ <template v-else-if="isWidget">
16
+ <template v-for="(row, rowIndex) in activatedConfig.columns">
17
+ <!-- 插槽展示 -->
18
+ <template v-if="row[0].type === 'slot'">
19
+ <x-report-tr-group
20
+ @updateImg="updateImg"
21
+ @selectRow="selectRow"
22
+ :show-img-in-cell="showImgInCell"
23
+ :img-prefix="imgPrefix"
24
+ :server-name="serverName"
25
+ :env="env"
26
+ :use-oss-for-img="useOssForImg"
27
+ :key="rowIndex"
28
+ :columns="row"
29
+ :no-top-border="noTopBorder"
30
+ :config-data="activatedConfig.data"
31
+ :config="activatedConfig"
32
+ :display="true">
33
+ </x-report-tr-group>
34
+ </template>
35
+ <!-- 普通行 -->
36
+ <template v-else>
37
+ <template v-if="!forDisplay">
38
+ <x-report-tr-group
39
+ @updateImg="updateImg"
40
+ @selectRow="selectRow"
41
+ :show-img-in-cell="showImgInCell"
42
+ :img-prefix="imgPrefix"
43
+ :server-name="serverName"
44
+ :env="env"
45
+ :use-oss-for-img="useOssForImg"
46
+ :key="rowIndex"
47
+ :columns="row"
48
+ :no-top-border="noTopBorder"
49
+ :config-data="activatedConfig.data"
50
+ :config="activatedConfig">
51
+ </x-report-tr-group>
52
+ </template>
53
+ <template v-else>
54
+ <x-report-tr-group
55
+ @updateImg="updateImg"
56
+ @selectRow="selectRow"
57
+ :show-img-in-cell="showImgInCell"
58
+ :img-prefix="imgPrefix"
59
+ :server-name="serverName"
60
+ :env="env"
61
+ :use-oss-for-img="useOssForImg"
62
+ :config="activatedConfig"
63
+ :key="rowIndex"
64
+ :columns="row"
65
+ :no-top-border="noTopBorder"
66
+ :config-data="activatedConfig.data"
67
+ :display="true">
68
+ </x-report-tr-group>
69
+ </template>
70
+ </template>
71
+ </template>
72
+ </template>
73
+ <template v-else>
74
+ <div :class=" noPadding ? 'reportMainNoPadding' : 'reportMain'" :style="activatedConfig.width > 0 ? ('width:' + activatedConfig.width + 'px') : undefined">
75
+ <!-- 大标题 -->
76
+ <h2 class="reportTitle" v-if="showTitle && activatedConfig.title" v-html="activatedConfig.title"></h2>
77
+ <!-- 小标题 / 介乎于标题与表格之间的内容 -->
78
+ <div class="subTitle" v-if="activatedConfig.subTitle && activatedConfig.subTitle.length">
79
+ <div class="subTitleItems" v-for="(item, itemIndex) in activatedConfig.subTitle" :key="itemIndex">
80
+ <template v-if="item.type === 'column'">
81
+ <span>{{ item.text }}</span>
82
+ </template>
83
+ <template v-else-if="item.type === 'inputs'">
84
+ <div class="inputsDiv">
85
+ <div class="inputsDivItem" v-for="(num, index) of calcFormatInputNum(item.format)" :key="index">
86
+ <span class="inputsDivItemLabel">{{ displayFormatStartText(item.format) }}</span>
87
+ <template v-if="!forDisplay">
88
+ <template v-if="item.inputReadOnly === true">
89
+ <a-input v-model="data[item.dataIndex][index]" :style="'width:' + (item.inputWidth ? item.inputWidth : '100') + '%'" :disabled="true"/>
90
+ </template>
91
+ <template v-else>
92
+ <a-input v-model="data[item.dataIndex][index]" :style="'width:' + (item.inputWidth ? item.inputWidth : '100') + '%'"/>
93
+ </template>
94
+ </template>
95
+ <template v-else>
96
+ {{ activatedConfig.data[item.dataIndex][index] }}
97
+ </template>
98
+ <span class="inputsDivItemLabel">{{ displayFormatText(item.format, index) }}</span>
99
+ </div>
100
+ </div>
101
+ </template>
102
+ </div>
103
+ </div>
104
+ <!-- 主体表格 -->
105
+ <table class="reportTable" v-if="render" :style="activatedConfig.style ? activatedConfig.style : undefined">
106
+ <tbody class="reportTable">
107
+ <template v-for="(row, rowIndex) in activatedConfig.columns">
108
+ <!-- 插槽展示 -->
109
+ <template v-if="row[0].type === 'slot'">
110
+ <x-report-tr-group
111
+ @updateImg="updateImg"
112
+ @selectRow="selectRow"
113
+ @slotRendered="slotRendered"
114
+ :show-img-in-cell="showImgInCell"
115
+ :img-prefix="imgPrefix"
116
+ :server-name="serverName"
117
+ :env="env"
118
+ :use-oss-for-img="useOssForImg"
119
+ :key="rowIndex"
120
+ :columns="row"
121
+ :no-top-border="noTopBorder"
122
+ :config-data="activatedConfig.data"
123
+ :config="activatedConfig"
124
+ :display="true">
125
+ </x-report-tr-group>
126
+ </template>
127
+ <!-- 列表 list -->
128
+ <template v-else-if="row[0].type === 'list'" >
129
+ <template v-for="(num, listIndex) in row[0].listLength + 1">
130
+ <template v-if="!forDisplay">
131
+ <x-report-tr-group
132
+ @slotRendered="slotRendered"
133
+ @updateImg="updateImg"
134
+ @selectRow="selectRow"
135
+ :show-img-in-cell="showImgInCell"
136
+ :img-prefix="imgPrefix"
137
+ :server-name="serverName"
138
+ :env="env"
139
+ :use-oss-for-img="useOssForImg"
140
+ :config="activatedConfig"
141
+ :key="rowIndex + listIndex"
142
+ :columns="row"
143
+ :no-top-border="noTopBorder"
144
+ :config-data="activatedConfig.data"
145
+ :list-index="listIndex">
146
+ </x-report-tr-group>
147
+ </template>
148
+ <template v-else>
149
+ <x-report-tr-group
150
+ @slotRendered="slotRendered"
151
+ @updateImg="updateImg"
152
+ @selectRow="selectRow"
153
+ :show-img-in-cell="showImgInCell"
154
+ :img-prefix="imgPrefix"
155
+ :server-name="serverName"
156
+ :env="env"
157
+ :use-oss-for-img="useOssForImg"
158
+ :config="activatedConfig"
159
+ :key="rowIndex + listIndex"
160
+ :columns="row"
161
+ :no-top-border="noTopBorder"
162
+ :config-data="activatedConfig.data"
163
+ :list-index="listIndex"
164
+ :display="true">
165
+ </x-report-tr-group>
166
+ </template>
167
+ </template>
168
+ </template>
169
+ <!-- 动态行 inputColumns -->
170
+ <template v-else-if="row[0].type === 'inputColumns'">
171
+ <template v-if="forDisplay">
172
+ <x-report-tr-group
173
+ @slotRendered="slotRendered"
174
+ @updateImg="updateImg"
175
+ @selectRow="selectRow"
176
+ :show-img-in-cell="showImgInCell"
177
+ :img-prefix="imgPrefix"
178
+ :server-name="serverName"
179
+ :env="env"
180
+ :use-oss-for-img="useOssForImg"
181
+ :config="activatedConfig"
182
+ :columns="row[0].definition"
183
+ :config-data="{arr: activatedConfig.data[row[0].dataIndex]}"
184
+ :input-columns="true"
185
+ :no-top-border="noTopBorder"
186
+ v-for="(item, definitionIndex) in activatedConfig.data[row[0].dataIndex]"
187
+ :input-columns-definition-index="definitionIndex"
188
+ :display="true"
189
+ :key="row[0].dataIndex + definitionIndex + rowIndex"></x-report-tr-group>
190
+ </template>
191
+ <template v-if="!forDisplay">
192
+ <x-report-tr-group
193
+ @slotRendered="slotRendered"
194
+ @updateImg="updateImg"
195
+ @selectRow="selectRow"
196
+ :show-img-in-cell="showImgInCell"
197
+ :img-prefix="imgPrefix"
198
+ :server-name="serverName"
199
+ :env="env"
200
+ :use-oss-for-img="useOssForImg"
201
+ :config="activatedConfig"
202
+ :columns="row[0].definition"
203
+ :config-data="{arr: activatedConfig.data[row[0].dataIndex]}"
204
+ :input-columns="true"
205
+ :no-top-border="noTopBorder"
206
+ v-for="(item, definitionIndex) in activatedConfig.data[row[0].dataIndex]"
207
+ :input-columns-definition-index="definitionIndex"
208
+ :key="row[0].dataIndex + definitionIndex + rowIndex"></x-report-tr-group>
209
+ <!-- 动态行交互按钮 -->
210
+ <x-report-tr-group
211
+ @slotRendered="slotRendered"
212
+ @updateImg="updateImg"
213
+ @selectRow="selectRow"
214
+ :show-img-in-cell="showImgInCell"
215
+ :img-prefix="imgPrefix"
216
+ :server-name="serverName"
217
+ :env="env"
218
+ :use-oss-for-img="useOssForImg"
219
+ :config="activatedConfig"
220
+ :key="rowIndex"
221
+ :columns="row"
222
+ :no-top-border="noTopBorder"
223
+ :config-data="activatedConfig.data"
224
+ :input-columns-button="true"
225
+ :input-columns="true">
226
+ </x-report-tr-group>
227
+ </template>
228
+ </template>
229
+ <!-- 普通行 -->
230
+ <template v-else>
231
+ <template v-if="!forDisplay">
232
+ <x-report-tr-group
233
+ @slotRendered="slotRendered"
234
+ @updateImg="updateImg"
235
+ @selectRow="selectRow"
236
+ :show-img-in-cell="showImgInCell"
237
+ :img-prefix="imgPrefix"
238
+ :server-name="serverName"
239
+ :env="env"
240
+ :use-oss-for-img="useOssForImg"
241
+ :key="rowIndex"
242
+ :columns="row"
243
+ :no-top-border="noTopBorder"
244
+ :config-data="activatedConfig.data"
245
+ :config="activatedConfig">
246
+ </x-report-tr-group>
247
+ </template>
248
+ <template v-else>
249
+ <x-report-tr-group
250
+ @slotRendered="slotRendered"
251
+ @updateImg="updateImg"
252
+ @selectRow="selectRow"
253
+ :show-img-in-cell="showImgInCell"
254
+ :img-prefix="imgPrefix"
255
+ :server-name="serverName"
256
+ :env="env"
257
+ :use-oss-for-img="useOssForImg"
258
+ :config="activatedConfig"
259
+ :key="rowIndex"
260
+ :columns="row"
261
+ :no-top-border="noTopBorder"
262
+ :config-data="activatedConfig.data"
263
+ :display="true">
264
+ </x-report-tr-group>
265
+ </template>
266
+ </template>
267
+ </template>
268
+ </tbody>
269
+ </table>
270
+ <div v-if="showImages" style="margin-top: 5%; display: flex;margin-bottom: 5%">
271
+ <p>图片:</p>
272
+ <div :key="imgIndex" v-for="(img,imgIndex) in imageList" style="margin-left: 3%;width: 200px">
273
+ <img :src="img.url" class="img" :alt="img.name"/>
274
+ <p style="overflow: hidden;text-overflow: ellipsis;white-space: nowrap;width: 100%;">{{ img.name }}</p>
275
+ </div>
276
+ </div>
277
+ </div>
278
+ </template>
279
+ </div>
280
+ </template>
281
+
282
+ <script>
283
+ import XReportTrGroup from './XReportTrGroup.vue'
284
+ import XReportJsonRender from './XReportJsonRender.vue'
285
+ import { getConfigByName } from '@vue2-client/services/api/common'
286
+ import XFormTable from '@vue2-client/base-client/components/common/XFormTable/XFormTable'
287
+
288
+ export default {
289
+ name: 'XReportDesign',
290
+ props: {
291
+ // 配置
292
+ config: {
293
+ type: Object,
294
+ require: true,
295
+ default: () => {}
296
+ },
297
+ showImgInCell: {
298
+ type: Boolean,
299
+ default: false
300
+ },
301
+ // 是否是展示用
302
+ forDisplay: {
303
+ type: Boolean,
304
+ default: false
305
+ },
306
+ // 命名空间
307
+ serverName: {
308
+ type: String,
309
+ default: 'af-system'
310
+ },
311
+ // 环境
312
+ env: {
313
+ type: String,
314
+ default: 'prod'
315
+ },
316
+ // 是否只能展示不可编辑
317
+ displayOnly: {
318
+ type: Boolean,
319
+ default: false
320
+ },
321
+ // 插槽名
322
+ slotConfigName: {
323
+ type: String,
324
+ default: undefined
325
+ },
326
+ // 将图片全部展示在表格之后,挨个罗列
327
+ showImages: {
328
+ type: Boolean,
329
+ default: false
330
+ },
331
+ // 图片罗列的数组
332
+ imageList: {
333
+ type: Array,
334
+ default: undefined
335
+ },
336
+ // 表格没有边距
337
+ noPadding: {
338
+ type: Boolean,
339
+ default: true
340
+ },
341
+ // 表格没有上边框,与noPadding搭配可以实现连续表格
342
+ noTopBorder: {
343
+ type: Boolean,
344
+ default: false
345
+ },
346
+ // 是否展示标题
347
+ showTitle: {
348
+ type: Boolean,
349
+ default: true
350
+ },
351
+ // 图片是否使用OSS来保存
352
+ useOssForImg: {
353
+ type: Boolean,
354
+ default: true
355
+ },
356
+ // 图片上传后添加前缀
357
+ imgPrefix: {
358
+ type: String,
359
+ default: undefined
360
+ }
361
+ },
362
+ components: {
363
+ XFormTable,
364
+ XReportTrGroup,
365
+ XReportJsonRender
366
+ },
367
+ inject: ['isWidget'],
368
+ data () {
369
+ return {
370
+ // 表单的数据
371
+ data: this.config.data,
372
+ // 插槽配置
373
+ slotConfig: undefined,
374
+ // 控制是否渲染
375
+ render: false,
376
+ // 用于展示的配置
377
+ activatedConfig: {}
378
+ }
379
+ },
380
+ methods: {
381
+ slotRendered () {
382
+ this.$emit('slotRendered')
383
+ },
384
+ updateImg (data) {
385
+ this.$emit('updateImg', data)
386
+ },
387
+ selectRow (selectedRowKeys, selectedRows) {
388
+ this.table_selectedRowKeys = selectedRowKeys
389
+ this.table_selectedRows = selectedRows
390
+ console.log('XReportDesign')
391
+ this.$emit('selectRow', selectedRowKeys, selectedRows)
392
+ },
393
+ // 根据format计算需要多少个输入框
394
+ calcFormatInputNum (formatStr) {
395
+ let count = 0
396
+ for (let i = 0; i < formatStr.length; i++) {
397
+ if (formatStr[i] == '{') {
398
+ count++
399
+ }
400
+ }
401
+ return count
402
+ },
403
+ // 根据format计算输入框之后的文字显示
404
+ displayFormatText (formatStr, num) {
405
+ let start = 0
406
+ let count = 0
407
+ num++
408
+ for (let i = 0; i < formatStr.length; i++) {
409
+ if (formatStr[i] === '}') {
410
+ start = i
411
+ count++
412
+ }
413
+ if (count === num) {
414
+ for (let j = start + 1; j < formatStr.length; j++) {
415
+ if (formatStr[j] === '{') {
416
+ return formatStr.slice(start + 1, j)
417
+ }
418
+ if (j === formatStr.length - 1 && formatStr[j] !== '}') {
419
+ return formatStr[j]
420
+ }
421
+ }
422
+ }
423
+ }
424
+ },
425
+ // 根据format计算输入框之前的文字显示
426
+ displayFormatStartText (formatStr) {
427
+ let count = 0
428
+ for (let i = 0; i < formatStr.length; i++) {
429
+ if (formatStr[i] === '{') {
430
+ break
431
+ } else {
432
+ count++
433
+ }
434
+ }
435
+ return formatStr.slice(0, count)
436
+ },
437
+ },
438
+ created () {
439
+ console.log('>>>> xreportdesign 渲染')
440
+ if (this.slotConfigName) {
441
+ getConfigByName(this.slotConfigName, undefined, res => {
442
+ this.slotConfig = res
443
+ res.data = { ...res.data, ...this.data }
444
+ this.config.data = res.data
445
+ this.activatedConfig = res
446
+ this.render = true
447
+ }, this.env === 'dev')
448
+ } else {
449
+ this.activatedConfig = this.config
450
+ this.render = true
451
+ }
452
+ if (this.activatedConfig.designMode !== 'json') {
453
+ this.activatedConfig.columns.forEach(row => {
454
+ if (row[0] && row[0].type && row[0].type === 'list' && row[0].listLength === 1) {
455
+ row.forEach(cell => {
456
+ cell.listLength = this.activatedConfig.data[cell.dataIndex].length
457
+ })
458
+ }
459
+ })
460
+ }
461
+ },
462
+ mounted () {
463
+ },
464
+ watch: {
465
+ config: {
466
+ deep: true,
467
+ handler (newVal) {
468
+ }
469
+ },
470
+ activatedConfig: {
471
+ handler (val) {
472
+ console.log('>>>> activatedConfig: ', val)
473
+ }
474
+ }
475
+ }
476
+ }
477
+ </script>
478
+
479
+ <style lang="less" scoped>
480
+ .img{
481
+ width: 95%;
482
+ height: 180px;
483
+ object-fit: cover;
484
+ }
485
+ .reportMain {
486
+ text-align: center;
487
+ margin: 0 auto;
488
+ font-size: 16px;
489
+ color: #000;
490
+ background-color: #fff;
491
+ border-radius: 8px;
492
+
493
+ .reportTitle {
494
+ font-weight: bold;
495
+ }
496
+
497
+ .subTitle {
498
+ display: flex;
499
+ justify-content: space-between;
500
+ margin-bottom: 1%;
501
+
502
+ .subTitleItems {
503
+ max-width: 30%;
504
+ }
505
+ }
506
+
507
+ .inputsDiv {
508
+ display: flex;
509
+ justify-content: space-between;
510
+ .inputsDivItem {
511
+ display: flex;
512
+ align-items: center;
513
+ padding: 0 4px;
514
+ white-space: nowrap;
515
+ .inputsDivItemLabel {
516
+ padding: 0 4px;
517
+ }
518
+ }
519
+ }
520
+
521
+ .reportTable {
522
+ width: 100%;
523
+ border-collapse: collapse;
524
+ table-layout:fixed;
525
+ word-break:break-all;
526
+ }
527
+ }
528
+ .reportMainForDisplay {
529
+ text-align: center;
530
+ margin: 10% auto;
531
+ font-size: 16px;
532
+ color: #000;
533
+ background-color: #fff;
534
+ border-radius: 8px;
535
+
536
+ .reportTitle {
537
+ font-weight: bold;
538
+ }
539
+
540
+ .subTitle {
541
+ display: flex;
542
+ justify-content: space-between;
543
+
544
+ .subTitleItems {
545
+ max-width: 30%;
546
+ }
547
+ }
548
+
549
+ .inputsDiv {
550
+ display: flex;
551
+ justify-content: space-around;
552
+ .inputsDivItem {
553
+ display: flex;
554
+ align-items: center;
555
+ padding: 0 4px;
556
+ white-space: nowrap;
557
+ .inputsDivItemLabel {
558
+ padding: 0 4px;
559
+ }
560
+ }
561
+ }
562
+
563
+ .reportTable {
564
+ width: 100%;
565
+ border-collapse: collapse;
566
+ table-layout:fixed;
567
+ word-break:break-all;
568
+ }
569
+ }
570
+ .reportMainNoPadding {
571
+ // text-align: center;
572
+ margin: 0 auto;
573
+ font-size: 16px;
574
+ color: #000;
575
+ // background-color: #fff;
576
+ border-radius: 8px;
577
+ height: auto;
578
+ min-height : 20vh;
579
+ overflow-y: auto;
580
+ overflow-x: hidden;
581
+
582
+ .reportTitle {
583
+ font-weight: bold;
584
+ }
585
+
586
+ .subTitle {
587
+ display: flex;
588
+ justify-content: space-between;
589
+
590
+ .subTitleItems {
591
+ max-width: 30%;
592
+ }
593
+ }
594
+
595
+ .inputsDiv {
596
+ display: flex;
597
+ justify-content: space-between;
598
+ .inputsDivItem {
599
+ display: flex;
600
+ align-items: center;
601
+ padding: 0 4px;
602
+ white-space: nowrap;
603
+ .inputsDivItemLabel {
604
+ padding: 0 4px;
605
+ }
606
+ }
607
+ }
608
+
609
+ .reportTable {
610
+ width: 100%;
611
+ border-collapse: collapse;
612
+ table-layout:fixed;
613
+ word-break:break-all;
614
+ }
615
+ }
616
+ .tools{
617
+ position: fixed;
618
+ right: 2%;
619
+ text-align: right;
620
+ width: 60%;
621
+ cursor: pointer;
622
+ .toolsItem{
623
+ width: 15%;
624
+ margin-right: 3%;
625
+ display: inline-block;
626
+ }
627
+ }
628
+ </style>