Commit 2ee917638a2ad8f065cb6731c758853d8da21b9d

Authored by 乔启韬
1 parent ed26918a

子表关联表-导出

Too many changes to show.

To preserve performance only 22 of 99 files are displayed.

1 -.fr-container {  
2 - /* Resets */  
3 - /*  
4 - This will set table to full width and then  
5 - all cells will be equal width  
6 - */  
7 - /* 1. Fix for Chrome 44 bug.  
8 - * https://code.google.com/p/chromium/issues/detail?id=506893 */  
9 - /* Height Percentages - Based off of height of parent */  
10 - /* Screen Height Percentage */  
11 - /* String Properties */  
12 - /* Max Width Percentages */  
13 - /* Max Width Scale */  
14 - /* Max Width String Properties */  
15 -}  
16 -.fr-container .outline {  
17 - outline: 1px solid;  
18 -}  
19 -.fr-container .outline-transparent {  
20 - outline: 1px solid transparent;  
21 -}  
22 -.fr-container .outline-0 {  
23 - outline: 0;  
24 -}  
25 -.fr-container .ba {  
26 - border-style: solid;  
27 - border-width: 1px;  
28 -}  
29 -.fr-container .bt {  
30 - border-top-style: solid;  
31 - border-top-width: 1px;  
32 -}  
33 -.fr-container .br {  
34 - border-right-style: solid;  
35 - border-right-width: 1px;  
36 -}  
37 -.fr-container .bb {  
38 - border-bottom-style: solid;  
39 - border-bottom-width: 1px;  
40 -}  
41 -.fr-container .bl {  
42 - border-left-style: solid;  
43 - border-left-width: 1px;  
44 -}  
45 -.fr-container .bn {  
46 - border-style: none;  
47 - border-width: 0;  
48 -}  
49 -.fr-container .br0 {  
50 - border-radius: 0;  
51 -}  
52 -.fr-container .br1 {  
53 - border-radius: 0.125rem;  
54 -}  
55 -.fr-container .br2 {  
56 - border-radius: 0.25rem;  
57 -}  
58 -.fr-container .br3 {  
59 - border-radius: 0.5rem;  
60 -}  
61 -.fr-container .br4 {  
62 - border-radius: 1rem;  
63 -}  
64 -.fr-container .br-100 {  
65 - border-radius: 100%;  
66 -}  
67 -.fr-container .br-pill {  
68 - border-radius: 9999px;  
69 -}  
70 -.fr-container .br--bottom {  
71 - border-top-left-radius: 0;  
72 - border-top-right-radius: 0;  
73 -}  
74 -.fr-container .br--top {  
75 - border-bottom-left-radius: 0;  
76 - border-bottom-right-radius: 0;  
77 -}  
78 -.fr-container .br--right {  
79 - border-top-left-radius: 0;  
80 - border-bottom-left-radius: 0;  
81 -}  
82 -.fr-container .br--left {  
83 - border-top-right-radius: 0;  
84 - border-bottom-right-radius: 0;  
85 -}  
86 -.fr-container .b--dotted {  
87 - border-style: dotted;  
88 -}  
89 -.fr-container .b--dashed {  
90 - border-style: dashed;  
91 -}  
92 -.fr-container .b--solid {  
93 - border-style: solid;  
94 -}  
95 -.fr-container .b--none {  
96 - border-style: none;  
97 -}  
98 -.fr-container .b--black-10 {  
99 - border-color: rgba(0, 0, 0, 0.1);  
100 -}  
101 -.fr-container .b--black-20 {  
102 - border-color: rgba(0, 0, 0, 0.2);  
103 -}  
104 -.fr-container .b--black-30 {  
105 - border-color: rgba(0, 0, 0, 0.3);  
106 -}  
107 -.fr-container .bw0 {  
108 - border-width: 0;  
109 -}  
110 -.fr-container .bw1 {  
111 - border-width: 0.125rem;  
112 -}  
113 -.fr-container .bw2 {  
114 - border-width: 0.25rem;  
115 -}  
116 -.fr-container .bw3 {  
117 - border-width: 0.5rem;  
118 -}  
119 -.fr-container .bw4 {  
120 - border-width: 1rem;  
121 -}  
122 -.fr-container .bw5 {  
123 - border-width: 2rem;  
124 -}  
125 -.fr-container .bt-0 {  
126 - border-top-width: 0;  
127 -}  
128 -.fr-container .br-0 {  
129 - border-right-width: 0;  
130 -}  
131 -.fr-container .bb-0 {  
132 - border-bottom-width: 0;  
133 -}  
134 -.fr-container .bl-0 {  
135 - border-left-width: 0;  
136 -}  
137 -.fr-container .shadow-1 {  
138 - box-shadow: 0 0 4px 2px rgba(0, 0, 0, 0.2);  
139 -}  
140 -.fr-container .shadow-2 {  
141 - box-shadow: 0 0 8px 2px rgba(0, 0, 0, 0.2);  
142 -}  
143 -.fr-container .shadow-3 {  
144 - box-shadow: 2px 2px 4px 2px rgba(0, 0, 0, 0.2);  
145 -}  
146 -.fr-container .shadow-4 {  
147 - box-shadow: 2px 2px 8px 0 rgba(0, 0, 0, 0.2);  
148 -}  
149 -.fr-container .shadow-5 {  
150 - box-shadow: 4px 4px 8px 0 rgba(0, 0, 0, 0.2);  
151 -}  
152 -.fr-container .top-0 {  
153 - top: 0;  
154 -}  
155 -.fr-container .right-0 {  
156 - right: 0;  
157 -}  
158 -.fr-container .bottom-0 {  
159 - bottom: 0;  
160 -}  
161 -.fr-container .left-0 {  
162 - left: 0;  
163 -}  
164 -.fr-container .top-1 {  
165 - top: 1rem;  
166 -}  
167 -.fr-container .right-1 {  
168 - right: 1rem;  
169 -}  
170 -.fr-container .bottom-1 {  
171 - bottom: 1rem;  
172 -}  
173 -.fr-container .left-1 {  
174 - left: 1rem;  
175 -}  
176 -.fr-container .top-2 {  
177 - top: 2rem;  
178 -}  
179 -.fr-container .right-2 {  
180 - right: 2rem;  
181 -}  
182 -.fr-container .bottom-2 {  
183 - bottom: 2rem;  
184 -}  
185 -.fr-container .left-2 {  
186 - left: 2rem;  
187 -}  
188 -.fr-container .top--1 {  
189 - top: -1rem;  
190 -}  
191 -.fr-container .right--1 {  
192 - right: -1rem;  
193 -}  
194 -.fr-container .bottom--1 {  
195 - bottom: -1rem;  
196 -}  
197 -.fr-container .left--1 {  
198 - left: -1rem;  
199 -}  
200 -.fr-container .top--2 {  
201 - top: -2rem;  
202 -}  
203 -.fr-container .right--2 {  
204 - right: -2rem;  
205 -}  
206 -.fr-container .bottom--2 {  
207 - bottom: -2rem;  
208 -}  
209 -.fr-container .left--2 {  
210 - left: -2rem;  
211 -}  
212 -.fr-container .absolute--fill {  
213 - top: 0;  
214 - right: 0;  
215 - bottom: 0;  
216 - left: 0;  
217 -}  
218 -.fr-container .dn {  
219 - display: none;  
220 -}  
221 -.fr-container .di {  
222 - display: inline;  
223 -}  
224 -.fr-container .db {  
225 - display: block;  
226 -}  
227 -.fr-container .dib {  
228 - display: inline-block;  
229 -}  
230 -.fr-container .dit {  
231 - display: inline-table;  
232 -}  
233 -.fr-container .dt {  
234 - display: table;  
235 -}  
236 -.fr-container .dtc {  
237 - display: table-cell;  
238 -}  
239 -.fr-container .dt-row {  
240 - display: table-row;  
241 -}  
242 -.fr-container .dt-row-group {  
243 - display: table-row-group;  
244 -}  
245 -.fr-container .dt-column {  
246 - display: table-column;  
247 -}  
248 -.fr-container .dt-column-group {  
249 - display: table-column-group;  
250 -}  
251 -.fr-container .dt--fixed {  
252 - table-layout: fixed;  
253 - width: 100%;  
254 -}  
255 -.fr-container .flex {  
256 - display: flex;  
257 -}  
258 -.fr-container .inline-flex {  
259 - display: inline-flex;  
260 -}  
261 -.fr-container .flex-auto {  
262 - flex: 1 1 auto;  
263 - min-width: 0;  
264 - /* 1 */  
265 - min-height: 0;  
266 - /* 1 */  
267 -}  
268 -.fr-container .flex-none {  
269 - flex: none;  
270 -}  
271 -.fr-container .flex-column {  
272 - flex-direction: column;  
273 -}  
274 -.fr-container .flex-row {  
275 - flex-direction: row;  
276 -}  
277 -.fr-container .flex-wrap {  
278 - flex-wrap: wrap;  
279 -}  
280 -.fr-container .flex-nowrap {  
281 - flex-wrap: nowrap;  
282 -}  
283 -.fr-container .flex-wrap-reverse {  
284 - flex-wrap: wrap-reverse;  
285 -}  
286 -.fr-container .flex-column-reverse {  
287 - flex-direction: column-reverse;  
288 -}  
289 -.fr-container .flex-row-reverse {  
290 - flex-direction: row-reverse;  
291 -}  
292 -.fr-container .items-start {  
293 - align-items: flex-start;  
294 -}  
295 -.fr-container .items-end {  
296 - align-items: flex-end;  
297 -}  
298 -.fr-container .items-center {  
299 - align-items: center;  
300 -}  
301 -.fr-container .items-baseline {  
302 - align-items: baseline;  
303 -}  
304 -.fr-container .items-stretch {  
305 - align-items: stretch;  
306 -}  
307 -.fr-container .self-start {  
308 - align-self: flex-start;  
309 -}  
310 -.fr-container .self-end {  
311 - align-self: flex-end;  
312 -}  
313 -.fr-container .self-center {  
314 - align-self: center;  
315 -}  
316 -.fr-container .self-baseline {  
317 - align-self: baseline;  
318 -}  
319 -.fr-container .self-stretch {  
320 - align-self: stretch;  
321 -}  
322 -.fr-container .justify-start {  
323 - justify-content: flex-start;  
324 -}  
325 -.fr-container .justify-end {  
326 - justify-content: flex-end;  
327 -}  
328 -.fr-container .justify-center {  
329 - justify-content: center;  
330 -}  
331 -.fr-container .justify-between {  
332 - justify-content: space-between;  
333 -}  
334 -.fr-container .justify-around {  
335 - justify-content: space-around;  
336 -}  
337 -.fr-container .content-start {  
338 - align-content: flex-start;  
339 -}  
340 -.fr-container .content-end {  
341 - align-content: flex-end;  
342 -}  
343 -.fr-container .content-center {  
344 - align-content: center;  
345 -}  
346 -.fr-container .content-between {  
347 - align-content: space-between;  
348 -}  
349 -.fr-container .content-around {  
350 - align-content: space-around;  
351 -}  
352 -.fr-container .content-stretch {  
353 - align-content: stretch;  
354 -}  
355 -.fr-container .order-0 {  
356 - order: 0;  
357 -}  
358 -.fr-container .order-1 {  
359 - order: 1;  
360 -}  
361 -.fr-container .order-2 {  
362 - order: 2;  
363 -}  
364 -.fr-container .order-3 {  
365 - order: 3;  
366 -}  
367 -.fr-container .order-4 {  
368 - order: 4;  
369 -}  
370 -.fr-container .order-5 {  
371 - order: 5;  
372 -}  
373 -.fr-container .order-6 {  
374 - order: 6;  
375 -}  
376 -.fr-container .order-7 {  
377 - order: 7;  
378 -}  
379 -.fr-container .order-8 {  
380 - order: 8;  
381 -}  
382 -.fr-container .order-last {  
383 - order: 99999;  
384 -}  
385 -.fr-container .flex-grow-0 {  
386 - flex-grow: 0;  
387 -}  
388 -.fr-container .flex-grow-1 {  
389 - flex-grow: 1;  
390 -}  
391 -.fr-container .flex-shrink-0 {  
392 - flex-shrink: 0;  
393 -}  
394 -.fr-container .flex-shrink-1 {  
395 - flex-shrink: 1;  
396 -}  
397 -.fr-container .fw1 {  
398 - font-weight: 100;  
399 -}  
400 -.fr-container .fw2 {  
401 - font-weight: 200;  
402 -}  
403 -.fr-container .fw3 {  
404 - font-weight: 300;  
405 -}  
406 -.fr-container .fw4 {  
407 - font-weight: 400;  
408 -}  
409 -.fr-container .fw5 {  
410 - font-weight: 500;  
411 -}  
412 -.fr-container .fw6 {  
413 - font-weight: 600;  
414 -}  
415 -.fr-container .fw7 {  
416 - font-weight: 700;  
417 -}  
418 -.fr-container .fw8 {  
419 - font-weight: 800;  
420 -}  
421 -.fr-container .fw9 {  
422 - font-weight: 900;  
423 -}  
424 -.fr-container .h1 {  
425 - height: 1rem;  
426 -}  
427 -.fr-container .h2 {  
428 - height: 2rem;  
429 -}  
430 -.fr-container .h3 {  
431 - height: 4rem;  
432 -}  
433 -.fr-container .h4 {  
434 - height: 8rem;  
435 -}  
436 -.fr-container .h5 {  
437 - height: 16rem;  
438 -}  
439 -.fr-container .h-25 {  
440 - height: 25%;  
441 -}  
442 -.fr-container .h-50 {  
443 - height: 50%;  
444 -}  
445 -.fr-container .h-75 {  
446 - height: 75%;  
447 -}  
448 -.fr-container .h-100 {  
449 - height: 100%;  
450 -}  
451 -.fr-container .min-h-100 {  
452 - min-height: 100%;  
453 -}  
454 -.fr-container .vh-25 {  
455 - height: 25vh;  
456 -}  
457 -.fr-container .vh-50 {  
458 - height: 50vh;  
459 -}  
460 -.fr-container .vh-75 {  
461 - height: 75vh;  
462 -}  
463 -.fr-container .vh-100 {  
464 - height: 100vh;  
465 -}  
466 -.fr-container .min-vh-100 {  
467 - min-height: 100vh;  
468 -}  
469 -.fr-container .h-auto {  
470 - height: auto;  
471 -}  
472 -.fr-container .h-inherit {  
473 - height: inherit;  
474 -}  
475 -.fr-container .tracked {  
476 - letter-spacing: 0.1em;  
477 -}  
478 -.fr-container .tracked-tight {  
479 - letter-spacing: -0.05em;  
480 -}  
481 -.fr-container .tracked-mega {  
482 - letter-spacing: 0.25em;  
483 -}  
484 -.fr-container .lh-solid {  
485 - line-height: 1;  
486 -}  
487 -.fr-container .lh-title {  
488 - line-height: 1.25;  
489 -}  
490 -.fr-container .lh-copy {  
491 - line-height: 1.5;  
492 -}  
493 -.fr-container .mw-100 {  
494 - max-width: 100%;  
495 -}  
496 -.fr-container .mw1 {  
497 - max-width: 1rem;  
498 -}  
499 -.fr-container .mw2 {  
500 - max-width: 2rem;  
501 -}  
502 -.fr-container .mw3 {  
503 - max-width: 4rem;  
504 -}  
505 -.fr-container .mw4 {  
506 - max-width: 8rem;  
507 -}  
508 -.fr-container .mw5 {  
509 - max-width: 16rem;  
510 -}  
511 -.fr-container .mw6 {  
512 - max-width: 32rem;  
513 -}  
514 -.fr-container .mw7 {  
515 - max-width: 48rem;  
516 -}  
517 -.fr-container .mw8 {  
518 - max-width: 64rem;  
519 -}  
520 -.fr-container .mw9 {  
521 - max-width: 96rem;  
522 -}  
523 -.fr-container .mw-none {  
524 - max-width: none;  
525 -}  
526 -.fr-container .w1 {  
527 - width: 1rem;  
528 -}  
529 -.fr-container .w2 {  
530 - width: 2rem;  
531 -}  
532 -.fr-container .w3 {  
533 - width: 4rem;  
534 -}  
535 -.fr-container .w4 {  
536 - width: 8rem;  
537 -}  
538 -.fr-container .w5 {  
539 - width: 16rem;  
540 -}  
541 -.fr-container .w-10 {  
542 - width: 10%;  
543 -}  
544 -.fr-container .w-20 {  
545 - width: 20%;  
546 -}  
547 -.fr-container .w-25 {  
548 - width: 25%;  
549 -}  
550 -.fr-container .w-30 {  
551 - width: 30%;  
552 -}  
553 -.fr-container .w-33 {  
554 - width: 33%;  
555 -}  
556 -.fr-container .w-34 {  
557 - width: 34%;  
558 -}  
559 -.fr-container .w-40 {  
560 - width: 40%;  
561 -}  
562 -.fr-container .w-50 {  
563 - width: 50%;  
564 -}  
565 -.fr-container .w-60 {  
566 - width: 60%;  
567 -}  
568 -.fr-container .w-70 {  
569 - width: 70%;  
570 -}  
571 -.fr-container .w-75 {  
572 - width: 75%;  
573 -}  
574 -.fr-container .w-80 {  
575 - width: 80%;  
576 -}  
577 -.fr-container .w-90 {  
578 - width: 90%;  
579 -}  
580 -.fr-container .w-100 {  
581 - width: 100%;  
582 -}  
583 -.fr-container .w-third {  
584 - width: calc(100% / 3);  
585 -}  
586 -.fr-container .w-two-thirds {  
587 - width: calc(100% / 1.5);  
588 -}  
589 -.fr-container .w-auto {  
590 - width: auto;  
591 -}  
592 -.fr-container .tl {  
593 - text-align: left;  
594 -}  
595 -.fr-container .tr {  
596 - text-align: right;  
597 -}  
598 -.fr-container .tc {  
599 - text-align: center;  
600 -}  
601 -.fr-container .tj {  
602 - text-align: justify;  
603 -}  
604 -.fr-container .overflow-visible {  
605 - overflow: visible;  
606 -}  
607 -.fr-container .overflow-hidden {  
608 - overflow: hidden;  
609 -}  
610 -.fr-container .overflow-scroll {  
611 - overflow: scroll;  
612 -}  
613 -.fr-container .overflow-auto {  
614 - overflow: auto;  
615 -}  
616 -.fr-container .overflow-x-visible {  
617 - overflow-x: visible;  
618 -}  
619 -.fr-container .overflow-x-hidden {  
620 - overflow-x: hidden;  
621 -}  
622 -.fr-container .overflow-x-scroll {  
623 - overflow-x: scroll;  
624 -}  
625 -.fr-container .overflow-x-auto {  
626 - overflow-x: auto;  
627 -}  
628 -.fr-container .overflow-y-visible {  
629 - overflow-y: visible;  
630 -}  
631 -.fr-container .overflow-y-hidden {  
632 - overflow-y: hidden;  
633 -}  
634 -.fr-container .overflow-y-scroll {  
635 - overflow-y: scroll;  
636 -}  
637 -.fr-container .overflow-y-auto {  
638 - overflow-y: auto;  
639 -}  
640 -.fr-container .static {  
641 - position: static;  
642 -}  
643 -.fr-container .relative {  
644 - position: relative;  
645 -}  
646 -.fr-container .absolute {  
647 - position: absolute;  
648 -}  
649 -.fr-container .fixed {  
650 - position: fixed;  
651 -}  
652 -.fr-container .o-100 {  
653 - opacity: 1;  
654 -}  
655 -.fr-container .o-90 {  
656 - opacity: 0.9;  
657 -}  
658 -.fr-container .o-80 {  
659 - opacity: 0.8;  
660 -}  
661 -.fr-container .o-70 {  
662 - opacity: 0.7;  
663 -}  
664 -.fr-container .o-60 {  
665 - opacity: 0.6;  
666 -}  
667 -.fr-container .o-50 {  
668 - opacity: 0.5;  
669 -}  
670 -.fr-container .o-40 {  
671 - opacity: 0.4;  
672 -}  
673 -.fr-container .o-30 {  
674 - opacity: 0.3;  
675 -}  
676 -.fr-container .o-20 {  
677 - opacity: 0.2;  
678 -}  
679 -.fr-container .o-10 {  
680 - opacity: 0.1;  
681 -}  
682 -.fr-container .o-05 {  
683 - opacity: 0.05;  
684 -}  
685 -.fr-container .o-025 {  
686 - opacity: 0.025;  
687 -}  
688 -.fr-container .o-0 {  
689 - opacity: 0;  
690 -}  
691 -.fr-container .pa0 {  
692 - padding: 0;  
693 -}  
694 -.fr-container .pa1 {  
695 - padding: 0.25rem;  
696 -}  
697 -.fr-container .pa2 {  
698 - padding: 0.5rem;  
699 -}  
700 -.fr-container .pa3 {  
701 - padding: 1rem;  
702 -}  
703 -.fr-container .pa4 {  
704 - padding: 2rem;  
705 -}  
706 -.fr-container .pa5 {  
707 - padding: 4rem;  
708 -}  
709 -.fr-container .pa6 {  
710 - padding: 8rem;  
711 -}  
712 -.fr-container .pa7 {  
713 - padding: 16rem;  
714 -}  
715 -.fr-container .pl0 {  
716 - padding-left: 0;  
717 -}  
718 -.fr-container .pl1 {  
719 - padding-left: 0.25rem;  
720 -}  
721 -.fr-container .pl2 {  
722 - padding-left: 0.5rem;  
723 -}  
724 -.fr-container .pl3 {  
725 - padding-left: 1rem;  
726 -}  
727 -.fr-container .pl4 {  
728 - padding-left: 2rem;  
729 -}  
730 -.fr-container .pl5 {  
731 - padding-left: 4rem;  
732 -}  
733 -.fr-container .pl6 {  
734 - padding-left: 8rem;  
735 -}  
736 -.fr-container .pl7 {  
737 - padding-left: 16rem;  
738 -}  
739 -.fr-container .pr0 {  
740 - padding-right: 0;  
741 -}  
742 -.fr-container .pr1 {  
743 - padding-right: 0.25rem;  
744 -}  
745 -.fr-container .pr2 {  
746 - padding-right: 0.5rem;  
747 -}  
748 -.fr-container .pr3 {  
749 - padding-right: 1rem;  
750 -}  
751 -.fr-container .pr4 {  
752 - padding-right: 2rem;  
753 -}  
754 -.fr-container .pr5 {  
755 - padding-right: 4rem;  
756 -}  
757 -.fr-container .pr6 {  
758 - padding-right: 8rem;  
759 -}  
760 -.fr-container .pr7 {  
761 - padding-right: 16rem;  
762 -}  
763 -.fr-container .pb0 {  
764 - padding-bottom: 0;  
765 -}  
766 -.fr-container .pb1 {  
767 - padding-bottom: 0.25rem;  
768 -}  
769 -.fr-container .pb2 {  
770 - padding-bottom: 0.5rem;  
771 -}  
772 -.fr-container .pb3 {  
773 - padding-bottom: 1rem;  
774 -}  
775 -.fr-container .pb4 {  
776 - padding-bottom: 2rem;  
777 -}  
778 -.fr-container .pb5 {  
779 - padding-bottom: 4rem;  
780 -}  
781 -.fr-container .pb6 {  
782 - padding-bottom: 8rem;  
783 -}  
784 -.fr-container .pb7 {  
785 - padding-bottom: 16rem;  
786 -}  
787 -.fr-container .pt0 {  
788 - padding-top: 0;  
789 -}  
790 -.fr-container .pt1 {  
791 - padding-top: 0.25rem;  
792 -}  
793 -.fr-container .pt2 {  
794 - padding-top: 0.5rem;  
795 -}  
796 -.fr-container .pt3 {  
797 - padding-top: 1rem;  
798 -}  
799 -.fr-container .pt4 {  
800 - padding-top: 2rem;  
801 -}  
802 -.fr-container .pt5 {  
803 - padding-top: 4rem;  
804 -}  
805 -.fr-container .pt6 {  
806 - padding-top: 8rem;  
807 -}  
808 -.fr-container .pt7 {  
809 - padding-top: 16rem;  
810 -}  
811 -.fr-container .pv0 {  
812 - padding-top: 0;  
813 - padding-bottom: 0;  
814 -}  
815 -.fr-container .pv1 {  
816 - padding-top: 0.25rem;  
817 - padding-bottom: 0.25rem;  
818 -}  
819 -.fr-container .pv2 {  
820 - padding-top: 0.5rem;  
821 - padding-bottom: 0.5rem;  
822 -}  
823 -.fr-container .pv3 {  
824 - padding-top: 1rem;  
825 - padding-bottom: 1rem;  
826 -}  
827 -.fr-container .pv4 {  
828 - padding-top: 2rem;  
829 - padding-bottom: 2rem;  
830 -}  
831 -.fr-container .pv5 {  
832 - padding-top: 4rem;  
833 - padding-bottom: 4rem;  
834 -}  
835 -.fr-container .pv6 {  
836 - padding-top: 8rem;  
837 - padding-bottom: 8rem;  
838 -}  
839 -.fr-container .pv7 {  
840 - padding-top: 16rem;  
841 - padding-bottom: 16rem;  
842 -}  
843 -.fr-container .ph0 {  
844 - padding-left: 0;  
845 - padding-right: 0;  
846 -}  
847 -.fr-container .ph1 {  
848 - padding-left: 0.25rem;  
849 - padding-right: 0.25rem;  
850 -}  
851 -.fr-container .ph2 {  
852 - padding-left: 0.5rem;  
853 - padding-right: 0.5rem;  
854 -}  
855 -.fr-container .ph3 {  
856 - padding-left: 1rem;  
857 - padding-right: 1rem;  
858 -}  
859 -.fr-container .ph4 {  
860 - padding-left: 2rem;  
861 - padding-right: 2rem;  
862 -}  
863 -.fr-container .ph5 {  
864 - padding-left: 4rem;  
865 - padding-right: 4rem;  
866 -}  
867 -.fr-container .ph6 {  
868 - padding-left: 8rem;  
869 - padding-right: 8rem;  
870 -}  
871 -.fr-container .ph7 {  
872 - padding-left: 16rem;  
873 - padding-right: 16rem;  
874 -}  
875 -.fr-container .ma1 {  
876 - margin: 0.25rem;  
877 -}  
878 -.fr-container .ma2 {  
879 - margin: 0.5rem;  
880 -}  
881 -.fr-container .ma3 {  
882 - margin: 1rem;  
883 -}  
884 -.fr-container .ma4 {  
885 - margin: 2rem;  
886 -}  
887 -.fr-container .ma5 {  
888 - margin: 4rem;  
889 -}  
890 -.fr-container .ma6 {  
891 - margin: 8rem;  
892 -}  
893 -.fr-container .ma7 {  
894 - margin: 16rem;  
895 -}  
896 -.fr-container .ma0 {  
897 - margin: 0;  
898 -}  
899 -.fr-container .ml1 {  
900 - margin-left: 0.25rem;  
901 -}  
902 -.fr-container .ml2 {  
903 - margin-left: 0.5rem;  
904 -}  
905 -.fr-container .ml3 {  
906 - margin-left: 1rem;  
907 -}  
908 -.fr-container .ml4 {  
909 - margin-left: 2rem;  
910 -}  
911 -.fr-container .ml5 {  
912 - margin-left: 4rem;  
913 -}  
914 -.fr-container .ml6 {  
915 - margin-left: 8rem;  
916 -}  
917 -.fr-container .ml7 {  
918 - margin-left: 16rem;  
919 -}  
920 -.fr-container .ml0 {  
921 - margin-left: 0;  
922 -}  
923 -.fr-container .mr1 {  
924 - margin-right: 0.25rem;  
925 -}  
926 -.fr-container .mr2 {  
927 - margin-right: 0.5rem;  
928 -}  
929 -.fr-container .mr3 {  
930 - margin-right: 1rem;  
931 -}  
932 -.fr-container .mr4 {  
933 - margin-right: 2rem;  
934 -}  
935 -.fr-container .mr5 {  
936 - margin-right: 4rem;  
937 -}  
938 -.fr-container .mr6 {  
939 - margin-right: 8rem;  
940 -}  
941 -.fr-container .mr7 {  
942 - margin-right: 16rem;  
943 -}  
944 -.fr-container .mr0 {  
945 - margin-right: 0;  
946 -}  
947 -.fr-container .mb1 {  
948 - margin-bottom: 0.25rem;  
949 -}  
950 -.fr-container .mb2 {  
951 - margin-bottom: 0.5rem;  
952 -}  
953 -.fr-container .mb3 {  
954 - margin-bottom: 1rem;  
955 -}  
956 -.fr-container .mb4 {  
957 - margin-bottom: 2rem;  
958 -}  
959 -.fr-container .mb5 {  
960 - margin-bottom: 4rem;  
961 -}  
962 -.fr-container .mb6 {  
963 - margin-bottom: 8rem;  
964 -}  
965 -.fr-container .mb7 {  
966 - margin-bottom: 16rem;  
967 -}  
968 -.fr-container .mb0 {  
969 - margin-bottom: 0;  
970 -}  
971 -.fr-container .mt1 {  
972 - margin-top: 0.25rem;  
973 -}  
974 -.fr-container .mt2 {  
975 - margin-top: 0.5rem;  
976 -}  
977 -.fr-container .mt3 {  
978 - margin-top: 1rem;  
979 -}  
980 -.fr-container .mt4 {  
981 - margin-top: 2rem;  
982 -}  
983 -.fr-container .mt5 {  
984 - margin-top: 4rem;  
985 -}  
986 -.fr-container .mt6 {  
987 - margin-top: 8rem;  
988 -}  
989 -.fr-container .mt7 {  
990 - margin-top: 16rem;  
991 -}  
992 -.fr-container .mt0 {  
993 - margin-top: 0;  
994 -}  
995 -.fr-container .mv1 {  
996 - margin-top: 0.25rem;  
997 - margin-bottom: 0.25rem;  
998 -}  
999 -.fr-container .mv2 {  
1000 - margin-top: 0.5rem;  
1001 - margin-bottom: 0.5rem;  
1002 -}  
1003 -.fr-container .mv3 {  
1004 - margin-top: 1rem;  
1005 - margin-bottom: 1rem;  
1006 -}  
1007 -.fr-container .mv4 {  
1008 - margin-top: 2rem;  
1009 - margin-bottom: 2rem;  
1010 -}  
1011 -.fr-container .mv5 {  
1012 - margin-top: 4rem;  
1013 - margin-bottom: 4rem;  
1014 -}  
1015 -.fr-container .mv6 {  
1016 - margin-top: 8rem;  
1017 - margin-bottom: 8rem;  
1018 -}  
1019 -.fr-container .mv7 {  
1020 - margin-top: 16rem;  
1021 - margin-bottom: 16rem;  
1022 -}  
1023 -.fr-container .mv0 {  
1024 - margin-top: 0;  
1025 - margin-bottom: 0;  
1026 -}  
1027 -.fr-container .mh1 {  
1028 - margin-left: 0.25rem;  
1029 - margin-right: 0.25rem;  
1030 -}  
1031 -.fr-container .mh2 {  
1032 - margin-left: 0.5rem;  
1033 - margin-right: 0.5rem;  
1034 -}  
1035 -.fr-container .mh3 {  
1036 - margin-left: 1rem;  
1037 - margin-right: 1rem;  
1038 -}  
1039 -.fr-container .mh4 {  
1040 - margin-left: 2rem;  
1041 - margin-right: 2rem;  
1042 -}  
1043 -.fr-container .mh5 {  
1044 - margin-left: 4rem;  
1045 - margin-right: 4rem;  
1046 -}  
1047 -.fr-container .mh6 {  
1048 - margin-left: 8rem;  
1049 - margin-right: 8rem;  
1050 -}  
1051 -.fr-container .mh7 {  
1052 - margin-left: 16rem;  
1053 - margin-right: 16rem;  
1054 -}  
1055 -.fr-container .mh0 {  
1056 - margin-left: 0;  
1057 - margin-right: 0;  
1058 -}  
1059 -.fr-container .debug * {  
1060 - outline: 1px solid gold;  
1061 -}  
1062 -.fr-container .debug-white * {  
1063 - outline: 1px solid white;  
1064 -}  
1065 -.fr-container .debug-black * {  
1066 - outline: 1px solid black;  
1067 -}  
1068 -.fr-container .debug-grid {  
1069 - background: transparent url( ) repeat top left;  
1070 -}  
1071 -.fr-container .truncate {  
1072 - white-space: nowrap;  
1073 - overflow: hidden;  
1074 - text-overflow: ellipsis;  
1075 -}  
1076 -.fr-container .bg-white {  
1077 - background-color: #fff;  
1078 -}  
1079 -.fr-container .pointer:hover {  
1080 - cursor: pointer;  
1081 -}  
1082 -.fr-container .link {  
1083 - color: #1890ff;  
1084 - font-size: 14px;  
1085 -}  
1086 -.fr-container .link:hover {  
1087 - color: #40a9ff;  
1088 - font-size: 14px;  
1089 -}  
1 -function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }  
2 -  
3 -import React, { forwardRef } from 'react';  
4 -import useForm from './useForm';  
5 -  
6 -var connectForm = function connectForm(Component) {  
7 - return /*#__PURE__*/forwardRef(function (props, ref) {  
8 - var form = useForm();  
9 - return /*#__PURE__*/React.createElement(Component, _extends({  
10 - ref: ref  
11 - }, props, {  
12 - form: form  
13 - }));  
14 - });  
15 -};  
16 -  
17 -export default connectForm;  
1 -import "antd/es/button/style";  
2 -import _Button from "antd/es/button";  
3 -import "antd/es/space/style";  
4 -import _Space from "antd/es/space";  
5 -import _ArrowDownOutlined from "@ant-design/icons/es/icons/ArrowDownOutlined";  
6 -import _ArrowUpOutlined from "@ant-design/icons/es/icons/ArrowUpOutlined";  
7 -import _CopyOutlined from "@ant-design/icons/es/icons/CopyOutlined";  
8 -import "antd/es/popconfirm/style";  
9 -import _Popconfirm from "antd/es/popconfirm";  
10 -import _DeleteOutlined from "@ant-design/icons/es/icons/DeleteOutlined";  
11 -  
12 -function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }  
13 -  
14 -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }  
15 -  
16 -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }  
17 -  
18 -function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }  
19 -  
20 -function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }  
21 -  
22 -/* eslint-disable jsx-a11y/anchor-is-valid */  
23 -import React from 'react';  
24 -import Core from '../../index';  
25 -  
26 -var CardList = function CardList(_ref) {  
27 - var _ref$displayList = _ref.displayList,  
28 - displayList = _ref$displayList === void 0 ? [] : _ref$displayList,  
29 - listData = _ref.listData,  
30 - changeList = _ref.changeList,  
31 - schema = _ref.schema,  
32 - deleteItem = _ref.deleteItem,  
33 - copyItem = _ref.copyItem,  
34 - addItem = _ref.addItem,  
35 - moveItemUp = _ref.moveItemUp,  
36 - moveItemDown = _ref.moveItemDown,  
37 - displayType = _ref.displayType,  
38 - getFieldsProps = _ref.getFieldsProps;  
39 - var _schema$props = schema.props,  
40 - props = _schema$props === void 0 ? {} : _schema$props,  
41 - itemProps = schema.itemProps;  
42 - var addBtnProps = {  
43 - type: 'dashed',  
44 - children: '新增一条'  
45 - };  
46 -  
47 - if (props.addBtnProps && _typeof(props.addBtnProps) === 'object') {  
48 - addBtnProps = _objectSpread(_objectSpread({}, addBtnProps), props.addBtnProps);  
49 - }  
50 -  
51 - return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("div", {  
52 - className: "fr-card-list"  
53 - }, displayList.map(function (item, idx) {  
54 - var fieldsProps = getFieldsProps(idx);  
55 - fieldsProps.displayType = displayType;  
56 - return /*#__PURE__*/React.createElement("div", {  
57 - className: "fr-card-item ".concat(displayType === 'row' ? 'fr-card-item-row' : ''),  
58 - key: idx  
59 - }, /*#__PURE__*/React.createElement("div", {  
60 - className: "fr-card-index"  
61 - }, idx + 1), /*#__PURE__*/React.createElement(Core, fieldsProps), /*#__PURE__*/React.createElement(_Space, {  
62 - direction: "horizontal",  
63 - className: "fr-card-toolbar"  
64 - }, !props.hideDelete && /*#__PURE__*/React.createElement(_Popconfirm, {  
65 - title: "\u786E\u5B9A\u5220\u9664?",  
66 - onConfirm: function onConfirm() {  
67 - return deleteItem(idx);  
68 - },  
69 - okText: "\u786E\u5B9A",  
70 - cancelText: "\u53D6\u6D88"  
71 - }, /*#__PURE__*/React.createElement(_DeleteOutlined, {  
72 - style: {  
73 - fontSize: 17,  
74 - marginLeft: 8  
75 - }  
76 - })), !props.hideAdd && !props.hideCopy && /*#__PURE__*/React.createElement(_CopyOutlined, {  
77 - style: {  
78 - fontSize: 16,  
79 - marginLeft: 8  
80 - },  
81 - onClick: function onClick() {  
82 - return copyItem(idx);  
83 - }  
84 - }), !props.hideMove && /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(_ArrowUpOutlined, {  
85 - style: {  
86 - fontSize: 16,  
87 - marginLeft: 4  
88 - },  
89 - onClick: function onClick() {  
90 - return moveItemUp(idx);  
91 - }  
92 - }), /*#__PURE__*/React.createElement(_ArrowDownOutlined, {  
93 - style: {  
94 - fontSize: 16,  
95 - marginLeft: 4  
96 - },  
97 - onClick: function onClick() {  
98 - return moveItemDown(idx);  
99 - }  
100 - }))));  
101 - })), /*#__PURE__*/React.createElement("div", {  
102 - style: {  
103 - marginTop: displayList.length > 0 ? 0 : 8  
104 - }  
105 - }, !props.hideAdd && /*#__PURE__*/React.createElement(_Button, _extends({  
106 - onClick: addItem  
107 - }, addBtnProps)), Array.isArray(props.buttons) ? props.buttons.map(function (item, idx) {  
108 - var callback = item.callback,  
109 - text = item.text,  
110 - html = item.html;  
111 -  
112 - var onClick = function onClick() {  
113 - console.log({  
114 - value: listData,  
115 - onChange: changeList,  
116 - schema: schema  
117 - });  
118 - };  
119 -  
120 - if (typeof window[callback] === 'function') {  
121 - onClick = function onClick() {  
122 - window[callback]({  
123 - value: listData,  
124 - onChange: changeList,  
125 - schema: schema  
126 - });  
127 - };  
128 - }  
129 -  
130 - return /*#__PURE__*/React.createElement(_Button, {  
131 - key: idx.toString(),  
132 - style: {  
133 - marginLeft: 8  
134 - },  
135 - type: "dashed",  
136 - onClick: onClick  
137 - }, /*#__PURE__*/React.createElement("span", {  
138 - dangerouslySetInnerHTML: {  
139 - __html: html || text  
140 - }  
141 - }));  
142 - }) : null));  
143 -};  
144 -  
145 -export default CardList;  
1 -import "antd/es/table/style";  
2 -import _Table from "antd/es/table";  
3 -import "antd/es/drawer/style";  
4 -import _Drawer from "antd/es/drawer";  
5 -import "antd/es/button/style";  
6 -import _Button from "antd/es/button";  
7 -import "antd/es/space/style";  
8 -import _Space from "antd/es/space";  
9 -import _ArrowDownOutlined from "@ant-design/icons/es/icons/ArrowDownOutlined";  
10 -import _ArrowUpOutlined from "@ant-design/icons/es/icons/ArrowUpOutlined";  
11 -import "antd/es/popconfirm/style";  
12 -import _Popconfirm from "antd/es/popconfirm";  
13 -var _excluded = ["buttons"],  
14 - _excluded2 = ["pagination"];  
15 -  
16 -function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }  
17 -  
18 -function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }  
19 -  
20 -function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }  
21 -  
22 -function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }  
23 -  
24 -function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }  
25 -  
26 -function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }  
27 -  
28 -function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }  
29 -  
30 -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }  
31 -  
32 -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }  
33 -  
34 -function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }  
35 -  
36 -function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }  
37 -  
38 -function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }  
39 -  
40 -/* eslint-disable jsx-a11y/anchor-is-valid */  
41 -import React, { useRef } from 'react';  
42 -import Core from '../../index';  
43 -import { useSet } from '../../../hooks';  
44 -import { getDataPath, getKeyFromPath, getDisplayValue } from '../../../utils';  
45 -import ErrorMessage from '../../RenderField/ErrorMessage';  
46 -var FIELD_LENGTH = 170;  
47 -  
48 -var DrawerList = function DrawerList(_ref) {  
49 - var _extends2;  
50 -  
51 - var _ref$displayList = _ref.displayList,  
52 - displayList = _ref$displayList === void 0 ? [] : _ref$displayList,  
53 - dataPath = _ref.dataPath,  
54 - children = _ref.children,  
55 - deleteItem = _ref.deleteItem,  
56 - addItem = _ref.addItem,  
57 - moveItemDown = _ref.moveItemDown,  
58 - moveItemUp = _ref.moveItemUp,  
59 - flatten = _ref.flatten,  
60 - errorFields = _ref.errorFields,  
61 - getFieldsProps = _ref.getFieldsProps,  
62 - schema = _ref.schema,  
63 - changeList = _ref.changeList,  
64 - listData = _ref.listData;  
65 - var _schema$props = schema.props,  
66 - props = _schema$props === void 0 ? {} : _schema$props,  
67 - _schema$itemProps = schema.itemProps,  
68 - itemProps = _schema$itemProps === void 0 ? {} : _schema$itemProps;  
69 -  
70 - var buttons = itemProps.buttons,  
71 - columnProps = _objectWithoutProperties(itemProps, _excluded);  
72 -  
73 - var _props$pagination = props.pagination,  
74 - pagination = _props$pagination === void 0 ? {} : _props$pagination,  
75 - rest = _objectWithoutProperties(props, _excluded2);  
76 -  
77 - var paginationConfig = pagination && _objectSpread({  
78 - size: 'small',  
79 - hideOnSinglePage: true  
80 - }, pagination);  
81 -  
82 - var currentIndex = useRef(-1);  
83 -  
84 - var _useSet = useSet({  
85 - showDrawer: false  
86 - }),  
87 - _useSet2 = _slicedToArray(_useSet, 2),  
88 - state = _useSet2[0],  
89 - setState = _useSet2[1];  
90 -  
91 - var showDrawer = state.showDrawer;  
92 - var dataSource = displayList.map(function (item, index) {  
93 - return _objectSpread(_objectSpread({}, item), {}, {  
94 - $idx: index  
95 - });  
96 - });  
97 - var columns = children.map(function (child) {  
98 - var item = flatten[child];  
99 - var schema = item && item.schema || {};  
100 -  
101 - var _dataIndex = getKeyFromPath(child);  
102 -  
103 - return _objectSpread({  
104 - dataIndex: _dataIndex,  
105 - title: schema.required ? /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("span", {  
106 - className: "fr-label-required"  
107 - }, " *"), /*#__PURE__*/React.createElement("span", null, schema.title)) : schema.title,  
108 - width: FIELD_LENGTH,  
109 - render: function render(value, record) {  
110 - var childPath = getDataPath(child, [record.$idx]);  
111 - var errorObj = errorFields.find(function (item) {  
112 - return item.name == childPath;  
113 - }) || {}; //TODO: 万一error在更深的层,这个办法是find不到的,会展示那一行没有提示。可以整一行加一个红线的方式处理  
114 -  
115 - return /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement("div", null, getDisplayValue(value, schema)), errorObj.error && /*#__PURE__*/React.createElement(ErrorMessage, {  
116 - message: errorObj.error,  
117 - schema: schema  
118 - }));  
119 - }  
120 - }, columnProps);  
121 - });  
122 - columns.push({  
123 - title: '操作',  
124 - key: '$action',  
125 - fixed: 'right',  
126 - width: 120,  
127 - render: function render(value, record, idx) {  
128 - var index = value && value.$idx || 0;  
129 - return /*#__PURE__*/React.createElement(_Space, null, /*#__PURE__*/React.createElement("a", {  
130 - onClick: function onClick() {  
131 - return openDrawer(index);  
132 - }  
133 - }, "\u7F16\u8F91"), !props.hideDelete && /*#__PURE__*/React.createElement(_Popconfirm, {  
134 - title: "\u786E\u5B9A\u5220\u9664?",  
135 - onConfirm: function onConfirm() {  
136 - return deleteItem(index);  
137 - },  
138 - okText: "\u786E\u5B9A",  
139 - cancelText: "\u53D6\u6D88"  
140 - }, /*#__PURE__*/React.createElement("a", null, "\u5220\u9664")), !props.hideMove && /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(_ArrowUpOutlined, {  
141 - style: {  
142 - color: '#1890ff',  
143 - fontSize: 16,  
144 - marginLeft: 4  
145 - },  
146 - onClick: function onClick() {  
147 - return moveItemUp(idx);  
148 - }  
149 - }), /*#__PURE__*/React.createElement(_ArrowDownOutlined, {  
150 - style: {  
151 - color: '#1890ff',  
152 - fontSize: 16,  
153 - marginLeft: 4  
154 - },  
155 - onClick: function onClick() {  
156 - return moveItemDown(idx);  
157 - }  
158 - })));  
159 - }  
160 - });  
161 - var fieldsProps = getFieldsProps(currentIndex.current);  
162 -  
163 - var openDrawer = function openDrawer(index) {  
164 - currentIndex.current = index;  
165 - setState({  
166 - showDrawer: true  
167 - });  
168 - };  
169 -  
170 - var closeDrawer = function closeDrawer() {  
171 - currentIndex.current = -1;  
172 - setState({  
173 - showDrawer: false  
174 - });  
175 - };  
176 -  
177 - var handleAdd = function handleAdd() {  
178 - var newIndex = addItem();  
179 - openDrawer(newIndex);  
180 - };  
181 -  
182 - return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("div", {  
183 - className: "w-100 mb2 tr"  
184 - }, !props.hideAdd && /*#__PURE__*/React.createElement(_Button, {  
185 - type: "primary",  
186 - size: "small",  
187 - onClick: handleAdd  
188 - }, "\u65B0\u589E"), Array.isArray(props.buttons) ? props.buttons.map(function (item, idx) {  
189 - var callback = item.callback,  
190 - text = item.text,  
191 - html = item.html;  
192 -  
193 - var onClick = function onClick() {  
194 - console.log({  
195 - value: listData,  
196 - onChange: changeList,  
197 - schema: schema  
198 - });  
199 - };  
200 -  
201 - if (typeof window[callback] === 'function') {  
202 - onClick = function onClick() {  
203 - window[callback]({  
204 - value: listData,  
205 - onChange: changeList,  
206 - schema: schema  
207 - });  
208 - };  
209 - }  
210 -  
211 - return /*#__PURE__*/React.createElement(_Button, {  
212 - key: idx.toString(),  
213 - style: {  
214 - marginLeft: 8  
215 - },  
216 - size: "small",  
217 - onClick: onClick  
218 - }, /*#__PURE__*/React.createElement("span", {  
219 - dangerouslySetInnerHTML: {  
220 - __html: html || text  
221 - }  
222 - }));  
223 - }) : null), /*#__PURE__*/React.createElement(_Drawer, {  
224 - width: "600",  
225 - title: "\u7F16\u8F91",  
226 - placement: "right",  
227 - onClose: closeDrawer,  
228 - visible: showDrawer,  
229 - destroyOnClose: true // 必须要加,currentIndex不是一个state,Core不会重新渲染就跪了  
230 -  
231 - }, /*#__PURE__*/React.createElement("div", {  
232 - className: "fr-container"  
233 - }, /*#__PURE__*/React.createElement(Core, fieldsProps))), /*#__PURE__*/React.createElement(_Table, _extends((_extends2 = {  
234 - size: "small",  
235 - scroll: {  
236 - x: 'max-content'  
237 - },  
238 - columns: columns,  
239 - dataSource: dataSource,  
240 - rowClassName: function rowClassName(record, idx) {  
241 - var index = record && record.$idx;  
242 - var hasError = errorFields.find(function (item) {  
243 - return item.name.indexOf("".concat(dataPath, "[").concat(index, "]")) > -1;  
244 - });  
245 - return hasError ? 'fr-row-error' : '';  
246 - },  
247 - rowKey: "$idx"  
248 - }, _defineProperty(_extends2, "size", "small"), _defineProperty(_extends2, "pagination", paginationConfig), _extends2), rest)));  
249 -};  
250 -  
251 -export default DrawerList;  
1 -import "antd/es/button/style";  
2 -import _Button from "antd/es/button";  
3 -import _ArrowDownOutlined from "@ant-design/icons/es/icons/ArrowDownOutlined";  
4 -import _ArrowUpOutlined from "@ant-design/icons/es/icons/ArrowUpOutlined";  
5 -import _CopyOutlined from "@ant-design/icons/es/icons/CopyOutlined";  
6 -import "antd/es/popconfirm/style";  
7 -import _Popconfirm from "antd/es/popconfirm";  
8 -import _DeleteOutlined from "@ant-design/icons/es/icons/DeleteOutlined";  
9 -  
10 -function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }  
11 -  
12 -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }  
13 -  
14 -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }  
15 -  
16 -function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }  
17 -  
18 -function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }  
19 -  
20 -import React from 'react';  
21 -import Core from '../../index';  
22 -  
23 -var SimpleList = function SimpleList(_ref) {  
24 - var schema = _ref.schema,  
25 - _ref$displayList = _ref.displayList,  
26 - displayList = _ref$displayList === void 0 ? [] : _ref$displayList,  
27 - listData = _ref.listData,  
28 - changeList = _ref.changeList,  
29 - deleteItem = _ref.deleteItem,  
30 - addItem = _ref.addItem,  
31 - copyItem = _ref.copyItem,  
32 - moveItemUp = _ref.moveItemUp,  
33 - moveItemDown = _ref.moveItemDown,  
34 - getFieldsProps = _ref.getFieldsProps;  
35 - var _schema$props = schema.props,  
36 - props = _schema$props === void 0 ? {} : _schema$props,  
37 - itemProps = schema.itemProps;  
38 - var addBtnProps = {  
39 - type: 'dashed',  
40 - children: '新增一条'  
41 - };  
42 -  
43 - if (props.addBtnProps && _typeof(props.addBtnProps) === 'object') {  
44 - addBtnProps = _objectSpread(_objectSpread({}, addBtnProps), props.addBtnProps);  
45 - }  
46 -  
47 - return /*#__PURE__*/React.createElement("div", {  
48 - className: "fr-list-1"  
49 - }, displayList.map(function (item, idx) {  
50 - var fieldsProps = getFieldsProps(idx);  
51 - fieldsProps.displayType = 'inline';  
52 -  
53 - if (props.hideTitle) {  
54 - fieldsProps.hideTitle = true;  
55 - }  
56 -  
57 - return /*#__PURE__*/React.createElement("div", {  
58 - key: idx,  
59 - style: {  
60 - display: 'flex'  
61 - }  
62 - }, /*#__PURE__*/React.createElement(Core, fieldsProps), /*#__PURE__*/React.createElement("div", {  
63 - style: {  
64 - marginTop: 6  
65 - }  
66 - }, !props.hideDelete && /*#__PURE__*/React.createElement(_Popconfirm, {  
67 - title: "\u786E\u5B9A\u5220\u9664?",  
68 - onConfirm: function onConfirm() {  
69 - return deleteItem(idx);  
70 - },  
71 - okText: "\u786E\u5B9A",  
72 - cancelText: "\u53D6\u6D88"  
73 - }, /*#__PURE__*/React.createElement(_DeleteOutlined, {  
74 - style: {  
75 - fontSize: 17,  
76 - marginLeft: 8  
77 - }  
78 - })), !props.hideAdd && !props.hideCopy && /*#__PURE__*/React.createElement(_CopyOutlined, {  
79 - style: {  
80 - fontSize: 15,  
81 - marginLeft: 8  
82 - },  
83 - onClick: function onClick() {  
84 - return copyItem(idx);  
85 - }  
86 - }), !props.hideMove && /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(_ArrowUpOutlined, {  
87 - style: {  
88 - fontSize: 16,  
89 - marginLeft: 8  
90 - },  
91 - onClick: function onClick() {  
92 - return moveItemUp(idx);  
93 - }  
94 - }), /*#__PURE__*/React.createElement(_ArrowDownOutlined, {  
95 - style: {  
96 - fontSize: 16,  
97 - marginLeft: 8  
98 - },  
99 - onClick: function onClick() {  
100 - return moveItemDown(idx);  
101 - }  
102 - }))));  
103 - }), /*#__PURE__*/React.createElement("div", {  
104 - style: {  
105 - marginTop: displayList.length > 0 ? 0 : 8  
106 - }  
107 - }, !props.hideAdd && /*#__PURE__*/React.createElement(_Button, _extends({  
108 - onClick: addItem  
109 - }, addBtnProps)), Array.isArray(props.buttons) ? props.buttons.map(function (item, idx) {  
110 - var callback = item.callback,  
111 - text = item.text,  
112 - html = item.html;  
113 -  
114 - var onClick = function onClick() {  
115 - console.log({  
116 - value: listData,  
117 - onChange: changeList,  
118 - schema: schema  
119 - });  
120 - };  
121 -  
122 - if (typeof window[callback] === 'function') {  
123 - onClick = function onClick() {  
124 - window[callback]({  
125 - value: listData,  
126 - onChange: changeList,  
127 - schema: schema  
128 - });  
129 - };  
130 - }  
131 -  
132 - return /*#__PURE__*/React.createElement(_Button, {  
133 - key: idx.toString(),  
134 - style: {  
135 - marginLeft: 8  
136 - },  
137 - type: "dashed",  
138 - onClick: onClick  
139 - }, /*#__PURE__*/React.createElement("span", {  
140 - dangerouslySetInnerHTML: {  
141 - __html: html || text  
142 - }  
143 - }));  
144 - }) : null));  
145 -};  
146 -  
147 -export default SimpleList;  
1 -import "antd/es/table/style";  
2 -import _Table from "antd/es/table";  
3 -import "antd/es/button/style";  
4 -import _Button from "antd/es/button";  
5 -import "antd/es/space/style";  
6 -import _Space from "antd/es/space";  
7 -import _ArrowDownOutlined from "@ant-design/icons/es/icons/ArrowDownOutlined";  
8 -import _ArrowUpOutlined from "@ant-design/icons/es/icons/ArrowUpOutlined";  
9 -import "antd/es/popconfirm/style";  
10 -import _Popconfirm from "antd/es/popconfirm";  
11 -var _excluded = ["buttons"],  
12 - _excluded2 = ["pagination"];  
13 -  
14 -function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }  
15 -  
16 -function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }  
17 -  
18 -function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }  
19 -  
20 -function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }  
21 -  
22 -function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }  
23 -  
24 -function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }  
25 -  
26 -function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }  
27 -  
28 -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }  
29 -  
30 -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }  
31 -  
32 -function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }  
33 -  
34 -function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }  
35 -  
36 -function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }  
37 -  
38 -/* eslint-disable jsx-a11y/anchor-is-valid */  
39 -import React from 'react';  
40 -import Core from '../../index';  
41 -// import ArrowDown from '../../../components/ArrowDown';  
42 -var FIELD_LENGTH = 170;  
43 -  
44 -var TableList = function TableList(_ref) {  
45 - var _ref$displayList = _ref.displayList,  
46 - displayList = _ref$displayList === void 0 ? [] : _ref$displayList,  
47 - dataIndex = _ref.dataIndex,  
48 - children = _ref.children,  
49 - deleteItem = _ref.deleteItem,  
50 - copyItem = _ref.copyItem,  
51 - addItem = _ref.addItem,  
52 - moveItemUp = _ref.moveItemUp,  
53 - moveItemDown = _ref.moveItemDown,  
54 - flatten = _ref.flatten,  
55 - schema = _ref.schema,  
56 - listData = _ref.listData,  
57 - changeList = _ref.changeList;  
58 - var _schema$props = schema.props,  
59 - props = _schema$props === void 0 ? {} : _schema$props,  
60 - _schema$itemProps = schema.itemProps,  
61 - itemProps = _schema$itemProps === void 0 ? {} : _schema$itemProps;  
62 -  
63 - var buttons = itemProps.buttons,  
64 - columnProps = _objectWithoutProperties(itemProps, _excluded);  
65 -  
66 - var _props$pagination = props.pagination,  
67 - pagination = _props$pagination === void 0 ? {} : _props$pagination,  
68 - rest = _objectWithoutProperties(props, _excluded2);  
69 -  
70 - var paginationConfig = pagination && _objectSpread({  
71 - size: 'small',  
72 - hideOnSinglePage: true  
73 - }, pagination);  
74 -  
75 - var dataSource = displayList.map(function (item, idx) {  
76 - return {  
77 - index: idx  
78 - };  
79 - });  
80 - var columns = children.map(function (child) {  
81 - var item = flatten[child];  
82 - var schema = item && item.schema || {};  
83 - return _objectSpread({  
84 - dataIndex: child,  
85 - title: schema.required ? /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("span", {  
86 - className: "fr-label-required"  
87 - }, " *"), /*#__PURE__*/React.createElement("span", null, schema.title)) : schema.title,  
88 - width: FIELD_LENGTH,  
89 - render: function render(value, record, index) {  
90 - // Check: record.index 似乎是antd自己会给的,不错哦  
91 - var childIndex = [].concat(_toConsumableArray(dataIndex), [record.index]);  
92 - return /*#__PURE__*/React.createElement(Core, {  
93 - hideTitle: true,  
94 - displayType: "inline",  
95 - key: index.toString(),  
96 - id: child,  
97 - dataIndex: childIndex  
98 - });  
99 - }  
100 - }, columnProps);  
101 - });  
102 -  
103 - if (!props.hideDelete || !props.hideAdd || !props.hideCopy || !props.hideMove) {  
104 - columns.push({  
105 - title: '操作',  
106 - key: '$action',  
107 - fixed: 'right',  
108 - width: 120,  
109 - render: function render(value, record, idx) {  
110 - return /*#__PURE__*/React.createElement(_Space, null, !props.hideAdd && !props.hideCopy && /*#__PURE__*/React.createElement("a", {  
111 - onClick: function onClick() {  
112 - return copyItem(idx);  
113 - }  
114 - }, "\u590D\u5236"), !props.hideDelete && /*#__PURE__*/React.createElement(_Popconfirm, {  
115 - title: "\u786E\u5B9A\u5220\u9664?",  
116 - onConfirm: function onConfirm() {  
117 - return deleteItem(idx);  
118 - },  
119 - okText: "\u786E\u5B9A",  
120 - cancelText: "\u53D6\u6D88"  
121 - }, /*#__PURE__*/React.createElement("a", null, "\u5220\u9664")), !props.hideMove && /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(_ArrowUpOutlined, {  
122 - style: {  
123 - color: '#1890ff',  
124 - fontSize: 16,  
125 - marginLeft: 4  
126 - },  
127 - onClick: function onClick() {  
128 - return moveItemUp(idx);  
129 - }  
130 - }), /*#__PURE__*/React.createElement(_ArrowDownOutlined, {  
131 - style: {  
132 - color: '#1890ff',  
133 - fontSize: 16,  
134 - marginLeft: 4  
135 - },  
136 - onClick: function onClick() {  
137 - return moveItemDown(idx);  
138 - }  
139 - })));  
140 - }  
141 - });  
142 - }  
143 -  
144 - return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("div", {  
145 - className: "w-100 mb2 tr"  
146 - }, !props.hideAdd && /*#__PURE__*/React.createElement(_Button, {  
147 - type: "primary",  
148 - size: "small",  
149 - onClick: addItem  
150 - }, "\u65B0\u589E"), Array.isArray(props.buttons) ? props.buttons.map(function (item, idx) {  
151 - var callback = item.callback,  
152 - text = item.text,  
153 - html = item.html;  
154 -  
155 - var onClick = function onClick() {  
156 - console.log({  
157 - value: listData,  
158 - onChange: changeList,  
159 - schema: schema  
160 - });  
161 - };  
162 -  
163 - if (typeof window[callback] === 'function') {  
164 - onClick = function onClick() {  
165 - window[callback]({  
166 - value: listData,  
167 - onChange: changeList,  
168 - schema: schema  
169 - });  
170 - };  
171 - }  
172 -  
173 - return /*#__PURE__*/React.createElement(_Button, {  
174 - key: idx.toString(),  
175 - style: {  
176 - marginLeft: 8  
177 - },  
178 - size: "small",  
179 - onClick: onClick  
180 - }, /*#__PURE__*/React.createElement("span", {  
181 - dangerouslySetInnerHTML: {  
182 - __html: html || text  
183 - }  
184 - }));  
185 - }) : null), /*#__PURE__*/React.createElement(_Table, _extends({  
186 - scroll: {  
187 - x: 'max-content'  
188 - },  
189 - columns: columns,  
190 - dataSource: dataSource,  
191 - rowKey: "index",  
192 - size: "small",  
193 - pagination: paginationConfig  
194 - }, rest)));  
195 -};  
196 -  
197 -export default TableList;  
1 -import "antd/es/table/style";  
2 -import _Table from "antd/es/table";  
3 -import "antd/es/alert/style";  
4 -import _Alert from "antd/es/alert";  
5 -import "antd/es/message/style";  
6 -import _message from "antd/es/message";  
7 -import "antd/es/input/style";  
8 -import _Input from "antd/es/input";  
9 -import _SearchOutlined from "@ant-design/icons/es/icons/SearchOutlined";  
10 -import "antd/es/tooltip/style";  
11 -import _Tooltip from "antd/es/tooltip";  
12 -import "antd/es/button/style";  
13 -import _Button from "antd/es/button";  
14 -import _ExclamationCircleOutlined from "@ant-design/icons/es/icons/ExclamationCircleOutlined";  
15 -import _SelectOutlined from "@ant-design/icons/es/icons/SelectOutlined";  
16 -import _ExpandAltOutlined from "@ant-design/icons/es/icons/ExpandAltOutlined";  
17 -import _EditOutlined from "@ant-design/icons/es/icons/EditOutlined";  
18 -import _EyeOutlined from "@ant-design/icons/es/icons/EyeOutlined";  
19 -import _CopyOutlined from "@ant-design/icons/es/icons/CopyOutlined";  
20 -import _PlusOutlined from "@ant-design/icons/es/icons/PlusOutlined";  
21 -import _DeleteOutlined from "@ant-design/icons/es/icons/DeleteOutlined";  
22 -import _ImportOutlined from "@ant-design/icons/es/icons/ImportOutlined";  
23 -import _ExportOutlined from "@ant-design/icons/es/icons/ExportOutlined";  
24 -import "antd/es/modal/style";  
25 -import _Modal from "antd/es/modal";  
26 -var _excluded = ["scrollY", "summary", "batchKey", "bar", "line", "searchKey", "rowSelection"];  
27 -  
28 -function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }  
29 -  
30 -function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }  
31 -  
32 -function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }  
33 -  
34 -function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }  
35 -  
36 -function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }  
37 -  
38 -function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }  
39 -  
40 -function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }  
41 -  
42 -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }  
43 -  
44 -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }  
45 -  
46 -function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }  
47 -  
48 -function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }  
49 -  
50 -function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }  
51 -  
52 -function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }  
53 -  
54 -function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }  
55 -  
56 -function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }  
57 -  
58 -function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }  
59 -  
60 -function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }  
61 -  
62 -function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }  
63 -  
64 -/* eslint-disable jsx-a11y/anchor-is-valid */  
65 -import React, { useEffect, useMemo, useRef, useState } from 'react';  
66 -import Core from '../../index';  
67 -var confirm = _Modal.confirm;  
68 -import { useVT } from 'virtualizedtableforantd4';  
69 -var BUTTON_ICONS_MAP = {  
70 - ExportOutlined: /*#__PURE__*/React.createElement(_ExportOutlined, null),  
71 - ImportOutlined: /*#__PURE__*/React.createElement(_ImportOutlined, null),  
72 - DeleteOutlined: /*#__PURE__*/React.createElement(_DeleteOutlined, null),  
73 - PlusOutlined: /*#__PURE__*/React.createElement(_PlusOutlined, null),  
74 - CopyOutlined: /*#__PURE__*/React.createElement(_CopyOutlined, null),  
75 - EyeOutlined: /*#__PURE__*/React.createElement(_EyeOutlined, null),  
76 - EditOutlined: /*#__PURE__*/React.createElement(_EditOutlined, null),  
77 - remove: /*#__PURE__*/React.createElement(_ExpandAltOutlined, null),  
78 - SelectOutlined: /*#__PURE__*/React.createElement(_SelectOutlined, null)  
79 -};  
80 -var FIELD_LENGTH = 170;  
81 -var EXPORT_STATUS = {  
82 - // 执行中  
83 - PROCESSING: 'info',  
84 - // 成功  
85 - SUCCESS: 'success',  
86 - // 失败  
87 - FAIL: 'error'  
88 -};  
89 -  
90 -var VirtualList = function VirtualList(_ref) {  
91 - var _line$buttons;  
92 -  
93 - var _ref$displayList = _ref.displayList,  
94 - displayList = _ref$displayList === void 0 ? [] : _ref$displayList,  
95 - dataIndex = _ref.dataIndex,  
96 - children = _ref.children,  
97 - deleteItem = _ref.deleteItem,  
98 - batchDelete = _ref.batchDelete,  
99 - addItem = _ref.addItem,  
100 - moveItemUp = _ref.moveItemUp,  
101 - moveItemDown = _ref.moveItemDown,  
102 - flatten = _ref.flatten,  
103 - schema = _ref.schema,  
104 - listData = _ref.listData,  
105 - changeList = _ref.changeList,  
106 - copyItem = _ref.copyItem;  
107 - var _schema$props = schema.props,  
108 - props = _schema$props === void 0 ? {} : _schema$props,  
109 - _schema$itemProps = schema.itemProps,  
110 - itemProps = _schema$itemProps === void 0 ? {} : _schema$itemProps,  
111 - fieldName = schema.fieldName,  
112 - _schema$qxProps = schema.qxProps,  
113 - qxProps = _schema$qxProps === void 0 ? {} : _schema$qxProps,  
114 - subformMode = schema.subformMode;  
115 -  
116 - var _props$scrollY = props.scrollY,  
117 - scrollY = _props$scrollY === void 0 ? 600 : _props$scrollY,  
118 - _summary = props.summary,  
119 - batchKey = props.batchKey,  
120 - _props$bar = props.bar,  
121 - bar = _props$bar === void 0 ? {} : _props$bar,  
122 - _props$line = props.line,  
123 - line = _props$line === void 0 ? {} : _props$line,  
124 - searchKey = props.searchKey,  
125 - rowSelection = props.rowSelection,  
126 - rest = _objectWithoutProperties(props, _excluded);  
127 -  
128 - var _useVT = useVT(function () {  
129 - return {  
130 - scroll: {  
131 - y: scrollY  
132 - }  
133 - };  
134 - }, []),  
135 - _useVT2 = _slicedToArray(_useVT, 2),  
136 - vt = _useVT2[0],  
137 - set_components = _useVT2[1];  
138 -  
139 - var _useState = useState(''),  
140 - _useState2 = _slicedToArray(_useState, 2),  
141 - keyWord = _useState2[0],  
142 - setKeyWord = _useState2[1];  
143 -  
144 - var _useState3 = useState([]),  
145 - _useState4 = _slicedToArray(_useState3, 2),  
146 - selectedRowKeys = _useState4[0],  
147 - setSelectedRowKeys = _useState4[1];  
148 -  
149 - var _useState5 = useState(),  
150 - _useState6 = _slicedToArray(_useState5, 2),  
151 - exportProgressData = _useState6[0],  
152 - setProgressData = _useState6[1];  
153 -  
154 - var _useState7 = useState(),  
155 - _useState8 = _slicedToArray(_useState7, 2),  
156 - intervalName = _useState8[0],  
157 - setIntervalName = _useState8[1];  
158 -  
159 - var exportTaskId = useRef('');  
160 - var newRowSelection = useMemo(function () {  
161 - var _bar$buttons;  
162 -  
163 - var _rowSelection = _.cloneDeep(rowSelection); // 根据是否含有批量操作按钮,渲染表格是否可选择  
164 -  
165 -  
166 - var selectable = false;  
167 -  
168 - if (((_bar$buttons = bar.buttons) === null || _bar$buttons === void 0 ? void 0 : _bar$buttons.findIndex(function (item) {  
169 - return item.code === 'DELETE';  
170 - })) > -1) {  
171 - selectable = true;  
172 - }  
173 -  
174 - if (_rowSelection && selectable) {  
175 - _rowSelection.onChange = function (_selectedRowKeys) {  
176 - setSelectedRowKeys(_selectedRowKeys);  
177 - };  
178 -  
179 - _rowSelection.selectedRowKeys = selectedRowKeys;  
180 - }  
181 -  
182 - return _rowSelection;  
183 - }, [rowSelection, selectedRowKeys, bar]);  
184 - useEffect(function () {  
185 - displayList.forEach(function (item, index) {  
186 - item._index = index;  
187 - });  
188 - }, [displayList]);  
189 - var _disdisplayList = [];  
190 -  
191 - if (props.originWidget === 'relSelector') {  
192 - displayList.forEach(function (item) {  
193 - if (!item.hasOwnProperty('$auth') || item.$auth) {  
194 - _disdisplayList.push(item);  
195 - }  
196 - });  
197 - } else {  
198 - _disdisplayList = displayList;  
199 - }  
200 -  
201 - var selectedIds = useMemo(function () {  
202 - var _selectedIds = [];  
203 - displayList.forEach(function (item) {  
204 - if (selectedRowKeys.includes(item._index)) {  
205 - _selectedIds.push(item.id);  
206 - }  
207 - });  
208 - return _selectedIds;  
209 - }, [selectedRowKeys, displayList]);  
210 - var dataSource = (keyWord.length ? _disdisplayList.filter(function (item) {  
211 - var _item$searchKey;  
212 -  
213 - return ((_item$searchKey = item[searchKey]) === null || _item$searchKey === void 0 ? void 0 : _item$searchKey.indexOf(keyWord)) > -1;  
214 - }) : _disdisplayList).map(function (item, idx) {  
215 - return _objectSpread({  
216 - index: item._index || idx  
217 - }, item);  
218 - });  
219 - var pagination = useMemo(function () {  
220 - return {  
221 - total: dataSource.length,  
222 - position: ['bottomRight'],  
223 - pageSize: 10,  
224 - showTotal: function showTotal(total) {  
225 - return "\u5171".concat(total, "\u6761\u8BB0\u5F55");  
226 - },  
227 - defaultCurrent: 1,  
228 - size: 'default'  
229 - };  
230 - }, [dataSource]);  
231 - var barButtons = useMemo(function () {  
232 - var _barButtons = _.cloneDeep(bar.buttons || []); // 选择、新增位置提前  
233 -  
234 -  
235 - ['ADD', 'SELECT'].forEach(function (code) {  
236 - var _index = _barButtons.findIndex(function (item) {  
237 - return item.code === code;  
238 - });  
239 -  
240 - if (_index > -1) {  
241 - var btn = _barButtons.splice(_index, 1);  
242 -  
243 - _barButtons.unshift.apply(_barButtons, _toConsumableArray(btn));  
244 - }  
245 - }); // 关联表的导入、导出不可用,先隐藏 TODO  
246 -  
247 - if (props.originWidget === 'relSelector') {  
248 - ['IMPORT', 'EXPORT'].forEach(function (code) {  
249 - var _index = _barButtons.findIndex(function (item) {  
250 - return item.code === code;  
251 - });  
252 -  
253 - if (_index > -1) {  
254 - _barButtons.splice(_index, 1);  
255 - }  
256 - });  
257 - } // 子表默认可以新增,删掉ADD按钮  
258 -  
259 -  
260 - if (props.originWidget === 'subform') {  
261 - var _index = _barButtons.findIndex(function (item) {  
262 - return item.code === 'ADD';  
263 - });  
264 -  
265 - if (_index > -1) {  
266 - _barButtons.splice(_index, 1);  
267 - }  
268 - }  
269 -  
270 - if (batchKey) {  
271 - _barButtons.push({  
272 - code: 'BATCH_ADD',  
273 - batch: true,  
274 - action: 'SYS',  
275 - name: '批量新增'  
276 - });  
277 - }  
278 -  
279 - if (subformMode) {  
280 - _barButtons.push({  
281 - code: 'subformEdit',  
282 - icon: 'EditOutlined',  
283 - batch: true,  
284 - action: 'SYS',  
285 - name: '子表编辑'  
286 - });  
287 - }  
288 -  
289 - return _barButtons;  
290 - }, [props]);  
291 - var columns = children.map(function (child) {  
292 - var item = flatten[child];  
293 - var schema = item && item.schema || {};  
294 - return {  
295 - dataIndex: child,  
296 - width: schema.width ? Number(schema.width) || FIELD_LENGTH : FIELD_LENGTH,  
297 - align: schema.align || 'left',  
298 - fixed: schema.fixed,  
299 - title: /*#__PURE__*/React.createElement("div", {  
300 - style: {  
301 - width: (parseInt(schema.width) || FIELD_LENGTH) + "px"  
302 - }  
303 - }, schema.required ? /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("span", {  
304 - className: "fr-label-required"  
305 - }, " *"), /*#__PURE__*/React.createElement("span", null, schema.title)) : schema.title),  
306 - render: function render(value, record, index) {  
307 - // Check: record.index 似乎是antd自己会给的,不错哦  
308 - var childIndex = [].concat(_toConsumableArray(dataIndex), [record.index]);  
309 - return /*#__PURE__*/React.createElement(Core, {  
310 - hideTitle: true,  
311 - displayType: "inline",  
312 - key: index.toString(),  
313 - id: child,  
314 - dataIndex: childIndex  
315 - });  
316 - }  
317 - };  
318 - });  
319 -  
320 - var handleAuth = function handleAuth(record, code) {  
321 - switch (code) {  
322 - case 'VIEW':  
323 - return !record.VIEW_flag_;  
324 -  
325 - case 'DELETE':  
326 - return !record.DELETE_flag_;  
327 -  
328 - case 'EDIT':  
329 - return !record.EDIT_flag_;  
330 - }  
331 - };  
332 -  
333 - var handleState = function handleState(record, code, originWidget) {  
334 - if (originWidget === 'subform') {  
335 - return '';  
336 - } else {  
337 - switch (code) {  
338 - case 'VIEW':  
339 - return record.VIEW_flag_ === true ? '' : 'none';  
340 -  
341 - case 'DELETE':  
342 - return record.DELETE_flag_ === true ? '' : 'none';  
343 -  
344 - case 'EDIT':  
345 - return record.EDIT_flag_ === true ? '' : 'none';  
346 - }  
347 - }  
348 - };  
349 -  
350 - if (!props.hideDelete && ((_line$buttons = line.buttons) === null || _line$buttons === void 0 ? void 0 : _line$buttons.length) || Array.isArray(itemProps.buttons) || props.removeable) {  
351 - var top = line.top,  
352 - _line$style = line.style,  
353 - style = _line$style === void 0 ? 'ICON' : _line$style,  
354 - fixed = line.fixed,  
355 - buttons = line.buttons;  
356 - var action = {  
357 - title: '操作',  
358 - key: '$action',  
359 - fixed: fixed ? top ? 'left' : 'right' : props.originWidget === 'subform' ? 'right' : false,  
360 - align: 'center',  
361 - width: ((buttons || []).length + (props.removeable ? 1 : 0)) * (style === 'ICON' ? 32 : style === 'TEXT' ? 36 : 57) + 16,  
362 - render: function render(value, record, idx) {  
363 - return /*#__PURE__*/React.createElement(React.Fragment, null, Array.isArray(itemProps.buttons) ? itemProps.buttons.map(function (item, idx) {  
364 - var callback = item.callback,  
365 - text = item.text,  
366 - html = item.html;  
367 -  
368 - var onClick = function onClick() {};  
369 -  
370 - if (typeof window[callback] === 'function') {  
371 - onClick = function onClick() {  
372 - window[callback]({  
373 - value: listData,  
374 - onChange: changeList,  
375 - schema: schema  
376 - });  
377 - };  
378 - }  
379 -  
380 - return /*#__PURE__*/React.createElement("a", {  
381 - key: idx.toString(),  
382 - style: {  
383 - marginLeft: 8  
384 - },  
385 - size: "small",  
386 - onClick: onClick  
387 - }, /*#__PURE__*/React.createElement("span", {  
388 - dangerouslySetInnerHTML: {  
389 - __html: html || text  
390 - }  
391 - }));  
392 - }) : null, Array.isArray(line.buttons) ? line.buttons.map(function (item) {  
393 - var name = item.name,  
394 - code = item.code,  
395 - needConfirm = item.needConfirm,  
396 - confirmContent = item.confirmContent,  
397 - icon = item.icon;  
398 - return /*#__PURE__*/React.createElement(_Tooltip, {  
399 - title: name  
400 - }, /*#__PURE__*/React.createElement(_Button, _extends({  
401 - key: code,  
402 - style: {  
403 - marginLeft: 8,  
404 - display: "".concat(handleState(record, code, props.originWidget))  
405 - }  
406 - }, item, {  
407 - icon: icon && style !== 'TEXT' ? BUTTON_ICONS_MAP[icon] : null,  
408 - type: 'link',  
409 - size: 'small' // disabled={props.originWidget === 'subform' ? false : handleAuth(record, code)}  
410 - ,  
411 - onClick: function onClick() {  
412 - if (needConfirm && confirmContent) {  
413 - confirm({  
414 - title: confirmContent,  
415 - icon: /*#__PURE__*/React.createElement(_ExclamationCircleOutlined, null),  
416 - okText: '确认',  
417 - okType: 'danger',  
418 - cancelText: '取消',  
419 - onOk: function onOk() {  
420 - if (code === 'DELETE' && props.originWidget === 'subform') {  
421 - deleteItem(idx);  
422 - } else if (code === 'COPY') {  
423 - copyItem(idx);  
424 - } else if (item.action === 'CUSTOM') {  
425 - props.handleCustom(item, record, schema.$id);  
426 - } else {  
427 - props.handleLineBtnClick(code, record, schema.$id, line.action);  
428 - }  
429 - },  
430 - onCancel: function onCancel() {}  
431 - });  
432 - } else {  
433 - if (code === 'DELETE' && props.originWidget === 'subform') {  
434 - deleteItem(idx);  
435 - } else if (code === 'COPY') {  
436 - copyItem(idx);  
437 - } else if (item.action === 'CUSTOM') {  
438 - props.handleCustom(item, record, schema.$id);  
439 - } else {  
440 - props.handleLineBtnClick(code, record, schema.$id, line.action);  
441 - }  
442 - }  
443 - }  
444 - }), style !== 'ICON' ? name : null)); // }  
445 - }) : null, props.removeable ? /*#__PURE__*/React.createElement(_Tooltip, {  
446 - title: '移除'  
447 - }, /*#__PURE__*/React.createElement(_Button, {  
448 - key: 'remove',  
449 - style: {  
450 - marginLeft: 8  
451 - },  
452 - icon: style !== 'TEXT' ? BUTTON_ICONS_MAP['remove'] : null,  
453 - type: 'link',  
454 - size: 'small',  
455 - onClick: function onClick() {  
456 - if (props.removeContent) {  
457 - confirm({  
458 - title: props.removeContent,  
459 - icon: /*#__PURE__*/React.createElement(_ExclamationCircleOutlined, null),  
460 - okText: '确认',  
461 - okType: 'danger',  
462 - cancelText: '取消',  
463 - onOk: function onOk() {  
464 - deleteItem(idx);  
465 - },  
466 - onCancel: function onCancel() {}  
467 - });  
468 - } else {  
469 - deleteItem(idx);  
470 - }  
471 - }  
472 - }, style !== 'ICON' ? '移除' : null)) : null);  
473 - }  
474 - };  
475 -  
476 - if (top) {  
477 - columns.unshift(action);  
478 - } else {  
479 - columns.push(action);  
480 - }  
481 - }  
482 -  
483 - var handleExport = /*#__PURE__*/function () {  
484 - var _ref2 = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee() {  
485 - var appCode, funCode, fieldName, result;  
486 - return regeneratorRuntime.wrap(function _callee$(_context) {  
487 - while (1) {  
488 - switch (_context.prev = _context.next) {  
489 - case 0:  
490 - setProgressData({  
491 - "percent": 0,  
492 - "status": "PROCESSING"  
493 - });  
494 - appCode = qxProps.appCode, funCode = qxProps.funCode, fieldName = qxProps.fieldName;  
495 - _context.next = 4;  
496 - return props.exportChild(appCode, funCode, fieldName);  
497 -  
498 - case 4:  
499 - result = _context.sent;  
500 - exportTaskId.current = result.taskId || '';  
501 -  
502 - if (result.downloadUrl) {  
503 - setTimeout(function () {  
504 - exportData(result.taskId);  
505 - }, 5000);  
506 - }  
507 -  
508 - case 7:  
509 - case "end":  
510 - return _context.stop();  
511 - }  
512 - }  
513 - }, _callee);  
514 - }));  
515 -  
516 - return function handleExport() {  
517 - return _ref2.apply(this, arguments);  
518 - };  
519 - }();  
520 -  
521 - var exportData = function exportData(taskId) {  
522 - // const {appCode, funCode, viewCode} = qxProps  
523 - // taskType: UPLOAD || EXPORT  
524 - props.exportProgress(taskId || exportTaskId.current).then(function (res) {  
525 - setProgressData(res || null);  
526 - });  
527 - };  
528 -  
529 - useEffect(function () {  
530 - if (exportProgressData) {  
531 - if (exportProgressData.status === 'PROCESSING' && !intervalName) {  
532 - setIntervalName(setInterval(function () {  
533 - return exportData();  
534 - }, 1000 * 10));  
535 - return;  
536 - }  
537 -  
538 - if (exportProgressData.status !== 'PROCESSING' && intervalName) {  
539 - clearInterval(intervalName);  
540 - return;  
541 - }  
542 - }  
543 -  
544 - return function () {  
545 - if (intervalName) {  
546 - setTimeout(function () {  
547 - clearInterval(intervalName);  
548 - }, 1000 * 60 * 10);  
549 - }  
550 - };  
551 - }, [exportProgressData]);  
552 -  
553 - var handleCloseExport = function handleCloseExport(taskId) {  
554 - var appCode = qxProps.appCode,  
555 - funCode = qxProps.funCode,  
556 - viewCode = qxProps.viewCode;  
557 - props.closeExport(appCode, funCode, viewCode, {  
558 - taskId: taskId  
559 - }).then(function (res) {  
560 - setProgressData(null);  
561 -  
562 - if (intervalName) {  
563 - clearInterval(intervalName);  
564 - }  
565 - });  
566 - };  
567 -  
568 - var getExportMessage = function getExportMessage() {  
569 - if (exportProgressData.status === 'SUCCESS') {  
570 - return /*#__PURE__*/React.createElement("div", null, "\u5BFC\u51FA\u6210\u529F\uFF0C\u70B9\u51FB", /*#__PURE__*/React.createElement(_Button, {  
571 - onClick: function onClick() {  
572 - return handleDownload(exportProgressData.downloadUrl, '导出文件.xlsx', props.REQUEST);  
573 - },  
574 - type: 'link'  
575 - }, "\u4E0B\u8F7D\u6587\u4EF6"), /*#__PURE__*/React.createElement(_Button, {  
576 - style: {  
577 - float: "right"  
578 - },  
579 - onClick: function onClick() {  
580 - return handleCloseExport(exportProgressData.taskId);  
581 - },  
582 - type: 'link'  
583 - }, "\u3010\u5173\u95ED\u63D0\u9192\u3011"));  
584 - }  
585 -  
586 - return /*#__PURE__*/React.createElement("div", null, "\u5BFC\u51FA\u8FDB\u884C\u4E2D\uFF0C\u8BF7\u7A0D\u540E......", /*#__PURE__*/React.createElement(_Button, {  
587 - onClick: function onClick() {  
588 - return exportData();  
589 - },  
590 - type: 'link'  
591 - }, "\u5237\u65B0"), /*#__PURE__*/React.createElement(_Button, {  
592 - style: {  
593 - float: "right"  
594 - },  
595 - onClick: function onClick() {  
596 - return handleCloseExport(exportProgressData.taskId);  
597 - },  
598 - type: 'link'  
599 - }, "\u3010\u5173\u95ED\u63D0\u9192\u3011"));  
600 - };  
601 -  
602 - return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("div", {  
603 - className: 'qx-virtual-searchLine',  
604 - style: {  
605 - flexDirection: searchKey ? 'row' : 'row-reverse'  
606 - }  
607 - }, searchKey ? /*#__PURE__*/React.createElement(_Input, {  
608 - style: {  
609 - width: '200px'  
610 - },  
611 - allowClear: true,  
612 - size: 'small',  
613 - placeholder: "\u8BF7\u8F93\u5165\u641C\u7D22\u6761\u4EF6",  
614 - prefix: /*#__PURE__*/React.createElement(_SearchOutlined, {  
615 - style: {  
616 - color: '#666'  
617 - }  
618 - }),  
619 - onChange: function onChange(e) {  
620 - var _e$target;  
621 -  
622 - setKeyWord(((_e$target = e.target) === null || _e$target === void 0 ? void 0 : _e$target.value) || '');  
623 - }  
624 - }) : /*#__PURE__*/React.createElement(React.Fragment, null), /*#__PURE__*/React.createElement("div", null, barButtons.map(function (item) {  
625 - var name = item.name,  
626 - code = item.code,  
627 - needConfirm = item.needConfirm,  
628 - confirmContent = item.confirmContent,  
629 - icon = item.icon,  
630 - action = item.action;  
631 - return /*#__PURE__*/React.createElement(_Button, _extends({  
632 - key: code,  
633 - style: {  
634 - marginLeft: 8  
635 - }  
636 - }, item, {  
637 - icon: icon ? BUTTON_ICONS_MAP[icon] : null,  
638 - onClick: function onClick() {  
639 - if (code === 'DELETE') {  
640 - if (!selectedRowKeys.length) {  
641 - return _message.warning('请选择数据');  
642 - }  
643 -  
644 - if (needConfirm && confirmContent) {  
645 - confirm({  
646 - title: '批量删除确认',  
647 - icon: /*#__PURE__*/React.createElement(_ExclamationCircleOutlined, null),  
648 - content: confirmContent,  
649 - okText: '确认',  
650 - okType: 'danger',  
651 - cancelText: '取消',  
652 - onOk: function onOk() {  
653 - if (props.originWidget === 'subform') {  
654 - batchDelete(selectedRowKeys);  
655 - setSelectedRowKeys([]);  
656 - } else {  
657 - props.handleBarBtnClick(code, fieldName, batchKey, selectedRowKeys, schema.$id, selectedIds);  
658 - }  
659 - },  
660 - onCancel: function onCancel() {}  
661 - });  
662 - } else {  
663 - if (props.originWidget === 'subform') {  
664 - batchDelete(selectedRowKeys);  
665 - setSelectedRowKeys([]);  
666 - } else {  
667 - props.handleBarBtnClick(code, fieldName, batchKey, selectedRowKeys, schema.$id, selectedIds);  
668 - }  
669 - }  
670 - } else if (code === 'EXPORT') {  
671 - handleExport();  
672 - } else if (code === 'SELECT') {  
673 - props.openRelSelect(schema.$id);  
674 - } else if (code === 'ADD') {  
675 - props.handleRelAdd(schema.$id);  
676 - } else if (code === 'subformEdit') {  
677 - props.handleBatchEdit(fieldName, schema.$id, selectedIds);  
678 - } else if (action === 'CUSTOM') {  
679 - props.handleCustom(item, selectedIds, schema.$id);  
680 - } else {  
681 - props.handleBarBtnClick(code, fieldName, batchKey, selectedRowKeys, schema.$id, selectedIds);  
682 - }  
683 - }  
684 - }), name); // }  
685 - })), Array.isArray(props.buttons) ? props.buttons.map(function (item, idx) {  
686 - var callback = item.callback,  
687 - text = item.text,  
688 - html = item.html;  
689 -  
690 - var onClick = function onClick() {};  
691 -  
692 - if (typeof window[callback] === 'function') {  
693 - onClick = function onClick() {  
694 - window[callback]({  
695 - value: listData,  
696 - onChange: changeList,  
697 - schema: schema  
698 - });  
699 - };  
700 - } else {  
701 - if (typeof callback === 'function') {  
702 - callback({  
703 - value: listData,  
704 - onChange: changeList,  
705 - schema: schema  
706 - });  
707 - }  
708 - }  
709 -  
710 - return /*#__PURE__*/React.createElement(_Button, {  
711 - key: idx.toString(),  
712 - style: {  
713 - marginLeft: 8  
714 - },  
715 - size: "small",  
716 - onClick: onClick  
717 - }, /*#__PURE__*/React.createElement("span", {  
718 - dangerouslySetInnerHTML: {  
719 - __html: html || text  
720 - }  
721 - }));  
722 - }) : null), exportProgressData ? /*#__PURE__*/React.createElement(_Alert, {  
723 - style: {  
724 - marginBottom: '12px'  
725 - },  
726 - message: getExportMessage(),  
727 - type: EXPORT_STATUS[exportProgressData.status] || 'info',  
728 - showIcon: true,  
729 - onClose: function onClose() {  
730 - handleCloseExport(exportProgressData.taskId);  
731 - }  
732 - }) : null, /*#__PURE__*/React.createElement(_Table, _extends({  
733 - className: 'qx-virtualList',  
734 - rowKey: "index",  
735 - scroll: {  
736 - y: scrollY,  
737 - x: '100%'  
738 - },  
739 - components: vt,  
740 - size: "small",  
741 - columns: columns,  
742 - dataSource: dataSource,  
743 - pagination: props.originWidget === 'subform' ? false : pagination,  
744 - style: {  
745 - marginBottom: 25  
746 - },  
747 - rowSelection: newRowSelection,  
748 - summary: function summary() {  
749 - if (!_summary) {  
750 - return null;  
751 - }  
752 -  
753 - return _summary(listData);  
754 - }  
755 - }, rest)), !props.hideAdd && props.originWidget === 'subform' && /*#__PURE__*/React.createElement(_Button, {  
756 - type: "link",  
757 - icon: /*#__PURE__*/React.createElement(_PlusOutlined, null),  
758 - onClick: addItem  
759 - }, "\u65B0\u589E"));  
760 -};  
761 -/**  
762 - * 文件下载。依赖HTML页面  
763 - *  
764 - * @param url 下载URL  
765 - * @param name 指定的文件名(包括扩展名)  
766 - * @param request  
767 - */  
768 -  
769 -  
770 -function handleDownload(_x, _x2, _x3) {  
771 - return _handleDownload.apply(this, arguments);  
772 -}  
773 -  
774 -function _handleDownload() {  
775 - _handleDownload = _asyncToGenerator( /*#__PURE__*/regeneratorRuntime.mark(function _callee2(url, name, request) {  
776 - var isDownload,  
777 - link,  
778 - blob,  
779 - downloadUrl,  
780 - _args2 = arguments;  
781 - return regeneratorRuntime.wrap(function _callee2$(_context2) {  
782 - while (1) {  
783 - switch (_context2.prev = _context2.next) {  
784 - case 0:  
785 - // eslint-disable-next-line prefer-rest-params  
786 - isDownload = _args2[2];  
787 -  
788 - if (isDownload === null || Boolean(isDownload)) {  
789 - _message.warning('即将开始下载,请勿重复点击。');  
790 - }  
791 -  
792 - link = document.createElement('a');  
793 - link.href = url;  
794 - link.download = name;  
795 - link.target = '_blank';  
796 - document.body.appendChild(link); //TODO 文件过大时,看不到下载进度  
797 -  
798 - _context2.next = 9;  
799 - return request.get(url, {  
800 - autoShowError: true  
801 - });  
802 -  
803 - case 9:  
804 - blob = _context2.sent;  
805 -  
806 - if (blob !== null) {  
807 - downloadUrl = URL.createObjectURL(blob);  
808 - link.href = downloadUrl;  
809 - link.click();  
810 - document.body.removeChild(link);  
811 - URL.revokeObjectURL(downloadUrl);  
812 - }  
813 -  
814 - case 11:  
815 - case "end":  
816 - return _context2.stop();  
817 - }  
818 - }  
819 - }, _callee2);  
820 - }));  
821 - return _handleDownload.apply(this, arguments);  
822 -}  
823 -  
824 -export default VirtualList;  
1 -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }  
2 -  
3 -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }  
4 -  
5 -function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }  
6 -  
7 -function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }  
8 -  
9 -function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }  
10 -  
11 -function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }  
12 -  
13 -function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }  
14 -  
15 -function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }  
16 -  
17 -function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }  
18 -  
19 -/* eslint-disable jsx-a11y/anchor-is-valid */  
20 -import React from 'react';  
21 -import { get } from 'lodash-es';  
22 -import { useStore, useTools } from '../../../hooks';  
23 -import { getDataPath, getKeyFromPath, getDisplayValue } from '../../../utils'; // import ArrowDown from '../../../components/ArrowDown';  
24 -  
25 -import "./list.css";  
26 -import SimpleList from './SimpleList';  
27 -import CardList from './CardList';  
28 -import TableList from './TableList';  
29 -import DrawerList from './DrawerList';  
30 -import VirtualList from './VirtualList';  
31 -  
32 -var RenderList = function RenderList(_ref) {  
33 - var parentId = _ref.parentId,  
34 - _ref$schema = _ref.schema,  
35 - schema = _ref$schema === void 0 ? {} : _ref$schema,  
36 - _ref$dataIndex = _ref.dataIndex,  
37 - dataIndex = _ref$dataIndex === void 0 ? [] : _ref$dataIndex,  
38 - _ref$children = _ref.children,  
39 - children = _ref$children === void 0 ? [] : _ref$children,  
40 - errorFields = _ref.errorFields,  
41 - displayType = _ref.displayType;  
42 -  
43 - var _useStore = useStore(),  
44 - formData = _useStore.formData,  
45 - flatten = _useStore.flatten;  
46 -  
47 - var _useTools = useTools(),  
48 - onItemChange = _useTools.onItemChange,  
49 - removeTouched = _useTools.removeTouched;  
50 -  
51 - var renderWidget = 'list';  
52 -  
53 - try {  
54 - renderWidget = schema.widget;  
55 - } catch (error) {} // 计算 list对应的formData  
56 -  
57 -  
58 - var dataPath = getDataPath(parentId, dataIndex);  
59 - var listData;  
60 -  
61 - if (typeof dataPath === 'string') {  
62 - // TODO: listData会有不少“窟窿”,submit 的时候,listData 需要补齐 or filter  
63 - listData = get(formData, dataPath);  
64 - }  
65 -  
66 - var displayList = Array.isArray(listData) ? listData : [];  
67 -  
68 - var changeList = function changeList(newList) {  
69 - onItemChange(dataPath, newList);  
70 - };  
71 -  
72 - var addItem = function addItem() {  
73 - var newList = [].concat(_toConsumableArray(displayList), [{}]);  
74 - var newIndex = newList.length - 1;  
75 - onItemChange(dataPath, newList);  
76 - return newIndex;  
77 - };  
78 -  
79 - var copyItem = function copyItem(idx) {  
80 - var newItem = displayList[idx];  
81 - delete newItem.id;  
82 - var newList = [].concat(_toConsumableArray(displayList.slice(0, idx)), [newItem], _toConsumableArray(displayList.slice(idx)));  
83 - onItemChange(dataPath, JSON.parse(JSON.stringify(newList)));  
84 - };  
85 -  
86 - var deleteItem = function deleteItem(idx) {  
87 - // TODO: 删除元素的时候,也需要delete相对于的校验信息(errorFields)  
88 - // remark: 删除时,不存在的item需要补齐,用null  
89 - var newList = displayList.filter(function (item, kdx) {  
90 - return kdx !== idx;  
91 - });  
92 - onItemChange(dataPath, newList);  
93 - removeTouched("".concat(dataPath, "[").concat(idx, "]"));  
94 - }; // 批量删除的方法  
95 -  
96 -  
97 - var batchDelete = function batchDelete(ids) {  
98 - var newList = displayList.filter(function (item, kdx) {  
99 - return !ids.includes(kdx);  
100 - });  
101 - onItemChange(dataPath, newList);  
102 - (ids || []).forEach(function (id) {  
103 - removeTouched("".concat(dataPath, "[").concat(id, "]"));  
104 - });  
105 - }; //TODO1: 上线翻页要正确!!现在是错的  
106 -  
107 -  
108 - var moveItemUp = function moveItemUp(idx) {  
109 - if (idx === 0) return;  
110 - var currentItem = displayList[idx];  
111 - var itemAbove = displayList[idx - 1];  
112 - var newList = displayList;  
113 - newList[idx] = itemAbove;  
114 - newList[idx - 1] = currentItem;  
115 - onItemChange(dataPath, newList); // TODO: 这块懒了,之后要处理一下  
116 -  
117 - removeTouched("".concat(dataPath, "[").concat(idx, "]"));  
118 - };  
119 -  
120 - var moveItemDown = function moveItemDown(idx) {  
121 - if (idx >= displayList.length - 1) return;  
122 - var currentItem = displayList[idx];  
123 - var itemBelow = displayList[idx + 1];  
124 - var newList = displayList;  
125 - newList[idx] = itemBelow;  
126 - newList[idx + 1] = currentItem;  
127 - onItemChange(dataPath, newList); // TODO: 这块懒了,之后要处理一下  
128 -  
129 - removeTouched("".concat(dataPath, "[").concat(idx, "]"));  
130 - };  
131 -  
132 - var itemSchema = {  
133 - type: 'object',  
134 - // properties: (schema.items && schema.items.properties) || {},  
135 - properties: {},  
136 - props: schema.props || {},  
137 - $id: schema.$id  
138 - };  
139 - var itemFlatten = {  
140 - schema: itemSchema,  
141 - children: children  
142 - };  
143 -  
144 - var getFieldsProps = function getFieldsProps(idx, extraProps) {  
145 - return _objectSpread({  
146 - _item: itemFlatten,  
147 - dataIndex: [].concat(_toConsumableArray(dataIndex), [idx])  
148 - }, extraProps);  
149 - };  
150 -  
151 - var displayProps = {  
152 - displayList: displayList,  
153 - changeList: changeList,  
154 - schema: schema,  
155 - dataPath: dataPath,  
156 - dataIndex: dataIndex,  
157 - children: children,  
158 - deleteItem: deleteItem,  
159 - batchDelete: batchDelete,  
160 - addItem: addItem,  
161 - copyItem: copyItem,  
162 - moveItemDown: moveItemDown,  
163 - moveItemUp: moveItemUp,  
164 - listData: listData,  
165 - flatten: flatten,  
166 - errorFields: errorFields,  
167 - displayType: displayType,  
168 - getFieldsProps: getFieldsProps  
169 - };  
170 -  
171 - switch (renderWidget) {  
172 - case 'list0':  
173 - case 'cardList':  
174 - return /*#__PURE__*/React.createElement(CardList, displayProps);  
175 -  
176 - case 'list1':  
177 - case 'simpleList':  
178 - return /*#__PURE__*/React.createElement(SimpleList, displayProps);  
179 -  
180 - case 'list2':  
181 - case 'tableList':  
182 - return /*#__PURE__*/React.createElement(TableList, displayProps);  
183 -  
184 - case 'list3':  
185 - case 'drawerList':  
186 - return /*#__PURE__*/React.createElement(DrawerList, displayProps);  
187 -  
188 - case 'list4':  
189 - case 'virtualList':  
190 - return /*#__PURE__*/React.createElement(VirtualList, displayProps);  
191 -  
192 - default:  
193 - return /*#__PURE__*/React.createElement(CardList, displayProps);  
194 - }  
195 -};  
196 -  
197 -export default RenderList;  
1 -.fr-container .fr-card-item {  
2 - border: 1px solid rgba(0, 0, 0, 0.1);  
3 - border-radius: 4px;  
4 - padding: 10px 12px 4px 12px;  
5 - margin-bottom: 8px;  
6 - position: relative;  
7 - display: flex;  
8 -}  
9 -.fr-container .fr-card-item-row {  
10 - padding-top: 34px;  
11 -}  
12 -.fr-container .fr-card-index {  
13 - position: absolute;  
14 - top: 0;  
15 - left: 0;  
16 - padding-left: 4px;  
17 - padding-right: 6px;  
18 - border-bottom-right-radius: 8px;  
19 - border-top-left-radius: 3px;  
20 - background-color: rgba(0, 0, 0, 0.36);  
21 - font-size: 8px;  
22 - color: #fff;  
23 -}  
24 -.fr-container .fr-card-toolbar {  
25 - position: absolute;  
26 - top: 8px;  
27 - right: 8px;  
28 - display: flex;  
29 -}  
30 -.qx-virtual-searchLine {  
31 - display: flex;  
32 - justify-content: space-between;  
33 - padding: 8px 10px;  
34 -}  
35 -.qx-virtual-searchLine .ant-input-affix-wrapper-sm {  
36 - padding: 4px 7px;  
37 -}  
38 -.qx-virtualList .ant-btn-sm {  
39 - padding: 0;  
40 -}  
41 -.qx-virtualList .qx-fr-input--readonly {  
42 - background: none;  
43 -}  
44 -.qx-virtualList .ant-select:not(.ant-select-customize-input) .ant-select-selector {  
45 - border: none;  
46 -}  
47 -.qx-virtualList .ant-pagination-total-text {  
48 - line-height: 32px;  
49 -}  
1 -function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }  
2 -  
3 -import React from 'react';  
4 -import Core from '../index';  
5 -  
6 -var RenderObject = function RenderObject(_ref) {  
7 - var _ref$children = _ref.children,  
8 - children = _ref$children === void 0 ? [] : _ref$children,  
9 - _ref$dataIndex = _ref.dataIndex,  
10 - dataIndex = _ref$dataIndex === void 0 ? [] : _ref$dataIndex,  
11 - displayType = _ref.displayType,  
12 - hideTitle = _ref.hideTitle;  
13 - return /*#__PURE__*/React.createElement(React.Fragment, null, children.map(function (child, i) {  
14 - var FRProps = {  
15 - displayType: displayType,  
16 - id: child,  
17 - dataIndex: dataIndex,  
18 - hideTitle: hideTitle  
19 - };  
20 - return /*#__PURE__*/React.createElement(Core, _extends({  
21 - key: i.toString()  
22 - }, FRProps));  
23 - }));  
24 -};  
25 -  
26 -export default RenderObject;  
1 -.fr-container .error-message {  
2 - color: #ff4d4f;  
3 - min-height: 24px;  
4 - font-size: 14px;  
5 - line-height: 1.5715;  
6 - transition: color 0.3s cubic-bezier(0.215, 0.61, 0.355, 1);  
7 -}  
1 -import React from 'react';  
2 -import { translateMessage } from '../../utils';  
3 -import "./ErrorMessage.css";  
4 -  
5 -var ErrorMessage = function ErrorMessage(_ref) {  
6 - var message = _ref.message,  
7 - schema = _ref.schema,  
8 - softHidden = _ref.softHidden,  
9 - hardHidden = _ref.hardHidden;  
10 - var msg = '';  
11 - if (typeof message === 'string') msg = message;  
12 -  
13 - if (Array.isArray(message)) {  
14 - msg = message[0] || '';  
15 - }  
16 -  
17 - msg = translateMessage(msg, schema);  
18 - if (hardHidden) return /*#__PURE__*/React.createElement("div", {  
19 - className: "error-message"  
20 - });  
21 - return !msg && softHidden ? null : /*#__PURE__*/React.createElement("div", {  
22 - className: "error-message"  
23 - }, msg);  
24 -};  
25 -  
26 -export default ErrorMessage;  
1 -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }  
2 -  
3 -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }  
4 -  
5 -function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }  
6 -  
7 -import React, { Suspense } from 'react';  
8 -import { getWidgetName, extraSchemaList } from '../../mapping';  
9 -import { useTools, useStore } from '../../hooks';  
10 -import { transformProps } from '../../createWidget';  
11 -import { isObjType, isListType, isObject } from '../../utils';  
12 -  
13 -var ErrorSchema = function ErrorSchema(schema) {  
14 - return /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement("div", {  
15 - style: {  
16 - color: 'red'  
17 - }  
18 - }, "schema\u672A\u5339\u914D\u5230\u5C55\u793A\u7EC4\u4EF6\uFF1A"), /*#__PURE__*/React.createElement("div", null, JSON.stringify(schema)));  
19 -};  
20 -  
21 -var ExtendedWidget = function ExtendedWidget(_ref) {  
22 - var schema = _ref.schema,  
23 - onChange = _ref.onChange,  
24 - value = _ref.value,  
25 - dependValues = _ref.dependValues,  
26 - children = _ref.children,  
27 - onItemChange = _ref.onItemChange,  
28 - formData = _ref.formData,  
29 - getValue = _ref.getValue,  
30 - readOnly = _ref.readOnly,  
31 - dataPath = _ref.dataPath,  
32 - disabled = _ref.disabled,  
33 - dataIndex = _ref.dataIndex;  
34 -  
35 - var _useTools = useTools(),  
36 - widgets = _useTools.widgets,  
37 - mapping = _useTools.mapping,  
38 - setValueByPath = _useTools.setValueByPath,  
39 - getSchemaByPath = _useTools.getSchemaByPath,  
40 - setSchemaByPath = _useTools.setSchemaByPath,  
41 - setSchema = _useTools.setSchema,  
42 - setValues = _useTools.setValues,  
43 - getValues = _useTools.getValues,  
44 - resetFields = _useTools.resetFields,  
45 - setErrorFields = _useTools.setErrorFields,  
46 - removeErrorField = _useTools.removeErrorField;  
47 -  
48 - var _useStore = useStore(),  
49 - globalProps = _useStore.globalProps; // if (isObjType(schema)) {  
50 - // return <Map value={value} onChange={onChange} children={children} />;  
51 - // }  
52 - // if (isListType(schema)) {  
53 - // return 'haha';  
54 - // }  
55 - // return <Input value={value} onChange={e => onChange(e.target.value)} />;  
56 - // TODO: calc widget, better way?  
57 - // let widgetName = useMemo(() => getWidgetName(schema, mapping), [  
58 - // JSON.stringify(schema),  
59 - // ]);  
60 -  
61 -  
62 - var widgetName = getWidgetName(schema, mapping);  
63 - var customName = schema.widget || schema['ui:widget'];  
64 -  
65 - if (customName && widgets[customName]) {  
66 - widgetName = customName;  
67 - }  
68 -  
69 - var readOnlyName = schema.readOnlyWidget || 'html';  
70 -  
71 - if (readOnly && !isObjType(schema) && !isListType(schema)) {  
72 - widgetName = readOnlyName;  
73 - }  
74 -  
75 - if (!widgetName) {  
76 - widgetName = 'input';  
77 - return /*#__PURE__*/React.createElement(ErrorSchema, {  
78 - schema: schema  
79 - });  
80 - }  
81 -  
82 - var Widget = widgets[widgetName];  
83 - var extraSchema = extraSchemaList[widgetName];  
84 -  
85 - var widgetProps = _objectSpread(_objectSpread({  
86 - schema: _objectSpread(_objectSpread({}, schema), extraSchema),  
87 - onChange: onChange,  
88 - value: value,  
89 - children: children,  
90 - disabled: disabled,  
91 - readOnly: readOnly  
92 - }, schema.props), globalProps);  
93 -  
94 - if (schema.type === 'string' && typeof schema.max === 'number') {  
95 - widgetProps.maxLength = schema.max;  
96 - }  
97 -  
98 - ['title', 'placeholder', 'disabled', 'format'].forEach(function (key) {  
99 - if (schema[key]) {  
100 - widgetProps[key] = schema[key];  
101 - }  
102 - });  
103 -  
104 - if (schema.props) {  
105 - widgetProps = _objectSpread(_objectSpread({}, widgetProps), schema.props);  
106 - }  
107 -  
108 - Object.keys(schema).forEach(function (key) {  
109 - if (typeof key === 'string' && key.toLowerCase().indexOf('props') > -1 && key.length > 5) {  
110 - widgetProps[key] = schema[key];  
111 - }  
112 - }); // 支持 addonAfter 为自定义组件的情况  
113 -  
114 - if (isObject(widgetProps.addonAfter) && widgetProps.addonAfter.widget) {  
115 - var AddonAfterWidget = widgets[widgetProps.addonAfter.widget];  
116 - widgetProps.addonAfter = /*#__PURE__*/React.createElement(AddonAfterWidget, schema);  
117 - }  
118 -  
119 - var hideSelf = function hideSelf() {  
120 - var hidden = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true;  
121 - setSchemaByPath(schema.$id, {  
122 - hidden: hidden  
123 - });  
124 - }; // 避免传组件不接受的props,按情况传多余的props  
125 -  
126 -  
127 - widgetProps.addons = {  
128 - dependValues: dependValues,  
129 - onItemChange: onItemChange,  
130 - getValue: getValue,  
131 - formData: formData,  
132 - dataPath: dataPath,  
133 - dataIndex: dataIndex,  
134 - setValueByPath: setValueByPath,  
135 - setValue: setValueByPath,  
136 - getSchemaByPath: getSchemaByPath,  
137 - setSchemaByPath: setSchemaByPath,  
138 - setSchema: setSchema,  
139 - setValues: setValues,  
140 - getValues: getValues,  
141 - resetFields: resetFields,  
142 - setErrorFields: setErrorFields,  
143 - removeErrorField: removeErrorField,  
144 - hideSelf: hideSelf  
145 - };  
146 - var finalProps = transformProps(widgetProps);  
147 - return /*#__PURE__*/React.createElement(Suspense, {  
148 - fallback: /*#__PURE__*/React.createElement("div", null)  
149 - }, /*#__PURE__*/React.createElement("div", {  
150 - className: "fr-item-wrapper"  
151 - }, /*#__PURE__*/React.createElement(Widget, finalProps)));  
152 -};  
153 -  
154 -var areEqual = function areEqual(prev, current) {  
155 - if (prev.schema && prev.schema.$id === '#') {  
156 - return false;  
157 - }  
158 -  
159 - if (prev.readOnly !== current.readOnly) {  
160 - return false;  
161 - }  
162 -  
163 - if (prev.disabled !== current.disabled) {  
164 - return false;  
165 - }  
166 -  
167 - if (JSON.stringify(prev.dependValues) !== JSON.stringify(current.dependValues)) {  
168 - return false;  
169 - }  
170 -  
171 - if (isObjType(prev.schema) && isObjType(current.schema)) {  
172 - return false;  
173 - }  
174 -  
175 - if (JSON.stringify(prev.value) === JSON.stringify(current.value) && JSON.stringify(prev.schema) === JSON.stringify(current.schema)) {  
176 - return true;  
177 - }  
178 -  
179 - return false;  
180 -};  
181 -  
182 -export default /*#__PURE__*/React.memo(ExtendedWidget, areEqual);  
1 -.fr-container .fr-form-item-extra {  
2 - clear: both;  
3 - color: rgba(0, 0, 0, 0.45);  
4 - font-size: 14px;  
5 - line-height: 1.5715;  
6 - min-height: 24px;  
7 -}  
1 -function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }  
2 -  
3 -import React from 'react';  
4 -import { useTools } from '../../hooks';  
5 -import "./Extra.css";  
6 -  
7 -var Extra = function Extra(_ref) {  
8 - var schema = _ref.schema;  
9 - var extra = schema.extra;  
10 -  
11 - var _useTools = useTools(),  
12 - widgets = _useTools.widgets;  
13 -  
14 - if (!extra) return null; // widget 这个api也可以不对外  
15 -  
16 - var widgetName = extra.widget;  
17 - var Widget = widgets[widgetName];  
18 - if (Widget) return /*#__PURE__*/React.createElement(Widget, {  
19 - schema: schema  
20 - });  
21 - var __html = '';  
22 -  
23 - if (typeof extra === 'string') {  
24 - __html = extra;  
25 - } // 内部BU使用的口子,这个api不对外,也没有必要  
26 -  
27 -  
28 - if (_typeof(extra) === 'object' && extra.text) {  
29 - __html = extra.text;  
30 - }  
31 -  
32 - return __html && /*#__PURE__*/React.createElement("div", {  
33 - className: "fr-form-item-extra",  
34 - dangerouslySetInnerHTML: {  
35 - __html: __html  
36 - }  
37 - });  
38 -};  
39 -  
40 -export default Extra;  
1 -import React from 'react';  
2 -import { useStore2 } from '../../hooks';  
3 -import { isCheckBoxType } from '../../utils';  
4 -  
5 -var Description = function Description(_ref) {  
6 - var displayType = _ref.displayType,  
7 - schema = _ref.schema;  
8 - var description = schema.description,  
9 - descType = schema.descType;  
10 - if (!description) return null;  
11 -  
12 - switch (displayType) {  
13 - case 'row':  
14 - return /*#__PURE__*/React.createElement("span", {  
15 - className: "fr-tooltip-toggle",  
16 - "aria-label": description  
17 - }, /*#__PURE__*/React.createElement("i", {  
18 - className: "fr-tooltip-icon"  
19 - }), /*#__PURE__*/React.createElement("div", {  
20 - className: "fr-tooltip-container"  
21 - }, /*#__PURE__*/React.createElement("i", {  
22 - className: "fr-tooltip-triangle"  
23 - }), description));  
24 -  
25 - case 'inline':  
26 - return null;  
27 -  
28 - default:  
29 - if (descType === 'icon') {  
30 - return /*#__PURE__*/React.createElement("span", {  
31 - className: "fr-tooltip-toggle",  
32 - "aria-label": description  
33 - }, /*#__PURE__*/React.createElement("i", {  
34 - className: "fr-tooltip-icon"  
35 - }), /*#__PURE__*/React.createElement("div", {  
36 - className: "fr-tooltip-container"  
37 - }, /*#__PURE__*/React.createElement("i", {  
38 - className: "fr-tooltip-triangle"  
39 - }), description));  
40 - }  
41 -  
42 - return /*#__PURE__*/React.createElement("span", {  
43 - className: "fr-desc ml2"  
44 - }, "( ".concat(description, " )"));  
45 - }  
46 -};  
47 -  
48 -var Title = function Title(_ref2) {  
49 - var labelClass = _ref2.labelClass,  
50 - labelStyle = _ref2.labelStyle,  
51 - schema = _ref2.schema,  
52 - displayType = _ref2.displayType;  
53 -  
54 - var _useStore = useStore2(),  
55 - globalDisplayType = _useStore.displayType,  
56 - readOnly = _useStore.readOnly;  
57 -  
58 - var title = schema.title,  
59 - required = schema.required,  
60 - type = schema.type;  
61 - var isObjType = type === 'object';  
62 -  
63 - var _displayType = schema.displayType || displayType || globalDisplayType || 'column';  
64 -  
65 - return /*#__PURE__*/React.createElement("div", {  
66 - className: labelClass,  
67 - style: labelStyle  
68 - }, title ? /*#__PURE__*/React.createElement("label", {  
69 - className: "fr-label-title ".concat(isCheckBoxType(schema, readOnly) || _displayType === 'column' ? 'no-colon' : '') // checkbox不带冒号  
70 - ,  
71 - title: title  
72 - }, required === true && /*#__PURE__*/React.createElement("span", {  
73 - className: "fr-label-required"  
74 - }, " *"), /*#__PURE__*/React.createElement("span", {  
75 - className: "".concat(isObjType ? 'b' : '', " ").concat(_displayType === 'column' ? 'flex-none' : '')  
76 - }, /*#__PURE__*/React.createElement("span", {  
77 - dangerouslySetInnerHTML: {  
78 - __html: title  
79 - }  
80 - })), /*#__PURE__*/React.createElement(Description, {  
81 - schema: schema,  
82 - displayType: _displayType  
83 - })) : null);  
84 -};  
85 -  
86 -export default Title;  
1 -function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }  
2 -  
3 -function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }  
4 -  
5 -import React, { useEffect, useRef } from 'react';  
6 -import { useStore, useStore2, useTools } from '../../hooks';  
7 -import useDebouncedCallback from '../../useDebounce';  
8 -import { getValueByPath, isCheckBoxType, isObjType } from '../../utils';  
9 -import ErrorMessage from './ErrorMessage';  
10 -import Extra from './Extra';  
11 -import FieldTitle from './Title';  
12 -import ExtendedWidget from './ExtendedWidget'; // TODO: 之后不要直接用get,收口到一个内部方法getValue,便于全局 ctrl + f 查找  
13 -  
14 -var RenderField = function RenderField(props) {  
15 - var $id = props.$id,  
16 - dataIndex = props.dataIndex,  
17 - dataPath = props.dataPath,  
18 - _value = props._value,  
19 - dependValues = props.dependValues,  
20 - _schema = props._schema,  
21 - labelClass = props.labelClass,  
22 - labelStyle = props.labelStyle,  
23 - _contentClass = props.contentClass,  
24 - children = props.children,  
25 - _props$errorFields = props.errorFields,  
26 - errorFields = _props$errorFields === void 0 ? [] : _props$errorFields,  
27 - hideTitle = props.hideTitle,  
28 - displayType = props.displayType;  
29 -  
30 - var _useStore = useStore(),  
31 - formData = _useStore.formData;  
32 -  
33 - var _useStore2 = useStore2(),  
34 - debounceInput = _useStore2.debounceInput,  
35 - readOnly = _useStore2.readOnly,  
36 - disabled = _useStore2.disabled,  
37 - showValidate = _useStore2.showValidate;  
38 -  
39 - var _useTools = useTools(),  
40 - onValuesChange = _useTools.onValuesChange,  
41 - onItemChange = _useTools.onItemChange,  
42 - setEditing = _useTools.setEditing,  
43 - touchKey = _useTools.touchKey;  
44 -  
45 - var formDataRef = useRef();  
46 - formDataRef.current = formData; // console.log('<renderField>', $id);  
47 -  
48 - var errObj = errorFields.find(function (err) {  
49 - return err.name === dataPath;  
50 - });  
51 - var errorMessage = errObj && errObj.error; // 是一个list  
52 -  
53 - var hasError = Array.isArray(errorMessage) && errorMessage.length > 0; // 补上这个class,会自动让下面所有的展示ui变红!  
54 -  
55 - var contentClass = hasError && showValidate ? _contentClass + ' ant-form-item-has-error' : _contentClass;  
56 - var contentStyle = {};  
57 - var debouncedSetEditing = useDebouncedCallback(setEditing, 350);  
58 -  
59 - var _readOnly = readOnly !== undefined ? readOnly : _schema.readOnly;  
60 -  
61 - var _disabled = disabled !== undefined ? disabled : _schema.disabled; // TODO: 优化一下,只有touch还是false的时候,setTouched  
62 -  
63 -  
64 - var onChange = function onChange(value) {  
65 - // 动过的key,算被touch了, 这里之后要考虑动的来源  
66 - touchKey(dataPath); // 开始编辑,节流  
67 -  
68 - if (debounceInput) {  
69 - setEditing(true);  
70 - debouncedSetEditing(false);  
71 - }  
72 -  
73 - if (typeof dataPath === 'string') {  
74 - onItemChange(dataPath, value);  
75 - } // 先不暴露给外部,这个api  
76 -  
77 -  
78 - if (typeof onValuesChange === 'function') {  
79 - onValuesChange(_defineProperty({}, dataPath, value), formDataRef.current);  
80 - }  
81 - };  
82 -  
83 - var titleProps = {  
84 - labelClass: labelClass,  
85 - labelStyle: labelStyle,  
86 - schema: _schema,  
87 - displayType: displayType  
88 - };  
89 - var messageProps = {  
90 - message: errorMessage,  
91 - schema: _schema,  
92 - displayType: displayType,  
93 - softHidden: displayType === 'inline',  
94 - // 这个是如果没有校验信息时,展示与否  
95 - hardHidden: showValidate === false || _readOnly === true // 这个是强制的展示与否  
96 -  
97 - };  
98 - var placeholderTitleProps = {  
99 - className: labelClass,  
100 - style: labelStyle  
101 - };  
102 -  
103 - var _showTitle = !hideTitle && typeof _schema.title === 'string'; // TODO: 这块最好能判断上一层是list1,  
104 -  
105 -  
106 - if (hideTitle && _schema.title) {  
107 - _schema.placeholder = _schema.placeholder || _schema.title;  
108 - }  
109 -  
110 - var _getValue = function _getValue(path) {  
111 - return getValueByPath(formData, path);  
112 - };  
113 -  
114 - var widgetProps = {  
115 - $id: $id,  
116 - schema: _schema,  
117 - readOnly: _readOnly,  
118 - disabled: _disabled,  
119 - onChange: onChange,  
120 - getValue: _getValue,  
121 - formData: formData,  
122 - value: _value,  
123 - dependValues: dependValues,  
124 - onItemChange: onItemChange,  
125 - dataIndex: dataIndex,  
126 - dataPath: dataPath,  
127 - children: children  
128 - }; // if (_schema && _schema.default !== undefined) {  
129 - // widgetProps.value = _schema.default;  
130 - // }  
131 - // checkbox必须单独处理,布局太不同了  
132 -  
133 - if (isCheckBoxType(_schema, _readOnly)) {  
134 - return /*#__PURE__*/React.createElement(React.Fragment, null, _showTitle && /*#__PURE__*/React.createElement("div", placeholderTitleProps), /*#__PURE__*/React.createElement("div", {  
135 - className: contentClass,  
136 - style: contentStyle  
137 - }, /*#__PURE__*/React.createElement(ExtendedWidget, widgetProps), /*#__PURE__*/React.createElement(Extra, widgetProps), /*#__PURE__*/React.createElement(ErrorMessage, messageProps)));  
138 - }  
139 -  
140 - var titleElement = /*#__PURE__*/React.createElement(FieldTitle, titleProps);  
141 -  
142 - if (isObjType(_schema)) {  
143 - titleElement = /*#__PURE__*/React.createElement("div", {  
144 - style: {  
145 - display: 'flex'  
146 - }  
147 - }, titleElement, /*#__PURE__*/React.createElement(ErrorMessage, messageProps));  
148 - return /*#__PURE__*/React.createElement("div", {  
149 - className: contentClass,  
150 - style: contentStyle  
151 - }, /*#__PURE__*/React.createElement(ExtendedWidget, _extends({}, widgetProps, {  
152 - message: errorMessage,  
153 - title: _showTitle ? titleElement : undefined  
154 - })), /*#__PURE__*/React.createElement(Extra, widgetProps));  
155 - }  
156 -  
157 - return /*#__PURE__*/React.createElement(React.Fragment, null, _showTitle && titleElement, /*#__PURE__*/React.createElement("div", {  
158 - className: "".concat(contentClass, " ").concat(hideTitle ? 'fr-content-no-title' : ''),  
159 - style: contentStyle  
160 - }, /*#__PURE__*/React.createElement(ExtendedWidget, widgetProps), /*#__PURE__*/React.createElement(Extra, widgetProps), /*#__PURE__*/React.createElement(ErrorMessage, messageProps)));  
161 -};  
162 -  
163 -export default RenderField;  
1 -var _excluded = ["id", "_item", "dataIndex", "hideTitle", "hideValidation", "debugCss"],  
2 - _excluded2 = ["id", "item", "dataIndex", "dataPath", "hideTitle", "hideValidation", "debugCss", "schema", "_value", "dependValues", "displayType", "column", "labelWidth", "readOnly", "errorFields", "effectiveLabelWidth"];  
3 -  
4 -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }  
5 -  
6 -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }  
7 -  
8 -function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }  
9 -  
10 -function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }  
11 -  
12 -function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }  
13 -  
14 -import React, { useRef } from 'react';  
15 -import RenderList from './RenderChildren/RenderList';  
16 -import RenderObject from './RenderChildren/RenderObject';  
17 -import RenderField from './RenderField';  
18 -import { useStore, useStore2 } from '../hooks';  
19 -import { isLooselyNumber, isCssLength, getParentProps, getParentPath, isListType, isCheckBoxType, isObjType, getValueByPath, getDataPath, parseRootValueInSchema, clone } from '../utils';  
20 -  
21 -var Core = function Core(_ref) {  
22 - var _ref$id = _ref.id,  
23 - id = _ref$id === void 0 ? '#' : _ref$id,  
24 - _item = _ref._item,  
25 - _ref$dataIndex = _ref.dataIndex,  
26 - dataIndex = _ref$dataIndex === void 0 ? [] : _ref$dataIndex,  
27 - _ref$hideTitle = _ref.hideTitle,  
28 - hideTitle = _ref$hideTitle === void 0 ? false : _ref$hideTitle,  
29 - _ref$hideValidation = _ref.hideValidation,  
30 - hideValidation = _ref$hideValidation === void 0 ? false : _ref$hideValidation,  
31 - debugCss = _ref.debugCss,  
32 - rest = _objectWithoutProperties(_ref, _excluded);  
33 -  
34 - // console.log('<Core>', id);  
35 - var snapShot = useRef();  
36 -  
37 - var _useStore = useStore(),  
38 - flatten = _useStore.flatten,  
39 - errorFields = _useStore.errorFields,  
40 - isEditing = _useStore.isEditing,  
41 - formData = _useStore.formData,  
42 - allTouched = _useStore.allTouched;  
43 -  
44 - var _useStore2 = useStore2(),  
45 - displayType = _useStore2.displayType,  
46 - column = _useStore2.column,  
47 - labelWidth = _useStore2.labelWidth,  
48 - readOnly = _useStore2.readOnly;  
49 -  
50 - var item = _item ? _item : flatten[id];  
51 - if (!item) return null;  
52 - var dataPath = getDataPath(id, dataIndex);  
53 - var parentPath = getParentPath(dataPath);  
54 -  
55 - var _value = getValueByPath(formData, dataPath);  
56 -  
57 - var schema = clone(item.schema);  
58 - var dependencies = schema.dependencies;  
59 - var dependValues = [];  
60 - var rootValue;  
61 -  
62 - try {  
63 - if (Array.isArray(dependencies)) {  
64 - dependencies.forEach(function (item) {  
65 - var itemPath = getDataPath(item, dataIndex);  
66 - var result = getValueByPath(formData, itemPath);  
67 - dependValues.push(result);  
68 - });  
69 - }  
70 - } catch (error) {  
71 - console.error("dependencies \u8BA1\u7B97\u62A5\u9519\uFF0C".concat(dependencies));  
72 - }  
73 -  
74 - try {  
75 - rootValue = getValueByPath(formData, parentPath);  
76 - } catch (error) {} // 节流部分逻辑,编辑时不执行  
77 -  
78 -  
79 - if (isEditing && snapShot.current) {  
80 - schema = snapShot.current;  
81 - } else {  
82 - if (JSON.stringify(schema).indexOf('rootValue') > -1) {  
83 - schema = parseRootValueInSchema(schema, rootValue);  
84 - }  
85 -  
86 - snapShot.current = schema;  
87 - } // 真正有效的label宽度需要从现在所在item开始一直往上回溯(设计成了继承关系),找到的第一个有值的 ui:labelWidth  
88 -  
89 -  
90 - var effectiveLabelWidth = getParentProps('labelWidth', id, flatten) || labelWidth;  
91 -  
92 - var dataProps = _objectSpread({  
93 - id: id,  
94 - item: item,  
95 - // 如果直接传了item,就不用id去取item, 暂时是内部属性,不外用  
96 - dataIndex: dataIndex,  
97 - // 数据来源是数组的第几个index,上层每有一个list,就push一个index  
98 - dataPath: dataPath,  
99 - _value: _value,  
100 - dependValues: dependValues,  
101 - hideTitle: hideTitle,  
102 - hideValidation: hideValidation,  
103 - debugCss: debugCss,  
104 - schema: schema,  
105 - displayType: displayType,  
106 - column: column,  
107 - labelWidth: labelWidth,  
108 - readOnly: readOnly,  
109 - errorFields: errorFields,  
110 - effectiveLabelWidth: effectiveLabelWidth,  
111 - allTouched: allTouched  
112 - }, rest);  
113 -  
114 - return /*#__PURE__*/React.createElement(CoreRender, dataProps);  
115 -};  
116 -  
117 -var CoreRender = function CoreRender(_ref2) {  
118 - var id = _ref2.id,  
119 - item = _ref2.item,  
120 - dataIndex = _ref2.dataIndex,  
121 - dataPath = _ref2.dataPath,  
122 - hideTitle = _ref2.hideTitle,  
123 - hideValidation = _ref2.hideValidation,  
124 - debugCss = _ref2.debugCss,  
125 - schema = _ref2.schema,  
126 - _value = _ref2._value,  
127 - dependValues = _ref2.dependValues,  
128 - displayType = _ref2.displayType,  
129 - column = _ref2.column,  
130 - labelWidth = _ref2.labelWidth,  
131 - readOnly = _ref2.readOnly,  
132 - errorFields = _ref2.errorFields,  
133 - effectiveLabelWidth = _ref2.effectiveLabelWidth,  
134 - rest = _objectWithoutProperties(_ref2, _excluded2);  
135 -  
136 - // if (schema.hidden) {  
137 - // return null;  
138 - // }  
139 - // 样式的逻辑全放在这层  
140 - // displayType 一层层网上找值  
141 - var _displayType = schema.displayType || rest.displayType || displayType || 'column';  
142 -  
143 - var isList = isListType(schema);  
144 - var isObj = isObjType(schema);  
145 - var isComplex = isObj || isList;  
146 - var isCheckBox = isCheckBoxType(schema, readOnly);  
147 - var width = schema.width || schema['ui:width'];  
148 - var containerClass = "fr-field ".concat(_displayType === 'inline' ? '' : 'w-100', " flex");  
149 - var labelClass = "fr-label";  
150 - var contentClass = "fr-content";  
151 -  
152 - if (typeof schema.className === 'string') {  
153 - containerClass += ' ' + schema.className;  
154 - } // common classNames dispite row or column  
155 -  
156 -  
157 - switch (schema.type) {  
158 - case 'object':  
159 - if (isObj) {  
160 - if (schema.title) {  
161 - labelClass += ' fr-label-object';  
162 - }  
163 -  
164 - containerClass += ' fr-field-object';  
165 - }  
166 -  
167 - break;  
168 -  
169 - case 'array':  
170 - // list 有两种展示形式!  
171 - if (isList) {  
172 - if (schema.title) {  
173 - labelClass += ' fr-label-list';  
174 - }  
175 -  
176 - containerClass += ' fr-field-column';  
177 - }  
178 -  
179 - break;  
180 -  
181 - case 'boolean':  
182 - if (isCheckBox) {  
183 - contentClass += ' fr-content-column'; // checkbox高度短,需要居中对齐  
184 -  
185 - containerClass += " flex ".concat(_displayType === 'column' ? 'flex-column' : '');  
186 - }  
187 -  
188 - break;  
189 -  
190 - default:  
191 - } // column specific className  
192 -  
193 -  
194 - if (!isComplex && !isCheckBox) {  
195 - if (_displayType === 'column') {  
196 - containerClass += ' flex-column';  
197 - labelClass += ' fr-label-column';  
198 - contentClass += ' fr-content-column';  
199 -  
200 - switch (schema.type) {  
201 - case 'object':  
202 - break;  
203 -  
204 - case 'array':  
205 - if (schema.title && !schema.enum) {// labelClass += ' b mb2';  
206 - }  
207 -  
208 - break;  
209 -  
210 - case 'boolean':  
211 - break;  
212 -  
213 - default:  
214 - }  
215 - } else if (_displayType === 'row') {  
216 - // row specific className  
217 - containerClass += '';  
218 - labelClass += ' fr-label-row';  
219 - contentClass += ' fr-content-row';  
220 -  
221 - if (!isObj && !isCheckBox) {  
222 - labelClass += ' flex-shrink-0 fr-label-row';  
223 - contentClass += ' flex-grow-1 relative';  
224 - }  
225 - }  
226 - } // style part  
227 -  
228 -  
229 - var columnStyle = {};  
230 -  
231 - if (schema.hidden) {  
232 - columnStyle.display = 'none';  
233 - } // if (!isComplex) {  
234 - // }  
235 -  
236 -  
237 - if (!isObj) {  
238 - if (width) {  
239 - columnStyle.width = width;  
240 - columnStyle.paddingRight = 8;  
241 - } else if (column > 1) {  
242 - columnStyle.width = "calc(100% /".concat(column, ")");  
243 - columnStyle.paddingRight = 8;  
244 - }  
245 - }  
246 -  
247 - var _labelWidth = isLooselyNumber(effectiveLabelWidth) ? Number(effectiveLabelWidth) : isCssLength(effectiveLabelWidth) ? effectiveLabelWidth : 110; // 默认是 110px 的长度  
248 -  
249 -  
250 - var labelStyle = {  
251 - width: _labelWidth  
252 - };  
253 -  
254 - if (isComplex || _displayType === 'column') {  
255 - labelStyle = {  
256 - flexGrow: 1  
257 - };  
258 - }  
259 -  
260 - if (_displayType === 'inline') {  
261 - labelStyle = {  
262 - marginTop: 5,  
263 - paddingLeft: 12  
264 - };  
265 - labelClass = '';  
266 - contentClass += ' fr-content-inline';  
267 -  
268 - if (containerClass.indexOf('fr-field-object') === -1) {  
269 - containerClass += ' fr-field-inline';  
270 - }  
271 - }  
272 -  
273 - var hasChildren = item.children && item.children.length > 0;  
274 - var fieldProps = {  
275 - $id: id,  
276 - dataIndex: dataIndex,  
277 - dataPath: dataPath,  
278 - _value: _value,  
279 - dependValues: dependValues,  
280 - _schema: schema,  
281 - labelClass: labelClass,  
282 - labelStyle: labelStyle,  
283 - contentClass: contentClass,  
284 - errorFields: errorFields,  
285 - // 层级间可使用的字段  
286 - displayType: _displayType,  
287 - hideTitle: hideTitle,  
288 - hideValidation: hideValidation  
289 - };  
290 - var objChildren = /*#__PURE__*/React.createElement("div", {  
291 - className: "flex flex-wrap"  
292 - }, /*#__PURE__*/React.createElement(RenderObject, {  
293 - dataIndex: dataIndex,  
294 - errorFields: errorFields,  
295 - displayType: _displayType,  
296 - hideTitle: hideTitle  
297 - }, item.children));  
298 - var listChildren = /*#__PURE__*/React.createElement(RenderList, {  
299 - parentId: id,  
300 - schema: schema,  
301 - dataIndex: dataIndex,  
302 - errorFields: errorFields,  
303 - displayType: _displayType,  
304 - hideTitle: hideTitle  
305 - }, item.children); // 计算 children  
306 -  
307 - var _children = null;  
308 -  
309 - if (hasChildren) {  
310 - if (isObj) {  
311 - _children = objChildren;  
312 - } else if (isList) {  
313 - _children = listChildren;  
314 - }  
315 - } else if (isCheckBox) {  
316 - _children = schema.title;  
317 - }  
318 -  
319 - return /*#__PURE__*/React.createElement("div", {  
320 - style: columnStyle,  
321 - className: "".concat(containerClass, " ").concat(debugCss ? 'debug' : '')  
322 - }, /*#__PURE__*/React.createElement(RenderField, fieldProps, _children));  
323 -};  
324 -  
325 -var areEqual = function areEqual(prev, current) {  
326 - if (prev.allTouched !== current.allTouched) {  
327 - return false;  
328 - }  
329 -  
330 - if (prev.displayType !== current.displayType) {  
331 - return false;  
332 - }  
333 -  
334 - if (prev.column !== current.column) {  
335 - return false;  
336 - }  
337 -  
338 - if (prev.labelWidth !== current.labelWidth) {  
339 - return false;  
340 - }  
341 -  
342 - if (JSON.stringify(prev.dependValues) !== JSON.stringify(current.dependValues)) {  
343 - return false;  
344 - }  
345 -  
346 - if (JSON.stringify(prev._value) === JSON.stringify(current._value) && JSON.stringify(prev.schema) === JSON.stringify(current.schema) && JSON.stringify(prev.errorFields) === JSON.stringify(current.errorFields)) {  
347 - return true;  
348 - }  
349 -  
350 - return false;  
351 -};  
352 -  
353 -var MCore = /*#__PURE__*/React.memo(CoreRender, areEqual);  
354 -export default Core;  
1 -var _excluded = ["schema"],  
2 - _excluded2 = ["onChange", "value", "defaultValue", "schema", "readOnly"];  
3 -  
4 -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }  
5 -  
6 -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }  
7 -  
8 -function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }  
9 -  
10 -function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }  
11 -  
12 -function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }  
13 -  
14 -import React from "react";  
15 -import { defaultGetValueFromEvent } from './utils';  
16 -export var createWidget = function createWidget(mapProps, extraSchema) {  
17 - return function (Component) {  
18 - return function (props) {  
19 - var schema = props.schema,  
20 - rest = _objectWithoutProperties(props, _excluded);  
21 -  
22 - var _schema = _objectSpread(_objectSpread({}, schema), extraSchema);  
23 -  
24 - var propsMap = typeof mapProps === 'function' ? mapProps(_objectSpread({  
25 - schema: _schema  
26 - }, rest)) : {};  
27 -  
28 - var _props = _objectSpread(_objectSpread({  
29 - schema: _schema  
30 - }, rest), propsMap);  
31 -  
32 - var finalProps = transformProps(_props);  
33 - return /*#__PURE__*/React.createElement(Component, finalProps);  
34 - };  
35 - };  
36 -};  
37 -export var transformProps = function transformProps(props) {  
38 - var onChange = props.onChange,  
39 - value = props.value,  
40 - defaultValue = props.defaultValue,  
41 - ownSchema = props.schema,  
42 - readOnly = props.readOnly,  
43 - rest = _objectWithoutProperties(props, _excluded2);  
44 -  
45 - var schema = _objectSpread({}, ownSchema);  
46 -  
47 - var _ref = schema || {},  
48 - trigger = _ref.trigger,  
49 - valuePropName = _ref.valuePropName;  
50 -  
51 - var controlProps = {};  
52 - var _valuePropName = 'value';  
53 -  
54 - var _value = value === undefined ? defaultValue : value;  
55 -  
56 - if (valuePropName && typeof valuePropName === 'string') {  
57 - _valuePropName = valuePropName;  
58 - controlProps[valuePropName] = _value;  
59 - } else {  
60 - controlProps.value = _value;  
61 - }  
62 -  
63 - var _onChange = function _onChange() {  
64 - for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {  
65 - args[_key] = arguments[_key];  
66 - }  
67 -  
68 - var newValue = defaultGetValueFromEvent.apply(void 0, [_valuePropName].concat(args));  
69 - onChange(newValue);  
70 - };  
71 -  
72 - if (trigger && typeof trigger === 'string') {  
73 - controlProps[trigger] = _onChange;  
74 - } else {  
75 - controlProps.onChange = _onChange;  
76 - }  
77 -  
78 - var usefulPropsFromSchema = {  
79 - disabled: schema.disabled || schema['ui:disabled'],  
80 - readOnly: schema.readOnly || schema['ui:readonly'] || readOnly,  
81 - hidden: schema.hidden || schema['ui:hidden']  
82 - };  
83 -  
84 - var _props = _objectSpread(_objectSpread(_objectSpread({}, controlProps), {}, {  
85 - schema: schema  
86 - }, usefulPropsFromSchema), rest);  
87 -  
88 - return _props;  
89 -};  
1 -function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }  
2 -  
3 -function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }  
4 -  
5 -function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }  
6 -  
7 -function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }  
8 -  
9 -function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }  
10 -  
11 -function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }  
12 -  
13 -function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }  
14 -  
15 -function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }  
16 -  
17 -function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }  
18 -  
19 -import { useReducer, useContext, useRef, useEffect, useState, createContext } from 'react';  
20 -export var Ctx = /*#__PURE__*/createContext(function () {});  
21 -export var StoreCtx = /*#__PURE__*/createContext({});  
22 -export var Store2Ctx = /*#__PURE__*/createContext({});  
23 -export var useTools = function useTools() {  
24 - return useContext(Ctx);  
25 -};  
26 -export var useStore = function useStore() {  
27 - return useContext(StoreCtx);  
28 -};  
29 -export var useStore2 = function useStore2() {  
30 - return useContext(Store2Ctx);  
31 -};  
32 -export var useSet = function useSet(initState) {  
33 - var _useReducer = useReducer(function (state, newState) {  
34 - var action = newState;  
35 -  
36 - if (typeof newState === 'function') {  
37 - action = action(state);  
38 - }  
39 -  
40 - if (newState.action && newState.payload) {  
41 - action = newState.payload;  
42 -  
43 - if (typeof action === 'function') {  
44 - action = action(state);  
45 - }  
46 - }  
47 -  
48 - var result = _objectSpread(_objectSpread({}, state), action); // console.group(newState.action || 'action'); // TODO: give it a name  
49 - // console.log('%cState:', 'color: #9E9E9E; font-weight: 700;', state);  
50 - // console.log('%cAction:', 'color: #00A7F7; font-weight: 700;', action);  
51 - // console.log('%cNext:', 'color: #47B04B; font-weight: 700;', result);  
52 - // console.groupEnd();  
53 -  
54 -  
55 - // console.group(newState.action || 'action'); // TODO: give it a name  
56 - // console.log('%cState:', 'color: #9E9E9E; font-weight: 700;', state);  
57 - // console.log('%cAction:', 'color: #00A7F7; font-weight: 700;', action);  
58 - // console.log('%cNext:', 'color: #47B04B; font-weight: 700;', result);  
59 - // console.groupEnd();  
60 - return result;  
61 - }, initState),  
62 - _useReducer2 = _slicedToArray(_useReducer, 2),  
63 - state = _useReducer2[0],  
64 - setState = _useReducer2[1];  
65 -  
66 - return [state, setState];  
67 -};  
68 -export function useInterval(callback, delay, start) {  
69 - var savedCallback = useRef();  
70 - useEffect(function () {  
71 - savedCallback.current = callback;  
72 - }, [callback]);  
73 - var id = useRef();  
74 - useEffect(function () {  
75 - if (!start) {  
76 - return;  
77 - }  
78 -  
79 - function tick() {  
80 - savedCallback && savedCallback.current && savedCallback.current();  
81 - }  
82 -  
83 - tick();  
84 -  
85 - if (delay !== null) {  
86 - id.current = setInterval(tick, delay);  
87 - return function () {  
88 - return clearInterval(id.current);  
89 - };  
90 - }  
91 - }, [delay, start]);  
92 - return function () {  
93 - return clearInterval(id.current);  
94 - };  
95 -}  
96 -export function usePrevious(value) {  
97 - // The ref object is a generic container whose current property is mutable ...  
98 - // ... and can hold any value, similar to an instance property on a class  
99 - var ref = useRef(); // Store current value in ref  
100 -  
101 - useEffect(function () {  
102 - ref.current = value;  
103 - }, [value]); // Only re-run if value changes  
104 - // Return previous value (happens before update in useEffect above)  
105 -  
106 - return ref.current;  
107 -}  
108 -export var useShowOnce = function useShowOnce(localKey) {  
109 - // 从 localStorage 读取 key 值  
110 - var _useState = useState(false),  
111 - _useState2 = _slicedToArray(_useState, 2),  
112 - show = _useState2[0],  
113 - setShow = _useState2[1];  
114 -  
115 - var localStr;  
116 -  
117 - try {  
118 - localStr = localStorage.getItem(localKey);  
119 - } catch (error) {}  
120 -  
121 - if (!localStr) {  
122 - setShow(true);  
123 - localStorage.setItem(localKey, JSON.stringify(true));  
124 - }  
125 -  
126 - return show;  
127 -};  
128 -export var useModal = function useModal() {  
129 - var _useState3 = useState(false),  
130 - _useState4 = _slicedToArray(_useState3, 2),  
131 - show = _useState4[0],  
132 - setShow = _useState4[1];  
133 -  
134 - var toggle = function toggle() {  
135 - return setShow(!show);  
136 - };  
137 -  
138 - return [show, toggle];  
139 -};  
140 -export var useWindowState = function useWindowState(initState) {  
141 - var _useState5 = useState(initState),  
142 - _useState6 = _slicedToArray(_useState5, 2),  
143 - state = _useState6[0],  
144 - setState = _useState6[1];  
145 -  
146 - return [state, setState];  
147 -};  
148 -export var useStorageState = function useStorageState() {  
149 - var initState = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};  
150 - var searchKey = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'SAVES';  
151 -  
152 - var readSearchFromStorage = function readSearchFromStorage() {  
153 - var searchStr = localStorage.getItem(searchKey);  
154 -  
155 - if (searchStr) {  
156 - try {  
157 - return JSON.parse(searchStr);  
158 - } catch (error) {  
159 - return initState;  
160 - }  
161 - }  
162 -  
163 - return initState;  
164 - };  
165 -  
166 - var _useState7 = useState(readSearchFromStorage()),  
167 - _useState8 = _slicedToArray(_useState7, 2),  
168 - data = _useState8[0],  
169 - setData = _useState8[1];  
170 -  
171 - var setSearchWithStorage = function setSearchWithStorage(search) {  
172 - setData(search);  
173 - localStorage.setItem(searchKey, JSON.stringify(search));  
174 - };  
175 -  
176 - return [data, setSearchWithStorage];  
177 -};  
1 -/*  
2 - 用于原有样式的覆盖  
3 - */  
4 -.fr-container {  
5 - /* Row */  
6 - /* 自定义类 */  
7 - /* 组件内部样式*/  
8 - /* 其他样式 */  
9 -}  
10 -.fr-container .fr-field {  
11 - font-size: 14px;  
12 - padding: 0;  
13 - color: rgba(0, 0, 0, 0.85);  
14 - line-height: 1.5715;  
15 - margin-bottom: 0;  
16 -}  
17 -.fr-container .fr-field-column {  
18 - flex-direction: column;  
19 -}  
20 -.fr-container .fr-field-object {  
21 - flex-direction: column;  
22 -}  
23 -.fr-container .fr-field-inline {  
24 - margin-bottom: 12px;  
25 -}  
26 -.fr-container .fr-item-wrapper {  
27 - position: relative;  
28 - display: flex;  
29 - align-items: center;  
30 - min-height: 32px;  
31 -}  
32 -.fr-container .ant-table-cell .fr-field {  
33 - margin-bottom: 0;  
34 -}  
35 -.fr-container .fr-collapse-object {  
36 - margin-bottom: 8px;  
37 - overflow: hidden;  
38 - background: #f7f7f7;  
39 - border-radius: 2px;  
40 -}  
41 -.fr-container .fr-collapse-object .ant-collapse-header {  
42 - padding-bottom: 4px !important;  
43 - padding-top: 4px !important;  
44 -}  
45 -.fr-container .fr-collapse-object .ant-collapse-content-box {  
46 - padding: 8px 8px 4px 8px !important;  
47 -}  
48 -.fr-container .fr-collapse-object .ant-collapse-arrow {  
49 - padding-top: 5px !important;  
50 -}  
51 -.fr-container .fr-label {  
52 - display: block;  
53 -}  
54 -.fr-container .fr-label-row {  
55 - text-align: right;  
56 - flex-shrink: 0;  
57 - margin-top: 5px;  
58 -}  
59 -.fr-container .fr-label-column {  
60 - margin-bottom: 4px;  
61 -}  
62 -.fr-container .fr-label-title {  
63 - display: inline-flex;  
64 - color: #333;  
65 - font-size: 14px;  
66 - min-height: 22px;  
67 - /* ""的标签页占位 */  
68 - line-height: 22px;  
69 -}  
70 -.fr-container .fr-label-required {  
71 - margin: 1px 4px 0 0;  
72 - color: #f5222d;  
73 - font-size: 14px;  
74 - font-family: SimSun, sans-serif;  
75 -}  
76 -.fr-container .fr-label-title::after {  
77 - content: ':';  
78 - position: relative;  
79 - top: -0.5px;  
80 - margin: 0 10px 0 2px;  
81 -}  
82 -.fr-container .fr-label-title.no-colon::after {  
83 - content: '';  
84 - margin: 0;  
85 -}  
86 -.fr-container .fr-label-object .fr-label-title {  
87 - font-size: 16px;  
88 - color: #222;  
89 -}  
90 -.fr-container .fr-label-list {  
91 - margin-bottom: 5px;  
92 -}  
93 -.fr-container .fr-content {  
94 - width: 100%;  
95 -}  
96 -.fr-container .fr-list-1 .fr-content {  
97 - min-width: 140px;  
98 -}  
99 -.fr-container .fr-list-1 .fr-content-row {  
100 - flex: 1;  
101 - position: relative;  
102 -}  
103 -.fr-container .fr-list-1 .fr-content.fr-content-inline {  
104 - width: unset;  
105 -}  
106 -.fr-container .fr-list-1 .fr-content.fr-content-inline.fr-content-no-title {  
107 - margin-right: 8px;  
108 -}  
109 -.fr-container .fr-desc {  
110 - /* margin-top: 3px; */  
111 - font-size: 12px;  
112 - word-break: break-all;  
113 - color: #888;  
114 -}  
115 -.fr-container .fr-validate {  
116 - margin-left: 12px;  
117 - font-size: 12px;  
118 - word-break: break-all;  
119 - color: #f5222d;  
120 -}  
121 -.fr-container .fr-validate-row {  
122 - margin: 3px 0 0 0;  
123 -}  
124 -.fr-container .fr-field-row .fr-tooltip-icon {  
125 - margin: 3px 2px 0 0;  
126 -}  
127 -.fr-container .hover-b--black-20:hover {  
128 - border-color: rgba(0, 0, 0, 0.3);  
129 -}  
130 -.fr-container .pt44 {  
131 - padding-top: 46px;  
132 -}  
133 -.fr-container .pv12 {  
134 - padding-top: 12px;  
135 - padding-bottom: 12px;  
136 -}  
137 -.fr-container .fr-move-icon {  
138 - position: absolute;  
139 - top: 0;  
140 - right: 0;  
141 - padding-top: 2px;  
142 - padding-right: 10px;  
143 - font-size: 24px;  
144 - font-weight: 300;  
145 -}  
146 -.fr-container .fr-move-icon:hover {  
147 - cursor: move;  
148 -}  
149 -.fr-container .fr-color-picker {  
150 - width: 100%;  
151 - display: flex;  
152 - flex-direction: row;  
153 - align-items: center;  
154 - color: #666;  
155 -}  
156 -.fr-container .fr-color-picker .rc-color-picker-trigger {  
157 - margin-right: 12px;  
158 - height: 32px;  
159 - width: 60px;  
160 - border: 1px solid #e5e5e5;  
161 -}  
162 -.fr-container .fr-color-picker > p {  
163 - margin: 0;  
164 - font-size: 14px;  
165 - line-height: 28px;  
166 -}  
167 -.fr-container .fr-color-picker .rc-color-picker-wrap {  
168 - display: flex;  
169 -}  
170 -.fr-container .next-input,  
171 -.fr-container .next-number-picker {  
172 - width: 100%;  
173 -}  
174 -.fr-container .upload-img {  
175 - max-width: 200px;  
176 - max-height: 200px;  
177 - margin-right: 24px;  
178 -}  
179 -.fr-container .fr-preview-image {  
180 - width: 160px;  
181 -}  
182 -.fr-container .fr-preview {  
183 - position: relative;  
184 - cursor: pointer;  
185 -}  
186 -.fr-container .fr-upload-mod,  
187 -.fr-container .fr-upload-file {  
188 - display: flex;  
189 -}  
190 -.fr-container .fr-upload-mod {  
191 - align-items: center;  
192 -}  
193 -.fr-container .fr-upload-mod .fr-upload-preview {  
194 - margin: 0 12px;  
195 -}  
196 -.fr-container .fr-upload-file .ant-upload-list-item {  
197 - margin: 5px 0 0 8px;  
198 -}  
199 -.fr-container .fr-upload-file .ant-upload-list-item-name {  
200 - margin-right: 6px;  
201 -}  
202 -.fr-container .fr-upload-file .ant-upload-list-item-info {  
203 - cursor: pointer;  
204 -}  
205 -.fr-container .fr-upload-file .next-upload-list-text .next-upload-list-item-done,  
206 -.fr-container .fr-upload-file .next-upload-list-text .next-upload-list-item .next-icon {  
207 - height: 28px;  
208 - line-height: 28px;  
209 - margin-left: 12px;  
210 -}  
211 -.fr-container .fr-upload-file .next-upload-list-item-name-wrap {  
212 - margin-top: -4px;  
213 -}  
214 -.fr-container .fr-sort-help-class {  
215 - background: #fff;  
216 -}  
217 -.fr-container .fold-icon.fold-icon-active {  
218 - transform: rotate(0deg);  
219 -}  
220 -.fr-container .fold-icon {  
221 - transform: rotate(-90deg);  
222 - transition: transform 0.24s;  
223 - cursor: pointer;  
224 - position: relative;  
225 -}  
226 -.fr-container .fold-icon::after {  
227 - content: '';  
228 - position: absolute;  
229 - top: -20px;  
230 - right: -10px;  
231 - bottom: -5px;  
232 - left: -20px;  
233 -}  
234 -.fr-container .fr-tooltip-toggle {  
235 - cursor: pointer;  
236 - position: relative;  
237 -}  
238 -.fr-container .fr-tooltip-toggle:hover .fr-tooltip-container {  
239 - opacity: 1;  
240 - visibility: visible;  
241 -}  
242 -.fr-container .fr-tooltip-icon {  
243 - height: 14px;  
244 - width: 14px;  
245 - background-image: url('');  
246 - background-size: cover;  
247 - display: block;  
248 - margin: 4px 0 0 4px;  
249 -}  
250 -.fr-container .fr-tooltip-container {  
251 - position: absolute;  
252 - width: 160px;  
253 - white-space: initial !important;  
254 - top: -4px;  
255 - left: 0;  
256 - bottom: unset;  
257 - transform: translateY(-100%);  
258 - text-align: left;  
259 - background: #2b222a;  
260 - padding: 4px;  
261 - margin-left: -69px;  
262 - border-radius: 4px;  
263 - color: #efefef;  
264 - font-size: 13px;  
265 - cursor: auto;  
266 - z-index: 99999;  
267 - transition: all 0.5s ease;  
268 - opacity: 0;  
269 - visibility: hidden;  
270 - word-wrap: break-word;  
271 -}  
272 -.fr-container .fr-tooltip-triangle {  
273 - position: absolute;  
274 - left: 50%;  
275 - border-left: 5px solid transparent;  
276 - border-right: 5px solid transparent;  
277 - border-top: 5px solid #2b222a;  
278 - transition: all 0.5s ease;  
279 - content: ' ';  
280 - font-size: 0;  
281 - line-height: 0;  
282 - margin-left: -5px;  
283 - width: 0;  
284 - bottom: -5px;  
285 -}  
286 -.fr-container .fr-tooltip-toggle::before,  
287 -.fr-container .fr-tooltip-toggle::after {  
288 - color: #efefef;  
289 - font-size: 13px;  
290 - opacity: 0;  
291 - pointer-events: none;  
292 - text-align: center;  
293 -}  
294 -.fr-container .fr-tooltip-toggle:focus::before,  
295 -.fr-container .fr-tooltip-toggle:focus::after,  
296 -.fr-container .fr-tooltip-toggle:hover::before,  
297 -.fr-container .fr-tooltip-toggle:hover::after {  
298 - opacity: 1;  
299 - transition: all 0.75s ease;  
300 -}  
301 -.fr-container .fr-slider {  
302 - display: flex;  
303 - width: 100%;  
304 - align-items: center;  
305 -}  
306 -.fr-container .fr-map {  
307 - display: flex;  
308 - flex-wrap: wrap;  
309 -}  
310 -.fr-container .fr-arrow-icon {  
311 - cursor: pointer;  
312 -}  
313 -.fr-container .fr-row-error {  
314 - background-color: rgba(255, 77, 79, 0.2);  
315 -}  
316 -.fr-container .fr-theme-card-wrap {  
317 - background-color: #fff;  
318 - padding: 36px 40px;  
319 - margin-bottom: 24px;  
320 - border-radius: 4px;  
321 - display: flex;  
322 - justify-content: space-between;  
323 -}  
324 -.fr-container .fr-theme-card-wrap .fr-theme-card-title {  
325 - font-size: 16px;  
326 - margin-bottom: 16px;  
327 -}  
1 -import * as React from 'react';  
2 -export interface Error {  
3 - /** 错误的数据路径 */  
4 - name: string;  
5 - /** 错误的内容 */  
6 - error: string[];  
7 -}  
8 -export interface FormParams {  
9 - formData?: any;  
10 - onChange?: (data: any) => void;  
11 - onValidate?: (valid: any) => void;  
12 - showValidate?: boolean;  
13 - /** 数据分析接口,表单展示完成渲染时触发 */  
14 - logOnMount?: (stats: any) => void;  
15 - /** 数据分析接口,表单提交成功时触发,获得本次表单填写的总时长 */  
16 - logOnSubmit?: (stats: any) => void;  
17 -}  
18 -  
19 -export interface ValidateParams {  
20 - formData: any;  
21 - schema: any;  
22 - error: Error[];  
23 - [k: string]: any;  
24 -}  
25 -export interface FormInstance {  
26 - formData: any;  
27 - schema: any;  
28 - flatten: any;  
29 - touchedKeys: string[];  
30 - touchKey: (key: string) => void;  
31 - onItemChange: (path: string, value: any) => void;  
32 - setValueByPath: (path: string, value: any) => void;  
33 - getSchemaByPath: (path: string) => object;  
34 - setSchemaByPath: (path: string, value: any) => void;  
35 - setSchema: (settings: any) => void;  
36 - setValues: (formData: any) => void;  
37 - getValues: () => any;  
38 - resetFields: () => void;  
39 - submit: () => Promise<void> | Promise<any[]>;  
40 - submitData: any;  
41 - errorFields: Error[];  
42 - isValidating: boolean;  
43 - outsideValidating: boolean;  
44 - isSubmitting: boolean;  
45 - endValidating: () => void;  
46 - endSubmitting: () => void;  
47 - setErrorFields: (error: Error[]) => void;  
48 - removeErrorField: (path: string) => void;  
49 - removeTouched: (path: string) => void;  
50 - changeTouchedKeys: (pathArray: string[]) => void;  
51 - isEditing: boolean;  
52 - setEditing: (status: boolean) => void;  
53 - syncStuff: (args: any) => void;  
54 - /** 折中升级方案中使用到,正常用不到 */  
55 - init: () => void;  
56 - /** 数据分析接口,表单展示完成渲染时触发 */  
57 - logOnMount?: (any) => void;  
58 - /** 数据分析接口,表单提交成功时触发,获得本次表单填写的总时长 */  
59 - logOnSubmit?: (any) => void;  
60 -}  
61 -  
62 -export type WatchProperties = {  
63 - [path: string]:  
64 - | {  
65 - handler: (value: any) => void;  
66 - immediate?: boolean;  
67 - }  
68 - | ((value: any) => void);  
69 -};  
70 -  
71 -export interface FRProps {  
72 - /** 表单 id */  
73 - id?: string | number;  
74 - /** 表单顶层的className */  
75 - className?: string;  
76 - /** 表单顶层的样式 */  
77 - style?: any;  
78 - /** 表单 schema */  
79 - schema: any;  
80 - /** form单例 */  
81 - form: FormInstance;  
82 - /** 组件和schema的映射规则 */  
83 - mapping?: any;  
84 - /** 自定义组件 */  
85 - widgets?: any;  
86 - /** 表单提交前钩子 */  
87 - displayType?: string;  
88 - /** 只读模式 */  
89 - readOnly?: boolean;  
90 - /** 禁用模式 */  
91 - disabled?: boolean;  
92 - /** 标签宽度 */  
93 - labelWidth?: string | number;  
94 - /** antd的全局config */  
95 - configProvider?: any;  
96 - theme?: string | number;  
97 - /** 覆盖默认的校验信息 */  
98 - validateMessages?: any;  
99 - /** 显示当前表单内部状态 */  
100 - debug?: boolean;  
101 - /** 显示css布局提示线 */  
102 - debugCss?: boolean;  
103 - locale?: string;  
104 - column?: number;  
105 - debounceInput?: boolean;  
106 - size?: string;  
107 - // 数据会作为 beforeFinish 的第四个参数传入  
108 - config?: any;  
109 - // 类似于 vuejs 的 watch 的用法,监控值的变化,触发 callback  
110 - watch?: WatchProperties;  
111 - /** 对象组件是否折叠(全局的控制) */  
112 - allCollapsed?: boolean;  
113 - /** 表单的全局共享属性 */  
114 - globalProps?: any;  
115 - /** 表单首次加载钩子 */  
116 - onMount?: () => void;  
117 - /** 表单提交前钩子 */  
118 - beforeFinish?: (params: ValidateParams) => Error[] | Promise<Error[]>;  
119 - /** 表单提交后钩子 */  
120 - onFinish?: (formData: any, error: Error[]) => void;  
121 - /** 时时与外部更新同步的钩子 */  
122 - onValuesChange?: (changedValues: any, formData: any) => void;  
123 - /** 隐藏的数据是否去掉,默认不去掉(false) */  
124 - removeHiddenData?: boolean;  
125 -}  
126 -  
127 -declare const FR: React.FC<FRProps>;  
128 -  
129 -export declare function useForm(params?: FormParams): FormInstance;  
130 -  
131 -export type ConnectedForm<T> = T & {  
132 - form: FormInstance;  
133 -};  
134 -  
135 -export declare function connectForm<T extends {} = any>(  
136 - component: React.ComponentType<ConnectedForm<T>>  
137 -): React.ComponentType<T>;  
138 -  
139 -export default FR;