@sugarat/easypicker2-client 2.7.2 → 2.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/assets/aria-legacy-B70JmEZA.js.map +1 -1
- package/dist/assets/aria-nkjrUMQ-.js.map +1 -1
- package/dist/assets/config-CnEgj70a.css +1 -0
- package/dist/assets/config-DR4Jo6x0.js +2 -0
- package/dist/assets/config-DR4Jo6x0.js.map +1 -0
- package/dist/assets/config-legacy-Frhed9Ou.js +2 -0
- package/dist/assets/config-legacy-Frhed9Ou.js.map +1 -0
- package/dist/assets/{data-analysis-B9140nBj.js → data-analysis-B8jQ_UrC.js} +2 -2
- package/dist/assets/data-analysis-B8jQ_UrC.js.map +1 -0
- package/dist/assets/{data-analysis-legacy-hCmX88pc.js → data-analysis-legacy-DjCCKm5W.js} +2 -2
- package/dist/assets/data-analysis-legacy-DjCCKm5W.js.map +1 -0
- package/dist/assets/{data-board-D3o_ZTM6.js → data-board-BGj6fORD.js} +2 -2
- package/dist/assets/data-board-BGj6fORD.js.map +1 -0
- package/dist/assets/{data-board-legacy-B3GeXOqc.js → data-board-legacy-D0aBtKuE.js} +2 -2
- package/dist/assets/data-board-legacy-D0aBtKuE.js.map +1 -0
- package/dist/assets/delete-filled-B3KAHg4C.js +2 -0
- package/dist/assets/delete-filled-B3KAHg4C.js.map +1 -0
- package/dist/assets/delete-filled-legacy-IwQ4U_-h.js +2 -0
- package/dist/assets/delete-filled-legacy-IwQ4U_-h.js.map +1 -0
- package/dist/assets/el-date-picker-2VHUEHRN.js +2 -0
- package/dist/assets/el-date-picker-2VHUEHRN.js.map +1 -0
- package/dist/assets/el-date-picker-legacy-6LjuTLvj.js +2 -0
- package/dist/assets/el-date-picker-legacy-6LjuTLvj.js.map +1 -0
- package/dist/assets/el-dropdown-item-C_iGHfk5.js +2 -0
- package/dist/assets/el-dropdown-item-C_iGHfk5.js.map +1 -0
- package/dist/assets/el-dropdown-item-legacy-Dd1a85un.js +2 -0
- package/dist/assets/el-dropdown-item-legacy-Dd1a85un.js.map +1 -0
- package/dist/assets/el-empty-C2yupmrg.css +1 -0
- package/dist/assets/el-empty-DM1AJWOT.js +2 -0
- package/dist/assets/el-empty-DM1AJWOT.js.map +1 -0
- package/dist/assets/el-empty-legacy-ZCYPIt_S.js +2 -0
- package/dist/assets/el-empty-legacy-ZCYPIt_S.js.map +1 -0
- package/dist/assets/el-input-number-CU7OpiYS.css +1 -0
- package/dist/assets/el-input-number-CgyrHNcj.js +2 -0
- package/dist/assets/el-input-number-CgyrHNcj.js.map +1 -0
- package/dist/assets/el-input-number-legacy-Bh6hK4h_.js +2 -0
- package/dist/assets/el-input-number-legacy-Bh6hK4h_.js.map +1 -0
- package/dist/assets/{el-loading-BzK_8zqi.js → el-loading-DqRoOOxo.js} +2 -2
- package/dist/assets/el-loading-DqRoOOxo.js.map +1 -0
- package/dist/assets/el-loading-legacy-CFNL_MoE.js +2 -0
- package/dist/assets/el-loading-legacy-CFNL_MoE.js.map +1 -0
- package/dist/assets/el-pagination-DVClk9XJ.js +2 -0
- package/dist/assets/el-pagination-DVClk9XJ.js.map +1 -0
- package/dist/assets/el-pagination-legacy-DwnhLxcB.js +2 -0
- package/dist/assets/el-pagination-legacy-DwnhLxcB.js.map +1 -0
- package/dist/assets/el-scrollbar-B_rEcSsQ.js +2 -0
- package/dist/assets/el-scrollbar-B_rEcSsQ.js.map +1 -0
- package/dist/assets/el-scrollbar-DFu7lMno.css +1 -0
- package/dist/assets/el-scrollbar-legacy-DVIFmrwk.js +2 -0
- package/dist/assets/el-scrollbar-legacy-DVIFmrwk.js.map +1 -0
- package/dist/assets/el-select-C5BnfITI.js +2 -0
- package/dist/assets/el-select-C5BnfITI.js.map +1 -0
- package/dist/assets/el-select-Dm4tLYz8.css +1 -0
- package/dist/assets/el-select-legacy-yKcmdaqh.js +2 -0
- package/dist/assets/el-select-legacy-yKcmdaqh.js.map +1 -0
- package/dist/assets/el-switch-BUjvki0a.js +2 -0
- package/dist/assets/el-switch-BUjvki0a.js.map +1 -0
- package/dist/assets/el-switch-legacy-CeDo4e_6.js +2 -0
- package/dist/assets/el-switch-legacy-CeDo4e_6.js.map +1 -0
- package/dist/assets/el-tab-pane-DKrBN9bA.js +2 -0
- package/dist/assets/el-tab-pane-DKrBN9bA.js.map +1 -0
- package/dist/assets/{el-tab-pane-legacy-CDSRCQdO.js → el-tab-pane-legacy-Ct9rYze8.js} +2 -2
- package/dist/assets/el-tab-pane-legacy-Ct9rYze8.js.map +1 -0
- package/dist/assets/{el-table-column-B2R1FOoB.js → el-table-column-cVnV9Qdi.js} +3 -3
- package/dist/assets/el-table-column-cVnV9Qdi.js.map +1 -0
- package/dist/assets/el-table-column-legacy-D2UbUqx0.js +24 -0
- package/dist/assets/el-table-column-legacy-D2UbUqx0.js.map +1 -0
- package/dist/assets/el-tag-Bgje3_SF.css +1 -0
- package/dist/assets/el-tag-CR8VXqUN.js +2 -0
- package/dist/assets/el-tag-CR8VXqUN.js.map +1 -0
- package/dist/assets/el-tag-legacy-diNMtlkE.js +2 -0
- package/dist/assets/el-tag-legacy-diNMtlkE.js.map +1 -0
- package/dist/assets/el-upload-B2Zxm6X5.css +1 -0
- package/dist/assets/el-upload-DRWHzvzW.js +2 -0
- package/dist/assets/el-upload-DRWHzvzW.js.map +1 -0
- package/dist/assets/el-upload-legacy-C7Y6h5AK.js +2 -0
- package/dist/assets/el-upload-legacy-C7Y6h5AK.js.map +1 -0
- package/dist/assets/index-8vfFTV-B.css +1 -0
- package/dist/assets/index-B2PHCM63.js +23 -0
- package/dist/assets/index-B2PHCM63.js.map +1 -0
- package/dist/assets/{index-C4H-Ptjt.css → index-BDkChTag.css} +1 -1
- package/dist/assets/index-BDsN2eKB.js +2 -0
- package/dist/assets/index-BDsN2eKB.js.map +1 -0
- package/dist/assets/index-BIKx9Xnn.js +2 -0
- package/dist/assets/index-BIKx9Xnn.js.map +1 -0
- package/dist/assets/index-BOFlLnYl.js +2 -0
- package/dist/assets/index-BOFlLnYl.js.map +1 -0
- package/dist/assets/index-BSMNPGJ5.css +1 -0
- package/dist/assets/index-BVp20vyj.css +1 -0
- package/dist/assets/index-BWExpeba.js +2 -0
- package/dist/assets/index-BWExpeba.js.map +1 -0
- package/dist/assets/index-B_7cUQcW.js +2 -0
- package/dist/assets/index-B_7cUQcW.js.map +1 -0
- package/dist/assets/index-BcJxc1ki.css +1 -0
- package/dist/assets/index-BgihxBmj.css +1 -0
- package/dist/assets/index-BjSgvXxj.css +1 -0
- package/dist/assets/index-BrOLxzFM.js.map +1 -1
- package/dist/assets/index-Bx68sw-c.js +2 -0
- package/dist/assets/index-Bx68sw-c.js.map +1 -0
- package/dist/assets/index-BxcfgZqH.js +2 -0
- package/dist/assets/index-BxcfgZqH.js.map +1 -0
- package/dist/assets/{index-ehQnwCE_.css → index-Bxvzu7zF.css} +1 -1
- package/dist/assets/index-BzQdnJY9.js +2 -0
- package/dist/assets/index-BzQdnJY9.js.map +1 -0
- package/dist/assets/index-CFpIdG49.css +1 -0
- package/dist/assets/index-CQjXznXy.js +2 -0
- package/dist/assets/index-CQjXznXy.js.map +1 -0
- package/dist/assets/index-CQud0ONT.css +1 -0
- package/dist/assets/index-CkyNID7q.css +1 -0
- package/dist/assets/index-CsfbnGni.css +1 -0
- package/dist/assets/index-CuGN8YoJ.js +2 -0
- package/dist/assets/index-CuGN8YoJ.js.map +1 -0
- package/dist/assets/index-D94P-51I.css +1 -0
- package/dist/assets/index-DLuR61Hw.css +1 -0
- package/dist/assets/index-DRKBIvKP.js +2 -0
- package/dist/assets/index-DRKBIvKP.js.map +1 -0
- package/dist/assets/index-DTRiT4Ia.js +2 -0
- package/dist/assets/index-DTRiT4Ia.js.map +1 -0
- package/dist/assets/index-DVSUcRaY.js +2 -0
- package/dist/assets/index-DVSUcRaY.js.map +1 -0
- package/dist/assets/index-DWOXO9QK.js +2 -0
- package/dist/assets/index-DWOXO9QK.js.map +1 -0
- package/dist/assets/index-DWi4klmy.js +2 -0
- package/dist/assets/index-DWi4klmy.js.map +1 -0
- package/dist/assets/index-DcUtl6Nq.css +1 -0
- package/dist/assets/index-Diw0ScGB.js +2 -0
- package/dist/assets/index-Diw0ScGB.js.map +1 -0
- package/dist/assets/index-Dk60yOI9.js +2 -0
- package/dist/assets/index-Dk60yOI9.js.map +1 -0
- package/dist/assets/index-FISBGs_l.css +1 -0
- package/dist/assets/index-LKJh-8oZ.css +1 -0
- package/dist/assets/index-MRZ7DYIX.js +2 -0
- package/dist/assets/index-MRZ7DYIX.js.map +1 -0
- package/dist/assets/index-Q8b92C8V.css +1 -0
- package/dist/assets/index-X0ZxbeZs.js +2 -0
- package/dist/assets/index-X0ZxbeZs.js.map +1 -0
- package/dist/assets/index-fz1mWSN_.js +2 -0
- package/dist/assets/index-fz1mWSN_.js.map +1 -0
- package/dist/assets/index-legacy-B5_Eg4NO.js +2 -0
- package/dist/assets/index-legacy-B5_Eg4NO.js.map +1 -0
- package/dist/assets/index-legacy-B71iq4Jg.js +2 -0
- package/dist/assets/index-legacy-B71iq4Jg.js.map +1 -0
- package/dist/assets/index-legacy-B7MgTgVj.js +2 -0
- package/dist/assets/index-legacy-B7MgTgVj.js.map +1 -0
- package/dist/assets/index-legacy-BLCMV_4m.js +2 -0
- package/dist/assets/index-legacy-BLCMV_4m.js.map +1 -0
- package/dist/assets/index-legacy-BLu3Mu8j.js +2 -0
- package/dist/assets/index-legacy-BLu3Mu8j.js.map +1 -0
- package/dist/assets/index-legacy-BSmhgZ-n.js +2 -0
- package/dist/assets/index-legacy-BSmhgZ-n.js.map +1 -0
- package/dist/assets/index-legacy-BTvagK_v.js +2 -0
- package/dist/assets/index-legacy-BTvagK_v.js.map +1 -0
- package/dist/assets/index-legacy-C-gHf8SN.js.map +1 -1
- package/dist/assets/index-legacy-C2bwTRoT.js +2 -0
- package/dist/assets/index-legacy-C2bwTRoT.js.map +1 -0
- package/dist/assets/index-legacy-CM7bG2hM.js +2 -0
- package/dist/assets/index-legacy-CM7bG2hM.js.map +1 -0
- package/dist/assets/index-legacy-CRa6h-UF.js +2 -0
- package/dist/assets/index-legacy-CRa6h-UF.js.map +1 -0
- package/dist/assets/index-legacy-CkcZHDIb.js +54 -0
- package/dist/assets/index-legacy-CkcZHDIb.js.map +1 -0
- package/dist/assets/index-legacy-Cp4ut576.js +2 -0
- package/dist/assets/index-legacy-Cp4ut576.js.map +1 -0
- package/dist/assets/index-legacy-CvW_2XYj.js +2 -0
- package/dist/assets/index-legacy-CvW_2XYj.js.map +1 -0
- package/dist/assets/index-legacy-CwUt8UiU.js +2 -0
- package/dist/assets/index-legacy-CwUt8UiU.js.map +1 -0
- package/dist/assets/index-legacy-CzoivdRy.js +2 -0
- package/dist/assets/index-legacy-CzoivdRy.js.map +1 -0
- package/dist/assets/index-legacy-D-mrc8ns.js +2 -0
- package/dist/assets/index-legacy-D-mrc8ns.js.map +1 -0
- package/dist/assets/index-legacy-D2hV5N51.js +2 -0
- package/dist/assets/index-legacy-D2hV5N51.js.map +1 -0
- package/dist/assets/index-legacy-D6Zqa9lw.js +2 -0
- package/dist/assets/index-legacy-D6Zqa9lw.js.map +1 -0
- package/dist/assets/index-legacy-DrA0B2e4.js +2 -0
- package/dist/assets/index-legacy-DrA0B2e4.js.map +1 -0
- package/dist/assets/index-legacy-DysxAWeo.js +2 -0
- package/dist/assets/index-legacy-DysxAWeo.js.map +1 -0
- package/dist/assets/index-legacy-TKeSN56S.js +16 -0
- package/dist/assets/index-legacy-TKeSN56S.js.map +1 -0
- package/dist/assets/index-legacy-erTEdV9o.js +2 -0
- package/dist/assets/index-legacy-erTEdV9o.js.map +1 -0
- package/dist/assets/index-legacy-pHu03Ans.js +2 -0
- package/dist/assets/index-legacy-pHu03Ans.js.map +1 -0
- package/dist/assets/index-legacy-w1mXHpIQ.js +2 -0
- package/dist/assets/index-legacy-w1mXHpIQ.js.map +1 -0
- package/dist/assets/index-mtfctTgx.css +1 -0
- package/dist/assets/index-sRZE1X3H.js +2 -0
- package/dist/assets/index-sRZE1X3H.js.map +1 -0
- package/dist/assets/index-uNaj-154.js +40 -0
- package/dist/assets/index-uNaj-154.js.map +1 -0
- package/dist/assets/index-vo_ird7L.js +2 -0
- package/dist/assets/index-vo_ird7L.js.map +1 -0
- package/dist/assets/linkDialog-Dida934t.css +1 -0
- package/dist/assets/linkDialog-legacy-0_j99SG_.js +2 -0
- package/dist/assets/linkDialog-legacy-0_j99SG_.js.map +1 -0
- package/dist/assets/linkDialog-vYdu1-Ul.js +2 -0
- package/dist/assets/linkDialog-vYdu1-Ul.js.map +1 -0
- package/dist/assets/other-BiIe9Z0L.js +2 -0
- package/dist/assets/other-BiIe9Z0L.js.map +1 -0
- package/dist/assets/other-legacy-Bfm4KL87.js +2 -0
- package/dist/assets/other-legacy-Bfm4KL87.js.map +1 -0
- package/dist/assets/polyfills-legacy-DqO_DCwg.js +1 -0
- package/dist/assets/{refresh-BA55HwKz.js → refresh-BnOQ8sKt.js} +2 -2
- package/dist/assets/refresh-BnOQ8sKt.js.map +1 -0
- package/dist/assets/{refresh-legacy-CpA05Fzr.js → refresh-legacy-D7NGa5wN.js} +2 -2
- package/dist/assets/refresh-legacy-D7NGa5wN.js.map +1 -0
- package/dist/assets/tip-CyB8omfw.js +2 -0
- package/dist/assets/tip-CyB8omfw.js.map +1 -0
- package/dist/assets/tip-legacy-DXZHLiK7.js +2 -0
- package/dist/assets/tip-legacy-DXZHLiK7.js.map +1 -0
- package/dist/assets/tipInfo-0FQ2unt4.js +2 -0
- package/dist/assets/tipInfo-0FQ2unt4.js.map +1 -0
- package/dist/assets/tipInfo-BPHCIpRm.css +1 -0
- package/dist/assets/tipInfo-legacy-cRqTuiqx.js +2 -0
- package/dist/assets/tipInfo-legacy-cRqTuiqx.js.map +1 -0
- package/dist/index.html +105 -128
- package/package.json +13 -35
- package/README.md +0 -86
- package/dist/assets/data-analysis-B9140nBj.js.map +0 -1
- package/dist/assets/data-analysis-legacy-hCmX88pc.js.map +0 -1
- package/dist/assets/data-board-D3o_ZTM6.js.map +0 -1
- package/dist/assets/data-board-legacy-B3GeXOqc.js.map +0 -1
- package/dist/assets/el-date-picker-DLwRZtue.js +0 -2
- package/dist/assets/el-date-picker-DLwRZtue.js.map +0 -1
- package/dist/assets/el-date-picker-legacy-D8g_iKhG.js +0 -2
- package/dist/assets/el-date-picker-legacy-D8g_iKhG.js.map +0 -1
- package/dist/assets/el-dialog-Cu2jwelC.css +0 -1
- package/dist/assets/el-dialog-Dq3XmL6w.js +0 -2
- package/dist/assets/el-dialog-Dq3XmL6w.js.map +0 -1
- package/dist/assets/el-dialog-legacy-DCFOVWEQ.js +0 -2
- package/dist/assets/el-dialog-legacy-DCFOVWEQ.js.map +0 -1
- package/dist/assets/el-dropdown-item-C3aOY1Nr.js +0 -2
- package/dist/assets/el-dropdown-item-C3aOY1Nr.js.map +0 -1
- package/dist/assets/el-dropdown-item-legacy-QQu1PUxO.js +0 -2
- package/dist/assets/el-dropdown-item-legacy-QQu1PUxO.js.map +0 -1
- package/dist/assets/el-form-item-Cc9R0dZ1.css +0 -1
- package/dist/assets/el-form-item-CtSEmj9z.js +0 -2
- package/dist/assets/el-form-item-CtSEmj9z.js.map +0 -1
- package/dist/assets/el-form-item-legacy-BS5eT84Y.js +0 -2
- package/dist/assets/el-form-item-legacy-BS5eT84Y.js.map +0 -1
- package/dist/assets/el-loading-BzK_8zqi.js.map +0 -1
- package/dist/assets/el-loading-legacy-DWfn3F3x.js +0 -2
- package/dist/assets/el-loading-legacy-DWfn3F3x.js.map +0 -1
- package/dist/assets/el-pagination-Qx_lnumK.js +0 -2
- package/dist/assets/el-pagination-Qx_lnumK.js.map +0 -1
- package/dist/assets/el-pagination-legacy-DqLvzT2t.js +0 -2
- package/dist/assets/el-pagination-legacy-DqLvzT2t.js.map +0 -1
- package/dist/assets/el-progress-CeLYmjYA.js +0 -2
- package/dist/assets/el-progress-CeLYmjYA.js.map +0 -1
- package/dist/assets/el-progress-legacy-CwFO38du.js +0 -2
- package/dist/assets/el-progress-legacy-CwFO38du.js.map +0 -1
- package/dist/assets/el-progress-njCW9-w4.css +0 -1
- package/dist/assets/el-select-BSO0hXRI.css +0 -1
- package/dist/assets/el-select-HG63LP3Z.js +0 -2
- package/dist/assets/el-select-HG63LP3Z.js.map +0 -1
- package/dist/assets/el-select-legacy-fKvGMZFT.js +0 -2
- package/dist/assets/el-select-legacy-fKvGMZFT.js.map +0 -1
- package/dist/assets/el-switch-FjmuXBNe.js +0 -2
- package/dist/assets/el-switch-FjmuXBNe.js.map +0 -1
- package/dist/assets/el-switch-legacy-CU4cCeO5.js +0 -2
- package/dist/assets/el-switch-legacy-CU4cCeO5.js.map +0 -1
- package/dist/assets/el-tab-pane-CuYcnzTM.js +0 -2
- package/dist/assets/el-tab-pane-CuYcnzTM.js.map +0 -1
- package/dist/assets/el-tab-pane-legacy-CDSRCQdO.js.map +0 -1
- package/dist/assets/el-table-column-B2R1FOoB.js.map +0 -1
- package/dist/assets/el-table-column-legacy-DDZdwCAr.js +0 -24
- package/dist/assets/el-table-column-legacy-DDZdwCAr.js.map +0 -1
- package/dist/assets/index-0SN-qZs5.js +0 -2
- package/dist/assets/index-0SN-qZs5.js.map +0 -1
- package/dist/assets/index-4ToTyeX6.css +0 -1
- package/dist/assets/index-5sS3uHi0.css +0 -1
- package/dist/assets/index-B5tZv3FB.css +0 -1
- package/dist/assets/index-BMhqAx1_.js +0 -2
- package/dist/assets/index-BMhqAx1_.js.map +0 -1
- package/dist/assets/index-BghihfR3.css +0 -1
- package/dist/assets/index-BjPgOd_H.js +0 -2
- package/dist/assets/index-BjPgOd_H.js.map +0 -1
- package/dist/assets/index-BjdYG4YE.js +0 -2
- package/dist/assets/index-BjdYG4YE.js.map +0 -1
- package/dist/assets/index-BkLqrfrW.js +0 -2
- package/dist/assets/index-BkLqrfrW.js.map +0 -1
- package/dist/assets/index-BvTJrWND.js +0 -2
- package/dist/assets/index-BvTJrWND.js.map +0 -1
- package/dist/assets/index-BxLy8VN3.js +0 -2
- package/dist/assets/index-BxLy8VN3.js.map +0 -1
- package/dist/assets/index-C0ZXXBCX.js +0 -40
- package/dist/assets/index-C0ZXXBCX.js.map +0 -1
- package/dist/assets/index-CbkKWoQA.css +0 -1
- package/dist/assets/index-CeWnhlkq.css +0 -1
- package/dist/assets/index-ChQZKkse.css +0 -1
- package/dist/assets/index-Cs-E_cyt.js +0 -2
- package/dist/assets/index-Cs-E_cyt.js.map +0 -1
- package/dist/assets/index-CsvxKrFP.js +0 -2
- package/dist/assets/index-CsvxKrFP.js.map +0 -1
- package/dist/assets/index-D2p3cWtM.css +0 -1
- package/dist/assets/index-DABL-KOd.js +0 -2
- package/dist/assets/index-DABL-KOd.js.map +0 -1
- package/dist/assets/index-DFVlBjXp.js +0 -2
- package/dist/assets/index-DFVlBjXp.js.map +0 -1
- package/dist/assets/index-DIlzTatU.js +0 -2
- package/dist/assets/index-DIlzTatU.js.map +0 -1
- package/dist/assets/index-DREZLSQi.js +0 -2
- package/dist/assets/index-DREZLSQi.js.map +0 -1
- package/dist/assets/index-DaSb9EV4.css +0 -1
- package/dist/assets/index-DclP3Kg-.js +0 -2
- package/dist/assets/index-DclP3Kg-.js.map +0 -1
- package/dist/assets/index-DlyJUJ0j.js +0 -2
- package/dist/assets/index-DlyJUJ0j.js.map +0 -1
- package/dist/assets/index-DnxF29eG.css +0 -1
- package/dist/assets/index-GC0X-O3Y.js +0 -2
- package/dist/assets/index-GC0X-O3Y.js.map +0 -1
- package/dist/assets/index-HzWmB96f.js +0 -2
- package/dist/assets/index-HzWmB96f.js.map +0 -1
- package/dist/assets/index-I0Y2y6h5.css +0 -1
- package/dist/assets/index-U2z5KAu0.js +0 -2
- package/dist/assets/index-U2z5KAu0.js.map +0 -1
- package/dist/assets/index-XNFQHmLL.css +0 -1
- package/dist/assets/index-dEAnfrhp.css +0 -1
- package/dist/assets/index-hhTdfxnD.css +0 -1
- package/dist/assets/index-legacy-B4IHsyj2.js +0 -42
- package/dist/assets/index-legacy-B4IHsyj2.js.map +0 -1
- package/dist/assets/index-legacy-BKxszgZW.js +0 -2
- package/dist/assets/index-legacy-BKxszgZW.js.map +0 -1
- package/dist/assets/index-legacy-BO3hAqA9.js +0 -2
- package/dist/assets/index-legacy-BO3hAqA9.js.map +0 -1
- package/dist/assets/index-legacy-BSXJnLod.js +0 -2
- package/dist/assets/index-legacy-BSXJnLod.js.map +0 -1
- package/dist/assets/index-legacy-BSv-V3Il.js +0 -2
- package/dist/assets/index-legacy-BSv-V3Il.js.map +0 -1
- package/dist/assets/index-legacy-CCqMKGqS.js +0 -2
- package/dist/assets/index-legacy-CCqMKGqS.js.map +0 -1
- package/dist/assets/index-legacy-CphqUnR0.js +0 -2
- package/dist/assets/index-legacy-CphqUnR0.js.map +0 -1
- package/dist/assets/index-legacy-D13WKbpb.js +0 -2
- package/dist/assets/index-legacy-D13WKbpb.js.map +0 -1
- package/dist/assets/index-legacy-D6IvG9Dt.js +0 -2
- package/dist/assets/index-legacy-D6IvG9Dt.js.map +0 -1
- package/dist/assets/index-legacy-DCezoU0z.js +0 -2
- package/dist/assets/index-legacy-DCezoU0z.js.map +0 -1
- package/dist/assets/index-legacy-DIwVyUHd.js +0 -2
- package/dist/assets/index-legacy-DIwVyUHd.js.map +0 -1
- package/dist/assets/index-legacy-DO2MADPO.js +0 -2
- package/dist/assets/index-legacy-DO2MADPO.js.map +0 -1
- package/dist/assets/index-legacy-DcFvM5kb.js +0 -2
- package/dist/assets/index-legacy-DcFvM5kb.js.map +0 -1
- package/dist/assets/index-legacy-Df_9F2Oo.js +0 -2
- package/dist/assets/index-legacy-Df_9F2Oo.js.map +0 -1
- package/dist/assets/index-legacy-Dhs-OKEx.js +0 -2
- package/dist/assets/index-legacy-Dhs-OKEx.js.map +0 -1
- package/dist/assets/index-legacy-DjWDlkzN.js +0 -2
- package/dist/assets/index-legacy-DjWDlkzN.js.map +0 -1
- package/dist/assets/index-legacy-DxQA53Qy.js +0 -2
- package/dist/assets/index-legacy-DxQA53Qy.js.map +0 -1
- package/dist/assets/index-legacy-GbLWntci.js +0 -2
- package/dist/assets/index-legacy-GbLWntci.js.map +0 -1
- package/dist/assets/index-legacy-I4qT4Thb.js +0 -2
- package/dist/assets/index-legacy-I4qT4Thb.js.map +0 -1
- package/dist/assets/index-legacy-quXi4jhF.js +0 -2
- package/dist/assets/index-legacy-quXi4jhF.js.map +0 -1
- package/dist/assets/index-tyMcidBi.js +0 -2
- package/dist/assets/index-tyMcidBi.js.map +0 -1
- package/dist/assets/index-ypHH_Z_A.css +0 -1
- package/dist/assets/isEqual-Cecwc716.js +0 -2
- package/dist/assets/isEqual-Cecwc716.js.map +0 -1
- package/dist/assets/isEqual-legacy-dqS7X02N.js +0 -2
- package/dist/assets/isEqual-legacy-dqS7X02N.js.map +0 -1
- package/dist/assets/other-legacy-DjiCmSH4.js +0 -2
- package/dist/assets/other-legacy-DjiCmSH4.js.map +0 -1
- package/dist/assets/other-yMAyytYx.js +0 -2
- package/dist/assets/other-yMAyytYx.js.map +0 -1
- package/dist/assets/polyfills-legacy-CPmsgIAF.js +0 -4
- package/dist/assets/refresh-BA55HwKz.js.map +0 -1
- package/dist/assets/refresh-legacy-CpA05Fzr.js.map +0 -1
- package/dist/assets/tip-CrU2GCmD.js +0 -2
- package/dist/assets/tip-CrU2GCmD.js.map +0 -1
- package/dist/assets/tip-legacy-B05oHh9-.js +0 -2
- package/dist/assets/tip-legacy-B05oHh9-.js.map +0 -1
- package/dist/assets/validator-Ca0QsRid.js +0 -2
- package/dist/assets/validator-Ca0QsRid.js.map +0 -1
- package/dist/assets/validator-legacy-D0GLFVMZ.js +0 -2
- package/dist/assets/validator-legacy-D0GLFVMZ.js.map +0 -1
- /package/dist/assets/{el-date-picker-NjWHL2Br.css → el-date-picker-C36c2CGO.css} +0 -0
- /package/dist/assets/{el-dropdown-item-CUgTpiu6.css → el-dropdown-item-5b6bMUQF.css} +0 -0
- /package/dist/assets/{el-loading-Uv12lkco.css → el-loading-BPl8mdQ3.css} +0 -0
- /package/dist/assets/{el-pagination-MvCAleW2.css → el-pagination-DMHBWKFj.css} +0 -0
- /package/dist/assets/{el-switch-D6dVIPlw.css → el-switch-CH9HekZJ.css} +0 -0
- /package/dist/assets/{el-tab-pane-kUw7IczA.css → el-tab-pane-CO1C5qCV.css} +0 -0
- /package/dist/assets/{el-table-column-DMXHP8sd.css → el-table-column-x3grTP_N.css} +0 -0
- /package/dist/assets/{tip-ovQu2XSt.css → tip-rRSL6nZ2.css} +0 -0
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index-DlyJUJ0j.js","sources":["../../node_modules/.pnpm/element-plus@2.2.13_vue@3.4.31_typescript@4.9.5_/node_modules/element-plus/es/components/card/src/card.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.4.31_typescript@4.9.5_/node_modules/element-plus/es/components/card/src/card2.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.4.31_typescript@4.9.5_/node_modules/element-plus/es/components/card/index.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.4.31_typescript@4.9.5_/node_modules/element-plus/es/components/input-number/src/input-number.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.4.31_typescript@4.9.5_/node_modules/element-plus/es/components/input-number/src/input-number2.mjs","../../node_modules/.pnpm/element-plus@2.2.13_vue@3.4.31_typescript@4.9.5_/node_modules/element-plus/es/components/input-number/index.mjs","../../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/circle-close-filled.mjs","../../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/circle-plus-filled.mjs","../../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/delete.mjs","../../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/edit.mjs","../../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/menu.mjs","../../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/plus.mjs","../../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/share.mjs","../../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/top.mjs","../../src/pages/dashboard/tasks/components/CategoryPanel.vue","../../src/pages/dashboard/tasks/components/CreateTask.vue","../../src/pages/dashboard/tasks/public.ts","../../src/pages/dashboard/tasks/components/infoPanel/ddl.vue","../../src/pages/dashboard/tasks/components/infoPanel/people.vue","../../src/pages/dashboard/tasks/components/infoPanel/template.vue","../../src/pages/dashboard/tasks/components/infoPanel/info.vue","../../src/pages/dashboard/tasks/components/infoPanel/tipInfo.vue","../../src/pages/dashboard/tasks/components/infoPanel/file.vue","../../src/pages/dashboard/tasks/index.vue"],"sourcesContent":["import '../../../utils/index.mjs';\nimport { buildProps, definePropType } from '../../../utils/vue/props/runtime.mjs';\n\nconst cardProps = buildProps({\n header: {\n type: String,\n default: \"\"\n },\n bodyStyle: {\n type: definePropType([String, Object, Array]),\n default: \"\"\n },\n shadow: {\n type: String,\n values: [\"always\", \"hover\", \"never\"],\n default: \"always\"\n }\n});\n\nexport { cardProps };\n//# sourceMappingURL=card.mjs.map\n","import { defineComponent, openBlock, createElementBlock, normalizeClass, unref, renderSlot, createTextVNode, toDisplayString, createCommentVNode, createElementVNode, normalizeStyle } from 'vue';\nimport '../../../hooks/index.mjs';\nimport { cardProps } from './card.mjs';\nimport _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';\nimport { useNamespace } from '../../../hooks/use-namespace/index.mjs';\n\nconst __default__ = {\n name: \"ElCard\"\n};\nconst _sfc_main = /* @__PURE__ */ defineComponent({\n ...__default__,\n props: cardProps,\n setup(__props) {\n const ns = useNamespace(\"card\");\n return (_ctx, _cache) => {\n return openBlock(), createElementBlock(\"div\", {\n class: normalizeClass([unref(ns).b(), unref(ns).is(`${_ctx.shadow}-shadow`)])\n }, [\n _ctx.$slots.header || _ctx.header ? (openBlock(), createElementBlock(\"div\", {\n key: 0,\n class: normalizeClass(unref(ns).e(\"header\"))\n }, [\n renderSlot(_ctx.$slots, \"header\", {}, () => [\n createTextVNode(toDisplayString(_ctx.header), 1)\n ])\n ], 2)) : createCommentVNode(\"v-if\", true),\n createElementVNode(\"div\", {\n class: normalizeClass(unref(ns).e(\"body\")),\n style: normalizeStyle(_ctx.bodyStyle)\n }, [\n renderSlot(_ctx.$slots, \"default\")\n ], 6)\n ], 2);\n };\n }\n});\nvar Card = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"__file\", \"/home/runner/work/element-plus/element-plus/packages/components/card/src/card.vue\"]]);\n\nexport { Card as default };\n//# sourceMappingURL=card2.mjs.map\n","import '../../utils/index.mjs';\nimport Card from './src/card2.mjs';\nexport { cardProps } from './src/card.mjs';\nimport { withInstall } from '../../utils/vue/install.mjs';\n\nconst ElCard = withInstall(Card);\n\nexport { ElCard, ElCard as default };\n//# sourceMappingURL=index.mjs.map\n","import { isNil } from 'lodash-unified';\nimport '../../../hooks/index.mjs';\nimport '../../../utils/index.mjs';\nimport '../../../constants/index.mjs';\nimport { buildProps } from '../../../utils/vue/props/runtime.mjs';\nimport { useSizeProp } from '../../../hooks/use-common-props/index.mjs';\nimport { isNumber } from '@vueuse/core';\nimport { CHANGE_EVENT, INPUT_EVENT, UPDATE_MODEL_EVENT } from '../../../constants/event.mjs';\n\nconst inputNumberProps = buildProps({\n id: {\n type: String,\n default: void 0\n },\n step: {\n type: Number,\n default: 1\n },\n stepStrictly: Boolean,\n max: {\n type: Number,\n default: Number.POSITIVE_INFINITY\n },\n min: {\n type: Number,\n default: Number.NEGATIVE_INFINITY\n },\n modelValue: Number,\n disabled: Boolean,\n size: useSizeProp,\n controls: {\n type: Boolean,\n default: true\n },\n controlsPosition: {\n type: String,\n default: \"\",\n values: [\"\", \"right\"]\n },\n valueOnClear: {\n type: [String, Number, null],\n validator: (val) => val === null || isNumber(val) || [\"min\", \"max\"].includes(val),\n default: null\n },\n name: String,\n label: String,\n placeholder: String,\n precision: {\n type: Number,\n validator: (val) => val >= 0 && val === Number.parseInt(`${val}`, 10)\n },\n validateEvent: {\n type: Boolean,\n default: true\n }\n});\nconst inputNumberEmits = {\n [CHANGE_EVENT]: (prev, cur) => prev !== cur,\n blur: (e) => e instanceof FocusEvent,\n focus: (e) => e instanceof FocusEvent,\n [INPUT_EVENT]: (val) => isNumber(val) || isNil(val),\n [UPDATE_MODEL_EVENT]: (val) => isNumber(val) || isNil(val)\n};\n\nexport { inputNumberEmits, inputNumberProps };\n//# sourceMappingURL=input-number.mjs.map\n","import { defineComponent, ref, reactive, computed, watch, onMounted, onUpdated, openBlock, createElementBlock, normalizeClass, unref, withModifiers, withDirectives, withKeys, createVNode, withCtx, createBlock, createCommentVNode } from 'vue';\nimport { isNil } from 'lodash-unified';\nimport { ElInput } from '../../input/index.mjs';\nimport { ElIcon } from '../../icon/index.mjs';\nimport '../../../directives/index.mjs';\nimport '../../../hooks/index.mjs';\nimport '../../../utils/index.mjs';\nimport { ArrowDown, Minus, ArrowUp, Plus } from '@element-plus/icons-vue';\nimport { inputNumberProps, inputNumberEmits } from './input-number.mjs';\nimport _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';\nimport { useLocale } from '../../../hooks/use-locale/index.mjs';\nimport { useNamespace } from '../../../hooks/use-namespace/index.mjs';\nimport { useFormItem } from '../../../hooks/use-form-item/index.mjs';\nimport { isNumber } from '@vueuse/core';\nimport { isUndefined } from '../../../utils/types.mjs';\nimport { debugWarn } from '../../../utils/error.mjs';\nimport { useSize, useDisabled } from '../../../hooks/use-common-props/index.mjs';\nimport { isString } from '@vue/shared';\nimport RepeatClick from '../../../directives/repeat-click/index.mjs';\n\nconst _hoisted_1 = [\"aria-label\", \"onKeydown\"];\nconst _hoisted_2 = [\"aria-label\", \"onKeydown\"];\nconst __default__ = {\n name: \"ElInputNumber\"\n};\nconst _sfc_main = /* @__PURE__ */ defineComponent({\n ...__default__,\n props: inputNumberProps,\n emits: inputNumberEmits,\n setup(__props, { expose, emit }) {\n const props = __props;\n const { t } = useLocale();\n const ns = useNamespace(\"input-number\");\n const input = ref();\n const data = reactive({\n currentValue: props.modelValue,\n userInput: null\n });\n const { formItem } = useFormItem();\n const minDisabled = computed(() => isNumber(props.modelValue) && ensurePrecision(props.modelValue, -1) < props.min);\n const maxDisabled = computed(() => isNumber(props.modelValue) && ensurePrecision(props.modelValue) > props.max);\n const numPrecision = computed(() => {\n const stepPrecision = getPrecision(props.step);\n if (!isUndefined(props.precision)) {\n if (stepPrecision > props.precision) {\n debugWarn(\"InputNumber\", \"precision should not be less than the decimal places of step\");\n }\n return props.precision;\n } else {\n return Math.max(getPrecision(props.modelValue), stepPrecision);\n }\n });\n const controlsAtRight = computed(() => {\n return props.controls && props.controlsPosition === \"right\";\n });\n const inputNumberSize = useSize();\n const inputNumberDisabled = useDisabled();\n const displayValue = computed(() => {\n if (data.userInput !== null) {\n return data.userInput;\n }\n let currentValue = data.currentValue;\n if (isNil(currentValue))\n return \"\";\n if (isNumber(currentValue)) {\n if (Number.isNaN(currentValue))\n return \"\";\n if (!isUndefined(props.precision)) {\n currentValue = currentValue.toFixed(props.precision);\n }\n }\n return currentValue;\n });\n const toPrecision = (num, pre) => {\n if (isUndefined(pre))\n pre = numPrecision.value;\n if (pre === 0)\n return Math.round(num);\n let snum = String(num);\n const pointPos = snum.indexOf(\".\");\n if (pointPos === -1)\n return num;\n const nums = snum.replace(\".\", \"\").split(\"\");\n const datum = nums[pointPos + pre];\n if (!datum)\n return num;\n const length = snum.length;\n if (snum.charAt(length - 1) === \"5\") {\n snum = `${snum.slice(0, Math.max(0, length - 1))}6`;\n }\n return Number.parseFloat(Number(snum).toFixed(pre));\n };\n const getPrecision = (value) => {\n if (isNil(value))\n return 0;\n const valueString = value.toString();\n const dotPosition = valueString.indexOf(\".\");\n let precision = 0;\n if (dotPosition !== -1) {\n precision = valueString.length - dotPosition - 1;\n }\n return precision;\n };\n const ensurePrecision = (val, coefficient = 1) => {\n if (!isNumber(val))\n return data.currentValue;\n return toPrecision(val + props.step * coefficient);\n };\n const increase = () => {\n if (inputNumberDisabled.value || maxDisabled.value)\n return;\n const value = props.modelValue || 0;\n const newVal = ensurePrecision(value);\n setCurrentValue(newVal);\n };\n const decrease = () => {\n if (inputNumberDisabled.value || minDisabled.value)\n return;\n const value = props.modelValue || 0;\n const newVal = ensurePrecision(value, -1);\n setCurrentValue(newVal);\n };\n const verifyValue = (value, update) => {\n const { max, min, step, precision, stepStrictly, valueOnClear } = props;\n let newVal = Number(value);\n if (isNil(value) || Number.isNaN(newVal)) {\n return null;\n }\n if (value === \"\") {\n if (valueOnClear === null) {\n return null;\n }\n newVal = isString(valueOnClear) ? { min, max }[valueOnClear] : valueOnClear;\n }\n if (stepStrictly) {\n newVal = toPrecision(Math.round(newVal / step) * step, precision);\n }\n if (!isUndefined(precision)) {\n newVal = toPrecision(newVal, precision);\n }\n if (newVal > max || newVal < min) {\n newVal = newVal > max ? max : min;\n update && emit(\"update:modelValue\", newVal);\n }\n return newVal;\n };\n const setCurrentValue = (value) => {\n var _a;\n const oldVal = data.currentValue;\n const newVal = verifyValue(value);\n if (oldVal === newVal)\n return;\n data.userInput = null;\n emit(\"update:modelValue\", newVal);\n emit(\"input\", newVal);\n emit(\"change\", newVal, oldVal);\n if (props.validateEvent) {\n (_a = formItem == null ? void 0 : formItem.validate) == null ? void 0 : _a.call(formItem, \"change\").catch((err) => debugWarn(err));\n }\n data.currentValue = newVal;\n };\n const handleInput = (value) => {\n return data.userInput = value;\n };\n const handleInputChange = (value) => {\n const newVal = value !== \"\" ? Number(value) : \"\";\n if (isNumber(newVal) && !Number.isNaN(newVal) || value === \"\") {\n setCurrentValue(newVal);\n }\n data.userInput = null;\n };\n const focus = () => {\n var _a, _b;\n (_b = (_a = input.value) == null ? void 0 : _a.focus) == null ? void 0 : _b.call(_a);\n };\n const blur = () => {\n var _a, _b;\n (_b = (_a = input.value) == null ? void 0 : _a.blur) == null ? void 0 : _b.call(_a);\n };\n const handleFocus = (event) => {\n emit(\"focus\", event);\n };\n const handleBlur = (event) => {\n var _a;\n emit(\"blur\", event);\n if (props.validateEvent) {\n (_a = formItem == null ? void 0 : formItem.validate) == null ? void 0 : _a.call(formItem, \"blur\").catch((err) => debugWarn(err));\n }\n };\n watch(() => props.modelValue, (value) => {\n data.currentValue = verifyValue(value, true);\n data.userInput = null;\n }, { immediate: true });\n onMounted(() => {\n var _a;\n const { min, max, modelValue } = props;\n const innerInput = (_a = input.value) == null ? void 0 : _a.input;\n innerInput.setAttribute(\"role\", \"spinbutton\");\n if (Number.isFinite(max)) {\n innerInput.setAttribute(\"aria-valuemax\", String(max));\n } else {\n innerInput.removeAttribute(\"aria-valuemax\");\n }\n if (Number.isFinite(min)) {\n innerInput.setAttribute(\"aria-valuemin\", String(min));\n } else {\n innerInput.removeAttribute(\"aria-valuemin\");\n }\n innerInput.setAttribute(\"aria-valuenow\", String(data.currentValue));\n innerInput.setAttribute(\"aria-disabled\", String(inputNumberDisabled.value));\n if (!isNumber(modelValue) && modelValue != null) {\n let val = Number(modelValue);\n if (Number.isNaN(val)) {\n val = null;\n }\n emit(\"update:modelValue\", val);\n }\n });\n onUpdated(() => {\n var _a;\n const innerInput = (_a = input.value) == null ? void 0 : _a.input;\n innerInput == null ? void 0 : innerInput.setAttribute(\"aria-valuenow\", `${data.currentValue}`);\n });\n expose({\n focus,\n blur\n });\n return (_ctx, _cache) => {\n return openBlock(), createElementBlock(\"div\", {\n class: normalizeClass([\n unref(ns).b(),\n unref(ns).m(unref(inputNumberSize)),\n unref(ns).is(\"disabled\", unref(inputNumberDisabled)),\n unref(ns).is(\"without-controls\", !_ctx.controls),\n unref(ns).is(\"controls-right\", unref(controlsAtRight))\n ]),\n onDragstart: _cache[0] || (_cache[0] = withModifiers(() => {\n }, [\"prevent\"]))\n }, [\n _ctx.controls ? withDirectives((openBlock(), createElementBlock(\"span\", {\n key: 0,\n role: \"button\",\n \"aria-label\": unref(t)(\"el.inputNumber.decrease\"),\n class: normalizeClass([unref(ns).e(\"decrease\"), unref(ns).is(\"disabled\", unref(minDisabled))]),\n onKeydown: withKeys(decrease, [\"enter\"])\n }, [\n createVNode(unref(ElIcon), null, {\n default: withCtx(() => [\n unref(controlsAtRight) ? (openBlock(), createBlock(unref(ArrowDown), { key: 0 })) : (openBlock(), createBlock(unref(Minus), { key: 1 }))\n ]),\n _: 1\n })\n ], 42, _hoisted_1)), [\n [unref(RepeatClick), decrease]\n ]) : createCommentVNode(\"v-if\", true),\n _ctx.controls ? withDirectives((openBlock(), createElementBlock(\"span\", {\n key: 1,\n role: \"button\",\n \"aria-label\": unref(t)(\"el.inputNumber.increase\"),\n class: normalizeClass([unref(ns).e(\"increase\"), unref(ns).is(\"disabled\", unref(maxDisabled))]),\n onKeydown: withKeys(increase, [\"enter\"])\n }, [\n createVNode(unref(ElIcon), null, {\n default: withCtx(() => [\n unref(controlsAtRight) ? (openBlock(), createBlock(unref(ArrowUp), { key: 0 })) : (openBlock(), createBlock(unref(Plus), { key: 1 }))\n ]),\n _: 1\n })\n ], 42, _hoisted_2)), [\n [unref(RepeatClick), increase]\n ]) : createCommentVNode(\"v-if\", true),\n createVNode(unref(ElInput), {\n id: _ctx.id,\n ref_key: \"input\",\n ref: input,\n type: \"number\",\n step: _ctx.step,\n \"model-value\": unref(displayValue),\n placeholder: _ctx.placeholder,\n disabled: unref(inputNumberDisabled),\n size: unref(inputNumberSize),\n max: _ctx.max,\n min: _ctx.min,\n name: _ctx.name,\n label: _ctx.label,\n \"validate-event\": false,\n onKeydown: [\n withKeys(withModifiers(increase, [\"prevent\"]), [\"up\"]),\n withKeys(withModifiers(decrease, [\"prevent\"]), [\"down\"])\n ],\n onBlur: handleBlur,\n onFocus: handleFocus,\n onInput: handleInput,\n onChange: handleInputChange\n }, null, 8, [\"id\", \"step\", \"model-value\", \"placeholder\", \"disabled\", \"size\", \"max\", \"min\", \"name\", \"label\", \"onKeydown\"])\n ], 34);\n };\n }\n});\nvar InputNumber = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"__file\", \"/home/runner/work/element-plus/element-plus/packages/components/input-number/src/input-number.vue\"]]);\n\nexport { InputNumber as default };\n//# sourceMappingURL=input-number2.mjs.map\n","import '../../utils/index.mjs';\nimport InputNumber from './src/input-number2.mjs';\nexport { inputNumberEmits, inputNumberProps } from './src/input-number.mjs';\nimport { withInstall } from '../../utils/vue/install.mjs';\n\nconst ElInputNumber = withInstall(InputNumber);\n\nexport { ElInputNumber, ElInputNumber as default };\n//# sourceMappingURL=index.mjs.map\n","import { defineComponent, openBlock, createElementBlock, createElementVNode } from 'vue';\nimport _export_sfc from './_virtual/plugin-vue_export-helper.mjs';\n\nconst _sfc_main = defineComponent({\n name: \"CircleCloseFilled\"\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: \"M512 64a448 448 0 1 1 0 896 448 448 0 0 1 0-896zm0 393.664L407.936 353.6a38.4 38.4 0 1 0-54.336 54.336L457.664 512 353.6 616.064a38.4 38.4 0 1 0 54.336 54.336L512 566.336 616.064 670.4a38.4 38.4 0 1 0 54.336-54.336L566.336 512 670.4 407.936a38.4 38.4 0 1 0-54.336-54.336L512 457.664z\"\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 circleCloseFilled = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"render\", _sfc_render]]);\n\nexport { circleCloseFilled as default };\n","import { defineComponent, openBlock, createElementBlock, createElementVNode } from 'vue';\nimport _export_sfc from './_virtual/plugin-vue_export-helper.mjs';\n\nconst _sfc_main = defineComponent({\n name: \"CirclePlusFilled\"\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: \"M512 64a448 448 0 1 1 0 896 448 448 0 0 1 0-896zm-38.4 409.6H326.4a38.4 38.4 0 1 0 0 76.8h147.2v147.2a38.4 38.4 0 0 0 76.8 0V550.4h147.2a38.4 38.4 0 0 0 0-76.8H550.4V326.4a38.4 38.4 0 1 0-76.8 0v147.2z\"\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 circlePlusFilled = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"render\", _sfc_render]]);\n\nexport { circlePlusFilled as default };\n","import { defineComponent, openBlock, createElementBlock, createElementVNode } from 'vue';\nimport _export_sfc from './_virtual/plugin-vue_export-helper.mjs';\n\nconst _sfc_main = defineComponent({\n name: \"Delete\"\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: \"M160 256H96a32 32 0 0 1 0-64h256V95.936a32 32 0 0 1 32-32h256a32 32 0 0 1 32 32V192h256a32 32 0 1 1 0 64h-64v672a32 32 0 0 1-32 32H192a32 32 0 0 1-32-32V256zm448-64v-64H416v64h192zM224 896h576V256H224v640zm192-128a32 32 0 0 1-32-32V416a32 32 0 0 1 64 0v320a32 32 0 0 1-32 32zm192 0a32 32 0 0 1-32-32V416a32 32 0 0 1 64 0v320a32 32 0 0 1-32 32z\"\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 _delete = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"render\", _sfc_render]]);\n\nexport { _delete as default };\n","import { defineComponent, openBlock, createElementBlock, createElementVNode } from 'vue';\nimport _export_sfc from './_virtual/plugin-vue_export-helper.mjs';\n\nconst _sfc_main = defineComponent({\n name: \"Edit\"\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: \"M832 512a32 32 0 1 1 64 0v352a32 32 0 0 1-32 32H160a32 32 0 0 1-32-32V160a32 32 0 0 1 32-32h352a32 32 0 0 1 0 64H192v640h640V512z\"\n}, null, -1);\nconst _hoisted_3 = /* @__PURE__ */ createElementVNode(\"path\", {\n fill: \"currentColor\",\n d: \"m469.952 554.24 52.8-7.552L847.104 222.4a32 32 0 1 0-45.248-45.248L477.44 501.44l-7.552 52.8zm422.4-422.4a96 96 0 0 1 0 135.808l-331.84 331.84a32 32 0 0 1-18.112 9.088L436.8 623.68a32 32 0 0 1-36.224-36.224l15.104-105.6a32 32 0 0 1 9.024-18.112l331.904-331.84a96 96 0 0 1 135.744 0z\"\n}, null, -1);\nconst _hoisted_4 = [\n _hoisted_2,\n _hoisted_3\n];\nfunction _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {\n return openBlock(), createElementBlock(\"svg\", _hoisted_1, _hoisted_4);\n}\nvar edit = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"render\", _sfc_render]]);\n\nexport { edit as default };\n","import { defineComponent, openBlock, createElementBlock, createElementVNode } from 'vue';\nimport _export_sfc from './_virtual/plugin-vue_export-helper.mjs';\n\nconst _sfc_main = defineComponent({\n name: \"Menu\"\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: \"M160 448a32 32 0 0 1-32-32V160.064a32 32 0 0 1 32-32h256a32 32 0 0 1 32 32V416a32 32 0 0 1-32 32H160zm448 0a32 32 0 0 1-32-32V160.064a32 32 0 0 1 32-32h255.936a32 32 0 0 1 32 32V416a32 32 0 0 1-32 32H608zM160 896a32 32 0 0 1-32-32V608a32 32 0 0 1 32-32h256a32 32 0 0 1 32 32v256a32 32 0 0 1-32 32H160zm448 0a32 32 0 0 1-32-32V608a32 32 0 0 1 32-32h255.936a32 32 0 0 1 32 32v256a32 32 0 0 1-32 32H608z\"\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 menu = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"render\", _sfc_render]]);\n\nexport { menu as default };\n","import { defineComponent, openBlock, createElementBlock, createElementVNode } from 'vue';\nimport _export_sfc from './_virtual/plugin-vue_export-helper.mjs';\n\nconst _sfc_main = defineComponent({\n name: \"Plus\"\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: \"M480 480V128a32 32 0 0 1 64 0v352h352a32 32 0 1 1 0 64H544v352a32 32 0 1 1-64 0V544H128a32 32 0 0 1 0-64h352z\"\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 plus = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"render\", _sfc_render]]);\n\nexport { plus as default };\n","import { defineComponent, openBlock, createElementBlock, createElementVNode } from 'vue';\nimport _export_sfc from './_virtual/plugin-vue_export-helper.mjs';\n\nconst _sfc_main = defineComponent({\n name: \"Share\"\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: \"m679.872 348.8-301.76 188.608a127.808 127.808 0 0 1 5.12 52.16l279.936 104.96a128 128 0 1 1-22.464 59.904l-279.872-104.96a128 128 0 1 1-16.64-166.272l301.696-188.608a128 128 0 1 1 33.92 54.272z\"\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 share = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"render\", _sfc_render]]);\n\nexport { share as default };\n","import { defineComponent, openBlock, createElementBlock, createElementVNode } from 'vue';\nimport _export_sfc from './_virtual/plugin-vue_export-helper.mjs';\n\nconst _sfc_main = defineComponent({\n name: \"Top\"\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: \"M572.235 205.282v600.365a30.118 30.118 0 1 1-60.235 0V205.282L292.382 438.633a28.913 28.913 0 0 1-42.646 0 33.43 33.43 0 0 1 0-45.236l271.058-288.045a28.913 28.913 0 0 1 42.647 0L834.5 393.397a33.43 33.43 0 0 1 0 45.176 28.913 28.913 0 0 1-42.647 0l-219.618-233.23z\"\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 top = /* @__PURE__ */ _export_sfc(_sfc_main, [[\"render\", _sfc_render]]);\n\nexport { top as default };\n","<template>\n <!-- 分类管理 -->\n <div class=\"panel\">\n <!-- 按钮 -->\n <div class=\"btn-area\">\n <h5>分类列表</h5>\n <h6 style=\"font-weight: lighter\">(点击分类可筛选任务)</h6>\n </div>\n <!-- 分类列表 -->\n <div style=\"margin-top: 15px\" class=\"category-list\">\n <div class=\"new-tag-wrap\">\n <!-- 新分类 -->\n <el-input\n class=\"input-new-tag el-tag\"\n v-if=\"isShowCreateCategory\"\n v-model=\"categoryName\"\n ref=\"saveTagInput\"\n placeholder=\"分类名称\"\n @keyup.enter=\"addCategory\"\n @focusout=\"addCategory\"\n ></el-input>\n <el-button\n v-else\n class=\"button-new-tag el-tag\"\n size=\"small\"\n @click=\"isShowCreateCategory = true\"\n >+ New 分类</el-button\n >\n <el-tag\n :effect=\"category === 'default' ? 'dark' : 'plain'\"\n @click=\"handleClickCategory('default')\"\n >默认{{ taskCount('default') }}</el-tag\n >\n <span class=\"list-tip\"\n ><el-tag\n type=\"danger\"\n :effect=\"category === 'trash' ? 'dark' : 'plain'\"\n @click=\"handleClickCategory('trash')\"\n ><el-icon><DeleteFilled /></el-icon> 回收站{{\n taskCount('trash')\n }}</el-tag\n ></span\n >\n </div>\n <div class=\"tag-wrap\">\n <div class=\"tag-list\">\n <el-tag\n v-for=\"tag in categorys\"\n :key=\"tag.k\"\n closable\n :effect=\"category === tag.k ? 'dark' : 'plain'\"\n @close=\"handleDeleteCategory(tag)\"\n @click=\"handleClickCategory(tag.k)\"\n >{{ tag.name }}{{ taskCount(tag.k) }}</el-tag\n >\n </div>\n </div>\n </div>\n </div>\n</template>\n<script lang=\"ts\">\nimport { ElMessage, ElMessageBox } from 'element-plus'\nimport { computed, defineComponent, ref } from 'vue'\nimport { DeleteFilled } from '@element-plus/icons-vue'\nimport { useStore } from 'vuex'\n\nexport default defineComponent({\n name: 'categoryPanel',\n components: {\n DeleteFilled\n },\n props: {\n category: {\n type: String,\n required: true,\n default: 'default'\n }\n },\n setup(props, context) {\n const $store = useStore()\n // 分类相关\n const categorys = computed(() => $store.state.category.categoryList)\n const tasks = computed(() => $store.state.task.taskList)\n const taskCount = (c: string) => {\n const count = tasks.value.filter((t: any) => t.category === c).length\n return count === 0 ? '' : ` (${count})`\n }\n const isShowCreateCategory = ref(false)\n const categoryName = ref('')\n const addCategory = () => {\n isShowCreateCategory.value = false\n if (!categoryName.value.trim()) {\n // ElMessage.warning('不能为空')\n return\n }\n $store\n .dispatch('category/createCategory', categoryName.value)\n .then(() => {\n ElMessage.success('创建成功')\n })\n .catch((err) => {\n if (err.code === 2001) {\n ElMessage.warning('分类名称已存在')\n }\n })\n categoryName.value = ''\n }\n\n const handleClickCategory = (k: string) => {\n context.emit('update:category', k)\n }\n\n const handleDeleteCategory = (c: any) => {\n ElMessageBox.confirm('是否删除', '提示', {\n confirmButtonText: '确定',\n cancelButtonText: '取消'\n })\n .then(() => {\n $store.dispatch('category/deleteCategory', c.k).then(() => {\n // 删除后变动的默认选择\n handleClickCategory('default')\n ElMessage.success('删除成功')\n // 获取最新的任务\n $store.dispatch('task/getTask')\n })\n })\n .catch(() => {\n ElMessage.info('取消删除')\n })\n }\n\n return {\n categorys,\n isShowCreateCategory,\n categoryName,\n addCategory,\n handleDeleteCategory,\n handleClickCategory,\n taskCount\n }\n }\n})\n</script>\n<style scoped lang=\"scss\">\n.el-tag {\n margin-left: 10px;\n margin-bottom: 10px;\n cursor: pointer;\n}\n.new-tag-wrap {\n display: flex;\n align-items: center;\n}\n.button-new-tag {\n margin-left: 10px;\n height: 32px;\n line-height: 30px;\n padding-top: 0;\n padding-bottom: 0;\n}\n.input-new-tag {\n width: 120px;\n padding: 0;\n margin-left: 10px;\n margin-bottom: 10px;\n vertical-align: bottom;\n}\n.panel {\n padding: 1em;\n background-color: #fff;\n margin: 10px auto;\n box-sizing: border-box;\n box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);\n border-radius: 4px;\n}\n.btn-area {\n display: flex;\n justify-content: center;\n}\n.list-tip {\n // color: #67c23a;\n // font-size: 10px;\n margin-right: 10px;\n flex: 1;\n text-align: right;\n}\n.tag-wrap {\n width: 100%;\n height: 150px;\n}\n.tag-list {\n height: 150px;\n overflow-x: hidden;\n overflow-y: scroll;\n display: flex;\n flex-wrap: wrap;\n :deep(.el-tag) {\n width: 140px;\n }\n :deep(.el-tag__content) {\n width: 100px;\n text-align: center;\n text-overflow: ellipsis;\n word-break: keep-all;\n overflow: hidden;\n }\n}\n</style>\n","<template>\n <div>\n <div class=\"btn-area\">\n <el-button size=\"large\" type=\"primary\" :plain=\"!isShowCreateTask\" @click=\"\n isShowCreateTask =\n !isShowCreateTask\n \">\n {{\n isShowCreateTask\n ? '关闭创建面板'\n : '创建收集任务'\n }}\n </el-button>\n </div>\n <!-- 新增区域 -->\n <div v-show=\"isShowCreateTask\">\n <div class=\"input-container\">\n <el-input placeholder=\"请输入任务名称(上述列表选择分类)\" v-model=\"taskName\"></el-input>\n <el-button @click=\"createTask\" :type=\"taskName?.length ? 'success' : 'default'\">确定</el-button>\n </div>\n </div>\n <tip class=\"p10\">\n 点击\n <el-icon>\n <Menu />\n </el-icon> 可以进一步的调整任务\n </tip>\n <tip>\n 设置截止时间,自动重命名,名单限制,批注,文件模板。。🚀\n </tip>\n </div>\n</template>\n<script lang=\"ts\" setup>\nimport { ElMessage } from 'element-plus'\nimport {\n computed,\n ref,\n} from 'vue'\nimport { useStore } from 'vuex'\nimport { Menu } from '@element-plus/icons-vue'\nimport Tip from './infoPanel/tip.vue'\n\nconst props = defineProps({\n activeCategoryKey: {\n type: String,\n default: 'default',\n },\n})\nconst $store = useStore()\nconst categorys = computed(() => $store.state.category\n .categoryList)\nconst categoryName = computed(() => {\n if (props.activeCategoryKey\n === 'default') {\n return '默认'\n }\n return categorys.value.find((v: any) => v.k\n === props.activeCategoryKey).name\n})\n// 任务相关\nconst isShowCreateTask = ref(false)\nconst taskName = ref('')\nconst createTask = () => {\n if (!taskName.value.trim()) {\n ElMessage.warning('不能为空')\n return\n }\n $store\n .dispatch('task/createTask', {\n name: taskName.value,\n category: props.activeCategoryKey,\n })\n .then(() => {\n ElMessage.success('创建成功')\n })\n taskName.value = ''\n}\n\n</script>\n<style scoped>\n.btn-area {\n display: flex;\n justify-content: center;\n}\n\n.input-container {\n margin: 15px auto;\n max-width: 600px;\n background-color: #fff;\n display: flex;\n justify-content: space-around;\n}\n</style>\n","import { ElMessage } from 'element-plus'\nimport { TaskApi } from '@/apis'\nimport { debounce } from '@/utils/other'\n\nexport const updateTaskInfo: (\n key: string,\n options: TaskApiTypes.TaskInfo,\n successInfo?: boolean\n) => void = debounce(\n (key, options, successInfo = true) => {\n if (key) {\n TaskApi.updateTaskMoreInfo(key, options)\n .then(() => {\n if (successInfo) {\n ElMessage.success({\n message: '设置成功',\n zIndex: 4000,\n duration: 1000\n })\n }\n })\n .catch(() => {\n ElMessage.error({\n message: '设置失败',\n zIndex: 4000\n })\n })\n }\n },\n 1000,\n true\n)\n","<template>\n <div class=\"tc ddl\">\n <tip\n :imgs=\"[\n 'https://img.cdn.sugarat.top/mdImg/MTY0OTE0OTI4NjU5Nw==649149286597',\n 'https://img.cdn.sugarat.top/mdImg/MTY0OTE0OTMxMDEyOQ==649149310129',\n 'https://img.cdn.sugarat.top/mdImg/MTY0OTE0OTM3MzgxOA==649149373818'\n ]\"\n >设置截止日期,截止后将不能再提交文件。</tip\n >\n <div class=\"tc flex fc fac\">\n <el-date-picker\n :editable=\"false\"\n v-model=\"newDate\"\n type=\"datetime\"\n placeholder=\"点击设置新截止日期\"\n @change=\"updateDDL\"\n :default-time=\"new Date(ddl)\"\n ></el-date-picker>\n <el-button v-if=\"newDate\" @click=\"closeDDL\">取消</el-button>\n </div>\n <div style=\"margin-top: 10px\" v-if=\"newDate\">\n <tip>{{ isOver ? '已经截止' : `剩余时间: ${waitTimeStr}` }} </tip>\n </div>\n </div>\n</template>\n<script lang=\"ts\" setup>\nimport { computed, onMounted, ref, watchEffect } from 'vue'\nimport { formatDate } from '@/utils/stringUtil'\nimport { updateTaskInfo } from '../../public'\nimport Tip from './tip.vue'\n\nconst props = defineProps({\n ddl: {\n type: String,\n default: '',\n required: false\n },\n k: {\n type: String,\n default: ''\n }\n})\n\nconst newDate = ref()\nwatchEffect(() => {\n if (props.ddl) {\n newDate.value = new Date(props.ddl)\n } else {\n newDate.value = null\n }\n})\n// 更新DDL\nconst updateDDL = () => {\n if (newDate.value) {\n const ddl = formatDate(\n new Date(newDate.value.getTime() - 1000 * 60 * 60 * 8)\n )\n updateTaskInfo(props.k, { ddl })\n }\n}\n// 关闭DDL\nconst closeDDL = () => {\n newDate.value = null\n updateTaskInfo(props.k, { ddl: null })\n}\n\nconst waitTime = ref(0)\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})\n\nconst refreshWaitTime = (loop = true) => {\n if (newDate.value) {\n waitTime.value = newDate.value.getTime() - Date.now()\n } else {\n waitTime.value = 0\n }\n if (loop) {\n setTimeout(() => {\n refreshWaitTime()\n }, 1000)\n }\n}\n\nonMounted(() => {\n refreshWaitTime()\n})\n</script>\n","<script lang=\"ts\" setup>\nimport type { UploadUserFile } from 'element-plus'\nimport { ElMessage, ElMessageBox } from 'element-plus'\nimport { computed, reactive, ref, watch, watchEffect } from 'vue'\nimport { useStore } from 'vuex'\nimport { updateTaskInfo } from '../../public'\nimport Tip from './tip.vue'\nimport { PeopleApi, TaskApi } from '@/apis'\nimport { tableToExcel, uploadFile } from '@/utils/networkUtil'\nimport { formatDate } from '@/utils/stringUtil'\nimport { useIsMobile } from '@/composables'\n\nconst props = defineProps({\n value: {\n type: Number,\n defalut: 0,\n },\n k: {\n type: String,\n default: '',\n },\n name: {\n type: String,\n default: '',\n },\n field: {\n type: String,\n default: '姓名',\n },\n})\n\nconst activeTab = ref('手动添加')\nconst userInputName = ref('')\nconst importStatus = ref(false)\n\nfunction handAddName() {\n if (!userInputName.value) {\n return\n }\n importStatus.value = true\n PeopleApi.addPeopleByUser(userInputName.value, props.k)\n .then(() => {\n ElMessage.success(`添加 ${userInputName.value} 成功`)\n })\n .catch(() => {\n ElMessage.error(`${userInputName.value} 已存在`)\n })\n .finally(() => {\n importStatus.value = false\n userInputName.value = ''\n })\n}\nconst checkMore = ref(false)\n\nconst people = ref(0)\nwatchEffect(() => {\n people.value = props.value as number\n})\n// 限制提交人员\nfunction updateLimitPeople(limit: boolean) {\n updateTaskInfo(props.k, {\n people: +limit,\n })\n people.value = +limit\n}\n\n// 查看提交情况\nconst showPeopleList = ref(false)\nconst peopleList: any = reactive([])\nconst selectSubmitStatus = ref('all')\nconst searchName = ref('')\nconst filterPeopleBySearchWord = computed(() => {\n if (!searchName.value) {\n return peopleList\n }\n return peopleList.filter(v => v.name.includes(searchName.value))\n})\nconst peopleSubmitData = computed(() => {\n if (selectSubmitStatus.value === 'all') {\n return filterPeopleBySearchWord.value\n }\n return filterPeopleBySearchWord.value.filter(\n p => p.status === selectSubmitStatus.value,\n )\n})\nconst isLoadingPeopleData = ref(false)\nfunction refreshSubmitData() {\n isLoadingPeopleData.value = true\n PeopleApi.getPeople(props.k, `${+checkMore.value}`).then((res) => {\n peopleList.splice(0, peopleList.length)\n peopleList.push(...res.data.people)\n peopleList.forEach((p) => {\n if (!p.status && p.count === 0) {\n p.lastDate = '暂无记录'\n }\n else {\n p.lastDate = formatDate(new Date(p.lastDate), 'yyyy-MM-dd hh:mm:ss')\n }\n })\n isLoadingPeopleData.value = false\n })\n}\nfunction handleCheckMore() {\n checkMore.value = !checkMore.value\n if (checkMore.value) {\n refreshSubmitData()\n }\n}\nfunction checkPeople() {\n showPeopleList.value = true\n // 默认不展示提交数量\n checkMore.value = false\n refreshSubmitData()\n}\nfunction handleDeletePeople(item: any) {\n ElMessageBox.confirm('确认删除此人员吗', '数据无价,请谨慎操作')\n .then(() => {\n PeopleApi.deletePeople(props.k, item.id).then(() => {\n ElMessage.success('删除成功')\n peopleList.splice(\n peopleList.findIndex(v => v.id === item.id),\n 1,\n )\n })\n })\n .catch(() => {\n ElMessage.info('取消删除')\n })\n}\n// 文件上传\nconst peopleFileList = ref<UploadUserFile[]>([])\nconst peopleUpload = ref()\n// 超出选择的文件个数\nfunction handleExceedFile() {\n ElMessage.error('只能选择一个文件,可删除后重新选择')\n}\n// 清空文件\nfunction clearFiles() {\n peopleFileList.value.splice(0, peopleFileList.value.length)\n peopleUpload.value.clearFiles()\n}\n// 开始上传\nfunction submitUploadPeople() {\n peopleFileList.value.forEach((file) => {\n uploadFile(\n file.raw,\n `${import.meta.env.VITE_APP_AXIOS_BASE_URL}public/upload`,\n {\n success: (e: any) => {\n const { name, type } = e.data\n PeopleApi.importPeople(props.k, name, type).then((res) => {\n const { success, fail } = res.data\n ElMessage.success(`导入完成:${success}成功,${fail.length}失败`)\n if (fail.length > 0) {\n setTimeout(() => {\n ElMessage.info('自动开始下载未成功导入名单')\n tableToExcel(\n ['未成功导入名单'],\n fail.map((v: string) => [v]),\n `${props.name}_导入失败名单_${formatDate(\n new Date(),\n 'yyyy年MM月日hh时mm分ss秒',\n )}.xlsx`,\n )\n }, 1000)\n }\n clearFiles()\n })\n },\n },\n )\n })\n}\n// 添加文件\nfunction handleChangeFile(file: any) {\n if (file.raw.type !== 'text/plain') {\n ElMessage.warning({\n message: '只支持txt文件',\n zIndex: 4000,\n })\n clearFiles()\n }\n}\nfunction handleExportExcel() {\n if (peopleSubmitData.value.length === 0) {\n ElMessage.warning('表格中没有可导出数据')\n return\n }\n const headers = [\n '姓名',\n '提交状态',\n '提交数量',\n '最后操作时间',\n ...(checkMore.value ? ['现存数量', '提交次数'] : []),\n ]\n const body = peopleSubmitData.value.map((v) => {\n const { name, status, lastDate, submitCount, fileCount, count } = v\n return [\n name,\n status ? '✔' : 'x',\n submitCount,\n status ? formatDate(new Date(lastDate)) : '',\n ...(checkMore.value ? [fileCount, count] : []),\n ]\n })\n tableToExcel(\n headers,\n body,\n `${props.name}_提交情况_${formatDate(\n new Date(),\n 'yyyy年MM月日hh时mm分ss秒',\n )}.xlsx`,\n )\n ElMessage.success('导出成功')\n}\n\nconst isMobile = useIsMobile()\nconst importPanelInfo = reactive({\n taskList: [],\n type: 'override',\n taskValue: '',\n})\nconst showImportPanel = ref(false)\nasync function openImportPanel() {\n const taskKey = props.k\n // 通过任务Key获取可用任务列表,与概况信息\n const { data } = await PeopleApi.getUsefulTemplate(taskKey)\n importPanelInfo.taskList = data\n importPanelInfo.taskValue = data[0]?.taskKey || ''\n showImportPanel.value = true\n}\nconst ImportTaskTipMsg = computed(() => {\n const { taskList, taskValue } = importPanelInfo\n const task = taskList.find(v => v.taskKey === taskValue)\n if (!task) {\n return '无可用任务'\n }\n return `${task.count} 条数据`\n})\nfunction handleSaveImportInfo() {\n PeopleApi.importPeopleFromTpl(\n props.k,\n importPanelInfo.taskValue,\n importPanelInfo.type,\n ).then((res) => {\n showImportPanel.value = false\n const { success, fail } = res.data\n ElMessage.success(`导入成功${success}条,失败${fail.length}条`)\n\n if (fail.length > 0) {\n setTimeout(() => {\n ElMessage.info('自动开始下载未成功导入名单')\n tableToExcel(\n ['未成功导入名单'],\n fail.map((v: string) => [v]),\n `${props.name}_导入失败名单_${formatDate(\n new Date(),\n 'yyyy年MM月日hh时mm分ss秒',\n )}.xlsx`,\n )\n }, 1000)\n }\n })\n}\n\nconst importPanelFlexStyle = computed(() => (isMobile.value ? '0 0 auto' : 0.5))\n\nconst bindField = ref('姓名')\nwatch(\n () => props.field,\n (v) => {\n bindField.value = v\n },\n {\n immediate: true,\n },\n)\nfunction handleSureBind() {\n // 空值校验\n if (!bindField.value.trim().length) {\n ElMessage.warning('绑定的表单项不能为空')\n return\n }\n\n // 提交保存\n TaskApi.updateTaskMoreInfo(props.k, {\n bindField: bindField.value,\n }).then(() => {\n ElMessage.success('保存成功')\n })\n}\n</script>\n\n<template>\n <div class=\"tc info-panel\">\n <Tip\n :imgs=\"[\n 'https://img.cdn.sugarat.top/mdImg/MTY1MDE4MzEwOTEzOQ==650183109139',\n 'https://img.cdn.sugarat.top/mdImg/MTY1MTQ5NjY3MTUyMw==651496671523',\n ]\"\n >\n 只有名单里的成员,才可提交文件\n </Tip>\n <el-button\n v-if=\"!people\"\n size=\"default\"\n round\n type=\"success\"\n @click=\"updateLimitPeople(true)\"\n >\n 开启\n </el-button>\n <el-button\n v-if=\"people\"\n size=\"default\"\n round\n type=\"danger\"\n @click=\"updateLimitPeople(false)\"\n >\n 关闭\n </el-button>\n <el-button\n v-if=\"people\"\n round\n size=\"default\"\n type=\"primary\"\n @click=\"checkPeople\"\n >\n 查看提交情况\n </el-button>\n <div v-if=\"people\" class=\"upload-people\">\n <el-radio-group v-model=\"activeTab\" size=\"small\">\n <el-radio-button label=\"文件导入\" />\n <el-radio-button label=\"任务导入\" />\n <el-radio-button label=\"手动添加\" />\n </el-radio-group>\n <div class=\"import-people-wrapper\">\n <div v-show=\"activeTab === '文件导入'\">\n <el-upload\n ref=\"peopleUpload\"\n v-model:file-list=\"peopleFileList\"\n accept=\"text/plain\"\n action=\"\"\n class=\"upload-demo\"\n :on-change=\"handleChangeFile\"\n :on-exceed=\"handleExceedFile\"\n :on-remove=\"clearFiles\"\n :auto-upload=\"false\"\n :limit=\"1\"\n >\n <template #trigger>\n <el-button size=\"small\" type=\"primary\">\n 选择文件\n </el-button>\n </template>\n <el-button\n style=\"margin-left: 10px\"\n size=\"small\"\n type=\"success\"\n :disabled=\"!peopleFileList.length\"\n @click=\"submitUploadPeople\"\n >\n 确定上传\n </el-button>\n <template #tip>\n <div class=\"el-upload__tip\">\n <Tip\n :imgs=\"[\n 'https://img.cdn.sugarat.top/mdImg/MTY1MDE4Mjk2NjUxMA==650182966510',\n ]\"\n >\n 只能上传 .txt 文本文件,每行一个名字\n </Tip>\n <Tip>如名字有特殊字符,建议去除</Tip>\n <Tip>上传文件导入的方式,为追加导入,不会覆盖已存在数据</Tip>\n </div>\n </template>\n </el-upload>\n </div>\n <div v-show=\"activeTab === '任务导入'\">\n <!-- 从其它任务导入 -->\n <el-button size=\"small\" type=\"success\" @click=\"openImportPanel\">\n 选择任务\n </el-button>\n <div class=\"p10\">\n <Tip>支持从已有的任务直接导入名单</Tip>\n </div>\n </div>\n <div v-show=\"activeTab === '手动添加'\">\n <div style=\"max-width: 300px; margin: 0 auto\">\n <el-input\n v-model=\"userInputName\"\n :disabled=\"importStatus\"\n placeholder=\"请输入姓名\"\n >\n <template #append>\n <el-button @click=\"handAddName\">\n 确定\n </el-button>\n </template>\n </el-input>\n </div>\n <div class=\"p10\">\n <Tip>会自动判重,不会重复添加</Tip>\n <Tip>大量名单优先推荐使用文件导入</Tip>\n </div>\n </div>\n </div>\n <div style=\"max-width: 320px; margin: 0 auto\">\n <el-form label-width=\"120px\">\n <el-form-item label=\"绑定表单项\" style=\"margin-bottom: 6px\">\n <el-input v-model=\"bindField\" size=\"small\" clearable>\n <template #append>\n <el-button @click=\"handleSureBind\">\n 确定\n </el-button>\n </template>\n </el-input>\n </el-form-item>\n <Tip style=\"\">\n 和表单项同名字段,可以避免重复填写!!\n </Tip>\n </el-form>\n </div>\n </div>\n <el-dialog v-model=\"showPeopleList\" :fullscreen=\"isMobile\" title=\"提交情况\">\n <!-- 上部分的筛选菜单 -->\n <div class=\"nav\">\n <div class=\"item\">\n <el-button\n :disabled=\"peopleList.length === 0\"\n type=\"success\"\n size=\"default\"\n @click=\"handleExportExcel\"\n >\n 导出记录\n </el-button>\n </div>\n <div class=\"item\">\n <el-select\n v-model=\"selectSubmitStatus\"\n size=\"default\"\n placeholder=\"状态筛选\"\n >\n <el-option label=\"全部\" value=\"all\" />\n <el-option label=\"已提交\" :value=\"1\" />\n <el-option label=\"未提交\" :value=\"0\" />\n </el-select>\n </div>\n <div class=\"item\">\n <el-input\n v-model=\"searchName\"\n size=\"default\"\n placeholder=\"输入要查询的姓名\"\n />\n </div>\n <div class=\"item\">\n <el-button type=\"primary\" size=\"default\" @click=\"handleCheckMore\">\n {{ checkMore ? '隐藏' : '显示' }}详细提交情况\n </el-button>\n </div>\n </div>\n <!-- 概况信息 -->\n <div class=\"tc p10\">\n <span>共: {{ peopleSubmitData.length }} 条数据</span>,\n <span>已提交: {{ peopleSubmitData.filter((v) => v.status).length }}</span>,\n <span>未提交: {{ peopleSubmitData.filter((v) => !v.status).length }}</span>\n </div>\n <div class=\"tc p10\">\n <Tip>\"提交次数\" 用户实际的提交次数</Tip>\n <Tip>\"现存数量\" 还存在于服务器上的文件数 (不包含删除) --- 慢查询</Tip>\n <Tip>\"提交数量\" 用户实际提交的文件数 (不包含撤回) --- 慢查询</Tip>\n </div>\n <!-- 数据部分 -->\n <el-table\n v-loading=\"isLoadingPeopleData\"\n element-loading-text=\"Loading...\"\n stripe\n border\n :data=\"peopleSubmitData\"\n height=\"460px\"\n >\n <el-table-column label=\"序号\" width=\"60\">\n <template #default=\"scope\">\n <div style=\"text-align: center\">\n {{ scope.$index + 1 }}\n </div>\n </template>\n </el-table-column>\n <el-table-column property=\"name\" label=\"姓名\" />\n <el-table-column label=\"提交状态\" width=\"100\">\n <template #default=\"scope\">\n <span v-if=\"scope.row.status\" class=\"submit-ok\">已提交</span>\n <span v-else class=\"submit-fail\">未提交</span>\n </template>\n </el-table-column>\n <el-table-column\n property=\"count\"\n label=\"提交次数\"\n width=\"94\"\n />\n <el-table-column\n sortable\n property=\"lastDate\"\n label=\"最后操作时间\"\n width=\"120\"\n />\n <template v-if=\"checkMore\">\n <el-table-column\n property=\"fileCount\"\n label=\"现存数量\"\n width=\"94\"\n />\n <el-table-column\n sortable\n property=\"submitCount\"\n label=\"提交数量\"\n width=\"120\"\n />\n </template>\n <el-table-column label=\"操作\" width=\"100\">\n <template #default=\"scope\">\n <el-button\n type=\"primary\"\n text\n size=\"small\"\n @click=\"handleDeletePeople(scope.row)\"\n >\n 删除\n </el-button>\n </template>\n </el-table-column>\n </el-table>\n </el-dialog>\n <el-dialog\n v-model=\"showImportPanel\"\n :fullscreen=\"isMobile\"\n title=\"人员列表导入\"\n >\n <el-form\n :model=\"importPanelInfo\"\n label-width=\"100px\"\n label-position=\"right\"\n >\n <el-form-item label=\"任务\">\n <el-select\n v-model=\"importPanelInfo.taskValue\"\n filterable\n placeholder=\"请选择\"\n no-data-text=\"无可用任务\"\n >\n <el-option\n v-for=\"t in importPanelInfo.taskList\"\n :key=\"t.taskKey\"\n :label=\"t.name\"\n :value=\"t.taskKey\"\n />\n </el-select>\n </el-form-item>\n <Tip>{{ ImportTaskTipMsg }}</Tip>\n <el-form-item label=\"任务\">\n <el-radio-group v-model=\"importPanelInfo.type\">\n <el-radio label=\"override\">\n 覆盖导入\n </el-radio>\n <el-radio label=\"add\">\n 追加导入\n </el-radio>\n </el-radio-group>\n </el-form-item>\n <Tip>\n {{\n importPanelInfo.type === 'override'\n ? '“覆盖导入” 将会覆盖原来的数据'\n : '“追加导入” 将只会导入不存在数据'\n }}\n </Tip>\n </el-form>\n <template #footer>\n <span class=\"dialog-footer\">\n <el-button @click=\"showImportPanel = false\">取 消</el-button>\n <el-button\n :disabled=\"!importPanelInfo.taskValue\"\n type=\"primary\"\n @click=\"handleSaveImportInfo\"\n >确 定</el-button>\n </span>\n </template>\n </el-dialog>\n </div>\n</template>\n\n<style scoped>\n.upload-people {\n padding: 10px;\n}\n\n.import-people-wrapper {\n padding: 10px 0;\n}\n.submit-ok {\n color: #67c23a;\n}\n\n.submit-fail {\n color: #f56c6c;\n}\n\n.nav {\n display: flex;\n flex-wrap: wrap;\n justify-content: center;\n padding-bottom: 5px;\n}\n\n.nav .item {\n margin-left: 10px;\n margin-top: 5px;\n}\n\n.info-panel :deep(.el-form-item__label) {\n flex: v-bind(importPanelFlexStyle);\n}\n\n.info-panel :deep(.el-upload-list__item-name) {\n justify-content: center;\n}\n</style>\n","<template>\n <div class=\"tc info-panel\">\n <tip\n :imgs=\"[\n 'https://img.cdn.sugarat.top/mdImg/MTY1MDE4MjY3MjUxNw==650182672517'\n ]\"\n >设置的模板文件,可供用户在提交页下载。</tip\n >\n <el-button\n v-if=\"template\"\n :disabled=\"!template\"\n @click=\"deleteTemplate\"\n size=\"default\"\n round\n type=\"danger\"\n >删除</el-button\n >\n <div class=\"p10\">{{ template || '尚未设置模板文件' }}</div>\n <div class=\"upload-file\" v-if=\"!template\">\n <el-upload\n action=\"\"\n ref=\"elUpload\"\n :on-exceed=\"handleExceedFile\"\n :on-remove=\"clearFiles\"\n :auto-upload=\"false\"\n :limit=\"1\"\n v-model:file-list=\"fileList\"\n >\n <template #trigger>\n <el-button size=\"small\" type=\"primary\">选取文件</el-button>\n </template>\n <el-button\n @click=\"submitUploadPeople\"\n style=\"margin-left: 10px\"\n size=\"small\"\n type=\"success\"\n >设为模板</el-button\n >\n <template #tip>\n <div class=\"el-upload__tip\">选择模板文件,然后点击上传</div>\n </template>\n </el-upload>\n </div>\n </div>\n</template>\n<script lang=\"ts\">\nimport { ElMessage, UploadUserFile } from 'element-plus'\nimport { defineComponent, ref, watchEffect } from 'vue'\nimport { FileApi } from '@/apis'\nimport { qiniuUpload } from '@/utils/networkUtil'\nimport { updateTaskInfo } from '../../public'\nimport Tip from './tip.vue'\n\nexport default defineComponent({\n name: 'templatePanel',\n props: {\n value: {\n type: String,\n default: ''\n },\n k: {\n type: String,\n default: ''\n }\n },\n setup(props) {\n const template = ref()\n watchEffect(() => {\n if (props.value) {\n template.value = props.value\n } else {\n template.value = ''\n }\n })\n const percentage = ref(0)\n // 删除模板\n const deleteTemplate = () => {\n if (template.value) {\n // 移除文件,避免空间被长时间占用\n updateTaskInfo(props.k, { template: '' })\n template.value = ''\n percentage.value = 0\n }\n }\n // 文件上传\n const fileList = ref<UploadUserFile[]>([])\n const elUpload = ref()\n // 超出选择的文件个数\n const handleExceedFile = () => {\n ElMessage.error('只能选择一个文件,可删除后重新选择')\n }\n // 清空文件\n const clearFiles = () => {\n elUpload.value.clearFiles()\n }\n // 开始上传\n const submitUploadPeople = () => {\n fileList.value.forEach((file) => {\n if (!props.k) {\n return\n }\n const { name } = file\n const key = `easypicker2/${props.k}_template/${name}`\n if (file.status === 'ready') {\n file.status = 'uploading'\n // qiniu上传\n FileApi.getUploadToken().then((res) => {\n qiniuUpload(res.data.token, file.raw, key, {\n success() {\n ElMessage.success('上传成功')\n updateTaskInfo(props.k, { template: name })\n // 清理上传完成的\n clearFiles()\n template.value = name\n file.status = 'success'\n // hash,key\n // console.log(data)\n },\n process(per: number) {\n file.percentage = ~~per\n }\n })\n })\n }\n })\n }\n return {\n template,\n deleteTemplate,\n fileList,\n handleExceedFile,\n clearFiles,\n submitUploadPeople,\n elUpload,\n percentage\n }\n },\n components: { Tip }\n})\n</script>\n\n<style lang=\"scss\" scoped>\n.info-panel :deep(.el-upload-list__item-name) {\n justify-content: center;\n}\n</style>\n","<script lang=\"ts\" setup>\nimport { ElMessage, ElMessageBox } from 'element-plus'\nimport { computed, reactive, ref, watch, watchEffect } from 'vue'\nimport {\n CircleCloseFilled,\n CirclePlusFilled,\n Top,\n} from '@element-plus/icons-vue'\nimport { updateTaskInfo } from '../../public'\nimport Tip from './tip.vue'\nimport { TaskApi } from '@/apis'\nimport InfosForm from '@/components/InfosForm/index.vue'\nimport {\n getDefaultFormat,\n parseFileFormat,\n parseInfo,\n} from '@/utils/stringUtil'\nimport { useIsMobile, useSiteConfig } from '@/composables'\n\nconst props = defineProps({\n rewrite: {\n type: Number,\n default: 0,\n },\n info: {\n typs: String,\n default: '[]',\n },\n k: {\n type: String,\n default: '',\n },\n format: {\n type: String,\n default: '',\n required: false,\n },\n})\nconst formatData = reactive(getDefaultFormat())\nconst openPreview = ref(false)\nconst infoTypeList = reactive<{ label: string, value: InfoItemType }[]>([\n {\n label: '输入框',\n value: 'input',\n },\n {\n label: '固定内容',\n value: 'text',\n },\n {\n label: '单选框',\n value: 'radio',\n },\n {\n label: '下拉选择',\n value: 'select',\n },\n])\nfunction getTypeDes(type: string) {\n return infoTypeList.find(v => v.value === type)?.label\n}\n\nconst selectType = ref<InfoItemType>('input')\n\nconst { value: siteConfig } = useSiteConfig()\nconst maxInputLength = computed(() => siteConfig.value.maxInputLength)\n\nconst autoRewrite = ref(false)\nconst infos = reactive<InfoItem[]>([])\nconst needSave = ref(false)\n\nconst showAddInfo = computed(() => infos.length < siteConfig.value.formLength && !openPreview.value)\n// 负责清空&更新\nwatch(\n () => props.info,\n () => {\n infos.splice(0, infos.length)\n selectType.value = 'input'\n openPreview.value = false\n infos.push(...parseInfo(props.info))\n needSave.value = false\n },\n {\n immediate: true,\n },\n)\n\n// 预计格式\nconst resFormat = computed(\n () => `${infos.map(v => v.text).join(formatData.splitChar)}.后缀`,\n)\nwatchEffect(() => {\n autoRewrite.value = !!props.rewrite\n})\nfunction handleChange(v: boolean) {\n updateTaskInfo(props.k, {\n rewrite: +v,\n })\n}\n\nfunction addInfo(infoList?: InfoItem[], type?: InfoItemType) {\n const list = infoList || infos\n const t = type || selectType.value\n const item: InfoItem = { text: `标题${list.length + 1}`, type: t, value: '' }\n if (t === 'radio' || t === 'select') {\n item.children = [{ text: '选项1' }, { text: '选项2' }]\n }\n list.push(item)\n needSave.value = true\n}\nfunction deleteInfo(idx: number, infoList?: InfoItem[], minLen = 1) {\n const list = infoList || infos\n if (list.length <= minLen) {\n return\n }\n list.splice(idx, 1)\n needSave.value = true\n}\nfunction judgeInfoForm(items: InfoItem[]) {\n return items.every(v => v.text.trim() && judgeInfoForm(v.children || []))\n}\nfunction saveInfo() {\n if (!judgeInfoForm(infos)) {\n ElMessage.error('请完整填写表单信息')\n setTimeout(() => {\n ElMessage.warning('不能有空项')\n }, 100)\n return\n }\n updateTaskInfo(props.k, {\n info: JSON.stringify(\n infos.map((v) => {\n // 特殊处理固定值的内容\n if (v.type === 'text') {\n v.value = v.text\n }\n return v\n }),\n ),\n })\n needSave.value = false\n}\n\nfunction moveInfoUp(idx: number) {\n if (idx === 0)\n return\n const temp = infos[idx - 1]\n infos.splice(idx - 1, 1)\n infos.splice(idx, 0, temp)\n}\n\nconst importPanelInfo = reactive({ taskList: [], taskValue: '' })\nconst showImportPanel = ref(false)\nasync function openImportPanel() {\n const taskKey = props.k\n // 通过任务Key获取可用任务列表,与概况信息\n const { data } = await TaskApi.getUsefulTemplate(taskKey)\n importPanelInfo.taskList = data\n importPanelInfo.taskValue = data[0]?.taskKey || ''\n showImportPanel.value = true\n}\n\nfunction handleSaveImportInfo() {\n const usefulInfo = importPanelInfo.taskList.find(\n v => v.taskKey === importPanelInfo.taskValue,\n ).info\n infos.splice(0, infos.length)\n infos.push(...parseInfo(usefulInfo))\n showImportPanel.value = false\n needSave.value = true\n}\n\nconst isMobile = useIsMobile()\nconst importPanelFlexStyle = computed(() => (isMobile.value ? '0 0 auto' : 0.5))\n\nfunction showHelp() {\n ElMessageBox.alert(\n '<p>固定内容主要用于重命名中,固定的部分,如“活动名”,“班级名”</p><p>如要设置注意事项,请使用 <strong>批注</strong> 功能</p>',\n '注意事项',\n { dangerouslyUseHTMLString: true },\n )\n}\n\nfunction handleChangeSplitChar() {\n updateTaskInfo(props.k, {\n format: JSON.stringify(formatData),\n })\n}\nconst splitCharList = reactive(['-', '+', '_'])\nwatchEffect(() => {\n if (props.format !== null) {\n Object.assign(formatData, parseFileFormat(props.format))\n }\n})\n</script>\n\n<template>\n <div class=\"tc\">\n <Tip\n :imgs=\"[\n 'https://img.cdn.sugarat.top/mdImg/MTY1MDE4MzM3NjUyNg==650183376526',\n 'https://img.cdn.sugarat.top/mdImg/MTY1MTQ5NjU2ODcyNg==651496568726',\n ]\"\n >\n 上传文件必填表单信息\n </Tip>\n <div class=\"auto-format\">\n <span>文件自动重命名:</span>\n <el-switch\n v-model=\"autoRewrite\"\n style=\"display: block\"\n active-color=\"#13ce66\"\n inactive-color=\"#ff4949\"\n active-text=\"开\"\n inactive-text=\"关\"\n @change=\"handleChange\"\n />\n </div>\n <div v-if=\"autoRewrite\" style=\"margin-bottom: 10px\">\n 预期格式:\n <span style=\"color: #409eff\">{{ resFormat }}</span>\n </div>\n <div v-if=\"autoRewrite\" style=\"margin-bottom: 10px\">\n 分割符:\n <el-select\n v-model=\"formatData.splitChar\"\n placeholder=\"分隔符\"\n style=\"width: 60px\"\n size=\"small\"\n @change=\"handleChangeSplitChar\"\n >\n <el-option v-for=\"v in splitCharList\" :key=\"v\" :label=\"v\" :value=\"v\" />\n </el-select>\n </div>\n <Tip v-if=\"autoRewrite\" style=\"color: red\">\n 开启自动重命名后,重点关注文件名格式是否符合预期\n </Tip>\n <div>\n 预览\n <el-switch\n v-model=\"openPreview\"\n inline-prompt\n active-text=\"是\"\n inactive-text=\"否\"\n active-color=\"#13ce66\"\n inactive-color=\"#ff4949\"\n />\n </div>\n <!-- 必填信息区域 -->\n <div class=\"form-wrapper\">\n <InfosForm v-if=\"openPreview\" :infos=\"infos\" :disabled=\"openPreview\" />\n <el-form v-else label-width=\"100px\">\n <el-form-item v-for=\"(item, idx) in infos\" :key=\"idx\">\n <template #label>\n <div class=\"flex fc fac\">\n <div class=\"num-wrapper\">\n <div>{{ idx + 1 }}</div>\n </div>\n <div class=\"form-item-type\" :class=\"item.type\">\n {{ getTypeDes(item.type) }}\n </div>\n </div>\n </template>\n <el-input\n v-model=\"item.text\"\n placeholder=\"输入内容\"\n :maxlength=\"maxInputLength\"\n clearable\n show-word-limit\n >\n <template #append>\n <div class=\"form-item-wrapper\">\n <el-icon\n :color=\"infos.length > 1 ? 'red' : 'grey'\"\n @click=\"deleteInfo(idx)\"\n >\n <CircleCloseFilled />\n </el-icon>\n <el-icon\n v-if=\"idx > 0\"\n color=\"#000\"\n style=\"margin-left: 6px\"\n @click=\"moveInfoUp(idx)\"\n >\n <Top />\n </el-icon>\n </div>\n </template>\n </el-input>\n <div\n v-if=\"item.type === 'radio' || item.type === 'select'\"\n class=\"radio-list\"\n >\n <el-input\n v-for=\"(v, idx2) in item.children\"\n :key=\"idx2\"\n v-model=\"v.text\"\n size=\"small\"\n placeholder=\"输入内容\"\n :maxlength=\"maxInputLength\"\n clearable\n show-word-limit\n >\n <template #append>\n <div class=\"form-item-wrapper\">\n <el-icon\n :color=\"item.children.length > 2 ? 'red' : 'grey'\"\n @click=\"deleteInfo(idx2, item.children, 2)\"\n >\n <CircleCloseFilled />\n </el-icon>\n <template v-if=\"idx2 + 1 === item.children.length\">\n <el-icon\n style=\"margin-left: 10px\"\n color=\"#67C23A\"\n @click=\"addInfo(item.children, item.type)\"\n >\n <CirclePlusFilled />\n </el-icon>\n </template>\n </div>\n </template>\n </el-input>\n </div>\n </el-form-item>\n </el-form>\n </div>\n <div v-if=\"showAddInfo\" class=\"p10\">\n <el-button\n size=\"small\"\n type=\"primary\"\n round\n @click=\"\n () => {\n addInfo()\n }\n \"\n >\n 添加一项\n </el-button>\n <el-select\n v-model=\"selectType\"\n style=\"margin: 0 10px\"\n size=\"small\"\n placeholder=\"选择添加的类型\"\n >\n <el-option\n v-for=\"(v, idx) in infoTypeList\"\n :key=\"idx\"\n :label=\"v.label\"\n :value=\"v.value\"\n />\n </el-select>\n <el-button type=\"primary\" text @click=\"showHelp\">\n 提示❓\n </el-button>\n </div>\n <!-- 从其它任务导入 -->\n <el-button size=\"small\" type=\"warning\" @click=\"openImportPanel\">\n 从其它任务导入\n </el-button>\n <div class=\"p10\">\n <Tip>支持从已有的任务直接导入表单信息</Tip>\n <el-button type=\"success\" style=\"width: 200px\" @click=\"saveInfo\">\n 保存\n </el-button>\n </div>\n <div v-if=\"needSave\" style=\"color: red\">\n 有变动,请记得点击保存\n </div>\n <div class=\"info-panel\">\n <el-dialog\n v-model=\"showImportPanel\"\n :fullscreen=\"isMobile\"\n title=\"表单信息导入\"\n >\n <el-form\n :model=\"importPanelInfo\"\n label-width=\"100px\"\n label-position=\"right\"\n >\n <el-form-item label=\"任务\">\n <el-select\n v-model=\"importPanelInfo.taskValue\"\n filterable\n placeholder=\"请选择\"\n no-data-text=\"无可用任务\"\n >\n <el-option\n v-for=\"t in importPanelInfo.taskList\"\n :key=\"t.taskKey\"\n :label=\"t.name\"\n :value=\"t.taskKey\"\n />\n </el-select>\n </el-form-item>\n <Tip>{{ importPanelInfo.taskValue ? '' : '无可用任务' }}</Tip>\n </el-form>\n <template #footer>\n <span class=\"dialog-footer\">\n <el-button @click=\"showImportPanel = false\">取 消</el-button>\n <el-button\n :disabled=\"!importPanelInfo.taskValue\"\n type=\"primary\"\n @click=\"handleSaveImportInfo\"\n >确 定\n </el-button>\n </span>\n </template>\n </el-dialog>\n </div>\n </div>\n</template>\n\n<style scoped lang=\"scss\">\n.auto-format {\n display: flex;\n justify-content: center;\n}\n\n:deep(.el-form-item__label) {\n display: flex;\n justify-content: center;\n align-items: flex-start;\n}\n\n.num-wrapper {\n display: flex;\n justify-content: center;\n align-items: center;\n width: 20px;\n height: 20px;\n border-radius: 50%;\n border: 2px solid #000;\n text-align: center;\n font-size: 14px;\n}\n\n.info-panel :deep(.el-form-item__label) {\n flex: v-bind(importPanelFlexStyle);\n justify-content: flex-end;\n}\n\n.form-wrapper {\n max-width: 380px;\n margin: 0 auto;\n}\n\n.form-wrapper :deep(.el-input-group__append) {\n background-color: transparent;\n border: none;\n box-shadow: none;\n padding: 0;\n}\n\n.form-item-wrapper {\n width: 50px;\n display: flex;\n justify-content: center;\n align-items: center;\n}\n\n.form-item-type {\n margin-left: 10px;\n font-size: 12px;\n width: 48px;\n text-align: left;\n}\n\n.radio-list {\n padding-top: 10px;\n}\n\n.radio-list :deep(.el-input) {\n width: 80%;\n}\n</style>\n","<!-- eslint-disable ts/ban-ts-comment -->\n<script lang=\"ts\" setup>\nimport { computed, reactive, ref, watch } from 'vue'\nimport { Plus } from '@element-plus/icons-vue'\nimport type { UploadProps, UploadUserFile } from 'element-plus'\nimport { ElMessage } from 'element-plus'\nimport { updateTaskInfo } from '../../public'\nimport Tip from './tip.vue'\nimport { FileApi, PublicApi, TaskApi } from '@/apis'\nimport { qiniuUpload } from '@/utils/networkUtil'\nimport { getTipImageKey } from '@/utils/stringUtil'\n\nconst props = defineProps({\n tip: {\n type: String,\n default: '',\n required: false,\n },\n k: {\n type: String,\n default: '',\n },\n})\nconst textValue = ref('')\n\nconst tipData = reactive<{\n text: string\n imgs: {\n uid: number\n name: string\n }[]\n}>({\n text: '',\n imgs: [],\n})\nconst MaxImgCount = ref(3)\nconst imageList = ref<UploadUserFile[]>([])\nconst previewList = computed(() => {\n // @ts-expect-error\n return imageList.value.map(v => v!.preview || v.url)\n})\nconst previewIdx = ref(0)\n\nwatch(\n () => props.tip,\n () => {\n // 初始化\n try {\n const parseData = JSON.parse(props.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 props.k,\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 = props.tip || ''\n tipData.imgs = []\n imageList.value = []\n }\n\n // 外部变动\n if (tipData.text) {\n textValue.value = tipData.text\n }\n else {\n textValue.value = ''\n }\n },\n {\n immediate: true,\n },\n)\nconst needSave = computed(() => tipData.text !== textValue.value)\n\n// 更新批注信息\nfunction updateTip(notify = true) {\n if (tipData.text !== textValue.value) {\n tipData.text = textValue.value\n }\n updateTaskInfo(props.k, { tip: JSON.stringify(tipData) }, notify)\n}\n\nconst imageViewerVisible = ref(false)\nfunction handleChangeFile(file: UploadUserFile) {\n if (!props.k) {\n return\n }\n const { name, uid } = file\n const key = getTipImageKey(props.k, name, uid)\n if (file.status === 'ready') {\n file.status = 'success'\n // qiniu上传\n FileApi.getUploadToken().then((res) => {\n qiniuUpload(res.data.token, file.raw, key, {\n success() {\n tipData.imgs.push({\n uid,\n name,\n })\n updateTip()\n },\n })\n })\n }\n}\nconst handleRemove: UploadProps['onRemove'] = (file) => {\n const { uid, name } = file\n const idx = tipData.imgs.findIndex(v => v.uid === uid)\n tipData.imgs.splice(idx, 1)\n updateTip()\n TaskApi.delTipImage(props.k, uid, name)\n}\n\nfunction handlePictureCardPreview(file) {\n imageViewerVisible.value = true\n const idx = imageList.value.findIndex(v => v.uid === file.uid)\n previewIdx.value = idx\n}\n// 超出选择的文件个数\nfunction handleExceedFile() {\n ElMessage.error(`只能选择${MaxImgCount.value}个图片,可删除后重新选择`)\n}\n</script>\n\n<template>\n <div class=\"tc ddl\">\n <Tip\n :imgs=\"[\n 'https://img.cdn.sugarat.top/mdImg/MTY1MTQ5NjI2OTI0MQ==651496269241',\n ]\"\n >\n 设置注意事项,供用户提交时查看\n </Tip>\n <Tip>注意控制字数和换行,避免展示异常,设置完记得预览一下,再投放</Tip>\n <div class=\"tc flex fc fac\">\n <el-input\n v-model=\"textValue\"\n :rows=\"5\"\n clearable\n :max=\"500\"\n show-word-limit\n type=\"textarea\"\n placeholder=\"请输入要展示的批注信息\"\n />\n </div>\n <div class=\"p10\">\n <el-button size=\"default\" type=\"success\" @click=\"updateTip\">\n 保存\n </el-button>\n <el-button size=\"default\" type=\"danger\" @click=\"textValue = ''\">\n 清空\n </el-button>\n </div>\n <Tip v-if=\"needSave\">\n 有变动记得保存\n </Tip>\n <Tip> 可以设置图片啦↓ 最多3张 </Tip>\n <el-upload\n v-model:file-list=\"imageList\"\n accept=\"image/*\"\n :limit=\"MaxImgCount\"\n action=\"\"\n list-type=\"picture-card\"\n :on-change=\"handleChangeFile\"\n :on-exceed=\"handleExceedFile\"\n :on-preview=\"handlePictureCardPreview\"\n :on-remove=\"handleRemove\"\n :auto-upload=\"false\"\n >\n <el-icon><Plus /></el-icon>\n </el-upload>\n <ElImageViewer\n v-if=\"imageViewerVisible\"\n hide-on-click-modal\n :initial-index=\"previewIdx\"\n :url-list=\"previewList\"\n teleported\n @close=\"imageViewerVisible = false\"\n />\n </div>\n</template>\n","<template>\n <div class=\"tc\">\n <tip class=\"title\"> ↓下方设置允许提交的文件类型↓ </tip>\n <tip>暂时只支持通过文件名后缀进行卡控,不区分大小写</tip>\n <tip>例如:txt,png,jpeg,webp</tip>\n <div class=\"tc\">\n <el-switch\n active-text=\"限制文件类型\"\n inactive-text=\"不限制文件类型\"\n @change=\"handleChange\"\n :value=\"formatData.status\"\n style=\"--el-switch-on-color: #13ce66; --el-switch-off-color: #ff4949\"\n />\n </div>\n <div v-show=\"formatData.status\">\n <tip>支持英文逗号\",\"分割,一次添加多个</tip>\n <div style=\"max-width: 300px; margin: 0 auto\">\n <el-input v-model=\"typeName\" placeholder=\"请输入文件类型(省略.)\">\n <template #append>\n <el-button @click=\"handleAddType\"> 确定 </el-button>\n </template>\n </el-input>\n </div>\n <el-tag\n v-for=\"(tag, idx) in formatData.format\"\n :key=\"idx\"\n class=\"type\"\n closable\n :disable-transitions=\"false\"\n @close=\"handleDelType(idx)\"\n >\n {{ tag }}\n </el-tag>\n <tip v-show=\"formatData.format.length\"\n >已添加: <span>{{ formatData.format.join(',') }}</span>\n <el-button type=\"primary\" text size=\"small\" @click=\"handleCopyType\"\n >一键复制</el-button\n >\n </tip>\n </div>\n <div class=\"split-line\"></div>\n <tip class=\"title\"\n >↓下方设置最大同时提交文件数量(16 >= x >=1 默认 10)↓</tip\n >\n <div class=\"tc\">\n <el-input-number\n :model-value=\"formatData.limit\"\n :min=\"1\"\n :max=\"16\"\n @change=\"handleChangeLimit\"\n />\n </div>\n <div class=\"split-line\"></div>\n <tip class=\"title\"> ↓下方设置文件最大的大小↓ </tip>\n <tip>1024B = 1KB, 1024KB = 1MB, 1024MB = 1GB</tip>\n <tip>0表示不限制</tip>\n <div class=\"tc\">\n <el-input-number\n :model-value=\"inputSize\"\n :min=\"0\"\n :max=\"1024\"\n @change=\"handleLimitSize\"\n />\n <el-select\n @change=\"handleChangeUnit\"\n v-model=\"formatData.sizeUnit\"\n placeholder=\"单位\"\n style=\"width: 100px\"\n >\n <el-option v-for=\"v in unitList\" :key=\"v\" :label=\"v\" :value=\"v\" />\n </el-select>\n </div>\n <div class=\"split-line\"></div>\n <tip :style=\"formatData.size === 0 ? 'color:grey' : 'color:red'\">{{\n formatData.size === 0\n ? '不限制大小'\n : `限制为不超过: ${formatSize(formatData.size)}`\n }}</tip>\n </div>\n</template>\n<script lang=\"ts\" setup>\nimport { ElMessage } from 'element-plus'\nimport { reactive, ref, watchEffect } from 'vue'\nimport {\n copyRes,\n formatSize,\n getDefaultFormat,\n parseFileFormat\n} from '@/utils/stringUtil'\nimport { updateTaskInfo } from '../../public'\nimport Tip from './tip.vue'\n\nconst props = defineProps({\n format: {\n type: String,\n default: '',\n required: false\n },\n k: {\n type: String,\n default: ''\n }\n})\n\nconst formatData = reactive(getDefaultFormat())\nconst typeName = ref('')\nconst updateInfo = () => {\n updateTaskInfo(props.k, {\n format: JSON.stringify(formatData)\n })\n}\nconst handleChange = (v: boolean) => {\n formatData.status = !!v\n updateInfo()\n}\n\nconst handleAddType = () => {\n const inputValue = typeName.value\n .split(',')\n // 转为小写\n .map((v) => v.trim().toLowerCase())\n for (const v of inputValue) {\n if (formatData.format.includes(v)) {\n ElMessage.error(`${v} 已存在`)\n return\n }\n }\n\n formatData.format.push(...inputValue)\n updateInfo()\n\n typeName.value = ''\n}\nconst handleDelType = (idx) => {\n formatData.format.splice(idx, 1)\n updateInfo()\n}\nconst handleCopyType = () => {\n copyRes(formatData.format.join(','))\n}\n\nconst handleChangeLimit = (limit: number) => {\n formatData.limit = limit\n updateInfo()\n}\n\nconst inputSize = ref(0)\nconst unitList = reactive(['B', 'KB', 'MB', 'GB'])\nconst handleChangeUnit = () => {\n const idx = unitList.findIndex((v) => v === formatData.sizeUnit)\n formatData.size = inputSize.value * 1024 ** idx\n updateInfo()\n}\nconst handleLimitSize = (limit: number) => {\n inputSize.value = limit\n const idx = unitList.findIndex((v) => v === formatData.sizeUnit)\n formatData.size = inputSize.value * 1024 ** idx\n updateInfo()\n}\n\nwatchEffect(() => {\n if (props.format !== null) {\n Object.assign(formatData, parseFileFormat(props.format))\n }\n})\n</script>\n<style scoped>\n.type {\n margin: 10px;\n}\n.split-line {\n margin-top: 10px;\n}\n.title {\n color: black;\n font-weight: bold;\n}\n</style>\n","<script lang=\"ts\" setup>\nimport { ElMessage, ElMessageBox } from 'element-plus'\nimport { computed, onMounted, reactive, ref, watchEffect } from 'vue'\nimport { useStore } from 'vuex'\nimport LinkDialog from '@components/linkDialog.vue'\nimport CategoryPanel from './components/CategoryPanel.vue'\nimport CreateTask from './components/CreateTask.vue'\nimport TaskInfo from './components/TaskInfo.vue'\nimport DDlPanel from './components/infoPanel/ddl.vue'\nimport PeoplePanel from './components/infoPanel/people.vue'\nimport TemplatePanel from './components/infoPanel/template.vue'\nimport InfoPanel from './components/infoPanel/info.vue'\nimport TipInfoPanel from './components/infoPanel/tipInfo.vue'\nimport FileInfoPanel from './components/infoPanel/file.vue'\nimport { copyRes } from '@/utils/stringUtil'\nimport { TaskApi } from '@/apis'\nimport { useIsMobile } from '@/composables'\n\nconst $store = useStore()\n\nconst isMobile = useIsMobile()\n// 分类相关\nconst categorys = computed(() => $store.state.category.categoryList)\n\n// 任务相关\nconst selectCategory = ref('default')\nconst tasks = computed<TaskApiTypes.TaskItem[]>(\n () => $store.state.task.taskList,\n)\nconst filterTasks = computed(() => {\n const t = tasks.value.filter(v => v.category === selectCategory.value)\n return t\n})\n\n// 删除任务\nfunction deleteTask(k: string, isTrash = false) {\n if (!k)\n return\n ElMessageBox.confirm(\n '确认删除此任务吗?',\n isTrash ? '!!回收站的删除后无法再恢复' : '数据无价,请谨慎操作',\n {\n confirmButtonText: '确定',\n cancelButtonText: '取消',\n type: isTrash ? 'error' : 'info',\n },\n )\n .then(() => {\n $store.dispatch('task/deleteTask', k).then(() => {\n ElMessage.success('删除成功')\n })\n })\n .catch(() => {\n ElMessage.info('取消删除')\n })\n}\n\n// 基本信息编辑\nconst showBaseInfoDialog = ref(false)\nconst taskBaseInfo = reactive({ name: '', category: '', key: '' })\nfunction editBaseInfo(task: any) {\n taskBaseInfo.name = task.name\n taskBaseInfo.category = task.category\n taskBaseInfo.key = task.key\n showBaseInfoDialog.value = true\n}\nfunction handleSaveEditInfo() {\n showBaseInfoDialog.value = false\n if (!taskBaseInfo.name.trim()) {\n ElMessage.warning('不能为空')\n return\n }\n $store.dispatch('task/updateTask', taskBaseInfo).then(() => {\n ElMessage.success('更新成功')\n })\n}\n\n// 生成分享链接\nconst shareTaskLink = ref('')\nconst showLinkModal = ref(false)\nconst shareTaskName = ref('')\nfunction shareTask(k: string) {\n shareTaskLink.value = 'default'\n const { origin } = window.location\n shareTaskLink.value = `${origin}/task/${k}`\n copyRes(shareTaskLink.value, '收集链接已自动复制到粘贴板')\n shareTaskName.value = tasks.value.find(v => v.key === k)?.name\n showLinkModal.value = true\n}\n\n// 附加属性编辑\nconst taskInfo = reactive<TaskApiTypes.TaskInfo>({})\nconst showTaskInfoPanel = ref(false)\nconst activeInfo = ref('info')\nconst activeTask: TaskApiTypes.TaskItem = reactive({\n category: '',\n key: '',\n name: '',\n recentLog: [],\n})\nfunction editMore(item: any) {\n Object.assign(activeTask, item)\n TaskApi.getTaskMoreInfo(item.key).then((res) => {\n // 先初始化,再赋值\n taskInfo.info = '[]'\n taskInfo.ddl = ''\n taskInfo.tip = ''\n taskInfo.format = ''\n taskInfo.bindField = ''\n setTimeout(() => {\n Object.assign(taskInfo, res.data)\n showTaskInfoPanel.value = true\n })\n })\n}\n\n// TODO: 有需要再优化,目前像bug\n// 用于选择默认展示项目\n// const taskCount = (c: string) => {\n// const count = tasks.value.filter((t: any) => t.category === c).length\n// return count\n// }\n\n// 选中一个有任务数据的分类\n// watchEffect(() => {\n// if (taskCount('default') > 0) {\n// return\n// }\n// if (categorys.value.length > 0) {\n// for (const c of categorys.value) {\n// if (taskCount(c.k) > 0) {\n// selectCategory.value = c.k\n// break\n// }\n// }\n// }\n// })\n\nonMounted(() => {\n $store.dispatch('category/getCategory')\n $store.dispatch('task/getTask')\n})\n\nfunction openTaskPage() {\n window.open(`/task/${activeTask.key}`)\n}\n</script>\n\n<template>\n <div class=\"tasks\">\n <!-- 分类管理 -->\n <div class=\"categorys-area\">\n <CategoryPanel v-model:category=\"selectCategory\" />\n </div>\n\n <!-- 任务管理 -->\n <div class=\"panel task-panel\">\n <!-- 创建任务 -->\n <CreateTask :active-category-key=\"selectCategory\" />\n\n <!-- 任务列表 -->\n <div class=\"task-list\">\n <TaskInfo\n v-for=\"item in filterTasks\"\n :key=\"item.key\"\n :item=\"item\"\n @edit=\"editBaseInfo\"\n @delete=\"deleteTask\"\n @share=\"shareTask\"\n @more=\"editMore\"\n />\n <el-empty\n v-if=\"filterTasks.length === 0\"\n description=\"此分类下没有任务哟,快去创建吧\"\n />\n </div>\n </div>\n\n <!-- 任务基本信息维护弹窗 -->\n <el-dialog\n v-model=\"showBaseInfoDialog\"\n draggable\n :fullscreen=\"isMobile\"\n title=\"基本信息修改\"\n >\n <el-form :model=\"taskBaseInfo\">\n <el-form-item label=\"任务名称\" label-width=\"100px\">\n <el-input v-model=\"taskBaseInfo.name\" autocomplete=\"off\" />\n </el-form-item>\n <el-form-item label=\"新的分类\" label-width=\"100px\">\n <el-select v-model=\"taskBaseInfo.category\" placeholder=\"请选择新分类\">\n <el-option label=\"默认\" value=\"default\" />\n <el-option\n v-for=\"c in categorys\"\n :key=\"c.k\"\n :label=\"c.name\"\n :value=\"c.k\"\n />\n </el-select>\n </el-form-item>\n </el-form>\n <template #footer>\n <span class=\"dialog-footer\">\n <el-button @click=\"showBaseInfoDialog = false\">取 消</el-button>\n <el-button type=\"primary\" @click=\"handleSaveEditInfo\">确 定</el-button>\n </span>\n </template>\n </el-dialog>\n\n <!-- 分享链接弹窗(二维码/链接/短链) -->\n <LinkDialog\n v-model:value=\"showLinkModal\"\n :download=\"false\"\n title=\"收取链接\"\n :link=\"shareTaskLink\"\n :share-text-prefix=\"shareTaskName\"\n />\n <!-- 附加属性编辑弹窗 -->\n <el-dialog\n v-model=\"showTaskInfoPanel\"\n :fullscreen=\"isMobile\"\n title=\"更多设置\"\n center\n >\n <div>\n <h3 class=\"tc\" style=\"font-size: 14px; color: #9e9e9e\">\n 任务名:<strong style=\"color: #000000\">{{ activeTask.name }}</strong>,\n <el-button type=\"primary\" text @click=\"openTaskPage\">\n 去查看效果\n </el-button>\n </h3>\n <el-tabs v-model=\"activeInfo\">\n <el-tab-pane label=\"截止日期\" name=\"ddl\">\n <DDlPanel :ddl=\"taskInfo.ddl\" :k=\"activeTask.key\" />\n </el-tab-pane>\n <el-tab-pane label=\"批注信息\" name=\"tip\">\n <TipInfoPanel\n :rewrite=\"taskInfo.rewrite\"\n :tip=\"taskInfo.tip\"\n :k=\"activeTask.key\"\n />\n </el-tab-pane>\n <el-tab-pane label=\"限制名单\" name=\"people\">\n <PeoplePanel\n :name=\"activeTask.name\"\n :value=\"taskInfo.people\"\n :k=\"activeTask.key\"\n :field=\"taskInfo.bindField\"\n />\n </el-tab-pane>\n <el-tab-pane label=\"必填信息\" name=\"info\">\n <InfoPanel\n :rewrite=\"taskInfo.rewrite\"\n :info=\"taskInfo.info\"\n :k=\"activeTask.key\"\n :format=\"taskInfo.format\"\n />\n </el-tab-pane>\n <el-tab-pane label=\"模板文件\" name=\"template\">\n <TemplatePanel :value=\"taskInfo.template\" :k=\"activeTask.key\" />\n </el-tab-pane>\n <el-tab-pane label=\"文件属性\" name=\"attr\">\n <FileInfoPanel :format=\"taskInfo.format\" :k=\"activeTask.key\" />\n </el-tab-pane>\n </el-tabs>\n </div>\n </el-dialog>\n </div>\n</template>\n\n<style scoped lang=\"scss\">\n.tasks {\n max-width: 1024px;\n margin: 0 auto;\n padding-bottom: 2em;\n}\n\n.tasks :deep(.el-dialog__body) {\n padding-top: 10px;\n}\n\n.panel {\n padding: 1em;\n background-color: #fff;\n margin: 10px auto;\n box-sizing: border-box;\n box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);\n border-radius: 4px;\n}\n\n.task-list {\n display: flex;\n flex-wrap: wrap;\n justify-content: space-around;\n}\n\n@media screen and (max-width: 700px) {\n .categorys-area {\n margin-top: 20px;\n }\n :deep(.el-tabs__nav-scroll) {\n overflow-x: scroll;\n &::-webkit-scrollbar {\n display: none; /* Chrome Safari */\n }\n }\n}\n</style>\n"],"names":["cardProps","buildProps","definePropType","__default__","_sfc_main","defineComponent","__props","ns","useNamespace","_ctx","_cache","openBlock","createElementBlock","normalizeClass","unref","renderSlot","createTextVNode","toDisplayString","createCommentVNode","createElementVNode","normalizeStyle","Card","_export_sfc","ElCard","withInstall","inputNumberProps","useSizeProp","val","isNumber","inputNumberEmits","CHANGE_EVENT","prev","cur","e","INPUT_EVENT","isNil","UPDATE_MODEL_EVENT","_hoisted_1","_hoisted_2","expose","emit","props","t","useLocale","input","ref","data","reactive","formItem","useFormItem","minDisabled","computed","ensurePrecision","maxDisabled","numPrecision","stepPrecision","getPrecision","isUndefined","controlsAtRight","inputNumberSize","useSize","inputNumberDisabled","useDisabled","displayValue","currentValue","toPrecision","num","pre","snum","pointPos","length","value","valueString","dotPosition","precision","coefficient","increase","newVal","setCurrentValue","decrease","verifyValue","update","max","min","step","stepStrictly","valueOnClear","isString","_a","oldVal","err","debugWarn","handleInput","handleInputChange","focus","_b","blur","handleFocus","event","handleBlur","watch","onMounted","modelValue","innerInput","onUpdated","withModifiers","withDirectives","withKeys","createVNode","ElIcon","withCtx","createBlock","ArrowDown","Minus","RepeatClick","ArrowUp","Plus","ElInput","InputNumber","ElInputNumber","_hoisted_3","_sfc_render","$props","$setup","$data","$options","circleCloseFilled","circlePlusFilled","_delete","_hoisted_4","edit","menu","plus","share","top","_sfc_main$9","DeleteFilled","context","$store","useStore","categorys","tasks","taskCount","c","count","isShowCreateCategory","categoryName","addCategory","ElMessage","handleClickCategory","k","ElMessageBox","_withScopeId","n","_pushScopeId","_popScopeId","_createElementVNode","_hoisted_5","_component_el_icon","__unplugin_components_3","_openBlock","_createElementBlock","_createBlock","_component_el_input","$event","_component_el_button","_createTextVNode","_createVNode","_component_el_tag","_toDisplayString","category","_withCtx","_component_DeleteFilled","_hoisted_6","_hoisted_7","_Fragment","_renderList","tag","isShowCreateTask","taskName","createTask","updateTaskInfo","debounce","key","options","successInfo","TaskApi","newDate","watchEffect","updateDDL","ddl","formatDate","closeDDL","waitTime","isOver","waitTimeStr","seconds","hour","day","minute","refreshWaitTime","loop","activeTab","userInputName","importStatus","handAddName","PeopleApi","checkMore","people","updateLimitPeople","limit","showPeopleList","peopleList","selectSubmitStatus","searchName","filterPeopleBySearchWord","v","peopleSubmitData","p","isLoadingPeopleData","refreshSubmitData","res","handleCheckMore","checkPeople","handleDeletePeople","item","peopleFileList","peopleUpload","handleExceedFile","clearFiles","submitUploadPeople","file","uploadFile","name","type","success","fail","tableToExcel","handleChangeFile","handleExportExcel","headers","body","status","lastDate","submitCount","fileCount","isMobile","useIsMobile","importPanelInfo","showImportPanel","openImportPanel","taskKey","ImportTaskTipMsg","taskList","taskValue","task","handleSaveImportInfo","importPanelFlexStyle","bindField","handleSureBind","_sfc_main$4","template","percentage","deleteTemplate","fileList","elUpload","FileApi","qiniuUpload","per","Tip","_component_el_upload","__unplugin_components_1","_component_tip","_createCommentVNode","formatData","getDefaultFormat","openPreview","infoTypeList","getTypeDes","selectType","siteConfig","useSiteConfig","maxInputLength","autoRewrite","infos","needSave","showAddInfo","parseInfo","resFormat","handleChange","addInfo","infoList","list","deleteInfo","idx","minLen","judgeInfoForm","items","saveInfo","moveInfoUp","temp","usefulInfo","showHelp","handleChangeSplitChar","splitCharList","parseFileFormat","textValue","tipData","MaxImgCount","imageList","previewList","previewIdx","parseData","PublicApi","url","updateTip","notify","imageViewerVisible","uid","getTipImageKey","handleRemove","handlePictureCardPreview","typeName","updateInfo","handleAddType","inputValue","handleDelType","handleCopyType","copyRes","handleChangeLimit","inputSize","unitList","handleChangeUnit","handleLimitSize","selectCategory","filterTasks","deleteTask","isTrash","showBaseInfoDialog","taskBaseInfo","editBaseInfo","handleSaveEditInfo","shareTaskLink","showLinkModal","shareTaskName","shareTask","origin","taskInfo","showTaskInfoPanel","activeInfo","activeTask","editMore","openTaskPage"],"mappings":"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","x_google_ignoreList":[0,1,2,3,4,5,6,7,8,9,10,11,12,13]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
@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}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
import{g as Ae,d as Ee,a as s,c,b as l,u as He,a1 as Ge,Z as U,O as _,r as h,$ as Je,bt as qe,o as Ke,aW as we,E as r,bf as Ye,i as Xe,j as d,w as n,F as $,C as le,t as k,a8 as se,k as N,S as g,e as u,D as y,a9 as ke,a5 as xe,a3 as Ze,aY as be,ag as oe,bX as Qe,ae as j,aa as et,af as $e,y as tt,v as at,x as lt,I as st,p as ot,f as nt,b0 as it,s as ut,ac as rt,a_ as dt,P as ct,_ as pt}from"./index-C0ZXXBCX.js";import{v as mt}from"./el-loading-BzK_8zqi.js";import{a as ft,E as vt}from"./el-progress-CeLYmjYA.js";import{E as _t,a as ht}from"./el-form-item-CtSEmj9z.js";import{T as E,E as gt}from"./tip-CrU2GCmD.js";import{I as yt,L as wt}from"./index-CsvxKrFP.js";import{u as kt}from"./el-dialog-Dq3XmL6w.js";import{E as Ne}from"./index-HzWmB96f.js";import"./index-BxLy8VN3.js";import"./isEqual-Cecwc716.js";import"./el-select-HG63LP3Z.js";import"./validator-Ca0QsRid.js";import"./aria-nkjrUMQ-.js";const xt=Ee({name:"UploadFilled"}),bt={viewBox:"0 0 1024 1024",xmlns:"http://www.w3.org/2000/svg"},$t=l("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),Nt=[$t];function Et(D,G,ne,ie,B,ue){return s(),c("svg",bt,Nt)}var Ft=Ae(xt,[["render",Et]]);const F=D=>(ot("data-v-8a74d233"),D=D(),nt(),D),Ct={class:"task-panel"},St={class:"pc-nav"},Ut={class:"nav"},zt={class:"logo"},It=F(()=>l("img",{style:{height:"40px",width:"170px"},src:"https://img.cdn.sugarat.top/easypicker/EasyPicker.png",alt:"logo"},null,-1)),Tt=["onClick"],Lt={key:0,"element-loading-text":"Loading...",class:"panel tc"},Mt={class:"name"},Vt={key:0,style:{color:"red"}},Dt={class:"tip-wrapper"},Bt={class:"ddl"},Pt={key:0},Rt={key:4},Wt={class:"infos"},Ot={key:0},jt={class:"infos"},At=F(()=>l("div",{class:"el-upload__text"},[u(" 将文件拖于此处 or "),l("em",null,"直接选择文件")],-1)),Ht={class:"p10"},Gt={class:"p10"},Jt={class:"p10 option-tips"},qt={style:{color:"red"}},Kt={style:{color:"red"}},Yt=F(()=>l("br",null,null,-1)),Xt=F(()=>l("br",null,null,-1)),Zt=F(()=>l("strong",null,"查询提交情况,需填写和提交时一样的表单信息",-1)),Qt=F(()=>l("br",null,null,-1)),ea=F(()=>l("strong",null,"选择大文件后需要等待一会儿才展示处理",-1)),ta=F(()=>l("br",null,null,-1)),aa={class:"withdraw"},la={key:1,class:"panel tc"},sa={class:"name"},oa={style:{"padding-top":"20px"}},na=Ee({__name:"index",setup(D){const G=kt(),ne=He(),ie=Ge(),B=U([{title:"我也要收集",path:"https://docs.ep.sugarat.top/"}]);function ue(t){if(B[t].path.startsWith("http")){window.location.href=B[t].path;return}ne.push({path:B[t].path})}const z=U({name:"",category:""}),o=U({bindField:""}),f=_(()=>it(o.format)),p=h(""),A=h(0),P=_(()=>A.value<=0),Fe=_(()=>{let t=~~(A.value/1e3),e=~~(t/(60*60));const a=~~(e/24);e%=24;const i=~~(t%3600/60);return t%=60,"剩余".concat(a,"天").concat(e,"时").concat(i,"分").concat(t,"秒")});function J(t=!0){if(o!=null&&o.ddl){const e=new Date(o.ddl);A.value=e.getTime()-Date.now()}else A.value=0;t&&setTimeout(()=>{J()},1e3)}const I=_(()=>{if(o!=null&&o.ddl){const t=new Date(o.ddl);return ut(t)}return""}),v=U([]),C=h([]),q=h(),K=_(()=>C.value.filter(t=>t.status==="uploading").length>0),Ce=t=>t.status==="uploading"||t.status==="success"?Ne.confirm("不影响已经上传成功的,正在上传的将取消上传","确定从列表移除文件吗?").then(()=>(t.status==="uploading"&&(r.info("取消".concat(t.name,"的上传")),t.subscription.unsubscribe()),!0)).catch(()=>!1):!0,Y=_(()=>v.every(t=>t.value)),T=_(()=>o.bindField.trim()||"姓名"),re=_(()=>v.find(t=>t.text===T.value)),Se=_(()=>o.people&&!re.value),x=U({peopleName:""});function de(t,e,a){if(!e){const i="请输入".concat(T.value);a(new Error(i)),r.error(i);return}be.checkPeopleIsExist(p.value,e).then(i=>{i.data.exist||r.error("你不在此次提交名单中,如有疑问请联系管理员"),a(i.data.exist?void 0:new Error("你不在此次提交名单中,如有疑问请联系管理员"))})}const ce=h(),Ue=U({peopleName:[{validator:de,trigger:"blur"}]});function X(){var t;if(re.value){const e=(t=v.find(a=>a.text===T.value))==null?void 0:t.value;return x.peopleName=e||"",new Promise(a=>{de(null,e,a)}).then(a=>!a)}return ce.value.validate(e=>e)}function ze(){const t=C.value;for(const e of t)if(!e.md5)r.info("文件(".concat(e.name,")的唯一指纹还在计算中,再等待一会儿再点击上传")),setTimeout(()=>{r.info("文件越大计算时间越长(1G通常需要20s)")},100);else if(e.status==="ready"){e.status="uploading";let{name:a}=e;const i=a;o.rewrite&&(a=v.map(W=>W.value).join(f.value.splitChar||"-")+oe(a)),a=rt(a);const te="easypicker2/".concat(p.value,"/").concat(e.md5,"/").concat(a);j.getUploadToken().then(W=>{dt(W.data.token,e.raw,te,{success(O){const{fsize:H}=O;j.addFile({originName:i,name:a,taskKey:p.value,taskName:z.name,size:H,hash:e.md5,info:JSON.stringify(v),people:x.peopleName}).then(()=>{e.status="success",r.success("文件:".concat(e.name,"提交成功")),o.people&&be.updatePeopleStatus(p.value,a,x.peopleName,e.md5)})},process(O,H,ae){e.percentage=Math.floor(O),e.subscription=ae}})})}}async function Ie(){if(!Y.value){r.warning("请先完成必要信息的填写");return}o.people&&!await X()||ze()}const Te=_(()=>{for(const t of C.value)if(t.status==="ready")return!0;return!1}),Le=_(()=>{for(const t of C.value)if(["success","ready"].includes(t.status))return!0;return!1}),L=h(0);function Me(t){const{name:e}=t;if(f.value.format.length&&f.value.status){const a=oe(e);if(!f.value.format.find(i=>a.toLowerCase().endsWith(i))){r.error("".concat(e," 格式不符合要求")),q.value.handleRemove(t);return}}if(f.value.size&&f.value.size<t.size){r.error("".concat(e," 大小").concat(xe(t.size)," 不符合要求")),q.value.handleRemove(t);return}L.value+=1,Qe(t.raw).then(a=>{t.md5=a,L.value-=1})}const pe=_(()=>f.value.limit||10);function Ve(){r.warning("一次提交最多只能选择".concat(pe.value,"个文件,请移除已经上传成功的或刷新页面"))}const Z=h(!1),me=h("");function De(){const t=C.value;for(const e of t)if(!e.md5)r.info("文件(".concat(e.name,")的唯一指纹还在计算中,再等待一会儿再点击上传")),setTimeout(()=>{r.info("文件越大计算时间越长(1G通常需要20s)")},100);else if(!["fail","uploading"].includes(e.status)){let{name:a}=e;o.rewrite&&(a=v.map(i=>i.value).join(f.value.splitChar||"-")+oe(a)),j.withdrawFile({taskKey:p.value,taskName:z.name,filename:a,hash:e.md5,info:JSON.stringify(v),peopleName:x.peopleName}).then(()=>{r.success("文件:".concat(e.name,"撤回成功")),e.name+=" - (已撤回 ✅ )",e.status="fail"}).catch(()=>{r.error("撤回失败: 没有文件:".concat(e.name,"对应提交记录"))})}}function fe(){j.getTemplateUrl(o.template,p.value).then(t=>{Z.value=!0;const{link:e}=t.data;me.value=e,et(e,o.template)}).catch(()=>{r.warning("文件已从服务器上移除,请联系管理员重新上传")})}const R=h(!1);async function Be(){if(!Y.value){r.warning("请先完成必要信息的填写");return}o.people&&!await X()||De()}async function Pe(){if(!Y.value){r.warning("请先完成必要信息的填写,需和提交时信息完全一致");return}o.people&&!await X()||j.checkSubmitStatus(p.value,v,x.peopleName).then(t=>{t.data.isSubmit?r.success("已经提交过啦"):r.warning("还未提交过哟")})}const Q=h(!1),ee=h(!1);function ve(t=[],e=[]){return t.length!==e.length?!1:t.every((a,i)=>a.type===e[i].type&&a.text===e[i].text&&ve(a.children,e[i].children))}function _e(t=!1){we.getTaskMoreInfo(p.value).then(e=>{Object.assign(o,e.data),ve(v,$e(o.info))||(v.splice(0,v.length),v.push(...$e(o.info)),t&&r.success("表单信息有更新")),J(!1),Q.value=!1})}function he(){ee.value=!0}function ge(){ee.value&&!K.value&&(ee.value=!1,_e(!0))}const Re=_(()=>P.value?I.value:I.value+Fe.value),S=U({text:"",imgs:[]}),w=h([]);Je(()=>o.tip,()=>{try{const t=JSON.parse(o.tip);S.imgs=t.imgs,S.text=t.text||"",w.value=S.imgs.map(e=>({...e,url:"https://img.cdn.sugarat.top/mdImg/MTY3NzkxMDI1NTU1Nw==20140524124237518.gif"})),w.value.length&&ct.getTipImageUrl(p.value,w.value.map(e=>({uid:e.uid,name:e.name}))).then(e=>{e.data.forEach((a,i)=>{w.value[i].url=a.cover,Object.assign(w.value[i],{preview:a.preview})})})}catch(t){S.text="",S.imgs=[],w.value=[]}});const M=qe("disabledUpload",!1);return Ke(()=>{p.value=ie.params.key,p.value&&(Q.value=!0,we.getTaskInfo(p.value).then(t=>{Object.assign(z,t.data),M.value=!!t.data.limitUpload,M.value&&Ne.alert("任务存储空间容量已达到上限,已经无法进行上传,请联系发起人扩容空间")}).catch(t=>{t.code===4001&&(r.error("任务不存在"),p.value="",z.name="任务不存在")}),_e(),J()),window.addEventListener("blur",he),window.addEventListener("focus",ge)}),Ye(()=>{window.removeEventListener("blur",he),window.removeEventListener("focus",ge)}),(t,e)=>{const a=Xe("router-link"),i=tt,te=gt,W=ft,O=at,H=_t,ae=ht,b=lt,We=st,Oe=vt,je=mt;return s(),c("div",Ct,[l("div",St,[l("div",Ut,[l("div",zt,[d(a,{to:"/"},{default:n(()=>[It]),_:1})]),l("nav",null,[(s(!0),c($,null,le(B,(m,V)=>(s(),c("div",{key:V,class:"nav-item",onClick:ye=>ue(V)},k(m.title),9,Tt))),128))])])]),p.value?se((s(),c("div",Lt,[l("h1",Mt,k(z.name),1),N(M)?(s(),c("h2",Vt," 任务存储空间容量已达到上限,已经无法进行上传,请联系发起人扩容空间 ")):g("",!0),S.text&&(!I.value||!P.value)?(s(),c($,{key:1},[d(i,null,{default:n(()=>[u("⚠️ 注意事项 ⚠️")]),_:1}),d(E,null,{default:n(()=>[l("div",Dt,[(s(!0),c($,null,le(S.text.split("\n"),(m,V)=>(s(),c("p",{key:V},k(m.replace(/\s/g," ")),1))),128))])]),_:1})],64)):g("",!0),w.value.length&&(!I.value||!P.value)?(s(!0),c($,{key:2},le(w.value,(m,V)=>(s(),y(te,{key:m.uid,"hide-on-click-modal":"",style:{width:"100px",height:"100px",margin:"10px"},src:m.url,"zoom-rate":1.2,"preview-src-list":w.value.map(ye=>ye.preview),"initial-index":V,fit:"contain"},null,8,["src","preview-src-list","initial-index"]))),128)):g("",!0),I.value?(s(),c($,{key:3},[d(i,null,{default:n(()=>[u("截止时间")]),_:1}),l("h2",Bt,k(Re.value),1),P.value?(s(),c("div",Pt,[d(W,{description:"已经结束啦!"})])):g("",!0)],64)):g("",!0),!I.value||!P.value?(s(),c("div",Rt,[d(i,null,{default:n(()=>[u("必要信息填写")]),_:1}),l("div",Wt,[se(l("div",null,[d(E,null,{default:n(()=>[u("“"+k(T.value)+"”在参与名单里才能正常提交",1)]),_:1})],512),[[ke,o.people]]),Se.value?(s(),c("div",Ot,[l("div",jt,[d(ae,{ref_key:"validModalRef",ref:ce,rules:Ue,"status-icon":"",model:x,disabled:K.value,"label-position":"top"},{default:n(()=>[d(H,{prop:"peopleName",label:T.value},{default:n(()=>[d(O,{modelValue:x.peopleName,"onUpdate:modelValue":e[0]||(e[0]=m=>x.peopleName=m),maxlength:14,clearable:"","show-word-limit":"",placeholder:"请输入 ".concat(T.value)},null,8,["modelValue","placeholder"])]),_:1},8,["label"])]),_:1},8,["rules","model","disabled"])])])):g("",!0),d(yt,{infos:v,disabled:K.value},null,8,["infos","disabled"])]),d(Oe,{ref_key:"fileUpload",ref:q,"file-list":C.value,"onUpdate:fileList":e[1]||(e[1]=m=>C.value=m),style:{"max-width":"400px",margin:"0 auto"},drag:!N(G),action:"","on-change":Me,"before-remove":Ce,"on-exceed":Ve,"auto-upload":!1,multiple:"",limit:pe.value},{tip:n(()=>[se(l("div",Ht,[d(E,null,{default:n(()=>[u(" 还有 "+k(L.value)+" 个文件正在生成校验信息,请稍等(1G通常需要20s) ",1)]),_:1})],512),[[ke,!!L.value]])]),default:n(()=>[N(G)?(s(),y(b,{key:0,type:"primary"},{default:n(()=>[u(" 选择文件 ")]),_:1})):(s(),c($,{key:1},[d(We,{class:"el-icon--upload"},{default:n(()=>[d(N(Ft))]),_:1}),At],64))]),_:1},8,["file-list","drag","limit"]),l("div",Gt,[R.value?(s(),y(b,{key:0,size:"default",type:"warning",disabled:!Le.value||!!L.value,onClick:Be},{default:n(()=>[u(" 一键撤回 ")]),_:1},8,["disabled"])):N(M)?g("",!0):(s(),y(b,{key:1,size:"default",type:"success",disabled:!Te.value||!!L.value,onClick:Ie},{default:n(()=>[u(" 提交文件 ")]),_:1},8,["disabled"])),d(b,{size:"default",onClick:Pe},{default:n(()=>[u(" 查询提交情况 ")]),_:1})]),l("div",Jt,[f.value.status&&f.value.format.length?(s(),y(E,{key:0},{default:n(()=>[u(" 限制格式为: "),l("span",qt,k(f.value.format.join(", ")),1)]),_:1})):g("",!0),f.value.size?(s(),y(E,{key:1},{default:n(()=>[u(" 限制文件大小不超过: "),l("span",Kt,k(N(xe)(f.value.size)),1)]),_:1})):g("",!0),R.value?(s(),y(E,{key:2},{default:n(()=>[u(" ① 须保证选择的文件与提交时的文件一致"),Yt,u(" ② 填写表单信息一致 "),Xt,u(" ③ 完全一模一样的文件的提交记录(内容md5+命名),将会一次性全部撤回 ")]),_:1})):(s(),c($,{key:3},[d(E,null,{default:n(()=>[Zt]),_:1}),d(E,null,{default:n(()=>[u(" ① 选择完文件,点击 ”提交文件“即可 "),Qt,u(" ② "),ea,o.template&&!N(M)?(s(),c($,{key:0},[ta,u(" ③ "),l("strong",null,[d(b,{type:"primary",text:"",style:{color:"#85ce61"},size:"small",onClick:fe},{default:n(()=>[u("右下角可 “查看提交示例” ")]),_:1})])],64)):g("",!0)]),_:1})],64))]),l("div",aa,[o.template&&!N(M)?(s(),y(b,{key:0,type:"primary",text:"",style:{color:"#85ce61"},size:"small",onClick:fe},{default:n(()=>[u(" 查看提交示例 ")]),_:1})):g("",!0),R.value?(s(),y(b,{key:1,size:"small",type:"primary",text:"",onClick:e[2]||(e[2]=m=>R.value=!1)},{default:n(()=>[u(" 正常提交 ")]),_:1})):(s(),y(b,{key:2,size:"small",type:"primary",text:"",onClick:e[3]||(e[3]=m=>R.value=!0)},{default:n(()=>[u(" 我要撤回 ")]),_:1}))])])):g("",!0)])),[[je,Q.value]]):(s(),c("div",la,[l("h1",sa,k(z.name),1)])),d(wt,{value:Z.value,"onUpdate:value":e[4]||(e[4]=m=>Z.value=m),title:"示例文件下载链接",link:me.value},null,8,["value","link"]),l("div",oa,[d(Ze,{type:"task"})])])}}}),wa=pt(na,[["__scopeId","data-v-8a74d233"]]);export{wa as default};
|
|
2
|
-
//# sourceMappingURL=index-GC0X-O3Y.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index-GC0X-O3Y.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, ' ') }}\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","_hoisted_1","_hoisted_2","createElementVNode","_hoisted_3","_sfc_render","_ctx","_cache","$props","$setup","$data","$options","openBlock","createElementBlock","uploadFilled","_export_sfc","isMobile","useIsMobile","$router","useRouter","$route","useRoute","pcNavs","reactive","handleNav","idx","taskInfo","taskMoreInfo","formatData","computed","parseFileFormat","k","ref","waitTime","isOver","waitTimeStr","seconds","hour","day","minute","refreshWaitTime","loop","date","ddlStr","formatDate","infos","fileList","fileUpload","disableForm","item","handleRemoveFile","file","ElMessageBox","ElMessage","isWriteFinish","limitBindField","isSameFieldName","v","showValidForm","validModal","validatePeopleName","rule","value","callback","message","PeopleApi","res","validModalRef","validModalRules","confirmPeopleName","_a","resolve","isValid","startUpload","uploadFiles","name","originName","getFileSuffix","normalizeFileName","key","FileApi","qiniuUpload","data","fsize","per","subscription","submitUpload","allowUpload","allowWithdraw","calculateMd5Count","handleChangeFile","suffix","formatSize","getFileMd5Hash","str","limitUploadCount","handleExceed","showLinkModel","templateLink","runWithdraw","downloadTemplate","link","downLoadByUrl","isWithdraw","startWithdraw","checkSubmitStatus","isLoadingData","readyRefresh","isEqualInfos","a","b","refreshTaskMoreInfo","hot","TaskApi","parseInfo","handleBlur","handleFocus","timeInfo","tipData","imageList","watch","parseData","PublicApi","url","e","disabledUpload","useLocalStorage","onMounted","err","onUnmounted"],"mappings":"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","x_google_ignoreList":[0]}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
import{$ as H,bu as fe,au as A,am as me,N as pe,d as ve,x as ge,cb as be,v as ye,I as Ce,cc as he,Q as Ee,r as h,bL as Be,Z as we,O as E,cd as _,at as ee,az as Me,o as ke,ak as Se,bO as Ie,i as B,a as d,D as v,w as c,a8 as K,j as w,b as f,H as i,aD as ne,aT as z,c as j,G as P,S as M,t as T,aP as D,T as Te,e as q,a9 as G,bh as Ae,bP as Re,aU as $e,ce as O,cf as ae,bK as se,bp as Le,aM as Ve,bm as ze}from"./index-C0ZXXBCX.js";import{b as Pe,d as De,e as Oe,f as He}from"./el-dialog-Dq3XmL6w.js";import{o as oe}from"./aria-nkjrUMQ-.js";import{i as Ne}from"./validator-Ca0QsRid.js";import{u as Ue}from"./index-BxLy8VN3.js";const Fe=(e,n)=>{let a;H(()=>e.value,l=>{var t,o;l?(a=document.activeElement,fe(n)&&((o=(t=n.value).focus)==null||o.call(t))):a.focus()})},Z="_trap-focus-children",b=[],te=e=>{if(b.length===0)return;const n=b[b.length-1][Z];if(n.length>0&&e.code===me.tab){if(n.length===1){e.preventDefault(),document.activeElement!==n[0]&&n[0].focus();return}const a=e.shiftKey,l=e.target===n[0],t=e.target===n[n.length-1];l&&a&&(e.preventDefault(),n[n.length-1].focus()),t&&!a&&(e.preventDefault(),n[0].focus())}},Ke={beforeMount(e){e[Z]=oe(e),b.push(e),b.length<=1&&document.addEventListener("keydown",te)},updated(e){A(()=>{e[Z]=oe(e)})},unmounted(){b.shift(),b.length===0&&document.removeEventListener("keydown",te)}},je=ve({name:"ElMessageBox",directives:{TrapFocus:Ke},components:{ElButton:ge,ElFocusTrap:be,ElInput:ye,ElOverlay:Pe,ElIcon:Ce,...he},inheritAttrs:!1,props:{buttonSize:{type:String,validator:Ne},modal:{type:Boolean,default:!0},lockScroll:{type:Boolean,default:!0},showClose:{type:Boolean,default:!0},closeOnClickModal:{type:Boolean,default:!0},closeOnPressEscape:{type:Boolean,default:!0},closeOnHashChange:{type:Boolean,default:!0},center:Boolean,draggable:Boolean,roundButton:{default:!1,type:Boolean},container:{type:String,default:"body"},boxType:{type:String,default:""}},emits:["vanish","action"],setup(e,{emit:n}){const{t:a}=Ue(),l=Ee("message-box"),t=h(!1),{nextZIndex:o}=Be(),s=we({autofocus:!0,beforeClose:null,callback:null,cancelButtonText:"",cancelButtonClass:"",confirmButtonText:"",confirmButtonClass:"",customClass:"",customStyle:{},dangerouslyUseHTMLString:!1,distinguishCancelAndClose:!1,icon:"",inputPattern:null,inputPlaceholder:"",inputType:"text",inputValue:null,inputValidator:null,inputErrorMessage:"",message:null,modalFade:!0,modalClass:"",showCancelButton:!1,showConfirmButton:!0,type:"",title:void 0,showInput:!1,action:"",confirmButtonLoading:!1,cancelButtonLoading:!1,confirmButtonDisabled:!1,editorErrorMessage:"",validateError:!1,zIndex:o()}),m=E(()=>{const r=s.type;return{[l.bm("icon",r)]:r&&_[r]}}),N=ee(),$=ee(),U=Me(E(()=>e.buttonSize),{prop:!0,form:!0,formItem:!0}),F=E(()=>s.icon||_[s.type]||""),u=E(()=>!!s.message),y=h(),X=h(),S=h(),L=h(),Q=h(),le=E(()=>s.confirmButtonClass);H(()=>s.inputValue,async r=>{await A(),e.boxType==="prompt"&&r!==null&&J()},{immediate:!0}),H(()=>t.value,r=>{var p,C;r&&(e.boxType!=="prompt"&&(s.autofocus?S.value=(C=(p=Q.value)==null?void 0:p.$el)!=null?C:y.value:S.value=y.value),s.zIndex=o()),e.boxType==="prompt"&&(r?A().then(()=>{var x;L.value&&L.value.$el&&(s.autofocus?S.value=(x=de())!=null?x:y.value:S.value=y.value)}):(s.editorErrorMessage="",s.validateError=!1))});const re=E(()=>e.draggable);De(y,X,re),ke(async()=>{await A(),e.closeOnHashChange&&window.addEventListener("hashchange",I)}),Se(()=>{e.closeOnHashChange&&window.removeEventListener("hashchange",I)});function I(){t.value&&(t.value=!1,A(()=>{s.action&&n("action",s.action)}))}const W=()=>{e.closeOnClickModal&&V(s.distinguishCancelAndClose?"close":"cancel")},ie=He(W),ue=r=>{if(s.inputType!=="textarea")return r.preventDefault(),V("confirm")},V=r=>{var p;e.boxType==="prompt"&&r==="confirm"&&!J()||(s.action=r,s.beforeClose?(p=s.beforeClose)==null||p.call(s,r,s,I):I())},J=()=>{if(e.boxType==="prompt"){const r=s.inputPattern;if(r&&!r.test(s.inputValue||""))return s.editorErrorMessage=s.inputErrorMessage||a("el.messagebox.error"),s.validateError=!0,!1;const p=s.inputValidator;if(typeof p=="function"){const C=p(s.inputValue);if(C===!1)return s.editorErrorMessage=s.inputErrorMessage||a("el.messagebox.error"),s.validateError=!0,!1;if(typeof C=="string")return s.editorErrorMessage=C,s.validateError=!0,!1}}return s.editorErrorMessage="",s.validateError=!1,!0},de=()=>{const r=L.value.$refs;return r.input||r.textarea},Y=()=>{V("close")},ce=()=>{e.closeOnPressEscape&&Y()};return e.lockScroll&&Oe(t),Fe(t),{...Ie(s),ns:l,overlayEvent:ie,visible:t,hasMessage:u,typeClass:m,contentId:N,inputId:$,btnSize:U,iconComponent:F,confirmButtonClasses:le,rootRef:y,focusStartRef:S,headerRef:X,inputRef:L,confirmRef:Q,doClose:I,handleClose:Y,onCloseRequested:ce,handleWrapperClick:W,handleInputEnter:ue,handleAction:V,t:a}}}),qe=["aria-label","aria-describedby"],Ge=["aria-label"],Ze=["id"];function Xe(e,n,a,l,t,o){const s=B("el-icon"),m=B("close"),N=B("el-input"),$=B("el-button"),U=B("el-focus-trap"),F=B("el-overlay");return d(),v(Ae,{name:"fade-in-linear",onAfterLeave:n[11]||(n[11]=u=>e.$emit("vanish")),persisted:""},{default:c(()=>[K(w(F,{"z-index":e.zIndex,"overlay-class":[e.ns.is("message-box"),e.modalClass],mask:e.modal},{default:c(()=>[f("div",{role:"dialog","aria-label":e.title,"aria-modal":"true","aria-describedby":e.showInput?void 0:e.contentId,class:i("".concat(e.ns.namespace.value,"-overlay-message-box")),onClick:n[8]||(n[8]=(...u)=>e.overlayEvent.onClick&&e.overlayEvent.onClick(...u)),onMousedown:n[9]||(n[9]=(...u)=>e.overlayEvent.onMousedown&&e.overlayEvent.onMousedown(...u)),onMouseup:n[10]||(n[10]=(...u)=>e.overlayEvent.onMouseup&&e.overlayEvent.onMouseup(...u))},[w(U,{loop:"",trapped:e.visible,"focus-trap-el":e.rootRef,"focus-start-el":e.focusStartRef,onReleaseRequested:e.onCloseRequested},{default:c(()=>[f("div",{ref:"rootRef",class:i([e.ns.b(),e.customClass,e.ns.is("draggable",e.draggable),{[e.ns.m("center")]:e.center}]),style:ne(e.customStyle),tabindex:"-1",onClick:n[7]||(n[7]=z(()=>{},["stop"]))},[e.title!==null&&e.title!==void 0?(d(),j("div",{key:0,ref:"headerRef",class:i(e.ns.e("header"))},[f("div",{class:i(e.ns.e("title"))},[e.iconComponent&&e.center?(d(),v(s,{key:0,class:i([e.ns.e("status"),e.typeClass])},{default:c(()=>[(d(),v(P(e.iconComponent)))]),_:1},8,["class"])):M("v-if",!0),f("span",null,T(e.title),1)],2),e.showClose?(d(),j("button",{key:0,type:"button",class:i(e.ns.e("headerbtn")),"aria-label":e.t("el.messagebox.close"),onClick:n[0]||(n[0]=u=>e.handleAction(e.distinguishCancelAndClose?"close":"cancel")),onKeydown:n[1]||(n[1]=D(z(u=>e.handleAction(e.distinguishCancelAndClose?"close":"cancel"),["prevent"]),["enter"]))},[w(s,{class:i(e.ns.e("close"))},{default:c(()=>[w(m)]),_:1},8,["class"])],42,Ge)):M("v-if",!0)],2)):M("v-if",!0),f("div",{id:e.contentId,class:i(e.ns.e("content"))},[f("div",{class:i(e.ns.e("container"))},[e.iconComponent&&!e.center&&e.hasMessage?(d(),v(s,{key:0,class:i([e.ns.e("status"),e.typeClass])},{default:c(()=>[(d(),v(P(e.iconComponent)))]),_:1},8,["class"])):M("v-if",!0),e.hasMessage?(d(),j("div",{key:1,class:i(e.ns.e("message"))},[Te(e.$slots,"default",{},()=>[e.dangerouslyUseHTMLString?(d(),v(P(e.showInput?"label":"p"),{key:1,for:e.showInput?e.inputId:void 0,innerHTML:e.message},null,8,["for","innerHTML"])):(d(),v(P(e.showInput?"label":"p"),{key:0,for:e.showInput?e.inputId:void 0},{default:c(()=>[q(T(e.dangerouslyUseHTMLString?"":e.message),1)]),_:1},8,["for"]))])],2)):M("v-if",!0)],2),K(f("div",{class:i(e.ns.e("input"))},[w(N,{id:e.inputId,ref:"inputRef",modelValue:e.inputValue,"onUpdate:modelValue":n[2]||(n[2]=u=>e.inputValue=u),type:e.inputType,placeholder:e.inputPlaceholder,"aria-invalid":e.validateError,class:i({invalid:e.validateError}),onKeydown:D(e.handleInputEnter,["enter"])},null,8,["id","modelValue","type","placeholder","aria-invalid","class","onKeydown"]),f("div",{class:i(e.ns.e("errormsg")),style:ne({visibility:e.editorErrorMessage?"visible":"hidden"})},T(e.editorErrorMessage),7)],2),[[G,e.showInput]])],10,Ze),f("div",{class:i(e.ns.e("btns"))},[e.showCancelButton?(d(),v($,{key:0,loading:e.cancelButtonLoading,class:i([e.cancelButtonClass]),round:e.roundButton,size:e.btnSize,onClick:n[3]||(n[3]=u=>e.handleAction("cancel")),onKeydown:n[4]||(n[4]=D(z(u=>e.handleAction("cancel"),["prevent"]),["enter"]))},{default:c(()=>[q(T(e.cancelButtonText||e.t("el.messagebox.cancel")),1)]),_:1},8,["loading","class","round","size"])):M("v-if",!0),K(w($,{ref:"confirmRef",type:"primary",loading:e.confirmButtonLoading,class:i([e.confirmButtonClasses]),round:e.roundButton,disabled:e.confirmButtonDisabled,size:e.btnSize,onClick:n[5]||(n[5]=u=>e.handleAction("confirm")),onKeydown:n[6]||(n[6]=D(z(u=>e.handleAction("confirm"),["prevent"]),["enter"]))},{default:c(()=>[q(T(e.confirmButtonText||e.t("el.messagebox.confirm")),1)]),_:1},8,["loading","class","round","disabled","size"]),[[G,e.showConfirmButton]])],2)],6)]),_:3},8,["trapped","focus-trap-el","focus-start-el","onReleaseRequested"])],42,qe)]),_:3},8,["z-index","overlay-class","mask"]),[[G,e.visible]])]),_:3})}var Qe=pe(je,[["render",Xe],["__file","/home/runner/work/element-plus/element-plus/packages/components/message-box/src/index.vue"]]);const R=new Map,We=(e,n,a=null)=>{const l=ze(Qe,e);return l.appContext=a,ae(l,n),document.body.appendChild(n.firstElementChild),l.component},Je=()=>document.createElement("div"),Ye=(e,n)=>{const a=Je();e.onVanish=()=>{ae(null,a),R.delete(t)},e.onAction=o=>{const s=R.get(t);let m;e.showInput?m={value:t.inputValue,action:o}:m=o,e.callback?e.callback(m,l.proxy):o==="cancel"||o==="close"?e.distinguishCancelAndClose&&o!=="cancel"?s.reject("close"):s.reject("cancel"):s.resolve(m)};const l=We(e,a,n),t=l.proxy;for(const o in e)se(e,o)&&!se(t.$props,o)&&(t[o]=e[o]);return H(()=>t.message,(o,s)=>{O(o)?l.slots.default=()=>[o]:O(s)&&!O(o)&&delete l.slots.default},{immediate:!0}),t.visible=!0,t};function k(e,n=null){if(!Re)return Promise.reject();let a;return $e(e)||O(e)?e={message:e}:a=e.callback,new Promise((l,t)=>{const o=Ye(e,n!=null?n:k._context);R.set(o,{options:e,callback:a,resolve:l,reject:t})})}const xe=["alert","confirm","prompt"],_e={alert:{closeOnPressEscape:!1,closeOnClickModal:!1},confirm:{showCancelButton:!0},prompt:{showCancelButton:!0,showInput:!0}};xe.forEach(e=>{k[e]=en(e)});function en(e){return(n,a,l,t)=>{let o;return Le(a)?(l=a,o=""):Ve(a)?o="":o=a,k(Object.assign({title:o,message:n,type:"",..._e[e]},l,{boxType:e}),t)}}k.close=()=>{R.forEach((e,n)=>{n.doClose()}),R.clear()};k._context=null;const g=k;g.install=e=>{g._context=e._context,e.config.globalProperties.$msgbox=g,e.config.globalProperties.$messageBox=g,e.config.globalProperties.$alert=g.alert,e.config.globalProperties.$confirm=g.confirm,e.config.globalProperties.$prompt=g.prompt};const ln=g;export{ln as E};
|
|
2
|
-
//# sourceMappingURL=index-HzWmB96f.js.map
|