Commit 2f6994fc22406faee7992b21070d67e20172055c

Authored by 乔启韬
1 parent e6006c4f

子表关联表-导出

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;
\ No newline at end of file
... ...
  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;
\ No newline at end of file
... ...
  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;
\ No newline at end of file
... ...
  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;
\ No newline at end of file
... ...
  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;
\ No newline at end of file
... ...
  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.childExportProgress(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;
\ No newline at end of file
... ...
  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;
\ No newline at end of file
... ...
  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;
\ No newline at end of file
... ...
  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;
\ No newline at end of file
... ...
  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);
\ No newline at end of file
... ...
  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;
\ No newline at end of file
... ...
  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;
\ No newline at end of file
... ...
  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;
\ No newline at end of file
... ...
  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;
\ No newline at end of file
... ...
  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 +};
\ No newline at end of file
... ...
  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 +};
\ No newline at end of file
... ...
  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;
... ...