@sugarat/easypicker2-client 2.7.0 → 2.7.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (165) hide show
  1. package/dist/assets/{data-analysis-CVdTnsNg.js → data-analysis-B9140nBj.js} +2 -2
  2. package/dist/assets/{data-analysis-CVdTnsNg.js.map → data-analysis-B9140nBj.js.map} +1 -1
  3. package/dist/assets/{data-analysis-legacy-CrjrJgyN.js → data-analysis-legacy-hCmX88pc.js} +2 -2
  4. package/dist/assets/{data-analysis-legacy-CrjrJgyN.js.map → data-analysis-legacy-hCmX88pc.js.map} +1 -1
  5. package/dist/assets/{data-board-CKaKy1IB.js → data-board-D3o_ZTM6.js} +2 -2
  6. package/dist/assets/{data-board-CKaKy1IB.js.map → data-board-D3o_ZTM6.js.map} +1 -1
  7. package/dist/assets/{data-board-legacy-DfESxuEd.js → data-board-legacy-B3GeXOqc.js} +2 -2
  8. package/dist/assets/{data-board-legacy-DfESxuEd.js.map → data-board-legacy-B3GeXOqc.js.map} +1 -1
  9. package/dist/assets/{el-date-picker-cVKa-X4K.js → el-date-picker-DLwRZtue.js} +2 -2
  10. package/dist/assets/{el-date-picker-cVKa-X4K.js.map → el-date-picker-DLwRZtue.js.map} +1 -1
  11. package/dist/assets/{el-date-picker-legacy-CJ2heCkq.js → el-date-picker-legacy-D8g_iKhG.js} +2 -2
  12. package/dist/assets/{el-date-picker-legacy-CJ2heCkq.js.map → el-date-picker-legacy-D8g_iKhG.js.map} +1 -1
  13. package/dist/assets/{el-dialog-U5Zmt3t3.js → el-dialog-Dq3XmL6w.js} +2 -2
  14. package/dist/assets/{el-dialog-U5Zmt3t3.js.map → el-dialog-Dq3XmL6w.js.map} +1 -1
  15. package/dist/assets/{el-dialog-legacy-u4KST5yo.js → el-dialog-legacy-DCFOVWEQ.js} +2 -2
  16. package/dist/assets/{el-dialog-legacy-u4KST5yo.js.map → el-dialog-legacy-DCFOVWEQ.js.map} +1 -1
  17. package/dist/assets/{el-dropdown-item-flwUs2cH.js → el-dropdown-item-C3aOY1Nr.js} +2 -2
  18. package/dist/assets/{el-dropdown-item-flwUs2cH.js.map → el-dropdown-item-C3aOY1Nr.js.map} +1 -1
  19. package/dist/assets/{el-dropdown-item-legacy-B2fmSGnI.js → el-dropdown-item-legacy-QQu1PUxO.js} +2 -2
  20. package/dist/assets/{el-dropdown-item-legacy-B2fmSGnI.js.map → el-dropdown-item-legacy-QQu1PUxO.js.map} +1 -1
  21. package/dist/assets/{el-form-item-B08Ira7l.js → el-form-item-CtSEmj9z.js} +2 -2
  22. package/dist/assets/{el-form-item-B08Ira7l.js.map → el-form-item-CtSEmj9z.js.map} +1 -1
  23. package/dist/assets/{el-form-item-legacy-CcX_hnMk.js → el-form-item-legacy-BS5eT84Y.js} +2 -2
  24. package/dist/assets/{el-form-item-legacy-CcX_hnMk.js.map → el-form-item-legacy-BS5eT84Y.js.map} +1 -1
  25. package/dist/assets/{el-loading-BMbhg8vq.js → el-loading-BzK_8zqi.js} +2 -2
  26. package/dist/assets/{el-loading-BMbhg8vq.js.map → el-loading-BzK_8zqi.js.map} +1 -1
  27. package/dist/assets/{el-loading-legacy-CRJF51cp.js → el-loading-legacy-DWfn3F3x.js} +2 -2
  28. package/dist/assets/{el-loading-legacy-CRJF51cp.js.map → el-loading-legacy-DWfn3F3x.js.map} +1 -1
  29. package/dist/assets/{el-pagination-D4Wuvfl8.js → el-pagination-Qx_lnumK.js} +2 -2
  30. package/dist/assets/{el-pagination-D4Wuvfl8.js.map → el-pagination-Qx_lnumK.js.map} +1 -1
  31. package/dist/assets/{el-pagination-legacy-C2E-fHif.js → el-pagination-legacy-DqLvzT2t.js} +2 -2
  32. package/dist/assets/{el-pagination-legacy-C2E-fHif.js.map → el-pagination-legacy-DqLvzT2t.js.map} +1 -1
  33. package/dist/assets/{el-progress-ChbdZpVl.js → el-progress-CeLYmjYA.js} +2 -2
  34. package/dist/assets/{el-progress-ChbdZpVl.js.map → el-progress-CeLYmjYA.js.map} +1 -1
  35. package/dist/assets/{el-progress-legacy-zjlCtRh2.js → el-progress-legacy-CwFO38du.js} +2 -2
  36. package/dist/assets/{el-progress-legacy-zjlCtRh2.js.map → el-progress-legacy-CwFO38du.js.map} +1 -1
  37. package/dist/assets/{el-select-DP5UYxt3.js → el-select-HG63LP3Z.js} +2 -2
  38. package/dist/assets/{el-select-DP5UYxt3.js.map → el-select-HG63LP3Z.js.map} +1 -1
  39. package/dist/assets/{el-select-legacy-D4o92tvp.js → el-select-legacy-fKvGMZFT.js} +2 -2
  40. package/dist/assets/{el-select-legacy-D4o92tvp.js.map → el-select-legacy-fKvGMZFT.js.map} +1 -1
  41. package/dist/assets/{el-switch-DAReoFaC.js → el-switch-FjmuXBNe.js} +2 -2
  42. package/dist/assets/{el-switch-DAReoFaC.js.map → el-switch-FjmuXBNe.js.map} +1 -1
  43. package/dist/assets/{el-switch-legacy-D1AVOg2z.js → el-switch-legacy-CU4cCeO5.js} +2 -2
  44. package/dist/assets/{el-switch-legacy-D1AVOg2z.js.map → el-switch-legacy-CU4cCeO5.js.map} +1 -1
  45. package/dist/assets/{el-tab-pane-6kk7HB4E.js → el-tab-pane-CuYcnzTM.js} +2 -2
  46. package/dist/assets/{el-tab-pane-6kk7HB4E.js.map → el-tab-pane-CuYcnzTM.js.map} +1 -1
  47. package/dist/assets/{el-tab-pane-legacy-7aEB8qvn.js → el-tab-pane-legacy-CDSRCQdO.js} +2 -2
  48. package/dist/assets/{el-tab-pane-legacy-7aEB8qvn.js.map → el-tab-pane-legacy-CDSRCQdO.js.map} +1 -1
  49. package/dist/assets/{el-table-column-DsGlAuX3.js → el-table-column-B2R1FOoB.js} +2 -2
  50. package/dist/assets/{el-table-column-DsGlAuX3.js.map → el-table-column-B2R1FOoB.js.map} +1 -1
  51. package/dist/assets/{el-table-column-legacy-C8A33Lav.js → el-table-column-legacy-DDZdwCAr.js} +2 -2
  52. package/dist/assets/{el-table-column-legacy-C8A33Lav.js.map → el-table-column-legacy-DDZdwCAr.js.map} +1 -1
  53. package/dist/assets/{index-mKO4gpWB.js → index-0SN-qZs5.js} +2 -2
  54. package/dist/assets/{index-mKO4gpWB.js.map → index-0SN-qZs5.js.map} +1 -1
  55. package/dist/assets/index-4ToTyeX6.css +1 -0
  56. package/dist/assets/{index-BnQi1XPn.js → index-BMhqAx1_.js} +2 -2
  57. package/dist/assets/{index-BnQi1XPn.js.map → index-BMhqAx1_.js.map} +1 -1
  58. package/dist/assets/{index-BK3KKBAN.js → index-BjPgOd_H.js} +2 -2
  59. package/dist/assets/{index-BK3KKBAN.js.map → index-BjPgOd_H.js.map} +1 -1
  60. package/dist/assets/{index-D6LMez3u.js → index-BjdYG4YE.js} +2 -2
  61. package/dist/assets/{index-D6LMez3u.js.map → index-BjdYG4YE.js.map} +1 -1
  62. package/dist/assets/{index-q94vR-7W.js → index-BkLqrfrW.js} +2 -2
  63. package/dist/assets/{index-q94vR-7W.js.map → index-BkLqrfrW.js.map} +1 -1
  64. package/dist/assets/{index-ggQcjFPK.js → index-BvTJrWND.js} +2 -2
  65. package/dist/assets/{index-ggQcjFPK.js.map → index-BvTJrWND.js.map} +1 -1
  66. package/dist/assets/{index-DjTj_2YG.js → index-BxLy8VN3.js} +2 -2
  67. package/dist/assets/{index-DjTj_2YG.js.map → index-BxLy8VN3.js.map} +1 -1
  68. package/dist/assets/index-C0ZXXBCX.js +40 -0
  69. package/dist/assets/index-C0ZXXBCX.js.map +1 -0
  70. package/dist/assets/{index-DkbS1z1O.js → index-Cs-E_cyt.js} +2 -2
  71. package/dist/assets/{index-DkbS1z1O.js.map → index-Cs-E_cyt.js.map} +1 -1
  72. package/dist/assets/index-CsvxKrFP.js +2 -0
  73. package/dist/assets/{index-BVM3WMNO.js.map → index-CsvxKrFP.js.map} +1 -1
  74. package/dist/assets/{index-BdVQjSN6.js → index-DABL-KOd.js} +2 -2
  75. package/dist/assets/{index-BdVQjSN6.js.map → index-DABL-KOd.js.map} +1 -1
  76. package/dist/assets/{index-BMZu8UZ6.js → index-DFVlBjXp.js} +2 -2
  77. package/dist/assets/{index-BMZu8UZ6.js.map → index-DFVlBjXp.js.map} +1 -1
  78. package/dist/assets/{index-CeKw5v7N.js → index-DIlzTatU.js} +2 -2
  79. package/dist/assets/{index-CeKw5v7N.js.map → index-DIlzTatU.js.map} +1 -1
  80. package/dist/assets/{index-Caxtv5sl.js → index-DREZLSQi.js} +2 -2
  81. package/dist/assets/{index-Caxtv5sl.js.map → index-DREZLSQi.js.map} +1 -1
  82. package/dist/assets/{index-my4zFbcM.js → index-DclP3Kg-.js} +2 -2
  83. package/dist/assets/{index-my4zFbcM.js.map → index-DclP3Kg-.js.map} +1 -1
  84. package/dist/assets/index-DlyJUJ0j.js +2 -0
  85. package/dist/assets/index-DlyJUJ0j.js.map +1 -0
  86. package/dist/assets/index-DnxF29eG.css +1 -0
  87. package/dist/assets/{index-DcmA3tsY.js → index-GC0X-O3Y.js} +2 -2
  88. package/dist/assets/{index-DcmA3tsY.js.map → index-GC0X-O3Y.js.map} +1 -1
  89. package/dist/assets/{index-Dczz94WX.js → index-HzWmB96f.js} +2 -2
  90. package/dist/assets/{index-Dczz94WX.js.map → index-HzWmB96f.js.map} +1 -1
  91. package/dist/assets/{index-ShzTlShR.css → index-I0Y2y6h5.css} +1 -1
  92. package/dist/assets/{index-D-JYypPJ.js → index-U2z5KAu0.js} +2 -2
  93. package/dist/assets/{index-D-JYypPJ.js.map → index-U2z5KAu0.js.map} +1 -1
  94. package/dist/assets/{index-legacy-BLKO-78a.js → index-legacy-B4IHsyj2.js} +13 -8
  95. package/dist/assets/index-legacy-B4IHsyj2.js.map +1 -0
  96. package/dist/assets/index-legacy-BKxszgZW.js +2 -0
  97. package/dist/assets/{index-legacy-pP3Pmgbs.js.map → index-legacy-BKxszgZW.js.map} +1 -1
  98. package/dist/assets/{index-legacy-BqL3XK76.js → index-legacy-BO3hAqA9.js} +2 -2
  99. package/dist/assets/{index-legacy-BqL3XK76.js.map → index-legacy-BO3hAqA9.js.map} +1 -1
  100. package/dist/assets/{index-legacy-8BA9X4aO.js → index-legacy-BSXJnLod.js} +2 -2
  101. package/dist/assets/{index-legacy-8BA9X4aO.js.map → index-legacy-BSXJnLod.js.map} +1 -1
  102. package/dist/assets/{index-legacy-DVOM8HaY.js → index-legacy-BSv-V3Il.js} +2 -2
  103. package/dist/assets/index-legacy-BSv-V3Il.js.map +1 -0
  104. package/dist/assets/{index-legacy-CUZgiMNa.js → index-legacy-CCqMKGqS.js} +2 -2
  105. package/dist/assets/{index-legacy-CUZgiMNa.js.map → index-legacy-CCqMKGqS.js.map} +1 -1
  106. package/dist/assets/{index-legacy-CRq_O11N.js → index-legacy-CphqUnR0.js} +2 -2
  107. package/dist/assets/{index-legacy-CRq_O11N.js.map → index-legacy-CphqUnR0.js.map} +1 -1
  108. package/dist/assets/{index-legacy-CW0OHQkF.js → index-legacy-D13WKbpb.js} +2 -2
  109. package/dist/assets/{index-legacy-CW0OHQkF.js.map → index-legacy-D13WKbpb.js.map} +1 -1
  110. package/dist/assets/{index-legacy-DD6zMGGT.js → index-legacy-D6IvG9Dt.js} +2 -2
  111. package/dist/assets/{index-legacy-DD6zMGGT.js.map → index-legacy-D6IvG9Dt.js.map} +1 -1
  112. package/dist/assets/{index-legacy-DasH54g3.js → index-legacy-DCezoU0z.js} +2 -2
  113. package/dist/assets/{index-legacy-DasH54g3.js.map → index-legacy-DCezoU0z.js.map} +1 -1
  114. package/dist/assets/{index-legacy-BFfoAOF1.js → index-legacy-DIwVyUHd.js} +2 -2
  115. package/dist/assets/{index-legacy-BFfoAOF1.js.map → index-legacy-DIwVyUHd.js.map} +1 -1
  116. package/dist/assets/{index-legacy-CslCZVZ0.js → index-legacy-DO2MADPO.js} +2 -2
  117. package/dist/assets/{index-legacy-CslCZVZ0.js.map → index-legacy-DO2MADPO.js.map} +1 -1
  118. package/dist/assets/{index-legacy-DcKfHHls.js → index-legacy-DcFvM5kb.js} +2 -2
  119. package/dist/assets/{index-legacy-DcKfHHls.js.map → index-legacy-DcFvM5kb.js.map} +1 -1
  120. package/dist/assets/{index-legacy-CqVgmAMA.js → index-legacy-Df_9F2Oo.js} +2 -2
  121. package/dist/assets/{index-legacy-CqVgmAMA.js.map → index-legacy-Df_9F2Oo.js.map} +1 -1
  122. package/dist/assets/{index-legacy-6cMsZS3c.js → index-legacy-Dhs-OKEx.js} +2 -2
  123. package/dist/assets/{index-legacy-6cMsZS3c.js.map → index-legacy-Dhs-OKEx.js.map} +1 -1
  124. package/dist/assets/{index-legacy-B4s89tRC.js → index-legacy-DjWDlkzN.js} +2 -2
  125. package/dist/assets/{index-legacy-B4s89tRC.js.map → index-legacy-DjWDlkzN.js.map} +1 -1
  126. package/dist/assets/{index-legacy-BezkAR3b.js → index-legacy-DxQA53Qy.js} +2 -2
  127. package/dist/assets/{index-legacy-BezkAR3b.js.map → index-legacy-DxQA53Qy.js.map} +1 -1
  128. package/dist/assets/{index-legacy-2f3kE3Xe.js → index-legacy-GbLWntci.js} +2 -2
  129. package/dist/assets/{index-legacy-2f3kE3Xe.js.map → index-legacy-GbLWntci.js.map} +1 -1
  130. package/dist/assets/{index-legacy-bElvuK5I.js → index-legacy-I4qT4Thb.js} +2 -2
  131. package/dist/assets/{index-legacy-bElvuK5I.js.map → index-legacy-I4qT4Thb.js.map} +1 -1
  132. package/dist/assets/{index-legacy-Dt4Eky4l.js → index-legacy-quXi4jhF.js} +2 -2
  133. package/dist/assets/{index-legacy-Dt4Eky4l.js.map → index-legacy-quXi4jhF.js.map} +1 -1
  134. package/dist/assets/{index-jSHW6lhR.js → index-tyMcidBi.js} +2 -2
  135. package/dist/assets/{index-jSHW6lhR.js.map → index-tyMcidBi.js.map} +1 -1
  136. package/dist/assets/{isEqual-DdkrQbjH.js → isEqual-Cecwc716.js} +2 -2
  137. package/dist/assets/{isEqual-DdkrQbjH.js.map → isEqual-Cecwc716.js.map} +1 -1
  138. package/dist/assets/{isEqual-legacy-4dmPHJnc.js → isEqual-legacy-dqS7X02N.js} +2 -2
  139. package/dist/assets/{isEqual-legacy-4dmPHJnc.js.map → isEqual-legacy-dqS7X02N.js.map} +1 -1
  140. package/dist/assets/{refresh-CCIG6-IB.js → refresh-BA55HwKz.js} +2 -2
  141. package/dist/assets/{refresh-CCIG6-IB.js.map → refresh-BA55HwKz.js.map} +1 -1
  142. package/dist/assets/{refresh-legacy-CchIU9Mh.js → refresh-legacy-CpA05Fzr.js} +2 -2
  143. package/dist/assets/{refresh-legacy-CchIU9Mh.js.map → refresh-legacy-CpA05Fzr.js.map} +1 -1
  144. package/dist/assets/{tip-BM0xMiq8.js → tip-CrU2GCmD.js} +2 -2
  145. package/dist/assets/{tip-BM0xMiq8.js.map → tip-CrU2GCmD.js.map} +1 -1
  146. package/dist/assets/{tip-legacy-DpAPUNpm.js → tip-legacy-B05oHh9-.js} +2 -2
  147. package/dist/assets/{tip-legacy-DpAPUNpm.js.map → tip-legacy-B05oHh9-.js.map} +1 -1
  148. package/dist/assets/validator-Ca0QsRid.js +2 -0
  149. package/dist/assets/{validator-DG4_rB-x.js.map → validator-Ca0QsRid.js.map} +1 -1
  150. package/dist/assets/validator-legacy-D0GLFVMZ.js +2 -0
  151. package/dist/assets/{validator-legacy-CN5REdqi.js.map → validator-legacy-D0GLFVMZ.js.map} +1 -1
  152. package/dist/index.html +2 -2
  153. package/package.json +4 -3
  154. package/dist/assets/index-1eHw6sEI.css +0 -1
  155. package/dist/assets/index-BG1GuMIu.css +0 -1
  156. package/dist/assets/index-BVM3WMNO.js +0 -2
  157. package/dist/assets/index-ITkwOdUc.js +0 -2
  158. package/dist/assets/index-ITkwOdUc.js.map +0 -1
  159. package/dist/assets/index-legacy-BLKO-78a.js.map +0 -1
  160. package/dist/assets/index-legacy-DVOM8HaY.js.map +0 -1
  161. package/dist/assets/index-legacy-pP3Pmgbs.js +0 -2
  162. package/dist/assets/index-yrncPnXk.js +0 -36
  163. package/dist/assets/index-yrncPnXk.js.map +0 -1
  164. package/dist/assets/validator-DG4_rB-x.js +0 -2
  165. package/dist/assets/validator-legacy-CN5REdqi.js +0 -2
@@ -0,0 +1,2 @@
1
+ System.register(["./index-legacy-B4IHsyj2.js","./el-dialog-legacy-DCFOVWEQ.js","./tip-legacy-B05oHh9-.js","./el-form-item-legacy-BS5eT84Y.js","./el-select-legacy-fKvGMZFT.js"],(function(e,l){"use strict";var a,o,r,i,t,d,n,s,u,c,p,b,v,m,h,f,g,_,x,y,k,w,V,z,S,C,E,L,B,R,T,U,I,$,G,j,P,F,M,N,D,K,Q,A,q,H,O,J,Y,Z,W,X,ee,le,ae,oe,re,ie,te,de,ne;return{setters:[e=>{a=e.J,o=e.aF,r=e.aK,i=e.aU,t=e.aG,d=e.M,n=e.aH,s=e.r,u=e.aj,c=e.O,p=e.az,b=e.aN,v=e.N,m=e.d,h=e.Q,f=e.a,g=e.c,_=e.b,x=e.a8,y=e.c6,k=e.k,w=e.bu,V=e.H,z=e.T,S=e.e,C=e.t,E=e.aT,L=e.au,B=e.aD,R=e.at,T=e.aL,U=e.c7,I=e.o,$=e.ai,G=e.Z,j=e.bO,P=e.$,F=e.aV,M=e.Y,N=e.aE,D=e._,K=e.D,Q=e.a6,A=e.a7,q=e.ab,H=e.c8,O=e.E,J=e.j,Y=e.w,Z=e.F,W=e.S,X=e.x,ee=e.v,le=e.C},e=>{ae=e.u,oe=e.E},e=>{re=e.E},e=>{ie=e.E,te=e.a},e=>{de=e.E,ne=e.a}],execute:function(){var l=document.createElement("style");l.textContent='@charset "UTF-8";.center[data-v-805533e3]{text-align:center;margin-top:10px}.el-radio-group{display:inline-flex;align-items:center;flex-wrap:wrap;font-size:0}.el-radio{--el-radio-font-size:var(--el-font-size-base);--el-radio-text-color:var(--el-text-color-regular);--el-radio-font-weight:var(--el-font-weight-primary);--el-radio-input-height:14px;--el-radio-input-width:14px;--el-radio-input-border-radius:var(--el-border-radius-circle);--el-radio-input-bg-color:var(--el-fill-color-blank);--el-radio-input-border:var(--el-border);--el-radio-input-border-color:var(--el-border-color);--el-radio-input-border-color-hover:var(--el-color-primary)}.el-radio{color:var(--el-radio-text-color);font-weight:var(--el-radio-font-weight);position:relative;cursor:pointer;display:inline-flex;align-items:center;white-space:nowrap;outline:0;font-size:var(--el-font-size-base);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;margin-right:32px;height:32px}.el-radio.el-radio--large{height:40px}.el-radio.el-radio--small{height:24px}.el-radio.is-bordered{padding:0 15px 0 9px;border-radius:var(--el-border-radius-base);border:var(--el-border);box-sizing:border-box}.el-radio.is-bordered.is-checked{border-color:var(--el-color-primary)}.el-radio.is-bordered.is-disabled{cursor:not-allowed;border-color:var(--el-border-color-lighter)}.el-radio.is-bordered.el-radio--large{padding:0 19px 0 11px;border-radius:var(--el-border-radius-base)}.el-radio.is-bordered.el-radio--large .el-radio__label{font-size:var(--el-font-size-base)}.el-radio.is-bordered.el-radio--large .el-radio__inner{height:14px;width:14px}.el-radio.is-bordered.el-radio--small{padding:0 11px 0 7px;border-radius:var(--el-border-radius-base)}.el-radio.is-bordered.el-radio--small .el-radio__label{font-size:12px}.el-radio.is-bordered.el-radio--small .el-radio__inner{height:12px;width:12px}.el-radio:last-child{margin-right:0}.el-radio__input{white-space:nowrap;cursor:pointer;outline:0;display:inline-flex;position:relative;vertical-align:middle}.el-radio__input.is-disabled .el-radio__inner{background-color:var(--el-disabled-bg-color);border-color:var(--el-disabled-border-color);cursor:not-allowed}.el-radio__input.is-disabled .el-radio__inner:after{cursor:not-allowed;background-color:var(--el-disabled-bg-color)}.el-radio__input.is-disabled .el-radio__inner+.el-radio__label{cursor:not-allowed}.el-radio__input.is-disabled.is-checked .el-radio__inner{background-color:var(--el-disabled-bg-color);border-color:var(--el-disabled-border-color)}.el-radio__input.is-disabled.is-checked .el-radio__inner:after{background-color:var(--el-text-color-placeholder)}.el-radio__input.is-disabled+span.el-radio__label{color:var(--el-text-color-placeholder);cursor:not-allowed}.el-radio__input.is-checked .el-radio__inner{border-color:var(--el-color-primary);background:var(--el-color-primary)}.el-radio__input.is-checked .el-radio__inner:after{transform:translate(-50%,-50%) scale(1)}.el-radio__input.is-checked+.el-radio__label{color:var(--el-color-primary)}.el-radio__input.is-focus .el-radio__inner{border-color:var(--el-radio-input-border-color-hover)}.el-radio__inner{border:var(--el-radio-input-border);border-radius:var(--el-radio-input-border-radius);width:var(--el-radio-input-width);height:var(--el-radio-input-height);background-color:var(--el-radio-input-bg-color);position:relative;cursor:pointer;display:inline-block;box-sizing:border-box}.el-radio__inner:hover{border-color:var(--el-radio-input-border-color-hover)}.el-radio__inner:after{width:4px;height:4px;border-radius:var(--el-radio-input-border-radius);background-color:var(--el-color-white);content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) scale(0);transition:transform .15s ease-in}.el-radio__original{opacity:0;outline:0;position:absolute;z-index:-1;top:0;left:0;right:0;bottom:0;margin:0}.el-radio__original:focus-visible+.el-radio__inner{outline:2px solid var(--el-radio-input-border-color-hover);outline-offset:1px;border-radius:var(--el-radio-input-border-radius)}.el-radio:focus:not(:focus-visible):not(.is-focus):not(:active):not(.is-disabled) .el-radio__inner{box-shadow:0 0 2px 2px var(--el-radio-input-border-color-hover)}.el-radio__label{font-size:var(--el-radio-font-size);padding-left:8px}.el-radio.el-radio--large .el-radio__label{font-size:14px}.el-radio.el-radio--large .el-radio__inner{width:14px;height:14px}.el-radio.el-radio--small .el-radio__label{font-size:12px}.el-radio.el-radio--small .el-radio__inner{width:12px;height:12px}[data-v-73d07e05] div.el-form-item>label{font-weight:700}[data-v-73d07e05] div.el-form-item>label:before{content:"* ";color:red}[data-v-73d07e05] div.el-form-item__content>.el-select{flex:1}.fixed-text[data-v-73d07e05]{background-color:#f5f7fa;padding:0 10px;width:100%;text-align:left}\n',document.head.appendChild(l);const se=Symbol("radioGroupKey"),ue=a({size:o,disabled:Boolean,label:{type:[String,Number,Boolean],default:""}}),ce=a({...ue,modelValue:{type:[String,Number,Boolean],default:""},name:{type:String,default:""},border:Boolean}),pe={[r]:e=>i(e)||t(e)||d(e),[n]:e=>i(e)||t(e)||d(e)},be=(e,l)=>{const a=s(),o=u(se,void 0),i=c((()=>!!o)),t=c({get:()=>i.value?o.modelValue:e.modelValue,set(t){i.value?o.changeEvent(t):l&&l(r,t),a.value.checked=e.modelValue===e.label}}),d=p(c((()=>null==o?void 0:o.size))),n=b(c((()=>null==o?void 0:o.disabled))),v=s(!1),m=c((()=>n.value||i.value&&t.value!==e.label?-1:0));return{radioRef:a,isGroup:i,radioGroup:o,focus:v,size:d,disabled:n,tabIndex:m,modelValue:t}},ve=["value","name","disabled"];var me=v(m({name:"ElRadio",props:ce,emits:pe,setup(e,{emit:l}){const a=e,o=h("radio"),{radioRef:r,radioGroup:i,focus:t,size:d,disabled:n,modelValue:s}=be(a,l);function u(){L((()=>l("change",s.value)))}return(e,l)=>{var a;return f(),g("label",{class:V([k(o).b(),k(o).is("disabled",k(n)),k(o).is("focus",k(t)),k(o).is("bordered",e.border),k(o).is("checked",k(s)===e.label),k(o).m(k(d))])},[_("span",{class:V([k(o).e("input"),k(o).is("disabled",k(n)),k(o).is("checked",k(s)===e.label)])},[x(_("input",{ref_key:"radioRef",ref:r,"onUpdate:modelValue":l[0]||(l[0]=e=>w(s)?s.value=e:null),class:V(k(o).e("original")),value:e.label,name:e.name||(null==(a=k(i))?void 0:a.name),disabled:k(n),type:"radio",onFocus:l[1]||(l[1]=e=>t.value=!0),onBlur:l[2]||(l[2]=e=>t.value=!1),onChange:u},null,42,ve),[[y,k(s)]]),_("span",{class:V(k(o).e("inner"))},null,2)],2),_("span",{class:V(k(o).e("label")),onKeydown:l[3]||(l[3]=E((()=>{}),["stop"]))},[z(e.$slots,"default",{},(()=>[S(C(e.label),1)]))],34)],2)}}}),[["__file","/home/runner/work/element-plus/element-plus/packages/components/radio/src/radio.vue"]]);const he=a({...ue,name:{type:String,default:""}}),fe=["value","name","disabled"];var ge=v(m({name:"ElRadioButton",props:he,setup(e){const l=e,a=h("radio"),{radioRef:o,focus:r,size:i,disabled:t,modelValue:d,radioGroup:n}=be(l),s=c((()=>({backgroundColor:(null==n?void 0:n.fill)||"",borderColor:(null==n?void 0:n.fill)||"",boxShadow:(null==n?void 0:n.fill)?`-1px 0 0 0 ${n.fill}`:"",color:(null==n?void 0:n.textColor)||""})));return(e,l)=>{var u;return f(),g("label",{class:V([k(a).b("button"),k(a).is("active",k(d)===e.label),k(a).is("disabled",k(t)),k(a).is("focus",k(r)),k(a).bm("button",k(i))])},[x(_("input",{ref_key:"radioRef",ref:o,"onUpdate:modelValue":l[0]||(l[0]=e=>w(d)?d.value=e:null),class:V(k(a).be("button","original-radio")),value:e.label,type:"radio",name:e.name||(null==(u=k(n))?void 0:u.name),disabled:k(t),onFocus:l[1]||(l[1]=e=>r.value=!0),onBlur:l[2]||(l[2]=e=>r.value=!1)},null,42,fe),[[y,k(d)]]),_("span",{class:V(k(a).be("button","inner")),style:B(k(d)===e.label?k(s):{}),onKeydown:l[3]||(l[3]=E((()=>{}),["stop"]))},[z(e.$slots,"default",{},(()=>[S(C(e.label),1)]))],38)],2)}}}),[["__file","/home/runner/work/element-plus/element-plus/packages/components/radio/src/radio-button.vue"]]);const _e=a({id:{type:String,default:void 0},size:o,disabled:Boolean,modelValue:{type:[String,Number,Boolean],default:""},fill:{type:String,default:""},label:{type:String,default:void 0},textColor:{type:String,default:""},name:{type:String,default:void 0},validateEvent:{type:Boolean,default:!0}}),xe=["id","aria-label","aria-labelledby"];var ye=v(m({name:"ElRadioGroup",props:_e,emits:pe,setup(e,{emit:l}){const a=e,o=h("radio"),i=R(),t=s(),{formItem:d}=T(),{inputId:n,isLabeledByFormItem:u}=U(a,{formItemContext:d});I((()=>{const e=t.value.querySelectorAll("[type=radio]"),l=e[0];!Array.from(e).some((e=>e.checked))&&l&&(l.tabIndex=0)}));const p=c((()=>a.name||i.value));return $(se,G({...j(a),changeEvent:e=>{l(r,e),L((()=>l("change",e)))},name:p})),P((()=>a.modelValue),(()=>{a.validateEvent&&(null==d||d.validate("change").catch((e=>F())))})),(e,l)=>(f(),g("div",{id:k(n),ref_key:"radioGroupRef",ref:t,class:V(k(o).b("group")),role:"radiogroup","aria-label":k(u)?void 0:e.label||"radio-group","aria-labelledby":k(u)?k(d).labelId:void 0},[z(e.$slots,"default")],10,xe))}}),[["__file","/home/runner/work/element-plus/element-plus/packages/components/radio/src/radio-group.vue"]]);const ke=e("b",M(me,{RadioButton:ge,RadioGroup:ye})),we=e("a",N(ye));e("E",N(ge));const Ve=D({name:"QrCode",props:{value:String},data:()=>({src:"",srcList:[]}),watch:{value(e){e&&(this.src=this.createEwm(e),this.srcList=[this.src])}},methods:{createEwm:(e,l)=>new AraleQRCode({text:e,size:400,foreground:"#000",...l}).toDataURL("image/png")},mounted(){this.value&&(this.src=this.createEwm(this.value),this.srcList=[this.src])}},[["render",function(e,l,a,o,r,i){const t=re;return f(),K(t,{style:{width:"150px",height:"150px"},src:r.src,"preview-src-list":r.srcList},null,8,["src","preview-src-list"])}]]),ze=m({name:"LinkDialog",components:{QrCode:Ve},props:{title:{type:String,default:"链接面板"},value:{type:Boolean},link:{type:String,default:""},download:{type:Boolean,default:!0},shareTextPrefix:{type:String,default:""}},emits:["update:value"],setup(e,l){const a=s(""),o=s(!1),r=ae(),{value:i}=Q();A((()=>{a.value=e.link})),A((()=>{o.value=e.value,o.value&&e.download&&setTimeout((()=>{O.success("如未自动开始下载,请复制链接到浏览器中执行下载")}),200)}));const t=c((()=>i.value.appName)),d=c((()=>`${t.value&&`【${t.value}】`}${e.shareTextPrefix} ${a.value}`)),n=c((()=>!!e.shareTextPrefix));return{shareLink:a,createShortLink:()=>{H(a.value).then((e=>{a.value=e,O.success("短链生成成功")}))},copyLink:()=>{q(a.value)},handleClose:()=>{l.emit("update:value",!1)},showModel:o,isMobile:r,shareText:d,copyShareText:()=>{q(d.value)},showShareTextPanel:n}}}),Se={class:"center"},Ce={class:"center"},Ee={class:"center"},Le={class:"center"};e("L",D(ze,[["render",function(e,l,a,o,r,i){const t=X,d=ee,n=Ve,s=oe;return f(),g("div",null,[J(s,{modelValue:e.showModel,"onUpdate:modelValue":l[1]||(l[1]=l=>e.showModel=l),fullscreen:e.isMobile,title:e.title,center:"",onClose:e.handleClose},{default:Y((()=>[_("div",null,[J(d,{modelValue:e.shareLink,"onUpdate:modelValue":l[0]||(l[0]=l=>e.shareLink=l),placeholder:"生成的链接"},{append:Y((()=>[J(t,{type:"primary",onClick:e.copyLink},{default:Y((()=>[S(" 复制 ")])),_:1},8,["onClick"])])),_:1},8,["modelValue"])]),_("div",Se,[J(n,{value:e.shareLink},null,8,["value"])]),_("div",Ce,[J(t,{type:"primary",onClick:e.createShortLink},{default:Y((()=>[S(" 生成短链 ")])),_:1},8,["onClick"])]),e.showShareTextPanel?(f(),g(Z,{key:0},[_("div",Ee,[J(d,{value:e.shareText,style:{width:"300px"},autosize:{minRows:3,maxRows:10},type:"textarea",placeholder:"分享信息"},null,8,["value"])]),_("div",Le,[J(t,{type:"success",round:"",onClick:e.copyShareText},{default:Y((()=>[S(" 复制分享信息 ")])),_:1},8,["onClick"])])],64)):W("",!0)])),_:1},8,["modelValue","fullscreen","title","onClose"])])}],["__scopeId","data-v-805533e3"]]));const Be={key:0,class:"fixed-text"},Re=m({__name:"index",props:{infos:{},disabled:{type:Boolean},labelPosition:{}},setup(e){const{value:l}=Q(),a=c((()=>l.value.maxInputLength));return(e,l)=>{const o=ee,r=ke,i=we,t=de,d=ne,n=ie,s=te;return f(),K(s,{disabled:e.disabled,"label-position":e.labelPosition||"top"},{default:Y((()=>[(f(!0),g(Z,null,le(e.infos,((e,l)=>(f(),K(n,{key:l,class:"ellipsis",label:"text"===e.type?"":e.text},{default:Y((()=>["text"===e.type?(f(),g("div",Be,C(e.text),1)):W("",!0),"input"===e.type?(f(),K(o,{key:1,modelValue:e.value,"onUpdate:modelValue":l=>e.value=l,maxlength:a.value,clearable:"","show-word-limit":"",placeholder:`请输入 ${e.text}`},null,8,["modelValue","onUpdate:modelValue","maxlength","placeholder"])):W("",!0),"radio"===e.type?(f(),K(i,{key:2,modelValue:e.value,"onUpdate:modelValue":l=>e.value=l},{default:Y((()=>[(f(!0),g(Z,null,le(e.children,((e,l)=>(f(),K(r,{key:l,label:e.text},{default:Y((()=>[S(C(e.text),1)])),_:2},1032,["label"])))),128))])),_:2},1032,["modelValue","onUpdate:modelValue"])):W("",!0),"select"===e.type?(f(),K(d,{key:3,modelValue:e.value,"onUpdate:modelValue":l=>e.value=l,"default-first-option":"",clearable:"",filterable:"",placeholder:`请选择 ${e.text}`},{default:Y((()=>[(f(!0),g(Z,null,le(e.children,((e,l)=>(f(),K(t,{key:l,label:e.text,value:e.text},null,8,["label","value"])))),128))])),_:2},1032,["modelValue","onUpdate:modelValue","placeholder"])):W("",!0)])),_:2},1032,["label"])))),128))])),_:1},8,["disabled","label-position"])}}});e("I",D(Re,[["__scopeId","data-v-73d07e05"]]))}}}));
2
+ //# sourceMappingURL=index-legacy-BKxszgZW.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index-legacy-pP3Pmgbs.js","sources":["../../node_modules/.pnpm/element-plus@2.2.13_vue@3.4.31_typescript@4.9.5_/node_modules/element-plus/es/tokens/radio.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.4.31_typescript@4.9.5_/node_modules/element-plus/es/components/radio/src/radio.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.4.31_typescript@4.9.5_/node_modules/element-plus/es/components/radio/src/use-radio.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.4.31_typescript@4.9.5_/node_modules/element-plus/es/components/radio/src/radio2.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.4.31_typescript@4.9.5_/node_modules/element-plus/es/components/radio/src/radio-button.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.4.31_typescript@4.9.5_/node_modules/element-plus/es/components/radio/src/radio-button2.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.4.31_typescript@4.9.5_/node_modules/element-plus/es/components/radio/src/radio-group.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.4.31_typescript@4.9.5_/node_modules/element-plus/es/components/radio/src/radio-group2.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.4.31_typescript@4.9.5_/node_modules/element-plus/es/components/radio/index.mjs","../../src/components/QrCode.vue","../../src/components/linkDialog.vue","../../src/components/InfosForm/index.vue"],"sourcesContent":["const radioGroupKey = Symbol(\"radioGroupKey\");\n\nexport { radioGroupKey };\n//# sourceMappingURL=radio.mjs.map\n","import '../../../utils/index.mjs';\nimport '../../../constants/index.mjs';\nimport '../../../hooks/index.mjs';\nimport { buildProps } from '../../../utils/vue/props/runtime.mjs';\nimport { useSizeProp } from '../../../hooks/use-common-props/index.mjs';\nimport { UPDATE_MODEL_EVENT, CHANGE_EVENT } from '../../../constants/event.mjs';\nimport { isString } from '@vue/shared';\nimport { isNumber, isBoolean } from '@vueuse/core';\n\nconst radioPropsBase = buildProps({\n size: useSizeProp,\n disabled: Boolean,\n label: {\n type: [String, Number, Boolean],\n default: \"\"\n }\n});\nconst radioProps = buildProps({\n ...radioPropsBase,\n modelValue: {\n type: [String, Number, Boolean],\n default: \"\"\n },\n name: {\n type: String,\n default: \"\"\n },\n border: Boolean\n});\nconst radioEmits = {\n [UPDATE_MODEL_EVENT]: (val) => isString(val) || isNumber(val) || isBoolean(val),\n [CHANGE_EVENT]: (val) => isString(val) || isNumber(val) || isBoolean(val)\n};\n\nexport { radioEmits, radioProps, radioPropsBase };\n//# sourceMappingURL=radio.mjs.map\n","import { ref, inject, computed } from 'vue';\nimport '../../../constants/index.mjs';\nimport '../../../tokens/index.mjs';\nimport '../../../hooks/index.mjs';\nimport { radioGroupKey } from '../../../tokens/radio.mjs';\nimport { UPDATE_MODEL_EVENT } from '../../../constants/event.mjs';\nimport { useSize, useDisabled } from '../../../hooks/use-common-props/index.mjs';\n\nconst useRadio = (props, emit) => {\n const radioRef = ref();\n const radioGroup = inject(radioGroupKey, void 0);\n const isGroup = computed(() => !!radioGroup);\n const modelValue = computed({\n get() {\n return isGroup.value ? radioGroup.modelValue : props.modelValue;\n },\n set(val) {\n if (isGroup.value) {\n radioGroup.changeEvent(val);\n } else {\n emit && emit(UPDATE_MODEL_EVENT, val);\n }\n radioRef.value.checked = props.modelValue === props.label;\n }\n });\n const size = useSize(computed(() => radioGroup == null ? void 0 : radioGroup.size));\n const disabled = useDisabled(computed(() => radioGroup == null ? void 0 : radioGroup.disabled));\n const focus = ref(false);\n const tabIndex = computed(() => {\n return disabled.value || isGroup.value && modelValue.value !== props.label ? -1 : 0;\n });\n return {\n radioRef,\n isGroup,\n radioGroup,\n focus,\n size,\n disabled,\n tabIndex,\n modelValue\n };\n};\n\nexport { useRadio };\n//# sourceMappingURL=use-radio.mjs.map\n","import { defineComponent, nextTick, openBlock, createElementBlock, normalizeClass, unref, createElementVNode, withDirectives, isRef, vModelRadio, withModifiers, renderSlot, createTextVNode, toDisplayString } from 'vue';\nimport '../../../hooks/index.mjs';\nimport { radioProps, radioEmits } from './radio.mjs';\nimport { useRadio } from './use-radio.mjs';\nimport _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';\nimport { useNamespace } from '../../../hooks/use-namespace/index.mjs';\n\nconst _hoisted_1 = [\"value\", \"name\", \"disabled\"];\nconst __default__ = {\n name: \"ElRadio\"\n};\nconst _sfc_main = /* @__PURE__ */ defineComponent({\n ...__default__,\n props: radioProps,\n emits: radioEmits,\n setup(__props, { emit }) {\n const props = __props;\n const ns = useNamespace(\"radio\");\n const { radioRef, radioGroup, focus, size, disabled, modelValue } = useRadio(props, emit);\n function handleChange() {\n nextTick(() => emit(\"change\", modelValue.value));\n }\n return (_ctx, _cache) => {\n var _a;\n return openBlock(), createElementBlock(\"label\", {\n class: normalizeClass([\n unref(ns).b(),\n unref(ns).is(\"disabled\", unref(disabled)),\n unref(ns).is(\"focus\", unref(focus)),\n unref(ns).is(\"bordered\", _ctx.border),\n unref(ns).is(\"checked\", unref(modelValue) === _ctx.label),\n unref(ns).m(unref(size))\n ])\n }, [\n createElementVNode(\"span\", {\n class: normalizeClass([\n unref(ns).e(\"input\"),\n unref(ns).is(\"disabled\", unref(disabled)),\n unref(ns).is(\"checked\", unref(modelValue) === _ctx.label)\n ])\n }, [\n withDirectives(createElementVNode(\"input\", {\n ref_key: \"radioRef\",\n ref: radioRef,\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = ($event) => isRef(modelValue) ? modelValue.value = $event : null),\n class: normalizeClass(unref(ns).e(\"original\")),\n value: _ctx.label,\n name: _ctx.name || ((_a = unref(radioGroup)) == null ? void 0 : _a.name),\n disabled: unref(disabled),\n type: \"radio\",\n onFocus: _cache[1] || (_cache[1] = ($event) => focus.value = true),\n onBlur: _cache[2] || (_cache[2] = ($event) => focus.value = false),\n onChange: handleChange\n }, null, 42, _hoisted_1), [\n [vModelRadio, unref(modelValue)]\n ]),\n createElementVNode(\"span\", {\n class: normalizeClass(unref(ns).e(\"inner\"))\n }, null, 2)\n ], 2),\n createElementVNode(\"span\", {\n class: normalizeClass(unref(ns).e(\"label\")),\n onKeydown: _cache[3] || (_cache[3] = withModifiers(() => {\n }, [\"stop\"]))\n }, [\n renderSlot(_ctx.$slots, \"default\", {}, () => [\n createTextVNode(toDisplayString(_ctx.label), 1)\n ])\n ], 34)\n ], 2);\n };\n }\n});\nvar Radio = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"__file\", \"/home/runner/work/element-plus/element-plus/packages/components/radio/src/radio.vue\"]]);\n\nexport { Radio as default };\n//# sourceMappingURL=radio2.mjs.map\n","import '../../../utils/index.mjs';\nimport { radioPropsBase } from './radio.mjs';\nimport { buildProps } from '../../../utils/vue/props/runtime.mjs';\n\nconst radioButtonProps = buildProps({\n ...radioPropsBase,\n name: {\n type: String,\n default: \"\"\n }\n});\n\nexport { radioButtonProps };\n//# sourceMappingURL=radio-button.mjs.map\n","import { defineComponent, computed, openBlock, createElementBlock, normalizeClass, unref, withDirectives, createElementVNode, isRef, vModelRadio, normalizeStyle, withModifiers, renderSlot, createTextVNode, toDisplayString } from 'vue';\nimport '../../../hooks/index.mjs';\nimport { useRadio } from './use-radio.mjs';\nimport { radioButtonProps } from './radio-button.mjs';\nimport _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';\nimport { useNamespace } from '../../../hooks/use-namespace/index.mjs';\n\nconst _hoisted_1 = [\"value\", \"name\", \"disabled\"];\nconst __default__ = {\n name: \"ElRadioButton\"\n};\nconst _sfc_main = /* @__PURE__ */ defineComponent({\n ...__default__,\n props: radioButtonProps,\n setup(__props) {\n const props = __props;\n const ns = useNamespace(\"radio\");\n const { radioRef, focus, size, disabled, modelValue, radioGroup } = useRadio(props);\n const activeStyle = computed(() => {\n return {\n backgroundColor: (radioGroup == null ? void 0 : radioGroup.fill) || \"\",\n borderColor: (radioGroup == null ? void 0 : radioGroup.fill) || \"\",\n boxShadow: (radioGroup == null ? void 0 : radioGroup.fill) ? `-1px 0 0 0 ${radioGroup.fill}` : \"\",\n color: (radioGroup == null ? void 0 : radioGroup.textColor) || \"\"\n };\n });\n return (_ctx, _cache) => {\n var _a;\n return openBlock(), createElementBlock(\"label\", {\n class: normalizeClass([\n unref(ns).b(\"button\"),\n unref(ns).is(\"active\", unref(modelValue) === _ctx.label),\n unref(ns).is(\"disabled\", unref(disabled)),\n unref(ns).is(\"focus\", unref(focus)),\n unref(ns).bm(\"button\", unref(size))\n ])\n }, [\n withDirectives(createElementVNode(\"input\", {\n ref_key: \"radioRef\",\n ref: radioRef,\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = ($event) => isRef(modelValue) ? modelValue.value = $event : null),\n class: normalizeClass(unref(ns).be(\"button\", \"original-radio\")),\n value: _ctx.label,\n type: \"radio\",\n name: _ctx.name || ((_a = unref(radioGroup)) == null ? void 0 : _a.name),\n disabled: unref(disabled),\n onFocus: _cache[1] || (_cache[1] = ($event) => focus.value = true),\n onBlur: _cache[2] || (_cache[2] = ($event) => focus.value = false)\n }, null, 42, _hoisted_1), [\n [vModelRadio, unref(modelValue)]\n ]),\n createElementVNode(\"span\", {\n class: normalizeClass(unref(ns).be(\"button\", \"inner\")),\n style: normalizeStyle(unref(modelValue) === _ctx.label ? unref(activeStyle) : {}),\n onKeydown: _cache[3] || (_cache[3] = withModifiers(() => {\n }, [\"stop\"]))\n }, [\n renderSlot(_ctx.$slots, \"default\", {}, () => [\n createTextVNode(toDisplayString(_ctx.label), 1)\n ])\n ], 38)\n ], 2);\n };\n }\n});\nvar RadioButton = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"__file\", \"/home/runner/work/element-plus/element-plus/packages/components/radio/src/radio-button.vue\"]]);\n\nexport { RadioButton as default };\n//# sourceMappingURL=radio-button2.mjs.map\n","import '../../../utils/index.mjs';\nimport '../../../hooks/index.mjs';\nimport { radioEmits } from './radio.mjs';\nimport { buildProps } from '../../../utils/vue/props/runtime.mjs';\nimport { useSizeProp } from '../../../hooks/use-common-props/index.mjs';\n\nconst radioGroupProps = buildProps({\n id: {\n type: String,\n default: void 0\n },\n size: useSizeProp,\n disabled: Boolean,\n modelValue: {\n type: [String, Number, Boolean],\n default: \"\"\n },\n fill: {\n type: String,\n default: \"\"\n },\n label: {\n type: String,\n default: void 0\n },\n textColor: {\n type: String,\n default: \"\"\n },\n name: {\n type: String,\n default: void 0\n },\n validateEvent: {\n type: Boolean,\n default: true\n }\n});\nconst radioGroupEmits = radioEmits;\n\nexport { radioGroupEmits, radioGroupProps };\n//# sourceMappingURL=radio-group.mjs.map\n","import { defineComponent, ref, nextTick, onMounted, computed, provide, reactive, toRefs, watch, openBlock, createElementBlock, unref, normalizeClass, renderSlot } from 'vue';\nimport '../../../constants/index.mjs';\nimport '../../../tokens/index.mjs';\nimport '../../../hooks/index.mjs';\nimport '../../../utils/index.mjs';\nimport { radioGroupProps, radioGroupEmits } from './radio-group.mjs';\nimport _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';\nimport { useNamespace } from '../../../hooks/use-namespace/index.mjs';\nimport { useId } from '../../../hooks/use-id/index.mjs';\nimport { useFormItem, useFormItemInputId } from '../../../hooks/use-form-item/index.mjs';\nimport { UPDATE_MODEL_EVENT } from '../../../constants/event.mjs';\nimport { radioGroupKey } from '../../../tokens/radio.mjs';\nimport { debugWarn } from '../../../utils/error.mjs';\n\nconst _hoisted_1 = [\"id\", \"aria-label\", \"aria-labelledby\"];\nconst __default__ = {\n name: \"ElRadioGroup\"\n};\nconst _sfc_main = /* @__PURE__ */ defineComponent({\n ...__default__,\n props: radioGroupProps,\n emits: radioGroupEmits,\n setup(__props, { emit }) {\n const props = __props;\n const ns = useNamespace(\"radio\");\n const radioId = useId();\n const radioGroupRef = ref();\n const { formItem } = useFormItem();\n const { inputId: groupId, isLabeledByFormItem } = useFormItemInputId(props, {\n formItemContext: formItem\n });\n const changeEvent = (value) => {\n emit(UPDATE_MODEL_EVENT, value);\n nextTick(() => emit(\"change\", value));\n };\n onMounted(() => {\n const radios = radioGroupRef.value.querySelectorAll(\"[type=radio]\");\n const firstLabel = radios[0];\n if (!Array.from(radios).some((radio) => radio.checked) && firstLabel) {\n firstLabel.tabIndex = 0;\n }\n });\n const name = computed(() => {\n return props.name || radioId.value;\n });\n provide(radioGroupKey, reactive({\n ...toRefs(props),\n changeEvent,\n name\n }));\n watch(() => props.modelValue, () => {\n if (props.validateEvent) {\n formItem == null ? void 0 : formItem.validate(\"change\").catch((err) => debugWarn(err));\n }\n });\n return (_ctx, _cache) => {\n return openBlock(), createElementBlock(\"div\", {\n id: unref(groupId),\n ref_key: \"radioGroupRef\",\n ref: radioGroupRef,\n class: normalizeClass(unref(ns).b(\"group\")),\n role: \"radiogroup\",\n \"aria-label\": !unref(isLabeledByFormItem) ? _ctx.label || \"radio-group\" : void 0,\n \"aria-labelledby\": unref(isLabeledByFormItem) ? unref(formItem).labelId : void 0\n }, [\n renderSlot(_ctx.$slots, \"default\")\n ], 10, _hoisted_1);\n };\n }\n});\nvar RadioGroup = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"__file\", \"/home/runner/work/element-plus/element-plus/packages/components/radio/src/radio-group.vue\"]]);\n\nexport { RadioGroup as default };\n//# sourceMappingURL=radio-group2.mjs.map\n","import '../../utils/index.mjs';\nimport Radio from './src/radio2.mjs';\nimport RadioButton from './src/radio-button2.mjs';\nimport RadioGroup from './src/radio-group2.mjs';\nexport { radioEmits, radioProps, radioPropsBase } from './src/radio.mjs';\nexport { radioGroupEmits, radioGroupProps } from './src/radio-group.mjs';\nexport { radioButtonProps } from './src/radio-button.mjs';\nimport { withInstall, withNoopInstall } from '../../utils/vue/install.mjs';\n\nconst ElRadio = withInstall(Radio, {\n RadioButton,\n RadioGroup\n});\nconst ElRadioGroup = withNoopInstall(RadioGroup);\nconst ElRadioButton = withNoopInstall(RadioButton);\n\nexport { ElRadio, ElRadioButton, ElRadioGroup, ElRadio as default };\n//# sourceMappingURL=index.mjs.map\n","<template>\n <el-image style=\"width: 150px; height: 150px\" :src=\"src\" :preview-src-list=\"srcList\"/>\n</template>\n<script>\nexport default {\n name: 'QrCode',\n props: {\n value: String,\n },\n data() {\n return {\n src: '',\n srcList: [],\n }\n },\n watch: {\n value(to) {\n if (!to) {\n return\n }\n this.src = this.createEwm(to)\n this.srcList = [this.src]\n },\n },\n methods: {\n createEwm(text, config) {\n // eslint-disable-next-line no-undef\n const canvasImg = new AraleQRCode({\n text,\n size: 400,\n foreground: '#000',\n ...config,\n })\n return canvasImg.toDataURL('image/png')\n },\n },\n mounted() {\n if (this.value) {\n this.src = this.createEwm(this.value)\n this.srcList = [this.src]\n }\n },\n}\n</script>\n","<script lang=\"ts\">\nimport { ElMessage } from 'element-plus'\nimport { defineComponent, ref, watchEffect } from 'vue'\nimport QrCode from '@components/QrCode.vue'\nimport { copyRes, getShortUrl } from '@/utils/stringUtil'\nimport { useIsMobile } from '@/composables'\n\nexport default defineComponent({\n name: 'LinkDialog',\n components: {\n QrCode,\n },\n props: {\n title: {\n type: String,\n default: '链接面板',\n },\n value: {\n type: Boolean,\n },\n link: {\n type: String,\n default: '',\n },\n download: {\n type: Boolean,\n default: true,\n },\n },\n emits: ['update:value'],\n setup(props, context) {\n const shareLink = ref('')\n const showModel = ref(false)\n const isMobile = useIsMobile()\n const copyLink = () => {\n copyRes(shareLink.value)\n }\n watchEffect(() => {\n shareLink.value = props.link\n })\n watchEffect(() => {\n showModel.value = props.value\n if (showModel.value && props.download) {\n setTimeout(() => {\n ElMessage.success('如未自动开始下载,请复制链接到浏览器中执行下载')\n }, 200)\n }\n })\n const handleClose = () => {\n context.emit('update:value', false)\n }\n const createShortLink = () => {\n getShortUrl(shareLink.value).then((v) => {\n shareLink.value = v\n ElMessage.success('短链生成成功')\n })\n }\n\n return {\n shareLink,\n createShortLink,\n copyLink,\n handleClose,\n showModel,\n isMobile,\n }\n },\n})\n</script>\n\n<template>\n <div>\n <el-dialog\n v-model=\"showModel\"\n :fullscreen=\"isMobile\"\n :title=\"title\"\n center\n @close=\"handleClose\"\n >\n <!-- 链接 -->\n <div>\n <el-input v-model=\"shareLink\" placeholder=\"生成的链接\">\n <template #prepend>\n <el-button type=\"primary\" @click=\"createShortLink\">\n 生成短链\n </el-button>\n </template>\n <template #append>\n <el-button type=\"primary\" @click=\"copyLink\">\n 复制\n </el-button>\n </template>\n </el-input>\n </div>\n <!-- 二维码 -->\n <div style=\"margin-top: 10px; text-align: center\">\n <QrCode :value=\"shareLink\" />\n </div>\n <!-- <template #footer>\n <span class=\"dialog-footer\">\n <el-button type=\"primary\" @click=\"$emit('update:value',false)\">关闭</el-button>\n </span>\n </template> -->\n </el-dialog>\n </div>\n</template>\n","<script setup lang=\"ts\">\nimport { computed } from 'vue'\nimport { useSiteConfig } from '@/composables'\n\ndefineProps<{\n infos: InfoItem[]\n disabled: boolean\n labelPosition?: 'left' | 'right' | 'top'\n}>()\n\nconst { value: siteConfig } = useSiteConfig()\nconst maxInputLength = computed(() => siteConfig.value.maxInputLength)\n</script>\n\n<template>\n <el-form :disabled=\"disabled\" :label-position=\"labelPosition || 'top'\">\n <el-form-item\n v-for=\"(info, idx) in infos\"\n :key=\"idx\"\n class=\"ellipsis\"\n :label=\"info.type === 'text' ? '' : info.text\"\n >\n <div v-if=\"info.type === 'text'\" class=\"fixed-text\">\n {{ info.text }}\n </div>\n <el-input\n v-if=\"info.type === 'input'\"\n v-model=\"info.value\"\n :maxlength=\"maxInputLength\"\n clearable\n show-word-limit\n :placeholder=\"`请输入 ${info.text}`\"\n />\n <el-radio-group v-if=\"info.type === 'radio'\" v-model=\"info.value\">\n <el-radio\n v-for=\"(r, idx) in info.children\"\n :key=\"idx\"\n :label=\"r.text\"\n >\n {{ r.text }}\n </el-radio>\n </el-radio-group>\n <el-select\n v-if=\"info.type === 'select'\"\n v-model=\"info.value\"\n default-first-option\n clearable\n filterable\n :placeholder=\"`请选择 ${info.text}`\"\n >\n <el-option\n v-for=\"(r, idx) in info.children\"\n :key=\"idx\"\n :label=\"r.text\"\n :value=\"r.text\"\n />\n </el-select>\n </el-form-item>\n </el-form>\n</template>\n\n<style scoped lang=\"scss\">\n:deep(div.el-form-item > label) {\n font-weight: bold;\n &::before {\n content: '* ';\n color: red;\n }\n}\n\n:deep(div.el-form-item__content > .el-select) {\n flex: 1;\n}\n.fixed-text {\n background-color: #f5f7fa;\n padding: 0 10px;\n width: 100%;\n text-align: left;\n}\n</style>\n"],"names":["radioGroupKey","Symbol","radioPropsBase","buildProps","size","useSizeProp","disabled","Boolean","label","type","String","Number","default","radioProps","modelValue","name","border","radioEmits","UPDATE_MODEL_EVENT","val","isString","isNumber","isBoolean","CHANGE_EVENT","useRadio","props","emit","radioRef","ref","radioGroup","inject","isGroup","computed","get","value","set","changeEvent","checked","useSize","useDisabled","focus","tabIndex","_hoisted_1","Radio","_export_sfc","defineComponent","emits","setup","__props","ns","useNamespace","handleChange","nextTick","_ctx","_cache","_a","openBlock","createElementBlock","class","normalizeClass","unref","b","is","m","createElementVNode","e","withDirectives","ref_key","$event","isRef","onFocus","onBlur","onChange","vModelRadio","onKeydown","withModifiers","renderSlot","$slots","createTextVNode","toDisplayString","radioButtonProps","RadioButton","activeStyle","backgroundColor","fill","borderColor","boxShadow","color","textColor","bm","be","style","normalizeStyle","radioGroupProps","id","validateEvent","RadioGroup","radioId","useId","radioGroupRef","formItem","useFormItem","inputId","groupId","isLabeledByFormItem","useFormItemInputId","formItemContext","onMounted","radios","querySelectorAll","firstLabel","Array","from","some","radio","provide","reactive","toRefs","watch","validate","catch","err","debugWarn","role","labelId","ElRadio","exports","withInstall","ElRadioGroup","withNoopInstall","data","src","srcList","to","this","createEwm","methods","text","config","AraleQRCode","foreground","toDataURL","mounted","_createBlock","_component_el_image","width","height","$data","_sfc_main$1","components","QrCode","title","link","download","context","shareLink","showModel","isMobile","useIsMobile","watchEffect","setTimeout","ElMessage","success","createShortLink","getShortUrl","then","v","copyLink","copyRes","handleClose","__unplugin_components_3","_openBlock","_createElementBlock","_createVNode","_component_el_dialog","fullscreen","onClose","_withCtx","_createElementVNode","_component_el_input","placeholder","prepend","onClick","_createTextVNode","append","siteConfig","useSiteConfig","maxInputLength"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4,5,6,7,8]}
1
+ {"version":3,"file":"index-legacy-BKxszgZW.js","sources":["../../node_modules/.pnpm/element-plus@2.2.13_vue@3.4.31_typescript@4.9.5_/node_modules/element-plus/es/tokens/radio.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.4.31_typescript@4.9.5_/node_modules/element-plus/es/components/radio/src/radio.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.4.31_typescript@4.9.5_/node_modules/element-plus/es/components/radio/src/use-radio.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.4.31_typescript@4.9.5_/node_modules/element-plus/es/components/radio/src/radio2.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.4.31_typescript@4.9.5_/node_modules/element-plus/es/components/radio/src/radio-button.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.4.31_typescript@4.9.5_/node_modules/element-plus/es/components/radio/src/radio-button2.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.4.31_typescript@4.9.5_/node_modules/element-plus/es/components/radio/src/radio-group.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.4.31_typescript@4.9.5_/node_modules/element-plus/es/components/radio/src/radio-group2.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.4.31_typescript@4.9.5_/node_modules/element-plus/es/components/radio/index.mjs","../../src/components/QrCode.vue","../../src/components/linkDialog.vue","../../src/components/InfosForm/index.vue"],"sourcesContent":["const radioGroupKey = Symbol(\"radioGroupKey\");\n\nexport { radioGroupKey };\n//# sourceMappingURL=radio.mjs.map\n","import '../../../utils/index.mjs';\nimport '../../../constants/index.mjs';\nimport '../../../hooks/index.mjs';\nimport { buildProps } from '../../../utils/vue/props/runtime.mjs';\nimport { useSizeProp } from '../../../hooks/use-common-props/index.mjs';\nimport { UPDATE_MODEL_EVENT, CHANGE_EVENT } from '../../../constants/event.mjs';\nimport { isString } from '@vue/shared';\nimport { isNumber, isBoolean } from '@vueuse/core';\n\nconst radioPropsBase = buildProps({\n size: useSizeProp,\n disabled: Boolean,\n label: {\n type: [String, Number, Boolean],\n default: \"\"\n }\n});\nconst radioProps = buildProps({\n ...radioPropsBase,\n modelValue: {\n type: [String, Number, Boolean],\n default: \"\"\n },\n name: {\n type: String,\n default: \"\"\n },\n border: Boolean\n});\nconst radioEmits = {\n [UPDATE_MODEL_EVENT]: (val) => isString(val) || isNumber(val) || isBoolean(val),\n [CHANGE_EVENT]: (val) => isString(val) || isNumber(val) || isBoolean(val)\n};\n\nexport { radioEmits, radioProps, radioPropsBase };\n//# sourceMappingURL=radio.mjs.map\n","import { ref, inject, computed } from 'vue';\nimport '../../../constants/index.mjs';\nimport '../../../tokens/index.mjs';\nimport '../../../hooks/index.mjs';\nimport { radioGroupKey } from '../../../tokens/radio.mjs';\nimport { UPDATE_MODEL_EVENT } from '../../../constants/event.mjs';\nimport { useSize, useDisabled } from '../../../hooks/use-common-props/index.mjs';\n\nconst useRadio = (props, emit) => {\n const radioRef = ref();\n const radioGroup = inject(radioGroupKey, void 0);\n const isGroup = computed(() => !!radioGroup);\n const modelValue = computed({\n get() {\n return isGroup.value ? radioGroup.modelValue : props.modelValue;\n },\n set(val) {\n if (isGroup.value) {\n radioGroup.changeEvent(val);\n } else {\n emit && emit(UPDATE_MODEL_EVENT, val);\n }\n radioRef.value.checked = props.modelValue === props.label;\n }\n });\n const size = useSize(computed(() => radioGroup == null ? void 0 : radioGroup.size));\n const disabled = useDisabled(computed(() => radioGroup == null ? void 0 : radioGroup.disabled));\n const focus = ref(false);\n const tabIndex = computed(() => {\n return disabled.value || isGroup.value && modelValue.value !== props.label ? -1 : 0;\n });\n return {\n radioRef,\n isGroup,\n radioGroup,\n focus,\n size,\n disabled,\n tabIndex,\n modelValue\n };\n};\n\nexport { useRadio };\n//# sourceMappingURL=use-radio.mjs.map\n","import { defineComponent, nextTick, openBlock, createElementBlock, normalizeClass, unref, createElementVNode, withDirectives, isRef, vModelRadio, withModifiers, renderSlot, createTextVNode, toDisplayString } from 'vue';\nimport '../../../hooks/index.mjs';\nimport { radioProps, radioEmits } from './radio.mjs';\nimport { useRadio } from './use-radio.mjs';\nimport _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';\nimport { useNamespace } from '../../../hooks/use-namespace/index.mjs';\n\nconst _hoisted_1 = [\"value\", \"name\", \"disabled\"];\nconst __default__ = {\n name: \"ElRadio\"\n};\nconst _sfc_main = /* @__PURE__ */ defineComponent({\n ...__default__,\n props: radioProps,\n emits: radioEmits,\n setup(__props, { emit }) {\n const props = __props;\n const ns = useNamespace(\"radio\");\n const { radioRef, radioGroup, focus, size, disabled, modelValue } = useRadio(props, emit);\n function handleChange() {\n nextTick(() => emit(\"change\", modelValue.value));\n }\n return (_ctx, _cache) => {\n var _a;\n return openBlock(), createElementBlock(\"label\", {\n class: normalizeClass([\n unref(ns).b(),\n unref(ns).is(\"disabled\", unref(disabled)),\n unref(ns).is(\"focus\", unref(focus)),\n unref(ns).is(\"bordered\", _ctx.border),\n unref(ns).is(\"checked\", unref(modelValue) === _ctx.label),\n unref(ns).m(unref(size))\n ])\n }, [\n createElementVNode(\"span\", {\n class: normalizeClass([\n unref(ns).e(\"input\"),\n unref(ns).is(\"disabled\", unref(disabled)),\n unref(ns).is(\"checked\", unref(modelValue) === _ctx.label)\n ])\n }, [\n withDirectives(createElementVNode(\"input\", {\n ref_key: \"radioRef\",\n ref: radioRef,\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = ($event) => isRef(modelValue) ? modelValue.value = $event : null),\n class: normalizeClass(unref(ns).e(\"original\")),\n value: _ctx.label,\n name: _ctx.name || ((_a = unref(radioGroup)) == null ? void 0 : _a.name),\n disabled: unref(disabled),\n type: \"radio\",\n onFocus: _cache[1] || (_cache[1] = ($event) => focus.value = true),\n onBlur: _cache[2] || (_cache[2] = ($event) => focus.value = false),\n onChange: handleChange\n }, null, 42, _hoisted_1), [\n [vModelRadio, unref(modelValue)]\n ]),\n createElementVNode(\"span\", {\n class: normalizeClass(unref(ns).e(\"inner\"))\n }, null, 2)\n ], 2),\n createElementVNode(\"span\", {\n class: normalizeClass(unref(ns).e(\"label\")),\n onKeydown: _cache[3] || (_cache[3] = withModifiers(() => {\n }, [\"stop\"]))\n }, [\n renderSlot(_ctx.$slots, \"default\", {}, () => [\n createTextVNode(toDisplayString(_ctx.label), 1)\n ])\n ], 34)\n ], 2);\n };\n }\n});\nvar Radio = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"__file\", \"/home/runner/work/element-plus/element-plus/packages/components/radio/src/radio.vue\"]]);\n\nexport { Radio as default };\n//# sourceMappingURL=radio2.mjs.map\n","import '../../../utils/index.mjs';\nimport { radioPropsBase } from './radio.mjs';\nimport { buildProps } from '../../../utils/vue/props/runtime.mjs';\n\nconst radioButtonProps = buildProps({\n ...radioPropsBase,\n name: {\n type: String,\n default: \"\"\n }\n});\n\nexport { radioButtonProps };\n//# sourceMappingURL=radio-button.mjs.map\n","import { defineComponent, computed, openBlock, createElementBlock, normalizeClass, unref, withDirectives, createElementVNode, isRef, vModelRadio, normalizeStyle, withModifiers, renderSlot, createTextVNode, toDisplayString } from 'vue';\nimport '../../../hooks/index.mjs';\nimport { useRadio } from './use-radio.mjs';\nimport { radioButtonProps } from './radio-button.mjs';\nimport _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';\nimport { useNamespace } from '../../../hooks/use-namespace/index.mjs';\n\nconst _hoisted_1 = [\"value\", \"name\", \"disabled\"];\nconst __default__ = {\n name: \"ElRadioButton\"\n};\nconst _sfc_main = /* @__PURE__ */ defineComponent({\n ...__default__,\n props: radioButtonProps,\n setup(__props) {\n const props = __props;\n const ns = useNamespace(\"radio\");\n const { radioRef, focus, size, disabled, modelValue, radioGroup } = useRadio(props);\n const activeStyle = computed(() => {\n return {\n backgroundColor: (radioGroup == null ? void 0 : radioGroup.fill) || \"\",\n borderColor: (radioGroup == null ? void 0 : radioGroup.fill) || \"\",\n boxShadow: (radioGroup == null ? void 0 : radioGroup.fill) ? `-1px 0 0 0 ${radioGroup.fill}` : \"\",\n color: (radioGroup == null ? void 0 : radioGroup.textColor) || \"\"\n };\n });\n return (_ctx, _cache) => {\n var _a;\n return openBlock(), createElementBlock(\"label\", {\n class: normalizeClass([\n unref(ns).b(\"button\"),\n unref(ns).is(\"active\", unref(modelValue) === _ctx.label),\n unref(ns).is(\"disabled\", unref(disabled)),\n unref(ns).is(\"focus\", unref(focus)),\n unref(ns).bm(\"button\", unref(size))\n ])\n }, [\n withDirectives(createElementVNode(\"input\", {\n ref_key: \"radioRef\",\n ref: radioRef,\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = ($event) => isRef(modelValue) ? modelValue.value = $event : null),\n class: normalizeClass(unref(ns).be(\"button\", \"original-radio\")),\n value: _ctx.label,\n type: \"radio\",\n name: _ctx.name || ((_a = unref(radioGroup)) == null ? void 0 : _a.name),\n disabled: unref(disabled),\n onFocus: _cache[1] || (_cache[1] = ($event) => focus.value = true),\n onBlur: _cache[2] || (_cache[2] = ($event) => focus.value = false)\n }, null, 42, _hoisted_1), [\n [vModelRadio, unref(modelValue)]\n ]),\n createElementVNode(\"span\", {\n class: normalizeClass(unref(ns).be(\"button\", \"inner\")),\n style: normalizeStyle(unref(modelValue) === _ctx.label ? unref(activeStyle) : {}),\n onKeydown: _cache[3] || (_cache[3] = withModifiers(() => {\n }, [\"stop\"]))\n }, [\n renderSlot(_ctx.$slots, \"default\", {}, () => [\n createTextVNode(toDisplayString(_ctx.label), 1)\n ])\n ], 38)\n ], 2);\n };\n }\n});\nvar RadioButton = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"__file\", \"/home/runner/work/element-plus/element-plus/packages/components/radio/src/radio-button.vue\"]]);\n\nexport { RadioButton as default };\n//# sourceMappingURL=radio-button2.mjs.map\n","import '../../../utils/index.mjs';\nimport '../../../hooks/index.mjs';\nimport { radioEmits } from './radio.mjs';\nimport { buildProps } from '../../../utils/vue/props/runtime.mjs';\nimport { useSizeProp } from '../../../hooks/use-common-props/index.mjs';\n\nconst radioGroupProps = buildProps({\n id: {\n type: String,\n default: void 0\n },\n size: useSizeProp,\n disabled: Boolean,\n modelValue: {\n type: [String, Number, Boolean],\n default: \"\"\n },\n fill: {\n type: String,\n default: \"\"\n },\n label: {\n type: String,\n default: void 0\n },\n textColor: {\n type: String,\n default: \"\"\n },\n name: {\n type: String,\n default: void 0\n },\n validateEvent: {\n type: Boolean,\n default: true\n }\n});\nconst radioGroupEmits = radioEmits;\n\nexport { radioGroupEmits, radioGroupProps };\n//# sourceMappingURL=radio-group.mjs.map\n","import { defineComponent, ref, nextTick, onMounted, computed, provide, reactive, toRefs, watch, openBlock, createElementBlock, unref, normalizeClass, renderSlot } from 'vue';\nimport '../../../constants/index.mjs';\nimport '../../../tokens/index.mjs';\nimport '../../../hooks/index.mjs';\nimport '../../../utils/index.mjs';\nimport { radioGroupProps, radioGroupEmits } from './radio-group.mjs';\nimport _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';\nimport { useNamespace } from '../../../hooks/use-namespace/index.mjs';\nimport { useId } from '../../../hooks/use-id/index.mjs';\nimport { useFormItem, useFormItemInputId } from '../../../hooks/use-form-item/index.mjs';\nimport { UPDATE_MODEL_EVENT } from '../../../constants/event.mjs';\nimport { radioGroupKey } from '../../../tokens/radio.mjs';\nimport { debugWarn } from '../../../utils/error.mjs';\n\nconst _hoisted_1 = [\"id\", \"aria-label\", \"aria-labelledby\"];\nconst __default__ = {\n name: \"ElRadioGroup\"\n};\nconst _sfc_main = /* @__PURE__ */ defineComponent({\n ...__default__,\n props: radioGroupProps,\n emits: radioGroupEmits,\n setup(__props, { emit }) {\n const props = __props;\n const ns = useNamespace(\"radio\");\n const radioId = useId();\n const radioGroupRef = ref();\n const { formItem } = useFormItem();\n const { inputId: groupId, isLabeledByFormItem } = useFormItemInputId(props, {\n formItemContext: formItem\n });\n const changeEvent = (value) => {\n emit(UPDATE_MODEL_EVENT, value);\n nextTick(() => emit(\"change\", value));\n };\n onMounted(() => {\n const radios = radioGroupRef.value.querySelectorAll(\"[type=radio]\");\n const firstLabel = radios[0];\n if (!Array.from(radios).some((radio) => radio.checked) && firstLabel) {\n firstLabel.tabIndex = 0;\n }\n });\n const name = computed(() => {\n return props.name || radioId.value;\n });\n provide(radioGroupKey, reactive({\n ...toRefs(props),\n changeEvent,\n name\n }));\n watch(() => props.modelValue, () => {\n if (props.validateEvent) {\n formItem == null ? void 0 : formItem.validate(\"change\").catch((err) => debugWarn(err));\n }\n });\n return (_ctx, _cache) => {\n return openBlock(), createElementBlock(\"div\", {\n id: unref(groupId),\n ref_key: \"radioGroupRef\",\n ref: radioGroupRef,\n class: normalizeClass(unref(ns).b(\"group\")),\n role: \"radiogroup\",\n \"aria-label\": !unref(isLabeledByFormItem) ? _ctx.label || \"radio-group\" : void 0,\n \"aria-labelledby\": unref(isLabeledByFormItem) ? unref(formItem).labelId : void 0\n }, [\n renderSlot(_ctx.$slots, \"default\")\n ], 10, _hoisted_1);\n };\n }\n});\nvar RadioGroup = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"__file\", \"/home/runner/work/element-plus/element-plus/packages/components/radio/src/radio-group.vue\"]]);\n\nexport { RadioGroup as default };\n//# sourceMappingURL=radio-group2.mjs.map\n","import '../../utils/index.mjs';\nimport Radio from './src/radio2.mjs';\nimport RadioButton from './src/radio-button2.mjs';\nimport RadioGroup from './src/radio-group2.mjs';\nexport { radioEmits, radioProps, radioPropsBase } from './src/radio.mjs';\nexport { radioGroupEmits, radioGroupProps } from './src/radio-group.mjs';\nexport { radioButtonProps } from './src/radio-button.mjs';\nimport { withInstall, withNoopInstall } from '../../utils/vue/install.mjs';\n\nconst ElRadio = withInstall(Radio, {\n RadioButton,\n RadioGroup\n});\nconst ElRadioGroup = withNoopInstall(RadioGroup);\nconst ElRadioButton = withNoopInstall(RadioButton);\n\nexport { ElRadio, ElRadioButton, ElRadioGroup, ElRadio as default };\n//# sourceMappingURL=index.mjs.map\n","<template>\n <el-image style=\"width: 150px; height: 150px\" :src=\"src\" :preview-src-list=\"srcList\"/>\n</template>\n<script>\nexport default {\n name: 'QrCode',\n props: {\n value: String,\n },\n data() {\n return {\n src: '',\n srcList: [],\n }\n },\n watch: {\n value(to) {\n if (!to) {\n return\n }\n this.src = this.createEwm(to)\n this.srcList = [this.src]\n },\n },\n methods: {\n createEwm(text, config) {\n // eslint-disable-next-line no-undef\n const canvasImg = new AraleQRCode({\n text,\n size: 400,\n foreground: '#000',\n ...config,\n })\n return canvasImg.toDataURL('image/png')\n },\n },\n mounted() {\n if (this.value) {\n this.src = this.createEwm(this.value)\n this.srcList = [this.src]\n }\n },\n}\n</script>\n","<script lang=\"ts\">\nimport { ElMessage } from 'element-plus'\nimport { computed, defineComponent, ref, watchEffect } from 'vue'\nimport QrCode from '@components/QrCode.vue'\nimport { copyRes, getShortUrl } from '@/utils/stringUtil'\nimport { useIsMobile, useSiteConfig } from '@/composables'\n\nexport default defineComponent({\n name: 'LinkDialog',\n components: {\n QrCode,\n },\n props: {\n title: {\n type: String,\n default: '链接面板',\n },\n value: {\n type: Boolean,\n },\n link: {\n type: String,\n default: '',\n },\n download: {\n type: Boolean,\n default: true,\n },\n shareTextPrefix: {\n type: String,\n default: '',\n },\n },\n emits: ['update:value'],\n setup(props, context) {\n const shareLink = ref('')\n const showModel = ref(false)\n const isMobile = useIsMobile()\n const copyLink = () => {\n copyRes(shareLink.value)\n }\n const { value: siteConfig } = useSiteConfig()\n\n watchEffect(() => {\n shareLink.value = props.link\n })\n watchEffect(() => {\n showModel.value = props.value\n if (showModel.value && props.download) {\n setTimeout(() => {\n ElMessage.success('如未自动开始下载,请复制链接到浏览器中执行下载')\n }, 200)\n }\n })\n const handleClose = () => {\n context.emit('update:value', false)\n }\n const createShortLink = () => {\n getShortUrl(shareLink.value).then((v) => {\n shareLink.value = v\n ElMessage.success('短链生成成功')\n })\n }\n const appName = computed(() => siteConfig.value.appName)\n const shareText = computed(() => {\n return `${appName.value && `【${appName.value}】`}${props.shareTextPrefix} ${shareLink.value}`\n })\n const copyShareText = () => {\n copyRes(shareText.value)\n }\n\n const showShareTextPanel = computed(() => !!props.shareTextPrefix)\n return {\n shareLink,\n createShortLink,\n copyLink,\n handleClose,\n showModel,\n isMobile,\n shareText,\n copyShareText,\n showShareTextPanel,\n }\n },\n})\n</script>\n\n<template>\n <div>\n <el-dialog v-model=\"showModel\" :fullscreen=\"isMobile\" :title=\"title\" center @close=\"handleClose\">\n <!-- 链接 -->\n <div>\n <el-input v-model=\"shareLink\" placeholder=\"生成的链接\">\n <template #append>\n <el-button type=\"primary\" @click=\"copyLink\">\n 复制\n </el-button>\n </template>\n </el-input>\n </div>\n <!-- 二维码 -->\n <div class=\"center\">\n <QrCode :value=\"shareLink\" />\n </div>\n <div class=\"center\">\n <el-button type=\"primary\" @click=\"createShortLink\">\n 生成短链\n </el-button>\n </div>\n <template v-if=\"showShareTextPanel\">\n <div class=\"center\">\n <el-input\n :value=\"shareText\" style=\"width: 300px\" :autosize=\"{ minRows: 3, maxRows: 10 }\" type=\"textarea\"\n placeholder=\"分享信息\"\n />\n </div>\n <div class=\"center\">\n <el-button type=\"success\" round @click=\"copyShareText\">\n 复制分享信息\n </el-button>\n </div>\n </template>\n </el-dialog>\n </div>\n</template>\n\n<style lang=\"scss\" scoped>\n.center {\n text-align: center;\n margin-top: 10px;\n}\n</style>\n","<script setup lang=\"ts\">\nimport { computed } from 'vue'\nimport { useSiteConfig } from '@/composables'\n\ndefineProps<{\n infos: InfoItem[]\n disabled: boolean\n labelPosition?: 'left' | 'right' | 'top'\n}>()\n\nconst { value: siteConfig } = useSiteConfig()\nconst maxInputLength = computed(() => siteConfig.value.maxInputLength)\n</script>\n\n<template>\n <el-form :disabled=\"disabled\" :label-position=\"labelPosition || 'top'\">\n <el-form-item\n v-for=\"(info, idx) in infos\"\n :key=\"idx\"\n class=\"ellipsis\"\n :label=\"info.type === 'text' ? '' : info.text\"\n >\n <div v-if=\"info.type === 'text'\" class=\"fixed-text\">\n {{ info.text }}\n </div>\n <el-input\n v-if=\"info.type === 'input'\"\n v-model=\"info.value\"\n :maxlength=\"maxInputLength\"\n clearable\n show-word-limit\n :placeholder=\"`请输入 ${info.text}`\"\n />\n <el-radio-group v-if=\"info.type === 'radio'\" v-model=\"info.value\">\n <el-radio\n v-for=\"(r, idx) in info.children\"\n :key=\"idx\"\n :label=\"r.text\"\n >\n {{ r.text }}\n </el-radio>\n </el-radio-group>\n <el-select\n v-if=\"info.type === 'select'\"\n v-model=\"info.value\"\n default-first-option\n clearable\n filterable\n :placeholder=\"`请选择 ${info.text}`\"\n >\n <el-option\n v-for=\"(r, idx) in info.children\"\n :key=\"idx\"\n :label=\"r.text\"\n :value=\"r.text\"\n />\n </el-select>\n </el-form-item>\n </el-form>\n</template>\n\n<style scoped lang=\"scss\">\n:deep(div.el-form-item > label) {\n font-weight: bold;\n &::before {\n content: '* ';\n color: red;\n }\n}\n\n:deep(div.el-form-item__content > .el-select) {\n flex: 1;\n}\n.fixed-text {\n background-color: #f5f7fa;\n padding: 0 10px;\n width: 100%;\n text-align: left;\n}\n</style>\n"],"names":["radioGroupKey","Symbol","radioPropsBase","buildProps","size","useSizeProp","disabled","Boolean","label","type","String","Number","default","radioProps","modelValue","name","border","radioEmits","UPDATE_MODEL_EVENT","val","isString","isNumber","isBoolean","CHANGE_EVENT","useRadio","props","emit","radioRef","ref","radioGroup","inject","isGroup","computed","get","value","set","changeEvent","checked","useSize","useDisabled","focus","tabIndex","_hoisted_1","Radio","_export_sfc","defineComponent","emits","setup","__props","ns","useNamespace","handleChange","nextTick","_ctx","_cache","_a","openBlock","createElementBlock","class","normalizeClass","unref","b","is","m","createElementVNode","e","withDirectives","ref_key","$event","isRef","onFocus","onBlur","onChange","vModelRadio","onKeydown","withModifiers","renderSlot","$slots","createTextVNode","toDisplayString","radioButtonProps","RadioButton","activeStyle","backgroundColor","fill","borderColor","boxShadow","color","textColor","bm","be","style","normalizeStyle","radioGroupProps","id","validateEvent","RadioGroup","radioId","useId","radioGroupRef","formItem","useFormItem","inputId","groupId","isLabeledByFormItem","useFormItemInputId","formItemContext","onMounted","radios","querySelectorAll","firstLabel","Array","from","some","radio","provide","reactive","toRefs","watch","validate","catch","err","debugWarn","role","labelId","ElRadio","exports","withInstall","ElRadioGroup","withNoopInstall","data","src","srcList","to","this","createEwm","methods","text","config","AraleQRCode","foreground","toDataURL","mounted","_createBlock","_component_el_image","width","height","$data","_sfc_main$1","components","QrCode","title","link","download","shareTextPrefix","context","shareLink","showModel","isMobile","useIsMobile","siteConfig","useSiteConfig","watchEffect","setTimeout","ElMessage","success","appName","shareText","showShareTextPanel","createShortLink","getShortUrl","then","v","copyLink","copyRes","handleClose","copyShareText","_hoisted_2","__unplugin_components_3","_openBlock","_createElementBlock","_createVNode","_component_el_dialog","fullscreen","onClose","_withCtx","_createElementVNode","_component_el_input","placeholder","append","onClick","_createTextVNode","_component_QrCode","_Fragment","key","_hoisted_3","autosize","minRows","maxRows","_hoisted_4","_component_el_button","round","_createCommentVNode","maxInputLength"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4,5,6,7,8]}
@@ -1,2 +1,2 @@
1
- System.register(["./index-legacy-BLKO-78a.js","./el-loading-legacy-CRJF51cp.js","./el-progress-legacy-zjlCtRh2.js","./el-form-item-legacy-CcX_hnMk.js","./tip-legacy-DpAPUNpm.js","./index-legacy-pP3Pmgbs.js","./el-dialog-legacy-u4KST5yo.js","./index-legacy-2f3kE3Xe.js","./index-legacy-6cMsZS3c.js","./isEqual-legacy-4dmPHJnc.js","./el-select-legacy-D4o92tvp.js","./validator-legacy-CN5REdqi.js","./aria-legacy-B70JmEZA.js"],(function(e,a){"use strict";var l,t,n,i,s,o,u,d,r,c,p,v,f,m,g,h,y,x,k,w,b,_,z,j,N,$,C,E,T,U,I,L,S,F,O,M,D,P,V,A,G,J,R,W,q,B,H,K,Y,X,Z,Q,ee,ae,le,te,ne,ie,se;return{setters:[e=>{l=e.g,t=e.d,n=e.a,i=e.c,s=e.b,o=e.u,u=e.a1,d=e.Z,r=e.O,c=e.r,p=e.$,v=e.bt,f=e.o,m=e.aW,g=e.E,h=e.bf,y=e.i,x=e.j,k=e.w,w=e.F,b=e.C,_=e.t,z=e.a8,j=e.k,N=e.S,$=e.e,C=e.D,E=e.a9,T=e.a5,U=e.a3,I=e.aY,L=e.ag,S=e.bX,F=e.ae,O=e.aa,M=e.af,D=e.y,P=e.v,V=e.x,A=e.I,G=e.p,J=e.f,R=e.b0,W=e.s,q=e.ac,B=e.a_,H=e.P,K=e._},e=>{Y=e.v},e=>{X=e.a,Z=e.E},e=>{Q=e.E,ee=e.a},e=>{ae=e.T,le=e.E},e=>{te=e.I,ne=e.L},e=>{ie=e.u},e=>{se=e.E},null,null,null,null,null],execute:function(){var a=document.createElement("style");a.textContent='@charset "UTF-8";.task-panel[data-v-8a74d233] ul.el-upload-list{border:1px dashed #d4d4d4;padding:10px}.task-panel[data-v-8a74d233] ul.el-upload-list:before{content:"此处展示选择文件列表";font-size:12px;position:relative;bottom:4px}.task-panel[data-v-8a74d233] .el-upload-list__item-name{display:block;overflow:hidden;max-width:290px;text-overflow:ellipsis;word-break:keep-all}.task-panel[data-v-8a74d233] .is-ready .el-icon--close{display:block;color:#000}.task-panel[data-v-8a74d233]{background-color:#f3f6f8;padding-bottom:1rem;position:relative}.pc-nav[data-v-8a74d233]{background-color:#fff;display:flex;padding:10px;justify-content:space-between;align-items:center}.pc-nav .exit[data-v-8a74d233]{cursor:pointer}.pc-nav .nav[data-v-8a74d233]{display:flex}.pc-nav .nav nav[data-v-8a74d233]{display:flex;align-items:center}.pc-nav .nav nav .nav-item[data-v-8a74d233]{font-size:1rem;color:#595959;padding:10px;cursor:pointer}.pc-nav .nav nav .nav-item.active[data-v-8a74d233]{color:#409eff!important;font-weight:600}.pc-nav .nav .exit[data-v-8a74d233]{color:#595959}.pc-nav .logo[data-v-8a74d233]{width:180px;margin:0 10px}.pc-nav .logo img[data-v-8a74d233]{height:40px}.panel[data-v-8a74d233]{max-width:1024px;padding:1em;background-color:#fff;margin:10px auto;box-sizing:border-box;box-shadow:0 2px 12px rgba(0,0,0,.1);border-radius:4px}.panel .name[data-v-8a74d233]{text-align:center}.panel .ddl[data-v-8a74d233]{margin-top:10px;color:#919191;font-size:14px}.panel .infos[data-v-8a74d233]{max-width:460px;margin:auto;overflow:hidden}.panel .infos[data-v-8a74d233] div.el-form-item>label{font-weight:700}.panel .infos[data-v-8a74d233] div.el-form-item>label:before{content:"* ";color:red}.withdraw[data-v-8a74d233]{text-align:right}.tip-wrapper[data-v-8a74d233]{line-height:20px;text-align:left;word-break:break-all;overflow:hidden;padding:0 20px;color:#e6a23c;max-width:320px;font-size:14px}\n',document.head.appendChild(a);const oe=t({name:"UploadFilled"}),ue={viewBox:"0 0 1024 1024",xmlns:"http://www.w3.org/2000/svg"},de=[s("path",{fill:"currentColor",d:"M544 864V672h128L512 480 352 672h128v192H320v-1.6c-5.376.32-10.496 1.6-16 1.6A240 240 0 0 1 64 624c0-123.136 93.12-223.488 212.608-237.248A239.808 239.808 0 0 1 512 192a239.872 239.872 0 0 1 235.456 194.752c119.488 13.76 212.48 114.112 212.48 237.248a240 240 0 0 1-240 240c-5.376 0-10.56-1.28-16-1.6v1.6H544z"},null,-1)];var re=l(oe,[["render",function(e,a,l,t,s,o){return n(),i("svg",ue,de)}]]);const ce=e=>(G("data-v-8a74d233"),e=e(),J(),e),pe={class:"task-panel"},ve={class:"pc-nav"},fe={class:"nav"},me={class:"logo"},ge=ce((()=>s("img",{style:{height:"40px",width:"170px"},src:"https://img.cdn.sugarat.top/easypicker/EasyPicker.png",alt:"logo"},null,-1))),he=["onClick"],ye={key:0,"element-loading-text":"Loading...",class:"panel tc"},xe={class:"name"},ke={key:0,style:{color:"red"}},we={class:"tip-wrapper"},be={class:"ddl"},_e={key:0},ze={key:4},je={class:"infos"},Ne={key:0},$e={class:"infos"},Ce=ce((()=>s("div",{class:"el-upload__text"},[$(" 将文件拖于此处 or "),s("em",null,"直接选择文件")],-1))),Ee={class:"p10"},Te={class:"p10"},Ue={class:"p10 option-tips"},Ie={style:{color:"red"}},Le={style:{color:"red"}},Se=ce((()=>s("br",null,null,-1))),Fe=ce((()=>s("br",null,null,-1))),Oe=ce((()=>s("strong",null,"查询提交情况,需填写和提交时一样的表单信息",-1))),Me=ce((()=>s("br",null,null,-1))),De=ce((()=>s("strong",null,"选择大文件后需要等待一会儿才展示处理",-1))),Pe=ce((()=>s("br",null,null,-1))),Ve={class:"withdraw"},Ae={key:1,class:"panel tc"},Ge={class:"name"},Je={style:{"padding-top":"20px"}};e("default",K(t({__name:"index",setup(e){const a=ie(),l=o(),t=u(),G=d([{title:"我也要收集",path:"https://docs.ep.sugarat.top/"}]),J=d({name:"",category:""}),K=d({bindField:""}),oe=r((()=>R(K.format))),ue=c(""),de=c(0),ce=r((()=>de.value<=0)),Re=r((()=>{let e=~~(de.value/1e3),a=~~(e/3600);const l=~~(a/24);a%=24;const t=~~(e%3600/60);return e%=60,`剩余${l}天${a}时${t}分${e}秒`}));function We(e=!0){if(K?.ddl){const e=new Date(K.ddl);de.value=e.getTime()-Date.now()}else de.value=0;e&&setTimeout((()=>{We()}),1e3)}const qe=r((()=>{if(K?.ddl){const e=new Date(K.ddl);return W(e)}return""})),Be=d([]),He=c([]),Ke=c(),Ye=r((()=>He.value.filter((e=>"uploading"===e.status)).length>0)),Xe=e=>"uploading"!==e.status&&"success"!==e.status||se.confirm("不影响已经上传成功的,正在上传的将取消上传","确定从列表移除文件吗?").then((()=>("uploading"===e.status&&(g.info(`取消${e.name}的上传`),e.subscription.unsubscribe()),!0))).catch((()=>!1)),Ze=r((()=>Be.every((e=>e.value)))),Qe=r((()=>K.bindField.trim()||"姓名")),ea=r((()=>Be.find((e=>e.text===Qe.value)))),aa=r((()=>K.people&&!ea.value)),la=d({peopleName:""});function ta(e,a,l){if(!a){const e=`请输入${Qe.value}`;return l(new Error(e)),void g.error(e)}I.checkPeopleIsExist(ue.value,a).then((e=>{e.data.exist||g.error("你不在此次提交名单中,如有疑问请联系管理员"),l(e.data.exist?void 0:new Error("你不在此次提交名单中,如有疑问请联系管理员"))}))}const na=c(),ia=d({peopleName:[{validator:ta,trigger:"blur"}]});function sa(){if(ea.value){const e=Be.find((e=>e.text===Qe.value))?.value;return la.peopleName=e||"",new Promise((a=>{ta(0,e,a)})).then((e=>!e))}return na.value.validate((e=>e))}async function oa(){if(Ze.value){if(K.people&&!(await sa()))return;!function(){const e=He.value;for(const a of e)if(a.md5){if("ready"===a.status){a.status="uploading";let{name:e}=a;const l=e;K.rewrite&&(e=Be.map((e=>e.value)).join(oe.value.splitChar||"-")+L(e)),e=q(e);const t=`easypicker2/${ue.value}/${a.md5}/${e}`;F.getUploadToken().then((n=>{B(n.data.token,a.raw,t,{success(t){const{fsize:n}=t;F.addFile({originName:l,name:e,taskKey:ue.value,taskName:J.name,size:n,hash:a.md5,info:JSON.stringify(Be),people:la.peopleName}).then((()=>{a.status="success",g.success(`文件:${a.name}提交成功`),K.people&&I.updatePeopleStatus(ue.value,e,la.peopleName,a.md5)}))},process(e,l,t){a.percentage=Math.floor(e),a.subscription=t}})}))}}else g.info(`文件(${a.name})的唯一指纹还在计算中,再等待一会儿再点击上传`),setTimeout((()=>{g.info("文件越大计算时间越长(1G通常需要20s)")}),100)}()}else g.warning("请先完成必要信息的填写")}const ua=r((()=>{for(const e of He.value)if("ready"===e.status)return!0;return!1})),da=r((()=>{for(const e of He.value)if(["success","ready"].includes(e.status))return!0;return!1})),ra=c(0);function ca(e){const{name:a}=e;if(oe.value.format.length&&oe.value.status){const l=L(a);if(!oe.value.format.find((e=>l.toLowerCase().endsWith(e))))return g.error(`${a} 格式不符合要求`),void Ke.value.handleRemove(e)}if(oe.value.size&&oe.value.size<e.size)return g.error(`${a} 大小${T(e.size)} 不符合要求`),void Ke.value.handleRemove(e);ra.value+=1,S(e.raw).then((a=>{e.md5=a,ra.value-=1}))}const pa=r((()=>oe.value.limit||10));function va(){g.warning(`一次提交最多只能选择${pa.value}个文件,请移除已经上传成功的或刷新页面`)}const fa=c(!1),ma=c("");function ga(){F.getTemplateUrl(K.template,ue.value).then((e=>{fa.value=!0;const{link:a}=e.data;ma.value=a,O(a,K.template)})).catch((()=>{g.warning("文件已从服务器上移除,请联系管理员重新上传")}))}const ha=c(!1);async function ya(){if(Ze.value){if(K.people&&!(await sa()))return;!function(){const e=He.value;for(const a of e)if(a.md5){if(!["fail","uploading"].includes(a.status)){let{name:e}=a;K.rewrite&&(e=Be.map((e=>e.value)).join(oe.value.splitChar||"-")+L(e)),F.withdrawFile({taskKey:ue.value,taskName:J.name,filename:e,hash:a.md5,info:JSON.stringify(Be),peopleName:la.peopleName}).then((()=>{g.success(`文件:${a.name}撤回成功`),a.name+=" - (已撤回 ✅ )",a.status="fail"})).catch((()=>{g.error(`撤回失败: 没有文件:${a.name}对应提交记录`)}))}}else g.info(`文件(${a.name})的唯一指纹还在计算中,再等待一会儿再点击上传`),setTimeout((()=>{g.info("文件越大计算时间越长(1G通常需要20s)")}),100)}()}else g.warning("请先完成必要信息的填写")}async function xa(){if(Ze.value){if(K.people&&!(await sa()))return;F.checkSubmitStatus(ue.value,Be,la.peopleName).then((e=>{e.data.isSubmit?g.success("已经提交过啦"):g.warning("还未提交过哟")}))}else g.warning("请先完成必要信息的填写,需和提交时信息完全一致")}const ka=c(!1),wa=c(!1);function ba(e=[],a=[]){return e.length===a.length&&e.every(((e,l)=>e.type===a[l].type&&e.text===a[l].text&&ba(e.children,a[l].children)))}function _a(e=!1){m.getTaskMoreInfo(ue.value).then((a=>{Object.assign(K,a.data),ba(Be,M(K.info))||(Be.splice(0,Be.length),Be.push(...M(K.info)),e&&g.success("表单信息有更新")),We(!1),ka.value=!1}))}function za(){wa.value=!0}function ja(){wa.value&&!Ye.value&&(wa.value=!1,_a(!0))}const Na=r((()=>ce.value?qe.value:qe.value+Re.value)),$a=d({text:"",imgs:[]}),Ca=c([]);p((()=>K.tip),(()=>{try{const e=JSON.parse(K.tip);$a.imgs=e.imgs,$a.text=e.text||"",Ca.value=$a.imgs.map((e=>({...e,url:"https://img.cdn.sugarat.top/mdImg/MTY3NzkxMDI1NTU1Nw==20140524124237518.gif"}))),Ca.value.length&&H.getTipImageUrl(ue.value,Ca.value.map((e=>({uid:e.uid,name:e.name})))).then((e=>{e.data.forEach(((e,a)=>{Ca.value[a].url=e.cover,Object.assign(Ca.value[a],{preview:e.preview})}))}))}catch{$a.text="",$a.imgs=[],Ca.value=[]}}));const Ea=v("disabledUpload",!1);return f((()=>{ue.value=t.params.key,ue.value&&(ka.value=!0,m.getTaskInfo(ue.value).then((e=>{Object.assign(J,e.data),Ea.value=!!e.data.limitUpload,Ea.value&&se.alert("任务存储空间容量已达到上限,已经无法进行上传,请联系发起人扩容空间")})).catch((e=>{4001===e.code&&(g.error("任务不存在"),ue.value="",J.name="任务不存在")})),_a(),We()),window.addEventListener("blur",za),window.addEventListener("focus",ja)})),h((()=>{window.removeEventListener("blur",za),window.removeEventListener("focus",ja)})),(e,t)=>{const o=y("router-link"),u=D,d=le,r=X,c=P,p=Q,v=ee,f=V,m=A,g=Z,h=Y;return n(),i("div",pe,[s("div",ve,[s("div",fe,[s("div",me,[x(o,{to:"/"},{default:k((()=>[ge])),_:1})]),s("nav",null,[(n(!0),i(w,null,b(G,((e,a)=>(n(),i("div",{key:a,class:"nav-item",onClick:e=>function(e){G[e].path.startsWith("http")?window.location.href=G[e].path:l.push({path:G[e].path})}(a)},_(e.title),9,he)))),128))])])]),ue.value?z((n(),i("div",ye,[s("h1",xe,_(J.name),1),j(Ea)?(n(),i("h2",ke," 任务存储空间容量已达到上限,已经无法进行上传,请联系发起人扩容空间 ")):N("",!0),!$a.text||qe.value&&ce.value?N("",!0):(n(),i(w,{key:1},[x(u,null,{default:k((()=>[$("⚠️ 注意事项 ⚠️")])),_:1}),x(ae,null,{default:k((()=>[s("div",we,[(n(!0),i(w,null,b($a.text.split("\n"),((e,a)=>(n(),i("p",{key:a},_(e.replace(/\s/g," ")),1)))),128))])])),_:1})],64)),!Ca.value.length||qe.value&&ce.value?N("",!0):(n(!0),i(w,{key:2},b(Ca.value,((e,a)=>(n(),C(d,{key:e.uid,"hide-on-click-modal":"",style:{width:"100px",height:"100px",margin:"10px"},src:e.url,"zoom-rate":1.2,"preview-src-list":Ca.value.map((e=>e.preview)),"initial-index":a,fit:"contain"},null,8,["src","preview-src-list","initial-index"])))),128)),qe.value?(n(),i(w,{key:3},[x(u,null,{default:k((()=>[$("截止时间")])),_:1}),s("h2",be,_(Na.value),1),ce.value?(n(),i("div",_e,[x(r,{description:"已经结束啦!"})])):N("",!0)],64)):N("",!0),qe.value&&ce.value?N("",!0):(n(),i("div",ze,[x(u,null,{default:k((()=>[$("必要信息填写")])),_:1}),s("div",je,[z(s("div",null,[x(ae,null,{default:k((()=>[$("“"+_(Qe.value)+"”在参与名单里才能正常提交",1)])),_:1})],512),[[E,K.people]]),aa.value?(n(),i("div",Ne,[s("div",$e,[x(v,{ref_key:"validModalRef",ref:na,rules:ia,"status-icon":"",model:la,disabled:Ye.value,"label-position":"top"},{default:k((()=>[x(p,{prop:"peopleName",label:Qe.value},{default:k((()=>[x(c,{modelValue:la.peopleName,"onUpdate:modelValue":t[0]||(t[0]=e=>la.peopleName=e),maxlength:14,clearable:"","show-word-limit":"",placeholder:`请输入 ${Qe.value}`},null,8,["modelValue","placeholder"])])),_:1},8,["label"])])),_:1},8,["rules","model","disabled"])])])):N("",!0),x(te,{infos:Be,disabled:Ye.value},null,8,["infos","disabled"])]),x(g,{ref_key:"fileUpload",ref:Ke,"file-list":He.value,"onUpdate:fileList":t[1]||(t[1]=e=>He.value=e),style:{"max-width":"400px",margin:"0 auto"},drag:!j(a),action:"","on-change":ca,"before-remove":Xe,"on-exceed":va,"auto-upload":!1,multiple:"",limit:pa.value},{tip:k((()=>[z(s("div",Ee,[x(ae,null,{default:k((()=>[$(" 还有 "+_(ra.value)+" 个文件正在生成校验信息,请稍等(1G通常需要20s) ",1)])),_:1})],512),[[E,!!ra.value]])])),default:k((()=>[j(a)?(n(),C(f,{key:0,type:"primary"},{default:k((()=>[$(" 选择文件 ")])),_:1})):(n(),i(w,{key:1},[x(m,{class:"el-icon--upload"},{default:k((()=>[x(j(re))])),_:1}),Ce],64))])),_:1},8,["file-list","drag","limit"]),s("div",Te,[ha.value?(n(),C(f,{key:0,size:"default",type:"warning",disabled:!da.value||!!ra.value,onClick:ya},{default:k((()=>[$(" 一键撤回 ")])),_:1},8,["disabled"])):j(Ea)?N("",!0):(n(),C(f,{key:1,size:"default",type:"success",disabled:!ua.value||!!ra.value,onClick:oa},{default:k((()=>[$(" 提交文件 ")])),_:1},8,["disabled"])),x(f,{size:"default",onClick:xa},{default:k((()=>[$(" 查询提交情况 ")])),_:1})]),s("div",Ue,[oe.value.status&&oe.value.format.length?(n(),C(ae,{key:0},{default:k((()=>[$(" 限制格式为: "),s("span",Ie,_(oe.value.format.join(", ")),1)])),_:1})):N("",!0),oe.value.size?(n(),C(ae,{key:1},{default:k((()=>[$(" 限制文件大小不超过: "),s("span",Le,_(j(T)(oe.value.size)),1)])),_:1})):N("",!0),ha.value?(n(),C(ae,{key:2},{default:k((()=>[$(" ① 须保证选择的文件与提交时的文件一致"),Se,$(" ② 填写表单信息一致 "),Fe,$(" ③ 完全一模一样的文件的提交记录(内容md5+命名),将会一次性全部撤回 ")])),_:1})):(n(),i(w,{key:3},[x(ae,null,{default:k((()=>[Oe])),_:1}),x(ae,null,{default:k((()=>[$(" ① 选择完文件,点击 ”提交文件“即可 "),Me,$(" ② "),De,K.template&&!j(Ea)?(n(),i(w,{key:0},[Pe,$(" ③ "),s("strong",null,[x(f,{type:"primary",text:"",style:{color:"#85ce61"},size:"small",onClick:ga},{default:k((()=>[$("右下角可 “查看提交示例” ")])),_:1})])],64)):N("",!0)])),_:1})],64))]),s("div",Ve,[K.template&&!j(Ea)?(n(),C(f,{key:0,type:"primary",text:"",style:{color:"#85ce61"},size:"small",onClick:ga},{default:k((()=>[$(" 查看提交示例 ")])),_:1})):N("",!0),ha.value?(n(),C(f,{key:1,size:"small",type:"primary",text:"",onClick:t[2]||(t[2]=e=>ha.value=!1)},{default:k((()=>[$(" 正常提交 ")])),_:1})):(n(),C(f,{key:2,size:"small",type:"primary",text:"",onClick:t[3]||(t[3]=e=>ha.value=!0)},{default:k((()=>[$(" 我要撤回 ")])),_:1}))])]))])),[[h,ka.value]]):(n(),i("div",Ae,[s("h1",Ge,_(J.name),1)])),x(ne,{value:fa.value,"onUpdate:value":t[4]||(t[4]=e=>fa.value=e),title:"示例文件下载链接",link:ma.value},null,8,["value","link"]),s("div",Je,[x(U,{type:"task"})])])}}}),[["__scopeId","data-v-8a74d233"]]))}}}));
2
- //# sourceMappingURL=index-legacy-BqL3XK76.js.map
1
+ System.register(["./index-legacy-B4IHsyj2.js","./el-loading-legacy-DWfn3F3x.js","./el-progress-legacy-CwFO38du.js","./el-form-item-legacy-BS5eT84Y.js","./tip-legacy-B05oHh9-.js","./index-legacy-BKxszgZW.js","./el-dialog-legacy-DCFOVWEQ.js","./index-legacy-GbLWntci.js","./index-legacy-Dhs-OKEx.js","./isEqual-legacy-dqS7X02N.js","./el-select-legacy-fKvGMZFT.js","./validator-legacy-D0GLFVMZ.js","./aria-legacy-B70JmEZA.js"],(function(e,a){"use strict";var l,t,n,i,s,o,u,d,r,c,p,v,f,m,g,h,y,x,k,w,b,_,z,j,N,$,C,E,T,U,I,L,S,F,O,M,D,P,V,A,G,J,R,W,q,B,H,K,Y,X,Z,Q,ee,ae,le,te,ne,ie,se;return{setters:[e=>{l=e.g,t=e.d,n=e.a,i=e.c,s=e.b,o=e.u,u=e.a1,d=e.Z,r=e.O,c=e.r,p=e.$,v=e.bt,f=e.o,m=e.aW,g=e.E,h=e.bf,y=e.i,x=e.j,k=e.w,w=e.F,b=e.C,_=e.t,z=e.a8,j=e.k,N=e.S,$=e.e,C=e.D,E=e.a9,T=e.a5,U=e.a3,I=e.aY,L=e.ag,S=e.bX,F=e.ae,O=e.aa,M=e.af,D=e.y,P=e.v,V=e.x,A=e.I,G=e.p,J=e.f,R=e.b0,W=e.s,q=e.ac,B=e.a_,H=e.P,K=e._},e=>{Y=e.v},e=>{X=e.a,Z=e.E},e=>{Q=e.E,ee=e.a},e=>{ae=e.T,le=e.E},e=>{te=e.I,ne=e.L},e=>{ie=e.u},e=>{se=e.E},null,null,null,null,null],execute:function(){var a=document.createElement("style");a.textContent='@charset "UTF-8";.task-panel[data-v-8a74d233] ul.el-upload-list{border:1px dashed #d4d4d4;padding:10px}.task-panel[data-v-8a74d233] ul.el-upload-list:before{content:"此处展示选择文件列表";font-size:12px;position:relative;bottom:4px}.task-panel[data-v-8a74d233] .el-upload-list__item-name{display:block;overflow:hidden;max-width:290px;text-overflow:ellipsis;word-break:keep-all}.task-panel[data-v-8a74d233] .is-ready .el-icon--close{display:block;color:#000}.task-panel[data-v-8a74d233]{background-color:#f3f6f8;padding-bottom:1rem;position:relative}.pc-nav[data-v-8a74d233]{background-color:#fff;display:flex;padding:10px;justify-content:space-between;align-items:center}.pc-nav .exit[data-v-8a74d233]{cursor:pointer}.pc-nav .nav[data-v-8a74d233]{display:flex}.pc-nav .nav nav[data-v-8a74d233]{display:flex;align-items:center}.pc-nav .nav nav .nav-item[data-v-8a74d233]{font-size:1rem;color:#595959;padding:10px;cursor:pointer}.pc-nav .nav nav .nav-item.active[data-v-8a74d233]{color:#409eff!important;font-weight:600}.pc-nav .nav .exit[data-v-8a74d233]{color:#595959}.pc-nav .logo[data-v-8a74d233]{width:180px;margin:0 10px}.pc-nav .logo img[data-v-8a74d233]{height:40px}.panel[data-v-8a74d233]{max-width:1024px;padding:1em;background-color:#fff;margin:10px auto;box-sizing:border-box;box-shadow:0 2px 12px rgba(0,0,0,.1);border-radius:4px}.panel .name[data-v-8a74d233]{text-align:center}.panel .ddl[data-v-8a74d233]{margin-top:10px;color:#919191;font-size:14px}.panel .infos[data-v-8a74d233]{max-width:460px;margin:auto;overflow:hidden}.panel .infos[data-v-8a74d233] div.el-form-item>label{font-weight:700}.panel .infos[data-v-8a74d233] div.el-form-item>label:before{content:"* ";color:red}.withdraw[data-v-8a74d233]{text-align:right}.tip-wrapper[data-v-8a74d233]{line-height:20px;text-align:left;word-break:break-all;overflow:hidden;padding:0 20px;color:#e6a23c;max-width:320px;font-size:14px}\n',document.head.appendChild(a);const oe=t({name:"UploadFilled"}),ue={viewBox:"0 0 1024 1024",xmlns:"http://www.w3.org/2000/svg"},de=[s("path",{fill:"currentColor",d:"M544 864V672h128L512 480 352 672h128v192H320v-1.6c-5.376.32-10.496 1.6-16 1.6A240 240 0 0 1 64 624c0-123.136 93.12-223.488 212.608-237.248A239.808 239.808 0 0 1 512 192a239.872 239.872 0 0 1 235.456 194.752c119.488 13.76 212.48 114.112 212.48 237.248a240 240 0 0 1-240 240c-5.376 0-10.56-1.28-16-1.6v1.6H544z"},null,-1)];var re=l(oe,[["render",function(e,a,l,t,s,o){return n(),i("svg",ue,de)}]]);const ce=e=>(G("data-v-8a74d233"),e=e(),J(),e),pe={class:"task-panel"},ve={class:"pc-nav"},fe={class:"nav"},me={class:"logo"},ge=ce((()=>s("img",{style:{height:"40px",width:"170px"},src:"https://img.cdn.sugarat.top/easypicker/EasyPicker.png",alt:"logo"},null,-1))),he=["onClick"],ye={key:0,"element-loading-text":"Loading...",class:"panel tc"},xe={class:"name"},ke={key:0,style:{color:"red"}},we={class:"tip-wrapper"},be={class:"ddl"},_e={key:0},ze={key:4},je={class:"infos"},Ne={key:0},$e={class:"infos"},Ce=ce((()=>s("div",{class:"el-upload__text"},[$(" 将文件拖于此处 or "),s("em",null,"直接选择文件")],-1))),Ee={class:"p10"},Te={class:"p10"},Ue={class:"p10 option-tips"},Ie={style:{color:"red"}},Le={style:{color:"red"}},Se=ce((()=>s("br",null,null,-1))),Fe=ce((()=>s("br",null,null,-1))),Oe=ce((()=>s("strong",null,"查询提交情况,需填写和提交时一样的表单信息",-1))),Me=ce((()=>s("br",null,null,-1))),De=ce((()=>s("strong",null,"选择大文件后需要等待一会儿才展示处理",-1))),Pe=ce((()=>s("br",null,null,-1))),Ve={class:"withdraw"},Ae={key:1,class:"panel tc"},Ge={class:"name"},Je={style:{"padding-top":"20px"}};e("default",K(t({__name:"index",setup(e){const a=ie(),l=o(),t=u(),G=d([{title:"我也要收集",path:"https://docs.ep.sugarat.top/"}]),J=d({name:"",category:""}),K=d({bindField:""}),oe=r((()=>R(K.format))),ue=c(""),de=c(0),ce=r((()=>de.value<=0)),Re=r((()=>{let e=~~(de.value/1e3),a=~~(e/3600);const l=~~(a/24);a%=24;const t=~~(e%3600/60);return e%=60,`剩余${l}天${a}时${t}分${e}秒`}));function We(e=!0){if(K?.ddl){const e=new Date(K.ddl);de.value=e.getTime()-Date.now()}else de.value=0;e&&setTimeout((()=>{We()}),1e3)}const qe=r((()=>{if(K?.ddl){const e=new Date(K.ddl);return W(e)}return""})),Be=d([]),He=c([]),Ke=c(),Ye=r((()=>He.value.filter((e=>"uploading"===e.status)).length>0)),Xe=e=>"uploading"!==e.status&&"success"!==e.status||se.confirm("不影响已经上传成功的,正在上传的将取消上传","确定从列表移除文件吗?").then((()=>("uploading"===e.status&&(g.info(`取消${e.name}的上传`),e.subscription.unsubscribe()),!0))).catch((()=>!1)),Ze=r((()=>Be.every((e=>e.value)))),Qe=r((()=>K.bindField.trim()||"姓名")),ea=r((()=>Be.find((e=>e.text===Qe.value)))),aa=r((()=>K.people&&!ea.value)),la=d({peopleName:""});function ta(e,a,l){if(!a){const e=`请输入${Qe.value}`;return l(new Error(e)),void g.error(e)}I.checkPeopleIsExist(ue.value,a).then((e=>{e.data.exist||g.error("你不在此次提交名单中,如有疑问请联系管理员"),l(e.data.exist?void 0:new Error("你不在此次提交名单中,如有疑问请联系管理员"))}))}const na=c(),ia=d({peopleName:[{validator:ta,trigger:"blur"}]});function sa(){if(ea.value){const e=Be.find((e=>e.text===Qe.value))?.value;return la.peopleName=e||"",new Promise((a=>{ta(0,e,a)})).then((e=>!e))}return na.value.validate((e=>e))}async function oa(){if(Ze.value){if(K.people&&!(await sa()))return;!function(){const e=He.value;for(const a of e)if(a.md5){if("ready"===a.status){a.status="uploading";let{name:e}=a;const l=e;K.rewrite&&(e=Be.map((e=>e.value)).join(oe.value.splitChar||"-")+L(e)),e=q(e);const t=`easypicker2/${ue.value}/${a.md5}/${e}`;F.getUploadToken().then((n=>{B(n.data.token,a.raw,t,{success(t){const{fsize:n}=t;F.addFile({originName:l,name:e,taskKey:ue.value,taskName:J.name,size:n,hash:a.md5,info:JSON.stringify(Be),people:la.peopleName}).then((()=>{a.status="success",g.success(`文件:${a.name}提交成功`),K.people&&I.updatePeopleStatus(ue.value,e,la.peopleName,a.md5)}))},process(e,l,t){a.percentage=Math.floor(e),a.subscription=t}})}))}}else g.info(`文件(${a.name})的唯一指纹还在计算中,再等待一会儿再点击上传`),setTimeout((()=>{g.info("文件越大计算时间越长(1G通常需要20s)")}),100)}()}else g.warning("请先完成必要信息的填写")}const ua=r((()=>{for(const e of He.value)if("ready"===e.status)return!0;return!1})),da=r((()=>{for(const e of He.value)if(["success","ready"].includes(e.status))return!0;return!1})),ra=c(0);function ca(e){const{name:a}=e;if(oe.value.format.length&&oe.value.status){const l=L(a);if(!oe.value.format.find((e=>l.toLowerCase().endsWith(e))))return g.error(`${a} 格式不符合要求`),void Ke.value.handleRemove(e)}if(oe.value.size&&oe.value.size<e.size)return g.error(`${a} 大小${T(e.size)} 不符合要求`),void Ke.value.handleRemove(e);ra.value+=1,S(e.raw).then((a=>{e.md5=a,ra.value-=1}))}const pa=r((()=>oe.value.limit||10));function va(){g.warning(`一次提交最多只能选择${pa.value}个文件,请移除已经上传成功的或刷新页面`)}const fa=c(!1),ma=c("");function ga(){F.getTemplateUrl(K.template,ue.value).then((e=>{fa.value=!0;const{link:a}=e.data;ma.value=a,O(a,K.template)})).catch((()=>{g.warning("文件已从服务器上移除,请联系管理员重新上传")}))}const ha=c(!1);async function ya(){if(Ze.value){if(K.people&&!(await sa()))return;!function(){const e=He.value;for(const a of e)if(a.md5){if(!["fail","uploading"].includes(a.status)){let{name:e}=a;K.rewrite&&(e=Be.map((e=>e.value)).join(oe.value.splitChar||"-")+L(e)),F.withdrawFile({taskKey:ue.value,taskName:J.name,filename:e,hash:a.md5,info:JSON.stringify(Be),peopleName:la.peopleName}).then((()=>{g.success(`文件:${a.name}撤回成功`),a.name+=" - (已撤回 ✅ )",a.status="fail"})).catch((()=>{g.error(`撤回失败: 没有文件:${a.name}对应提交记录`)}))}}else g.info(`文件(${a.name})的唯一指纹还在计算中,再等待一会儿再点击上传`),setTimeout((()=>{g.info("文件越大计算时间越长(1G通常需要20s)")}),100)}()}else g.warning("请先完成必要信息的填写")}async function xa(){if(Ze.value){if(K.people&&!(await sa()))return;F.checkSubmitStatus(ue.value,Be,la.peopleName).then((e=>{e.data.isSubmit?g.success("已经提交过啦"):g.warning("还未提交过哟")}))}else g.warning("请先完成必要信息的填写,需和提交时信息完全一致")}const ka=c(!1),wa=c(!1);function ba(e=[],a=[]){return e.length===a.length&&e.every(((e,l)=>e.type===a[l].type&&e.text===a[l].text&&ba(e.children,a[l].children)))}function _a(e=!1){m.getTaskMoreInfo(ue.value).then((a=>{Object.assign(K,a.data),ba(Be,M(K.info))||(Be.splice(0,Be.length),Be.push(...M(K.info)),e&&g.success("表单信息有更新")),We(!1),ka.value=!1}))}function za(){wa.value=!0}function ja(){wa.value&&!Ye.value&&(wa.value=!1,_a(!0))}const Na=r((()=>ce.value?qe.value:qe.value+Re.value)),$a=d({text:"",imgs:[]}),Ca=c([]);p((()=>K.tip),(()=>{try{const e=JSON.parse(K.tip);$a.imgs=e.imgs,$a.text=e.text||"",Ca.value=$a.imgs.map((e=>({...e,url:"https://img.cdn.sugarat.top/mdImg/MTY3NzkxMDI1NTU1Nw==20140524124237518.gif"}))),Ca.value.length&&H.getTipImageUrl(ue.value,Ca.value.map((e=>({uid:e.uid,name:e.name})))).then((e=>{e.data.forEach(((e,a)=>{Ca.value[a].url=e.cover,Object.assign(Ca.value[a],{preview:e.preview})}))}))}catch{$a.text="",$a.imgs=[],Ca.value=[]}}));const Ea=v("disabledUpload",!1);return f((()=>{ue.value=t.params.key,ue.value&&(ka.value=!0,m.getTaskInfo(ue.value).then((e=>{Object.assign(J,e.data),Ea.value=!!e.data.limitUpload,Ea.value&&se.alert("任务存储空间容量已达到上限,已经无法进行上传,请联系发起人扩容空间")})).catch((e=>{4001===e.code&&(g.error("任务不存在"),ue.value="",J.name="任务不存在")})),_a(),We()),window.addEventListener("blur",za),window.addEventListener("focus",ja)})),h((()=>{window.removeEventListener("blur",za),window.removeEventListener("focus",ja)})),(e,t)=>{const o=y("router-link"),u=D,d=le,r=X,c=P,p=Q,v=ee,f=V,m=A,g=Z,h=Y;return n(),i("div",pe,[s("div",ve,[s("div",fe,[s("div",me,[x(o,{to:"/"},{default:k((()=>[ge])),_:1})]),s("nav",null,[(n(!0),i(w,null,b(G,((e,a)=>(n(),i("div",{key:a,class:"nav-item",onClick:e=>function(e){G[e].path.startsWith("http")?window.location.href=G[e].path:l.push({path:G[e].path})}(a)},_(e.title),9,he)))),128))])])]),ue.value?z((n(),i("div",ye,[s("h1",xe,_(J.name),1),j(Ea)?(n(),i("h2",ke," 任务存储空间容量已达到上限,已经无法进行上传,请联系发起人扩容空间 ")):N("",!0),!$a.text||qe.value&&ce.value?N("",!0):(n(),i(w,{key:1},[x(u,null,{default:k((()=>[$("⚠️ 注意事项 ⚠️")])),_:1}),x(ae,null,{default:k((()=>[s("div",we,[(n(!0),i(w,null,b($a.text.split("\n"),((e,a)=>(n(),i("p",{key:a},_(e.replace(/\s/g," ")),1)))),128))])])),_:1})],64)),!Ca.value.length||qe.value&&ce.value?N("",!0):(n(!0),i(w,{key:2},b(Ca.value,((e,a)=>(n(),C(d,{key:e.uid,"hide-on-click-modal":"",style:{width:"100px",height:"100px",margin:"10px"},src:e.url,"zoom-rate":1.2,"preview-src-list":Ca.value.map((e=>e.preview)),"initial-index":a,fit:"contain"},null,8,["src","preview-src-list","initial-index"])))),128)),qe.value?(n(),i(w,{key:3},[x(u,null,{default:k((()=>[$("截止时间")])),_:1}),s("h2",be,_(Na.value),1),ce.value?(n(),i("div",_e,[x(r,{description:"已经结束啦!"})])):N("",!0)],64)):N("",!0),qe.value&&ce.value?N("",!0):(n(),i("div",ze,[x(u,null,{default:k((()=>[$("必要信息填写")])),_:1}),s("div",je,[z(s("div",null,[x(ae,null,{default:k((()=>[$("“"+_(Qe.value)+"”在参与名单里才能正常提交",1)])),_:1})],512),[[E,K.people]]),aa.value?(n(),i("div",Ne,[s("div",$e,[x(v,{ref_key:"validModalRef",ref:na,rules:ia,"status-icon":"",model:la,disabled:Ye.value,"label-position":"top"},{default:k((()=>[x(p,{prop:"peopleName",label:Qe.value},{default:k((()=>[x(c,{modelValue:la.peopleName,"onUpdate:modelValue":t[0]||(t[0]=e=>la.peopleName=e),maxlength:14,clearable:"","show-word-limit":"",placeholder:`请输入 ${Qe.value}`},null,8,["modelValue","placeholder"])])),_:1},8,["label"])])),_:1},8,["rules","model","disabled"])])])):N("",!0),x(te,{infos:Be,disabled:Ye.value},null,8,["infos","disabled"])]),x(g,{ref_key:"fileUpload",ref:Ke,"file-list":He.value,"onUpdate:fileList":t[1]||(t[1]=e=>He.value=e),style:{"max-width":"400px",margin:"0 auto"},drag:!j(a),action:"","on-change":ca,"before-remove":Xe,"on-exceed":va,"auto-upload":!1,multiple:"",limit:pa.value},{tip:k((()=>[z(s("div",Ee,[x(ae,null,{default:k((()=>[$(" 还有 "+_(ra.value)+" 个文件正在生成校验信息,请稍等(1G通常需要20s) ",1)])),_:1})],512),[[E,!!ra.value]])])),default:k((()=>[j(a)?(n(),C(f,{key:0,type:"primary"},{default:k((()=>[$(" 选择文件 ")])),_:1})):(n(),i(w,{key:1},[x(m,{class:"el-icon--upload"},{default:k((()=>[x(j(re))])),_:1}),Ce],64))])),_:1},8,["file-list","drag","limit"]),s("div",Te,[ha.value?(n(),C(f,{key:0,size:"default",type:"warning",disabled:!da.value||!!ra.value,onClick:ya},{default:k((()=>[$(" 一键撤回 ")])),_:1},8,["disabled"])):j(Ea)?N("",!0):(n(),C(f,{key:1,size:"default",type:"success",disabled:!ua.value||!!ra.value,onClick:oa},{default:k((()=>[$(" 提交文件 ")])),_:1},8,["disabled"])),x(f,{size:"default",onClick:xa},{default:k((()=>[$(" 查询提交情况 ")])),_:1})]),s("div",Ue,[oe.value.status&&oe.value.format.length?(n(),C(ae,{key:0},{default:k((()=>[$(" 限制格式为: "),s("span",Ie,_(oe.value.format.join(", ")),1)])),_:1})):N("",!0),oe.value.size?(n(),C(ae,{key:1},{default:k((()=>[$(" 限制文件大小不超过: "),s("span",Le,_(j(T)(oe.value.size)),1)])),_:1})):N("",!0),ha.value?(n(),C(ae,{key:2},{default:k((()=>[$(" ① 须保证选择的文件与提交时的文件一致"),Se,$(" ② 填写表单信息一致 "),Fe,$(" ③ 完全一模一样的文件的提交记录(内容md5+命名),将会一次性全部撤回 ")])),_:1})):(n(),i(w,{key:3},[x(ae,null,{default:k((()=>[Oe])),_:1}),x(ae,null,{default:k((()=>[$(" ① 选择完文件,点击 ”提交文件“即可 "),Me,$(" ② "),De,K.template&&!j(Ea)?(n(),i(w,{key:0},[Pe,$(" ③ "),s("strong",null,[x(f,{type:"primary",text:"",style:{color:"#85ce61"},size:"small",onClick:ga},{default:k((()=>[$("右下角可 “查看提交示例” ")])),_:1})])],64)):N("",!0)])),_:1})],64))]),s("div",Ve,[K.template&&!j(Ea)?(n(),C(f,{key:0,type:"primary",text:"",style:{color:"#85ce61"},size:"small",onClick:ga},{default:k((()=>[$(" 查看提交示例 ")])),_:1})):N("",!0),ha.value?(n(),C(f,{key:1,size:"small",type:"primary",text:"",onClick:t[2]||(t[2]=e=>ha.value=!1)},{default:k((()=>[$(" 正常提交 ")])),_:1})):(n(),C(f,{key:2,size:"small",type:"primary",text:"",onClick:t[3]||(t[3]=e=>ha.value=!0)},{default:k((()=>[$(" 我要撤回 ")])),_:1}))])]))])),[[h,ka.value]]):(n(),i("div",Ae,[s("h1",Ge,_(J.name),1)])),x(ne,{value:fa.value,"onUpdate:value":t[4]||(t[4]=e=>fa.value=e),title:"示例文件下载链接",link:ma.value},null,8,["value","link"]),s("div",Je,[x(U,{type:"task"})])])}}}),[["__scopeId","data-v-8a74d233"]]))}}}));
2
+ //# sourceMappingURL=index-legacy-BO3hAqA9.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index-legacy-BqL3XK76.js","sources":["../../node_modules/.pnpm/@element-plus+icons-vue@1.1.4_vue@3.4.31_typescript@4.9.5_/node_modules/@element-plus/icons-vue/dist/es/upload-filled.mjs","../../src/pages/task/index.vue"],"sourcesContent":["import { defineComponent, openBlock, createElementBlock, createElementVNode } from 'vue';\nimport _export_sfc from './_virtual/plugin-vue_export-helper.mjs';\n\nconst _sfc_main = defineComponent({\n name: \"UploadFilled\"\n});\nconst _hoisted_1 = {\n viewBox: \"0 0 1024 1024\",\n xmlns: \"http://www.w3.org/2000/svg\"\n};\nconst _hoisted_2 = /* @__PURE__ */ createElementVNode(\"path\", {\n fill: \"currentColor\",\n d: \"M544 864V672h128L512 480 352 672h128v192H320v-1.6c-5.376.32-10.496 1.6-16 1.6A240 240 0 0 1 64 624c0-123.136 93.12-223.488 212.608-237.248A239.808 239.808 0 0 1 512 192a239.872 239.872 0 0 1 235.456 194.752c119.488 13.76 212.48 114.112 212.48 237.248a240 240 0 0 1-240 240c-5.376 0-10.56-1.28-16-1.6v1.6H544z\"\n}, null, -1);\nconst _hoisted_3 = [\n _hoisted_2\n];\nfunction _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {\n return openBlock(), createElementBlock(\"svg\", _hoisted_1, _hoisted_3);\n}\nvar uploadFilled = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"render\", _sfc_render]]);\n\nexport { uploadFilled as default };\n","<script lang=\"ts\" setup>\nimport { ElMessage, ElMessageBox } from 'element-plus'\nimport type { FormInstance, UploadInstance, UploadUserFile } from 'element-plus'\nimport { computed, onMounted, onUnmounted, reactive, ref, watch } from 'vue'\nimport { useRoute, useRouter } from 'vue-router'\nimport HomeFooter from '@components/HomeFooter/index.vue'\nimport LinkDialog from '@components/linkDialog.vue'\nimport { UploadFilled } from '@element-plus/icons-vue'\nimport { useStore } from 'vuex'\nimport { useLocalStorage } from '@vueuse/core'\nimport Tip from '../dashboard/tasks/components/infoPanel/tip.vue'\nimport {\n formatDate,\n formatSize,\n getFileMd5Hash,\n getFileSuffix,\n normalizeFileName,\n parseFileFormat,\n parseInfo,\n} from '@/utils/stringUtil'\nimport { downLoadByUrl, qiniuUpload } from '@/utils/networkUtil'\nimport { FileApi, PeopleApi, PublicApi, TaskApi } from '@/apis'\nimport InfosForm from '@/components/InfosForm/index.vue'\nimport { useIsMobile } from '@/composables'\n\nconst isMobile = useIsMobile()\n// 顶部导航\nconst $router = useRouter()\nconst $route = useRoute()\nconst pcNavs = reactive([\n {\n title: '我也要收集',\n path: 'https://docs.ep.sugarat.top/',\n },\n])\nfunction handleNav(idx: number) {\n if (pcNavs[idx].path.startsWith('http')) {\n window.location.href = pcNavs[idx].path\n return\n }\n $router.push({\n path: pcNavs[idx].path,\n })\n}\n\n// 任务基本信息展示\nconst taskInfo = reactive<TaskApiTypes.TaskInfo>({\n name: '',\n category: '',\n})\nconst taskMoreInfo = reactive<Partial<TaskApiTypes.TaskInfo>>({\n bindField: '',\n})\nconst formatData = computed(() => parseFileFormat(taskMoreInfo.format))\nconst k = ref('')\n\n// 用于展示截止日期\nconst waitTime = ref(0)\n// 判断是否结束\nconst isOver = computed(() => waitTime.value <= 0)\nconst waitTimeStr = computed(() => {\n let seconds = ~~(waitTime.value / 1000)\n let hour = ~~(seconds / (60 * 60))\n const day = ~~(hour / 24)\n hour %= 24\n const minute = ~~((seconds % 3600) / 60)\n seconds %= 60\n return `剩余${day}天${hour}时${minute}分${seconds}秒`\n})\nfunction refreshWaitTime(loop = true) {\n if (taskMoreInfo?.ddl) {\n const date = new Date(taskMoreInfo.ddl)\n waitTime.value = date.getTime() - Date.now()\n }\n else {\n waitTime.value = 0\n }\n if (loop) {\n setTimeout(() => {\n refreshWaitTime()\n }, 1000)\n }\n}\nconst ddlStr = computed(() => {\n if (taskMoreInfo?.ddl) {\n const date = new Date(taskMoreInfo.ddl)\n return formatDate(date)\n }\n return ''\n})\n\n// 必填信息\nconst infos = reactive<InfoItem[]>([])\n\n// 文件上传部分\n\n// 文件上传\nconst fileList = ref<(UploadUserFile & { md5: string, subscription: any })[]>(\n [],\n)\nconst fileUpload = ref<UploadInstance>()\nconst disableForm = computed(\n () => fileList.value.filter(item => item.status === 'uploading').length > 0,\n)\nconst handleRemoveFile: any = (file: any) => {\n if (file.status === 'uploading' || file.status === 'success') {\n return ElMessageBox.confirm(\n '不影响已经上传成功的,正在上传的将取消上传',\n '确定从列表移除文件吗?',\n )\n .then(() => {\n if (file.status === 'uploading') {\n ElMessage.info(`取消${file.name}的上传`)\n // 取消上传\n file.subscription.unsubscribe() // 取消上传\n }\n return true\n })\n .catch(() => false)\n }\n return true\n}\n\n// 校验表单填写\nconst isWriteFinish = computed(() => infos.every(item => item.value))\n// 提交文件\n\nconst limitBindField = computed(() => {\n return taskMoreInfo.bindField.trim() || '姓名'\n})\n\n// 身份核验表单\nconst isSameFieldName = computed(() =>\n infos.find(v => v.text === limitBindField.value),\n)\nconst showValidForm = computed(\n () => taskMoreInfo.people && !isSameFieldName.value,\n)\nconst validModal = reactive({\n peopleName: '',\n})\n\nfunction validatePeopleName(rule: any, value: any, callback: any) {\n if (!value) {\n const message = `请输入${limitBindField.value}`\n callback(new Error(message))\n ElMessage.error(message)\n return\n }\n // 异步校验\n PeopleApi.checkPeopleIsExist(k.value, value).then((res) => {\n if (!res.data.exist) {\n ElMessage.error('你不在此次提交名单中,如有疑问请联系管理员')\n }\n callback(\n res.data.exist\n ? undefined\n : new Error('你不在此次提交名单中,如有疑问请联系管理员'),\n )\n })\n}\n\nconst validModalRef = ref<FormInstance>()\nconst validModalRules = reactive({\n peopleName: [{ validator: validatePeopleName, trigger: 'blur' }],\n})\nfunction confirmPeopleName() {\n // 处理表单必填项含有 limitBindField 的情况\n if (isSameFieldName.value) {\n const value = infos.find(v => v.text === limitBindField.value)?.value\n validModal.peopleName = value || ''\n return new Promise((resolve) => {\n validatePeopleName(null, value, resolve)\n }).then(v => !v)\n }\n return validModalRef.value.validate((isValid: boolean) => isValid)\n}\n\nfunction startUpload() {\n const uploadFiles = fileList.value\n for (const file of uploadFiles) {\n if (!file.md5) {\n ElMessage.info(\n `文件(${file.name})的唯一指纹还在计算中,再等待一会儿再点击上传`,\n )\n setTimeout(() => {\n ElMessage.info('文件越大计算时间越长(1G通常需要20s)')\n }, 100)\n }\n else if (file.status === 'ready') {\n // 开始上传\n file.status = 'uploading'\n let { name } = file\n const originName = name\n // 如果开启了自动重命名,这里重命名一下\n if (taskMoreInfo.rewrite) {\n name\n = infos.map(v => v.value).join(formatData.value.splitChar || '-')\n + getFileSuffix(name)\n }\n // 替换不合法的字符\n name = normalizeFileName(name)\n const key = `easypicker2/${k.value}/${file.md5}/${name}`\n\n FileApi.getUploadToken().then((res) => {\n qiniuUpload(res.data.token, file.raw, key, {\n success(data: any) {\n const { fsize } = data\n FileApi.addFile({\n originName,\n name,\n taskKey: k.value,\n taskName: taskInfo.name,\n size: fsize,\n hash: file.md5,\n info: JSON.stringify(infos),\n people: validModal.peopleName,\n }).then(() => {\n file.status = 'success'\n ElMessage.success(`文件:${file.name}提交成功`)\n if (taskMoreInfo.people) {\n // 无感知更新一下\n PeopleApi.updatePeopleStatus(\n k.value,\n name,\n validModal.peopleName,\n file.md5,\n )\n }\n })\n },\n process(per: number, data: any, subscription: any) {\n file.percentage = Math.floor(per)\n // 挂载取消上传的方法\n file.subscription = subscription\n },\n })\n })\n }\n }\n}\n\nasync function submitUpload() {\n if (!isWriteFinish.value) {\n ElMessage.warning('请先完成必要信息的填写')\n return\n }\n\n if (taskMoreInfo.people) {\n const isValid = await confirmPeopleName()\n if (!isValid) {\n return\n }\n }\n startUpload()\n}\n\n// 是否允许上传\nconst allowUpload = computed(() => {\n for (const file of fileList.value) {\n if (file.status === 'ready') {\n return true\n }\n }\n return false\n})\n\n// 是否允许撤回\nconst allowWithdraw = computed(() => {\n for (const file of fileList.value) {\n if (['success', 'ready'].includes(file.status)) {\n return true\n }\n }\n return false\n})\n\n// 添加文件\n// 正在计算MD5值的文件个数\nconst calculateMd5Count = ref(0)\nfunction handleChangeFile(file: any) {\n // 校验文件后缀名\n const { name } = file\n if (formatData.value.format.length && formatData.value.status) {\n const suffix = getFileSuffix(name)\n if (\n !formatData.value.format.find(v => suffix.toLowerCase().endsWith(v))\n ) {\n ElMessage.error(`${name} 格式不符合要求`)\n fileUpload.value.handleRemove(file)\n return\n }\n }\n\n // 校验文件大小\n if (formatData.value.size && formatData.value.size < file.size) {\n ElMessage.error(`${name} 大小${formatSize(file.size)} 不符合要求`)\n fileUpload.value.handleRemove(file)\n return\n }\n\n calculateMd5Count.value += 1\n // 计算md5 hash\n getFileMd5Hash(file.raw).then((str) => {\n file.md5 = str\n calculateMd5Count.value -= 1\n })\n}\n\nconst limitUploadCount = computed(() => formatData.value.limit || 10)\nfunction handleExceed() {\n ElMessage.warning(\n `一次提交最多只能选择${limitUploadCount.value}个文件,请移除已经上传成功的或刷新页面`,\n )\n}\nconst showLinkModel = ref(false)\nconst templateLink = ref('')\nfunction runWithdraw() {\n const uploadFiles = fileList.value\n for (const file of uploadFiles) {\n if (!file.md5) {\n ElMessage.info(\n `文件(${file.name})的唯一指纹还在计算中,再等待一会儿再点击上传`,\n )\n setTimeout(() => {\n ElMessage.info('文件越大计算时间越长(1G通常需要20s)')\n }, 100)\n }\n else if (!['fail', 'uploading'].includes(file.status)) {\n // 准备开始撤回\n let { name } = file\n\n // 如果开启了自动重命名,这里重命名一下\n if (taskMoreInfo.rewrite) {\n name\n = infos.map(v => v.value).join(formatData.value.splitChar || '-')\n + getFileSuffix(name)\n }\n\n FileApi.withdrawFile({\n taskKey: k.value,\n taskName: taskInfo.name,\n filename: name,\n hash: file.md5,\n info: JSON.stringify(infos),\n peopleName: validModal.peopleName,\n })\n .then(() => {\n ElMessage.success(`文件:${file.name}撤回成功`)\n file.name += ' - (已撤回 ✅ )'\n file.status = 'fail'\n })\n .catch(() => {\n ElMessage.error(`撤回失败: 没有文件:${file.name}对应提交记录`)\n })\n }\n }\n}\nfunction downloadTemplate() {\n FileApi.getTemplateUrl(taskMoreInfo.template, k.value)\n .then((res) => {\n showLinkModel.value = true\n const { link } = res.data\n templateLink.value = link\n downLoadByUrl(link, taskMoreInfo.template)\n })\n .catch(() => {\n ElMessage.warning('文件已从服务器上移除,请联系管理员重新上传')\n })\n}\n\n// 撤回相关逻辑\nconst isWithdraw = ref(false)\nasync function startWithdraw() {\n // 校验表单填写\n if (!isWriteFinish.value) {\n ElMessage.warning('请先完成必要信息的填写')\n return\n }\n if (taskMoreInfo.people) {\n const isValid = await confirmPeopleName()\n if (!isValid) {\n return\n }\n }\n runWithdraw()\n}\n\n// 查询提交情况\nasync function checkSubmitStatus() {\n // 校验表单填写\n if (!isWriteFinish.value) {\n ElMessage.warning('请先完成必要信息的填写,需和提交时信息完全一致')\n return\n }\n // 卡控人员限制\n if (taskMoreInfo.people) {\n const isValid = await confirmPeopleName()\n if (!isValid) {\n return\n }\n }\n FileApi.checkSubmitStatus(k.value, infos, validModal.peopleName).then(\n (res) => {\n if (res.data.isSubmit) {\n ElMessage.success('已经提交过啦')\n }\n else {\n ElMessage.warning('还未提交过哟')\n }\n },\n )\n}\nconst isLoadingData = ref(false)\nconst readyRefresh = ref(false)\nfunction isEqualInfos(a: InfoItem[] = [], b: InfoItem[] = []) {\n if (a.length !== b.length) {\n return false\n }\n return a.every(\n (v, i) =>\n v.type === b[i].type\n && v.text === b[i].text\n && isEqualInfos(v.children, b[i].children),\n )\n}\nfunction refreshTaskMoreInfo(hot = false) {\n TaskApi.getTaskMoreInfo(k.value).then((res) => {\n Object.assign(taskMoreInfo, res.data)\n if (!isEqualInfos(infos, parseInfo(taskMoreInfo.info))) {\n infos.splice(0, infos.length)\n infos.push(...parseInfo(taskMoreInfo.info))\n if (hot) {\n ElMessage.success('表单信息有更新')\n }\n }\n refreshWaitTime(false)\n isLoadingData.value = false\n })\n}\nfunction handleBlur() {\n readyRefresh.value = true\n}\nfunction handleFocus() {\n if (readyRefresh.value && !disableForm.value) {\n readyRefresh.value = false\n refreshTaskMoreInfo(true)\n }\n}\n\n// 展示的时间提示文案\nconst timeInfo = computed(() => {\n if (!isOver.value) {\n return ddlStr.value + waitTimeStr.value\n }\n return ddlStr.value\n})\n\n// tipImage\nconst tipData = reactive<{\n text: string\n imgs: {\n uid: number\n name: string\n }[]\n}>({\n text: '',\n imgs: [],\n})\nconst imageList = ref<\n { name: string, uid: number, preview?: string, url: string }[]\n>([])\n\nwatch(\n () => taskMoreInfo.tip,\n () => {\n // 初始化\n try {\n const parseData = JSON.parse(taskMoreInfo.tip)\n tipData.imgs = parseData.imgs\n tipData.text = parseData.text || ''\n imageList.value = tipData.imgs.map((v) => {\n return {\n ...v,\n url: 'https://img.cdn.sugarat.top/mdImg/MTY3NzkxMDI1NTU1Nw==20140524124237518.gif',\n }\n })\n if (imageList.value.length) {\n // 异步填充url\n PublicApi.getTipImageUrl(\n k.value,\n imageList.value.map(v => ({\n uid: v.uid,\n name: v.name,\n })),\n ).then((v) => {\n v.data.forEach((url, idx) => {\n imageList.value[idx].url = url.cover\n Object.assign(imageList.value[idx], {\n preview: url.preview,\n })\n })\n })\n }\n }\n catch {\n tipData.text = ''\n tipData.imgs = []\n imageList.value = []\n }\n },\n)\n\n// 禁用上传\nconst disabledUpload = useLocalStorage('disabledUpload', false)\n\nonMounted(() => {\n k.value = $route.params.key as string\n if (k.value) {\n isLoadingData.value = true\n TaskApi.getTaskInfo(k.value)\n .then((res) => {\n Object.assign(taskInfo, res.data)\n disabledUpload.value = !!res.data.limitUpload\n if (disabledUpload.value) {\n ElMessageBox.alert(\n '任务存储空间容量已达到上限,已经无法进行上传,请联系发起人扩容空间',\n )\n }\n })\n .catch((err) => {\n if (err.code === 4001) {\n ElMessage.error('任务不存在')\n k.value = ''\n taskInfo.name = '任务不存在'\n }\n })\n refreshTaskMoreInfo()\n refreshWaitTime()\n }\n // 页面隐藏\n window.addEventListener('blur', handleBlur)\n\n // 页面展示\n window.addEventListener('focus', handleFocus)\n})\n\nonUnmounted(() => {\n // 页面隐藏\n window.removeEventListener('blur', handleBlur)\n // 页面展示\n window.removeEventListener('focus', handleFocus)\n})\n</script>\n\n<template>\n <div class=\"task-panel\">\n <div class=\"pc-nav\">\n <div class=\"nav\">\n <!-- LOGO -->\n <div class=\"logo\">\n <router-link to=\"/\">\n <img\n style=\"height: 40px; width: 170px\"\n src=\"https://img.cdn.sugarat.top/easypicker/EasyPicker.png\"\n alt=\"logo\"\n >\n </router-link>\n </div>\n <nav>\n <div\n v-for=\"(n, idx) in pcNavs\"\n :key=\"idx\"\n class=\"nav-item\"\n @click=\"handleNav(idx)\"\n >\n {{ n.title }}\n </div>\n </nav>\n </div>\n </div>\n <!-- 有效 -->\n <div\n v-if=\"k\"\n v-loading=\"isLoadingData\"\n element-loading-text=\"Loading...\"\n class=\"panel tc\"\n >\n <!-- 任务名 -->\n <h1 class=\"name\">\n {{ taskInfo.name }}\n </h1>\n <h2 v-if=\"disabledUpload\" style=\"color: red\">\n 任务存储空间容量已达到上限,已经无法进行上传,请联系发起人扩容空间\n </h2>\n <!-- 提示信息 -->\n <!-- 时间截止了也不再展示 -->\n <template v-if=\"tipData.text && (ddlStr ? !isOver : true)\">\n <el-divider>⚠️ 注意事项 ⚠️</el-divider>\n <Tip>\n <div class=\"tip-wrapper\">\n <p v-for=\"(t, i) in tipData.text.split('\\n')\" :key=\"i\">\n {{ t.replace(/\\s/g, '&nbsp;') }}\n </p>\n </div>\n </Tip>\n </template>\n <template v-if=\"imageList.length && (ddlStr ? !isOver : true)\">\n <el-image\n v-for=\"(img, idx) in imageList\"\n :key=\"img.uid\"\n hide-on-click-modal\n style=\"width: 100px; height: 100px; margin: 10px\"\n :src=\"img.url\"\n :zoom-rate=\"1.2\"\n :preview-src-list=\"imageList.map((v) => v.preview)\"\n :initial-index=\"idx\"\n fit=\"contain\"\n />\n </template>\n <!-- 截止时间字符串 -->\n <template v-if=\"ddlStr\">\n <el-divider>截止时间</el-divider>\n <h2 class=\"ddl\">\n {{ timeInfo }}\n </h2>\n <div v-if=\"isOver\">\n <el-empty description=\"已经结束啦!\" />\n </div>\n </template>\n <!-- 未设置ddl 或者 设置了还未结束 -->\n <div v-if=\"!ddlStr || !isOver\">\n <el-divider>必要信息填写</el-divider>\n <div class=\"infos\">\n <div v-show=\"taskMoreInfo.people\">\n <Tip>“{{ limitBindField }}”在参与名单里才能正常提交</Tip>\n </div>\n <div v-if=\"showValidForm\">\n <div class=\"infos\">\n <el-form\n ref=\"validModalRef\"\n :rules=\"validModalRules\"\n status-icon\n :model=\"validModal\"\n :disabled=\"disableForm\"\n label-position=\"top\"\n >\n <el-form-item prop=\"peopleName\" :label=\"limitBindField\">\n <el-input\n v-model=\"validModal.peopleName\"\n :maxlength=\"14\"\n clearable\n show-word-limit\n :placeholder=\"`请输入 ${limitBindField}`\"\n />\n </el-form-item>\n </el-form>\n </div>\n </div>\n <InfosForm :infos=\"infos\" :disabled=\"disableForm\" />\n </div>\n <el-upload\n ref=\"fileUpload\"\n v-model:file-list=\"fileList\"\n style=\"max-width: 400px; margin: 0 auto\"\n :drag=\"!isMobile\"\n action=\"\"\n :on-change=\"handleChangeFile\"\n :before-remove=\"handleRemoveFile\"\n :on-exceed=\"handleExceed\"\n :auto-upload=\"false\"\n multiple\n :limit=\"limitUploadCount\"\n >\n <el-button v-if=\"isMobile\" type=\"primary\">\n 选择文件\n </el-button>\n <template v-else>\n <el-icon class=\"el-icon--upload\">\n <UploadFilled />\n </el-icon>\n <div class=\"el-upload__text\">\n 将文件拖于此处 or <em>直接选择文件</em>\n </div>\n </template>\n <template #tip>\n <div v-show=\"!!calculateMd5Count\" class=\"p10\">\n <Tip>\n 还有\n {{ calculateMd5Count }}\n 个文件正在生成校验信息,请稍等(1G通常需要20s)\n </Tip>\n </div>\n </template>\n </el-upload>\n <div class=\"p10\">\n <el-button\n v-if=\"isWithdraw\"\n size=\"default\"\n type=\"warning\"\n :disabled=\"!allowWithdraw || !!calculateMd5Count\"\n @click=\"startWithdraw\"\n >\n 一键撤回\n </el-button>\n <el-button\n v-else-if=\"!disabledUpload\"\n size=\"default\"\n type=\"success\"\n :disabled=\"!allowUpload || !!calculateMd5Count\"\n @click=\"submitUpload\"\n >\n 提交文件\n </el-button>\n <el-button size=\"default\" @click=\"checkSubmitStatus\">\n 查询提交情况\n </el-button>\n </div>\n <!-- 提示信息 -->\n <div class=\"p10 option-tips\">\n <Tip v-if=\"formatData.status && formatData.format.length\">\n 限制格式为:\n <span style=\"color: red\">{{\n formatData.format.join(', ')\n }}</span>\n </Tip>\n <Tip v-if=\"formatData.size\">\n 限制文件大小不超过:\n <span style=\"color: red\">{{\n formatSize(formatData.size)\n }}</span>\n </Tip>\n <template v-if=\"isWithdraw\">\n <Tip>\n ① 须保证选择的文件与提交时的文件一致<br>\n ② 填写表单信息一致 <br>\n ③\n 完全一模一样的文件的提交记录(内容md5+命名),将会一次性全部撤回\n </Tip>\n </template>\n <template v-else>\n <Tip>\n <strong>查询提交情况,需填写和提交时一样的表单信息</strong>\n </Tip>\n <Tip>\n ① 选择完文件,点击 ”提交文件“即可 <br>\n ② <strong>选择大文件后需要等待一会儿才展示处理</strong>\n <template v-if=\"taskMoreInfo.template && !disabledUpload\">\n <br>\n ③\n <strong>\n <el-button\n type=\"primary\"\n text\n style=\"color: #85ce61\"\n size=\"small\"\n @click=\"downloadTemplate\"\n >右下角可 “查看提交示例”\n </el-button>\n </strong>\n </template>\n </Tip>\n </template>\n </div>\n <div class=\"withdraw\">\n <el-button\n v-if=\"taskMoreInfo.template && !disabledUpload\"\n type=\"primary\"\n text\n style=\"color: #85ce61\"\n size=\"small\"\n @click=\"downloadTemplate\"\n >\n 查看提交示例\n </el-button>\n <el-button\n v-if=\"isWithdraw\"\n size=\"small\"\n type=\"primary\"\n text\n @click=\"isWithdraw = false\"\n >\n 正常提交\n </el-button>\n <el-button\n v-else\n size=\"small\"\n type=\"primary\"\n text\n @click=\"isWithdraw = true\"\n >\n 我要撤回\n </el-button>\n </div>\n </div>\n </div>\n <!-- 无效任务 -->\n <div v-else class=\"panel tc\">\n <h1 class=\"name\">\n {{ taskInfo.name }}\n </h1>\n </div>\n <LinkDialog\n v-model:value=\"showLinkModel\"\n title=\"示例文件下载链接\"\n :link=\"templateLink\"\n />\n <div style=\"padding-top: 20px\">\n <HomeFooter type=\"task\" />\n </div>\n </div>\n</template>\n\n<style scoped lang=\"scss\">\n.task-panel :deep(ul.el-upload-list) {\n border: 1px dashed #d4d4d4;\n padding: 10px;\n\n &::before {\n content: '此处展示选择文件列表';\n font-size: 12px;\n position: relative;\n bottom: 4px;\n }\n}\n\n.task-panel :deep(.el-upload-list__item-name) {\n display: block;\n overflow: hidden;\n max-width: 290px;\n text-overflow: ellipsis;\n word-break: keep-all;\n}\n\n.task-panel :deep(.is-ready .el-icon--close) {\n display: block;\n color: black;\n}\n\n.task-panel {\n background-color: #f3f6f8;\n padding-bottom: 1rem;\n position: relative;\n}\n\n.pc-nav {\n background-color: #fff;\n display: flex;\n padding: 10px;\n justify-content: space-between;\n align-items: center;\n\n .exit {\n cursor: pointer;\n }\n\n .nav {\n display: flex;\n\n nav {\n display: flex;\n align-items: center;\n\n .nav-item {\n font-size: 1rem;\n color: #595959;\n padding: 10px;\n cursor: pointer;\n\n &.active {\n color: #409eff !important;\n font-weight: 600;\n }\n }\n }\n\n .exit {\n color: #595959;\n }\n }\n\n .logo {\n width: 180px;\n margin: 0 10px;\n\n img {\n height: 40px;\n }\n }\n}\n\n.panel {\n max-width: 1024px;\n padding: 1em;\n background-color: #fff;\n margin: 10px auto;\n box-sizing: border-box;\n box-shadow: 0 2px 12px 0 rgb(0 0 0 / 10%);\n border-radius: 4px;\n\n .name {\n text-align: center;\n }\n\n .ddl {\n margin-top: 10px;\n color: #919191;\n font-size: 14px;\n }\n\n .infos {\n max-width: 460px;\n margin: auto;\n overflow: hidden;\n :deep(div.el-form-item > label) {\n font-weight: bold;\n &::before {\n content: '* ';\n color: red;\n }\n }\n }\n}\n\n.withdraw {\n text-align: right;\n}\n\n.tip-wrapper {\n line-height: 20px;\n text-align: left;\n word-break: break-all;\n // max-height: 100px;\n overflow: hidden;\n padding: 0 20px;\n color: #e6a23c;\n max-width: 320px;\n font-size: 14px;\n}\n</style>\n"],"names":["_sfc_main","defineComponent","name","_hoisted_1","viewBox","xmlns","_hoisted_3","createElementVNode","fill","d","uploadFilled","_export_sfc","_ctx","_cache","$props","$setup","$data","$options","openBlock","createElementBlock","isMobile","useIsMobile","$router","useRouter","$route","useRoute","pcNavs","reactive","title","path","taskInfo","category","taskMoreInfo","bindField","formatData","computed","parseFileFormat","format","k","ref","waitTime","isOver","value","waitTimeStr","seconds","hour","day","minute","refreshWaitTime","loop","ddl","date","Date","getTime","now","setTimeout","ddlStr","formatDate","infos","fileList","fileUpload","disableForm","filter","item","status","length","handleRemoveFile","file","ElMessageBox","confirm","then","ElMessage","info","subscription","unsubscribe","catch","isWriteFinish","every","limitBindField","trim","isSameFieldName","find","v","text","showValidForm","people","validModal","peopleName","validatePeopleName","rule","callback","message","Error","error","PeopleApi","checkPeopleIsExist","res","data","exist","validModalRef","validModalRules","validator","trigger","confirmPeopleName","Promise","resolve","validate","isValid","async","submitUpload","uploadFiles","md5","originName","rewrite","map","join","splitChar","getFileSuffix","normalizeFileName","key","FileApi","getUploadToken","qiniuUpload","token","raw","success","fsize","addFile","taskKey","taskName","size","hash","JSON","stringify","updatePeopleStatus","process","per","percentage","Math","floor","startUpload","warning","allowUpload","allowWithdraw","includes","calculateMd5Count","handleChangeFile","suffix","toLowerCase","endsWith","handleRemove","formatSize","getFileMd5Hash","str","limitUploadCount","limit","handleExceed","showLinkModel","templateLink","downloadTemplate","getTemplateUrl","template","link","downLoadByUrl","isWithdraw","startWithdraw","withdrawFile","filename","runWithdraw","checkSubmitStatus","isSubmit","isLoadingData","readyRefresh","isEqualInfos","a","b","i","type","children","refreshTaskMoreInfo","hot","TaskApi","getTaskMoreInfo","Object","assign","parseInfo","splice","push","handleBlur","handleFocus","timeInfo","tipData","imgs","imageList","watch","tip","parseData","parse","url","PublicApi","getTipImageUrl","uid","forEach","idx","cover","preview","disabledUpload","useLocalStorage","onMounted","params","getTaskInfo","limitUpload","alert","err","code","window","addEventListener","onUnmounted","removeEventListener","startsWith","location","href"],"mappings":"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","x_google_ignoreList":[0]}
1
+ {"version":3,"file":"index-legacy-BO3hAqA9.js","sources":["../../node_modules/.pnpm/@element-plus+icons-vue@1.1.4_vue@3.4.31_typescript@4.9.5_/node_modules/@element-plus/icons-vue/dist/es/upload-filled.mjs","../../src/pages/task/index.vue"],"sourcesContent":["import { defineComponent, openBlock, createElementBlock, createElementVNode } from 'vue';\nimport _export_sfc from './_virtual/plugin-vue_export-helper.mjs';\n\nconst _sfc_main = defineComponent({\n name: \"UploadFilled\"\n});\nconst _hoisted_1 = {\n viewBox: \"0 0 1024 1024\",\n xmlns: \"http://www.w3.org/2000/svg\"\n};\nconst _hoisted_2 = /* @__PURE__ */ createElementVNode(\"path\", {\n fill: \"currentColor\",\n d: \"M544 864V672h128L512 480 352 672h128v192H320v-1.6c-5.376.32-10.496 1.6-16 1.6A240 240 0 0 1 64 624c0-123.136 93.12-223.488 212.608-237.248A239.808 239.808 0 0 1 512 192a239.872 239.872 0 0 1 235.456 194.752c119.488 13.76 212.48 114.112 212.48 237.248a240 240 0 0 1-240 240c-5.376 0-10.56-1.28-16-1.6v1.6H544z\"\n}, null, -1);\nconst _hoisted_3 = [\n _hoisted_2\n];\nfunction _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {\n return openBlock(), createElementBlock(\"svg\", _hoisted_1, _hoisted_3);\n}\nvar uploadFilled = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"render\", _sfc_render]]);\n\nexport { uploadFilled as default };\n","<script lang=\"ts\" setup>\nimport { ElMessage, ElMessageBox } from 'element-plus'\nimport type { FormInstance, UploadInstance, UploadUserFile } from 'element-plus'\nimport { computed, onMounted, onUnmounted, reactive, ref, watch } from 'vue'\nimport { useRoute, useRouter } from 'vue-router'\nimport HomeFooter from '@components/HomeFooter/index.vue'\nimport LinkDialog from '@components/linkDialog.vue'\nimport { UploadFilled } from '@element-plus/icons-vue'\nimport { useStore } from 'vuex'\nimport { useLocalStorage } from '@vueuse/core'\nimport Tip from '../dashboard/tasks/components/infoPanel/tip.vue'\nimport {\n formatDate,\n formatSize,\n getFileMd5Hash,\n getFileSuffix,\n normalizeFileName,\n parseFileFormat,\n parseInfo,\n} from '@/utils/stringUtil'\nimport { downLoadByUrl, qiniuUpload } from '@/utils/networkUtil'\nimport { FileApi, PeopleApi, PublicApi, TaskApi } from '@/apis'\nimport InfosForm from '@/components/InfosForm/index.vue'\nimport { useIsMobile } from '@/composables'\n\nconst isMobile = useIsMobile()\n// 顶部导航\nconst $router = useRouter()\nconst $route = useRoute()\nconst pcNavs = reactive([\n {\n title: '我也要收集',\n path: 'https://docs.ep.sugarat.top/',\n },\n])\nfunction handleNav(idx: number) {\n if (pcNavs[idx].path.startsWith('http')) {\n window.location.href = pcNavs[idx].path\n return\n }\n $router.push({\n path: pcNavs[idx].path,\n })\n}\n\n// 任务基本信息展示\nconst taskInfo = reactive<TaskApiTypes.TaskInfo>({\n name: '',\n category: '',\n})\nconst taskMoreInfo = reactive<Partial<TaskApiTypes.TaskInfo>>({\n bindField: '',\n})\nconst formatData = computed(() => parseFileFormat(taskMoreInfo.format))\nconst k = ref('')\n\n// 用于展示截止日期\nconst waitTime = ref(0)\n// 判断是否结束\nconst isOver = computed(() => waitTime.value <= 0)\nconst waitTimeStr = computed(() => {\n let seconds = ~~(waitTime.value / 1000)\n let hour = ~~(seconds / (60 * 60))\n const day = ~~(hour / 24)\n hour %= 24\n const minute = ~~((seconds % 3600) / 60)\n seconds %= 60\n return `剩余${day}天${hour}时${minute}分${seconds}秒`\n})\nfunction refreshWaitTime(loop = true) {\n if (taskMoreInfo?.ddl) {\n const date = new Date(taskMoreInfo.ddl)\n waitTime.value = date.getTime() - Date.now()\n }\n else {\n waitTime.value = 0\n }\n if (loop) {\n setTimeout(() => {\n refreshWaitTime()\n }, 1000)\n }\n}\nconst ddlStr = computed(() => {\n if (taskMoreInfo?.ddl) {\n const date = new Date(taskMoreInfo.ddl)\n return formatDate(date)\n }\n return ''\n})\n\n// 必填信息\nconst infos = reactive<InfoItem[]>([])\n\n// 文件上传部分\n\n// 文件上传\nconst fileList = ref<(UploadUserFile & { md5: string, subscription: any })[]>(\n [],\n)\nconst fileUpload = ref<UploadInstance>()\nconst disableForm = computed(\n () => fileList.value.filter(item => item.status === 'uploading').length > 0,\n)\nconst handleRemoveFile: any = (file: any) => {\n if (file.status === 'uploading' || file.status === 'success') {\n return ElMessageBox.confirm(\n '不影响已经上传成功的,正在上传的将取消上传',\n '确定从列表移除文件吗?',\n )\n .then(() => {\n if (file.status === 'uploading') {\n ElMessage.info(`取消${file.name}的上传`)\n // 取消上传\n file.subscription.unsubscribe() // 取消上传\n }\n return true\n })\n .catch(() => false)\n }\n return true\n}\n\n// 校验表单填写\nconst isWriteFinish = computed(() => infos.every(item => item.value))\n// 提交文件\n\nconst limitBindField = computed(() => {\n return taskMoreInfo.bindField.trim() || '姓名'\n})\n\n// 身份核验表单\nconst isSameFieldName = computed(() =>\n infos.find(v => v.text === limitBindField.value),\n)\nconst showValidForm = computed(\n () => taskMoreInfo.people && !isSameFieldName.value,\n)\nconst validModal = reactive({\n peopleName: '',\n})\n\nfunction validatePeopleName(rule: any, value: any, callback: any) {\n if (!value) {\n const message = `请输入${limitBindField.value}`\n callback(new Error(message))\n ElMessage.error(message)\n return\n }\n // 异步校验\n PeopleApi.checkPeopleIsExist(k.value, value).then((res) => {\n if (!res.data.exist) {\n ElMessage.error('你不在此次提交名单中,如有疑问请联系管理员')\n }\n callback(\n res.data.exist\n ? undefined\n : new Error('你不在此次提交名单中,如有疑问请联系管理员'),\n )\n })\n}\n\nconst validModalRef = ref<FormInstance>()\nconst validModalRules = reactive({\n peopleName: [{ validator: validatePeopleName, trigger: 'blur' }],\n})\nfunction confirmPeopleName() {\n // 处理表单必填项含有 limitBindField 的情况\n if (isSameFieldName.value) {\n const value = infos.find(v => v.text === limitBindField.value)?.value\n validModal.peopleName = value || ''\n return new Promise((resolve) => {\n validatePeopleName(null, value, resolve)\n }).then(v => !v)\n }\n return validModalRef.value.validate((isValid: boolean) => isValid)\n}\n\nfunction startUpload() {\n const uploadFiles = fileList.value\n for (const file of uploadFiles) {\n if (!file.md5) {\n ElMessage.info(\n `文件(${file.name})的唯一指纹还在计算中,再等待一会儿再点击上传`,\n )\n setTimeout(() => {\n ElMessage.info('文件越大计算时间越长(1G通常需要20s)')\n }, 100)\n }\n else if (file.status === 'ready') {\n // 开始上传\n file.status = 'uploading'\n let { name } = file\n const originName = name\n // 如果开启了自动重命名,这里重命名一下\n if (taskMoreInfo.rewrite) {\n name\n = infos.map(v => v.value).join(formatData.value.splitChar || '-')\n + getFileSuffix(name)\n }\n // 替换不合法的字符\n name = normalizeFileName(name)\n const key = `easypicker2/${k.value}/${file.md5}/${name}`\n\n FileApi.getUploadToken().then((res) => {\n qiniuUpload(res.data.token, file.raw, key, {\n success(data: any) {\n const { fsize } = data\n FileApi.addFile({\n originName,\n name,\n taskKey: k.value,\n taskName: taskInfo.name,\n size: fsize,\n hash: file.md5,\n info: JSON.stringify(infos),\n people: validModal.peopleName,\n }).then(() => {\n file.status = 'success'\n ElMessage.success(`文件:${file.name}提交成功`)\n if (taskMoreInfo.people) {\n // 无感知更新一下\n PeopleApi.updatePeopleStatus(\n k.value,\n name,\n validModal.peopleName,\n file.md5,\n )\n }\n })\n },\n process(per: number, data: any, subscription: any) {\n file.percentage = Math.floor(per)\n // 挂载取消上传的方法\n file.subscription = subscription\n },\n })\n })\n }\n }\n}\n\nasync function submitUpload() {\n if (!isWriteFinish.value) {\n ElMessage.warning('请先完成必要信息的填写')\n return\n }\n\n if (taskMoreInfo.people) {\n const isValid = await confirmPeopleName()\n if (!isValid) {\n return\n }\n }\n startUpload()\n}\n\n// 是否允许上传\nconst allowUpload = computed(() => {\n for (const file of fileList.value) {\n if (file.status === 'ready') {\n return true\n }\n }\n return false\n})\n\n// 是否允许撤回\nconst allowWithdraw = computed(() => {\n for (const file of fileList.value) {\n if (['success', 'ready'].includes(file.status)) {\n return true\n }\n }\n return false\n})\n\n// 添加文件\n// 正在计算MD5值的文件个数\nconst calculateMd5Count = ref(0)\nfunction handleChangeFile(file: any) {\n // 校验文件后缀名\n const { name } = file\n if (formatData.value.format.length && formatData.value.status) {\n const suffix = getFileSuffix(name)\n if (\n !formatData.value.format.find(v => suffix.toLowerCase().endsWith(v))\n ) {\n ElMessage.error(`${name} 格式不符合要求`)\n fileUpload.value.handleRemove(file)\n return\n }\n }\n\n // 校验文件大小\n if (formatData.value.size && formatData.value.size < file.size) {\n ElMessage.error(`${name} 大小${formatSize(file.size)} 不符合要求`)\n fileUpload.value.handleRemove(file)\n return\n }\n\n calculateMd5Count.value += 1\n // 计算md5 hash\n getFileMd5Hash(file.raw).then((str) => {\n file.md5 = str\n calculateMd5Count.value -= 1\n })\n}\n\nconst limitUploadCount = computed(() => formatData.value.limit || 10)\nfunction handleExceed() {\n ElMessage.warning(\n `一次提交最多只能选择${limitUploadCount.value}个文件,请移除已经上传成功的或刷新页面`,\n )\n}\nconst showLinkModel = ref(false)\nconst templateLink = ref('')\nfunction runWithdraw() {\n const uploadFiles = fileList.value\n for (const file of uploadFiles) {\n if (!file.md5) {\n ElMessage.info(\n `文件(${file.name})的唯一指纹还在计算中,再等待一会儿再点击上传`,\n )\n setTimeout(() => {\n ElMessage.info('文件越大计算时间越长(1G通常需要20s)')\n }, 100)\n }\n else if (!['fail', 'uploading'].includes(file.status)) {\n // 准备开始撤回\n let { name } = file\n\n // 如果开启了自动重命名,这里重命名一下\n if (taskMoreInfo.rewrite) {\n name\n = infos.map(v => v.value).join(formatData.value.splitChar || '-')\n + getFileSuffix(name)\n }\n\n FileApi.withdrawFile({\n taskKey: k.value,\n taskName: taskInfo.name,\n filename: name,\n hash: file.md5,\n info: JSON.stringify(infos),\n peopleName: validModal.peopleName,\n })\n .then(() => {\n ElMessage.success(`文件:${file.name}撤回成功`)\n file.name += ' - (已撤回 ✅ )'\n file.status = 'fail'\n })\n .catch(() => {\n ElMessage.error(`撤回失败: 没有文件:${file.name}对应提交记录`)\n })\n }\n }\n}\nfunction downloadTemplate() {\n FileApi.getTemplateUrl(taskMoreInfo.template, k.value)\n .then((res) => {\n showLinkModel.value = true\n const { link } = res.data\n templateLink.value = link\n downLoadByUrl(link, taskMoreInfo.template)\n })\n .catch(() => {\n ElMessage.warning('文件已从服务器上移除,请联系管理员重新上传')\n })\n}\n\n// 撤回相关逻辑\nconst isWithdraw = ref(false)\nasync function startWithdraw() {\n // 校验表单填写\n if (!isWriteFinish.value) {\n ElMessage.warning('请先完成必要信息的填写')\n return\n }\n if (taskMoreInfo.people) {\n const isValid = await confirmPeopleName()\n if (!isValid) {\n return\n }\n }\n runWithdraw()\n}\n\n// 查询提交情况\nasync function checkSubmitStatus() {\n // 校验表单填写\n if (!isWriteFinish.value) {\n ElMessage.warning('请先完成必要信息的填写,需和提交时信息完全一致')\n return\n }\n // 卡控人员限制\n if (taskMoreInfo.people) {\n const isValid = await confirmPeopleName()\n if (!isValid) {\n return\n }\n }\n FileApi.checkSubmitStatus(k.value, infos, validModal.peopleName).then(\n (res) => {\n if (res.data.isSubmit) {\n ElMessage.success('已经提交过啦')\n }\n else {\n ElMessage.warning('还未提交过哟')\n }\n },\n )\n}\nconst isLoadingData = ref(false)\nconst readyRefresh = ref(false)\nfunction isEqualInfos(a: InfoItem[] = [], b: InfoItem[] = []) {\n if (a.length !== b.length) {\n return false\n }\n return a.every(\n (v, i) =>\n v.type === b[i].type\n && v.text === b[i].text\n && isEqualInfos(v.children, b[i].children),\n )\n}\nfunction refreshTaskMoreInfo(hot = false) {\n TaskApi.getTaskMoreInfo(k.value).then((res) => {\n Object.assign(taskMoreInfo, res.data)\n if (!isEqualInfos(infos, parseInfo(taskMoreInfo.info))) {\n infos.splice(0, infos.length)\n infos.push(...parseInfo(taskMoreInfo.info))\n if (hot) {\n ElMessage.success('表单信息有更新')\n }\n }\n refreshWaitTime(false)\n isLoadingData.value = false\n })\n}\nfunction handleBlur() {\n readyRefresh.value = true\n}\nfunction handleFocus() {\n if (readyRefresh.value && !disableForm.value) {\n readyRefresh.value = false\n refreshTaskMoreInfo(true)\n }\n}\n\n// 展示的时间提示文案\nconst timeInfo = computed(() => {\n if (!isOver.value) {\n return ddlStr.value + waitTimeStr.value\n }\n return ddlStr.value\n})\n\n// tipImage\nconst tipData = reactive<{\n text: string\n imgs: {\n uid: number\n name: string\n }[]\n}>({\n text: '',\n imgs: [],\n})\nconst imageList = ref<\n { name: string, uid: number, preview?: string, url: string }[]\n>([])\n\nwatch(\n () => taskMoreInfo.tip,\n () => {\n // 初始化\n try {\n const parseData = JSON.parse(taskMoreInfo.tip)\n tipData.imgs = parseData.imgs\n tipData.text = parseData.text || ''\n imageList.value = tipData.imgs.map((v) => {\n return {\n ...v,\n url: 'https://img.cdn.sugarat.top/mdImg/MTY3NzkxMDI1NTU1Nw==20140524124237518.gif',\n }\n })\n if (imageList.value.length) {\n // 异步填充url\n PublicApi.getTipImageUrl(\n k.value,\n imageList.value.map(v => ({\n uid: v.uid,\n name: v.name,\n })),\n ).then((v) => {\n v.data.forEach((url, idx) => {\n imageList.value[idx].url = url.cover\n Object.assign(imageList.value[idx], {\n preview: url.preview,\n })\n })\n })\n }\n }\n catch {\n tipData.text = ''\n tipData.imgs = []\n imageList.value = []\n }\n },\n)\n\n// 禁用上传\nconst disabledUpload = useLocalStorage('disabledUpload', false)\n\nonMounted(() => {\n k.value = $route.params.key as string\n if (k.value) {\n isLoadingData.value = true\n TaskApi.getTaskInfo(k.value)\n .then((res) => {\n Object.assign(taskInfo, res.data)\n disabledUpload.value = !!res.data.limitUpload\n if (disabledUpload.value) {\n ElMessageBox.alert(\n '任务存储空间容量已达到上限,已经无法进行上传,请联系发起人扩容空间',\n )\n }\n })\n .catch((err) => {\n if (err.code === 4001) {\n ElMessage.error('任务不存在')\n k.value = ''\n taskInfo.name = '任务不存在'\n }\n })\n refreshTaskMoreInfo()\n refreshWaitTime()\n }\n // 页面隐藏\n window.addEventListener('blur', handleBlur)\n\n // 页面展示\n window.addEventListener('focus', handleFocus)\n})\n\nonUnmounted(() => {\n // 页面隐藏\n window.removeEventListener('blur', handleBlur)\n // 页面展示\n window.removeEventListener('focus', handleFocus)\n})\n</script>\n\n<template>\n <div class=\"task-panel\">\n <div class=\"pc-nav\">\n <div class=\"nav\">\n <!-- LOGO -->\n <div class=\"logo\">\n <router-link to=\"/\">\n <img\n style=\"height: 40px; width: 170px\"\n src=\"https://img.cdn.sugarat.top/easypicker/EasyPicker.png\"\n alt=\"logo\"\n >\n </router-link>\n </div>\n <nav>\n <div\n v-for=\"(n, idx) in pcNavs\"\n :key=\"idx\"\n class=\"nav-item\"\n @click=\"handleNav(idx)\"\n >\n {{ n.title }}\n </div>\n </nav>\n </div>\n </div>\n <!-- 有效 -->\n <div\n v-if=\"k\"\n v-loading=\"isLoadingData\"\n element-loading-text=\"Loading...\"\n class=\"panel tc\"\n >\n <!-- 任务名 -->\n <h1 class=\"name\">\n {{ taskInfo.name }}\n </h1>\n <h2 v-if=\"disabledUpload\" style=\"color: red\">\n 任务存储空间容量已达到上限,已经无法进行上传,请联系发起人扩容空间\n </h2>\n <!-- 提示信息 -->\n <!-- 时间截止了也不再展示 -->\n <template v-if=\"tipData.text && (ddlStr ? !isOver : true)\">\n <el-divider>⚠️ 注意事项 ⚠️</el-divider>\n <Tip>\n <div class=\"tip-wrapper\">\n <p v-for=\"(t, i) in tipData.text.split('\\n')\" :key=\"i\">\n {{ t.replace(/\\s/g, '&nbsp;') }}\n </p>\n </div>\n </Tip>\n </template>\n <template v-if=\"imageList.length && (ddlStr ? !isOver : true)\">\n <el-image\n v-for=\"(img, idx) in imageList\"\n :key=\"img.uid\"\n hide-on-click-modal\n style=\"width: 100px; height: 100px; margin: 10px\"\n :src=\"img.url\"\n :zoom-rate=\"1.2\"\n :preview-src-list=\"imageList.map((v) => v.preview)\"\n :initial-index=\"idx\"\n fit=\"contain\"\n />\n </template>\n <!-- 截止时间字符串 -->\n <template v-if=\"ddlStr\">\n <el-divider>截止时间</el-divider>\n <h2 class=\"ddl\">\n {{ timeInfo }}\n </h2>\n <div v-if=\"isOver\">\n <el-empty description=\"已经结束啦!\" />\n </div>\n </template>\n <!-- 未设置ddl 或者 设置了还未结束 -->\n <div v-if=\"!ddlStr || !isOver\">\n <el-divider>必要信息填写</el-divider>\n <div class=\"infos\">\n <div v-show=\"taskMoreInfo.people\">\n <Tip>“{{ limitBindField }}”在参与名单里才能正常提交</Tip>\n </div>\n <div v-if=\"showValidForm\">\n <div class=\"infos\">\n <el-form\n ref=\"validModalRef\"\n :rules=\"validModalRules\"\n status-icon\n :model=\"validModal\"\n :disabled=\"disableForm\"\n label-position=\"top\"\n >\n <el-form-item prop=\"peopleName\" :label=\"limitBindField\">\n <el-input\n v-model=\"validModal.peopleName\"\n :maxlength=\"14\"\n clearable\n show-word-limit\n :placeholder=\"`请输入 ${limitBindField}`\"\n />\n </el-form-item>\n </el-form>\n </div>\n </div>\n <InfosForm :infos=\"infos\" :disabled=\"disableForm\" />\n </div>\n <el-upload\n ref=\"fileUpload\"\n v-model:file-list=\"fileList\"\n style=\"max-width: 400px; margin: 0 auto\"\n :drag=\"!isMobile\"\n action=\"\"\n :on-change=\"handleChangeFile\"\n :before-remove=\"handleRemoveFile\"\n :on-exceed=\"handleExceed\"\n :auto-upload=\"false\"\n multiple\n :limit=\"limitUploadCount\"\n >\n <el-button v-if=\"isMobile\" type=\"primary\">\n 选择文件\n </el-button>\n <template v-else>\n <el-icon class=\"el-icon--upload\">\n <UploadFilled />\n </el-icon>\n <div class=\"el-upload__text\">\n 将文件拖于此处 or <em>直接选择文件</em>\n </div>\n </template>\n <template #tip>\n <div v-show=\"!!calculateMd5Count\" class=\"p10\">\n <Tip>\n 还有\n {{ calculateMd5Count }}\n 个文件正在生成校验信息,请稍等(1G通常需要20s)\n </Tip>\n </div>\n </template>\n </el-upload>\n <div class=\"p10\">\n <el-button\n v-if=\"isWithdraw\"\n size=\"default\"\n type=\"warning\"\n :disabled=\"!allowWithdraw || !!calculateMd5Count\"\n @click=\"startWithdraw\"\n >\n 一键撤回\n </el-button>\n <el-button\n v-else-if=\"!disabledUpload\"\n size=\"default\"\n type=\"success\"\n :disabled=\"!allowUpload || !!calculateMd5Count\"\n @click=\"submitUpload\"\n >\n 提交文件\n </el-button>\n <el-button size=\"default\" @click=\"checkSubmitStatus\">\n 查询提交情况\n </el-button>\n </div>\n <!-- 提示信息 -->\n <div class=\"p10 option-tips\">\n <Tip v-if=\"formatData.status && formatData.format.length\">\n 限制格式为:\n <span style=\"color: red\">{{\n formatData.format.join(', ')\n }}</span>\n </Tip>\n <Tip v-if=\"formatData.size\">\n 限制文件大小不超过:\n <span style=\"color: red\">{{\n formatSize(formatData.size)\n }}</span>\n </Tip>\n <template v-if=\"isWithdraw\">\n <Tip>\n ① 须保证选择的文件与提交时的文件一致<br>\n ② 填写表单信息一致 <br>\n ③\n 完全一模一样的文件的提交记录(内容md5+命名),将会一次性全部撤回\n </Tip>\n </template>\n <template v-else>\n <Tip>\n <strong>查询提交情况,需填写和提交时一样的表单信息</strong>\n </Tip>\n <Tip>\n ① 选择完文件,点击 ”提交文件“即可 <br>\n ② <strong>选择大文件后需要等待一会儿才展示处理</strong>\n <template v-if=\"taskMoreInfo.template && !disabledUpload\">\n <br>\n ③\n <strong>\n <el-button\n type=\"primary\"\n text\n style=\"color: #85ce61\"\n size=\"small\"\n @click=\"downloadTemplate\"\n >右下角可 “查看提交示例”\n </el-button>\n </strong>\n </template>\n </Tip>\n </template>\n </div>\n <div class=\"withdraw\">\n <el-button\n v-if=\"taskMoreInfo.template && !disabledUpload\"\n type=\"primary\"\n text\n style=\"color: #85ce61\"\n size=\"small\"\n @click=\"downloadTemplate\"\n >\n 查看提交示例\n </el-button>\n <el-button\n v-if=\"isWithdraw\"\n size=\"small\"\n type=\"primary\"\n text\n @click=\"isWithdraw = false\"\n >\n 正常提交\n </el-button>\n <el-button\n v-else\n size=\"small\"\n type=\"primary\"\n text\n @click=\"isWithdraw = true\"\n >\n 我要撤回\n </el-button>\n </div>\n </div>\n </div>\n <!-- 无效任务 -->\n <div v-else class=\"panel tc\">\n <h1 class=\"name\">\n {{ taskInfo.name }}\n </h1>\n </div>\n <LinkDialog\n v-model:value=\"showLinkModel\"\n title=\"示例文件下载链接\"\n :link=\"templateLink\"\n />\n <div style=\"padding-top: 20px\">\n <HomeFooter type=\"task\" />\n </div>\n </div>\n</template>\n\n<style scoped lang=\"scss\">\n.task-panel :deep(ul.el-upload-list) {\n border: 1px dashed #d4d4d4;\n padding: 10px;\n\n &::before {\n content: '此处展示选择文件列表';\n font-size: 12px;\n position: relative;\n bottom: 4px;\n }\n}\n\n.task-panel :deep(.el-upload-list__item-name) {\n display: block;\n overflow: hidden;\n max-width: 290px;\n text-overflow: ellipsis;\n word-break: keep-all;\n}\n\n.task-panel :deep(.is-ready .el-icon--close) {\n display: block;\n color: black;\n}\n\n.task-panel {\n background-color: #f3f6f8;\n padding-bottom: 1rem;\n position: relative;\n}\n\n.pc-nav {\n background-color: #fff;\n display: flex;\n padding: 10px;\n justify-content: space-between;\n align-items: center;\n\n .exit {\n cursor: pointer;\n }\n\n .nav {\n display: flex;\n\n nav {\n display: flex;\n align-items: center;\n\n .nav-item {\n font-size: 1rem;\n color: #595959;\n padding: 10px;\n cursor: pointer;\n\n &.active {\n color: #409eff !important;\n font-weight: 600;\n }\n }\n }\n\n .exit {\n color: #595959;\n }\n }\n\n .logo {\n width: 180px;\n margin: 0 10px;\n\n img {\n height: 40px;\n }\n }\n}\n\n.panel {\n max-width: 1024px;\n padding: 1em;\n background-color: #fff;\n margin: 10px auto;\n box-sizing: border-box;\n box-shadow: 0 2px 12px 0 rgb(0 0 0 / 10%);\n border-radius: 4px;\n\n .name {\n text-align: center;\n }\n\n .ddl {\n margin-top: 10px;\n color: #919191;\n font-size: 14px;\n }\n\n .infos {\n max-width: 460px;\n margin: auto;\n overflow: hidden;\n :deep(div.el-form-item > label) {\n font-weight: bold;\n &::before {\n content: '* ';\n color: red;\n }\n }\n }\n}\n\n.withdraw {\n text-align: right;\n}\n\n.tip-wrapper {\n line-height: 20px;\n text-align: left;\n word-break: break-all;\n // max-height: 100px;\n overflow: hidden;\n padding: 0 20px;\n color: #e6a23c;\n max-width: 320px;\n font-size: 14px;\n}\n</style>\n"],"names":["_sfc_main","defineComponent","name","_hoisted_1","viewBox","xmlns","_hoisted_3","createElementVNode","fill","d","uploadFilled","_export_sfc","_ctx","_cache","$props","$setup","$data","$options","openBlock","createElementBlock","isMobile","useIsMobile","$router","useRouter","$route","useRoute","pcNavs","reactive","title","path","taskInfo","category","taskMoreInfo","bindField","formatData","computed","parseFileFormat","format","k","ref","waitTime","isOver","value","waitTimeStr","seconds","hour","day","minute","refreshWaitTime","loop","ddl","date","Date","getTime","now","setTimeout","ddlStr","formatDate","infos","fileList","fileUpload","disableForm","filter","item","status","length","handleRemoveFile","file","ElMessageBox","confirm","then","ElMessage","info","subscription","unsubscribe","catch","isWriteFinish","every","limitBindField","trim","isSameFieldName","find","v","text","showValidForm","people","validModal","peopleName","validatePeopleName","rule","callback","message","Error","error","PeopleApi","checkPeopleIsExist","res","data","exist","validModalRef","validModalRules","validator","trigger","confirmPeopleName","Promise","resolve","validate","isValid","async","submitUpload","uploadFiles","md5","originName","rewrite","map","join","splitChar","getFileSuffix","normalizeFileName","key","FileApi","getUploadToken","qiniuUpload","token","raw","success","fsize","addFile","taskKey","taskName","size","hash","JSON","stringify","updatePeopleStatus","process","per","percentage","Math","floor","startUpload","warning","allowUpload","allowWithdraw","includes","calculateMd5Count","handleChangeFile","suffix","toLowerCase","endsWith","handleRemove","formatSize","getFileMd5Hash","str","limitUploadCount","limit","handleExceed","showLinkModel","templateLink","downloadTemplate","getTemplateUrl","template","link","downLoadByUrl","isWithdraw","startWithdraw","withdrawFile","filename","runWithdraw","checkSubmitStatus","isSubmit","isLoadingData","readyRefresh","isEqualInfos","a","b","i","type","children","refreshTaskMoreInfo","hot","TaskApi","getTaskMoreInfo","Object","assign","parseInfo","splice","push","handleBlur","handleFocus","timeInfo","tipData","imgs","imageList","watch","tip","parseData","parse","url","PublicApi","getTipImageUrl","uid","forEach","idx","cover","preview","disabledUpload","useLocalStorage","onMounted","params","getTaskInfo","limitUpload","alert","err","code","window","addEventListener","onUnmounted","removeEventListener","startsWith","location","href"],"mappings":"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","x_google_ignoreList":[0]}