fast-element-plus 1.0.0 → 1.0.1
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/Fast.png +0 -0
- package/LICENSE +201 -0
- package/README.md +164 -0
- package/README.zh.md +164 -0
- package/dist/index.full.js +28446 -0
- package/dist/index.full.js.map +1 -0
- package/dist/index.full.min.js +36 -0
- package/dist/index.full.min.js.map +1 -0
- package/dist/index.full.min.mjs +36 -0
- package/dist/index.full.min.mjs.map +1 -0
- package/dist/index.full.mjs +28445 -0
- package/dist/index.full.mjs.map +1 -0
- package/dist/styles/index.css +984 -0
- package/dist/styles/index.css.map +1 -0
- package/es/component.d.ts +3 -0
- package/es/component.mjs +52 -0
- package/es/component.mjs.map +1 -0
- package/es/components/avatar/index.d.ts +14 -0
- package/es/components/avatar/index.mjs +8 -0
- package/es/components/avatar/index.mjs.map +1 -0
- package/es/components/avatar/src/avatar.d.ts +96 -0
- package/es/components/avatar/src/avatar.mjs +76 -0
- package/es/components/avatar/src/avatar.mjs.map +1 -0
- package/es/components/button/index.d.ts +15 -0
- package/es/components/button/index.mjs +11 -0
- package/es/components/button/index.mjs.map +1 -0
- package/es/components/button/src/button.d.ts +173 -0
- package/es/components/button/src/button.mjs +118 -0
- package/es/components/button/src/button.mjs.map +1 -0
- package/es/components/carNumber/index.d.ts +9 -0
- package/es/components/carNumber/index.mjs +12 -0
- package/es/components/carNumber/index.mjs.map +1 -0
- package/es/components/carNumber/src/carNumber.d.ts +217 -0
- package/es/components/carNumber/src/carNumber.mjs +164 -0
- package/es/components/carNumber/src/carNumber.mjs.map +1 -0
- package/es/components/carNumber/src/common.d.ts +15 -0
- package/es/components/carNumber/src/common.mjs +75 -0
- package/es/components/carNumber/src/common.mjs.map +1 -0
- package/es/components/contextMenu/index.d.ts +9 -0
- package/es/components/contextMenu/index.mjs +9 -0
- package/es/components/contextMenu/index.mjs.map +1 -0
- package/es/components/contextMenu/src/contextMenu.d.ts +32 -0
- package/es/components/contextMenu/src/contextMenu.mjs +85 -0
- package/es/components/contextMenu/src/contextMenu.mjs.map +1 -0
- package/es/components/contextMenu/src/contextMenu.type.d.ts +33 -0
- package/es/components/contextMenu/src/contextMenu.type.mjs +2 -0
- package/es/components/contextMenu/src/contextMenu.type.mjs.map +1 -0
- package/es/components/dialog/index.d.ts +14 -0
- package/es/components/dialog/index.mjs +11 -0
- package/es/components/dialog/index.mjs.map +1 -0
- package/es/components/dialog/src/dialog.d.ts +454 -0
- package/es/components/dialog/src/dialog.mjs +285 -0
- package/es/components/dialog/src/dialog.mjs.map +1 -0
- package/es/components/drawer/index.d.ts +14 -0
- package/es/components/drawer/index.mjs +8 -0
- package/es/components/drawer/index.mjs.map +1 -0
- package/es/components/drawer/src/drawer.d.ts +449 -0
- package/es/components/drawer/src/drawer.mjs +284 -0
- package/es/components/drawer/src/drawer.mjs.map +1 -0
- package/es/components/form/index.d.ts +23 -0
- package/es/components/form/index.mjs +19 -0
- package/es/components/form/index.mjs.map +1 -0
- package/es/components/form/src/form.d.ts +194 -0
- package/es/components/form/src/form.mjs +109 -0
- package/es/components/form/src/form.mjs.map +1 -0
- package/es/components/form/src/formItem.d.ts +190 -0
- package/es/components/form/src/formItem.mjs +117 -0
- package/es/components/form/src/formItem.mjs.map +1 -0
- package/es/components/form/utils/form.d.ts +81 -0
- package/es/components/form/utils/form.mjs +217 -0
- package/es/components/form/utils/form.mjs.map +1 -0
- package/es/components/formItemTip/index.d.ts +12 -0
- package/es/components/formItemTip/index.mjs +10 -0
- package/es/components/formItemTip/index.mjs.map +1 -0
- package/es/components/formItemTip/src/formItemTip.d.ts +22 -0
- package/es/components/formItemTip/src/formItemTip.mjs +38 -0
- package/es/components/formItemTip/src/formItemTip.mjs.map +1 -0
- package/es/components/icon/index.d.ts +12 -0
- package/es/components/icon/index.mjs +8 -0
- package/es/components/icon/index.mjs.map +1 -0
- package/es/components/icon/src/icon.d.ts +39 -0
- package/es/components/icon/src/icon.mjs +69 -0
- package/es/components/icon/src/icon.mjs.map +1 -0
- package/es/components/iconSelector/index.d.ts +7 -0
- package/es/components/iconSelector/index.mjs +8 -0
- package/es/components/iconSelector/index.mjs.map +1 -0
- package/es/components/iconSelector/src/iconSelector.d.ts +23 -0
- package/es/components/iconSelector/src/iconSelector.mjs +143 -0
- package/es/components/iconSelector/src/iconSelector.mjs.map +1 -0
- package/es/components/image/index.d.ts +12 -0
- package/es/components/image/index.mjs +10 -0
- package/es/components/image/index.mjs.map +1 -0
- package/es/components/image/src/image.d.ts +225 -0
- package/es/components/image/src/image.mjs +90 -0
- package/es/components/image/src/image.mjs.map +1 -0
- package/es/components/index.d.ts +21 -0
- package/es/components/index.mjs +100 -0
- package/es/components/index.mjs.map +1 -0
- package/es/components/layoutGrid/index.d.ts +16 -0
- package/es/components/layoutGrid/index.mjs +14 -0
- package/es/components/layoutGrid/index.mjs.map +1 -0
- package/es/components/layoutGrid/src/layoutGrid.d.ts +60 -0
- package/es/components/layoutGrid/src/layoutGrid.mjs +178 -0
- package/es/components/layoutGrid/src/layoutGrid.mjs.map +1 -0
- package/es/components/layoutGrid/src/layoutGrid.type.d.ts +12 -0
- package/es/components/layoutGrid/src/layoutGrid.type.mjs +2 -0
- package/es/components/layoutGrid/src/layoutGrid.type.mjs.map +1 -0
- package/es/components/layoutGrid/src/layoutGridItem.d.ts +100 -0
- package/es/components/layoutGrid/src/layoutGridItem.mjs +97 -0
- package/es/components/layoutGrid/src/layoutGridItem.mjs.map +1 -0
- package/es/components/select/index.d.ts +22 -0
- package/es/components/select/index.mjs +17 -0
- package/es/components/select/index.mjs.map +1 -0
- package/es/components/select/src/select.d.ts +1201 -0
- package/es/components/select/src/select.mjs +559 -0
- package/es/components/select/src/select.mjs.map +1 -0
- package/es/components/select/src/select.type.d.ts +28 -0
- package/es/components/select/src/select.type.mjs +2 -0
- package/es/components/select/src/select.type.mjs.map +1 -0
- package/es/components/select/src/selectOption.d.ts +99 -0
- package/es/components/select/src/selectOption.mjs +71 -0
- package/es/components/select/src/selectOption.mjs.map +1 -0
- package/es/components/selectPage/index.d.ts +14 -0
- package/es/components/selectPage/index.mjs +11 -0
- package/es/components/selectPage/index.mjs.map +1 -0
- package/es/components/selectPage/src/selectPage.d.ts +595 -0
- package/es/components/selectPage/src/selectPage.mjs +381 -0
- package/es/components/selectPage/src/selectPage.mjs.map +1 -0
- package/es/components/selectV2/index.d.ts +14 -0
- package/es/components/selectV2/index.mjs +11 -0
- package/es/components/selectV2/index.mjs.map +1 -0
- package/es/components/selectV2/src/selectV2.d.ts +1407 -0
- package/es/components/selectV2/src/selectV2.mjs +606 -0
- package/es/components/selectV2/src/selectV2.mjs.map +1 -0
- package/es/components/table/images/artwork.png.mjs +5 -0
- package/es/components/table/images/artwork.png.mjs.map +1 -0
- package/es/components/table/images/index.d.ts +4 -0
- package/es/components/table/images/notImage.png.mjs +5 -0
- package/es/components/table/images/notImage.png.mjs.map +1 -0
- package/es/components/table/index.d.ts +35 -0
- package/es/components/table/index.mjs +32 -0
- package/es/components/table/index.mjs.map +1 -0
- package/es/components/table/src/page.type.d.ts +145 -0
- package/es/components/table/src/page.type.mjs +16 -0
- package/es/components/table/src/page.type.mjs.map +1 -0
- package/es/components/table/src/table.d.ts +1382 -0
- package/es/components/table/src/table.mjs +1046 -0
- package/es/components/table/src/table.mjs.map +1 -0
- package/es/components/table/src/table.state.d.ts +115 -0
- package/es/components/table/src/table.state.mjs +2 -0
- package/es/components/table/src/table.state.mjs.map +1 -0
- package/es/components/table/src/table.type.d.ts +316 -0
- package/es/components/table/src/table.type.mjs +14 -0
- package/es/components/table/src/table.type.mjs.map +1 -0
- package/es/components/table/src/tableColumn.d.ts +644 -0
- package/es/components/table/src/tableColumn.mjs +604 -0
- package/es/components/table/src/tableColumn.mjs.map +1 -0
- package/es/components/table/src/tableColumnSettingDialog.d.ts +18 -0
- package/es/components/table/src/tableColumnSettingDialog.mjs +430 -0
- package/es/components/table/src/tableColumnSettingDialog.mjs.map +1 -0
- package/es/components/table/src/tablePagination.d.ts +24 -0
- package/es/components/table/src/tablePagination.mjs +56 -0
- package/es/components/table/src/tablePagination.mjs.map +1 -0
- package/es/components/table/src/tableSearchForm.d.ts +88 -0
- package/es/components/table/src/tableSearchForm.mjs +269 -0
- package/es/components/table/src/tableSearchForm.mjs.map +1 -0
- package/es/components/table/src/tableSearchFormItem.d.ts +37 -0
- package/es/components/table/src/tableSearchFormItem.mjs +121 -0
- package/es/components/table/src/tableSearchFormItem.mjs.map +1 -0
- package/es/components/table/src/useTable.d.ts +32 -0
- package/es/components/table/src/useTable.mjs +374 -0
- package/es/components/table/src/useTable.mjs.map +1 -0
- package/es/components/table/utils/table.d.ts +45 -0
- package/es/components/table/utils/table.mjs +122 -0
- package/es/components/table/utils/table.mjs.map +1 -0
- package/es/components/tree/index.d.ts +15 -0
- package/es/components/tree/index.mjs +12 -0
- package/es/components/tree/index.mjs.map +1 -0
- package/es/components/tree/src/tree.d.ts +668 -0
- package/es/components/tree/src/tree.mjs +364 -0
- package/es/components/tree/src/tree.mjs.map +1 -0
- package/es/components/tree/src/tree.props.d.ts +81 -0
- package/es/components/tree/src/tree.props.mjs +71 -0
- package/es/components/tree/src/tree.props.mjs.map +1 -0
- package/es/components/tree/src/tree.type.d.ts +36 -0
- package/es/components/tree/src/tree.type.mjs +2 -0
- package/es/components/tree/src/tree.type.mjs.map +1 -0
- package/es/components/treeSelect/index.d.ts +14 -0
- package/es/components/treeSelect/index.mjs +11 -0
- package/es/components/treeSelect/index.mjs.map +1 -0
- package/es/components/treeSelect/src/treeSelect.d.ts +1063 -0
- package/es/components/treeSelect/src/treeSelect.mjs +492 -0
- package/es/components/treeSelect/src/treeSelect.mjs.map +1 -0
- package/es/components/upload/index.d.ts +15 -0
- package/es/components/upload/index.mjs +11 -0
- package/es/components/upload/index.mjs.map +1 -0
- package/es/components/upload/src/upload.d.ts +525 -0
- package/es/components/upload/src/upload.mjs +140 -0
- package/es/components/upload/src/upload.mjs.map +1 -0
- package/es/components/upload/src/useUpload.d.ts +65 -0
- package/es/components/upload/src/useUpload.mjs +150 -0
- package/es/components/upload/src/useUpload.mjs.map +1 -0
- package/es/components/upload/utils/upload.d.ts +30 -0
- package/es/components/upload/utils/upload.mjs +119 -0
- package/es/components/upload/utils/upload.mjs.map +1 -0
- package/es/components/uploadImage/index.d.ts +14 -0
- package/es/components/uploadImage/index.mjs +11 -0
- package/es/components/uploadImage/index.mjs.map +1 -0
- package/es/components/uploadImage/src/uploadImage.d.ts +575 -0
- package/es/components/uploadImage/src/uploadImage.mjs +207 -0
- package/es/components/uploadImage/src/uploadImage.mjs.map +1 -0
- package/es/components/uploadImages/index.d.ts +14 -0
- package/es/components/uploadImages/index.mjs +8 -0
- package/es/components/uploadImages/index.mjs.map +1 -0
- package/es/components/uploadImages/src/uploadImages.d.ts +544 -0
- package/es/components/uploadImages/src/uploadImages.mjs +194 -0
- package/es/components/uploadImages/src/uploadImages.mjs.map +1 -0
- package/es/constants/index.d.ts +2 -0
- package/es/constants/index.mjs +7 -0
- package/es/constants/index.mjs.map +1 -0
- package/es/constants/mime.d.ts +61 -0
- package/es/constants/mime.mjs +62 -0
- package/es/constants/mime.mjs.map +1 -0
- package/es/constants/regex.d.ts +78 -0
- package/es/constants/regex.mjs +79 -0
- package/es/constants/regex.mjs.map +1 -0
- package/es/directive.d.ts +2 -0
- package/es/directive.mjs +11 -0
- package/es/directive.mjs.map +1 -0
- package/es/directives/click-copy/index.d.ts +2 -0
- package/es/directives/click-copy/index.mjs +36 -0
- package/es/directives/click-copy/index.mjs.map +1 -0
- package/es/directives/click-debounce/index.d.ts +2 -0
- package/es/directives/click-debounce/index.mjs +20 -0
- package/es/directives/click-debounce/index.mjs.map +1 -0
- package/es/directives/click-draggable/index.d.ts +2 -0
- package/es/directives/click-draggable/index.mjs +38 -0
- package/es/directives/click-draggable/index.mjs.map +1 -0
- package/es/directives/click-icon-copy/index.d.ts +2 -0
- package/es/directives/click-icon-copy/index.mjs +54 -0
- package/es/directives/click-icon-copy/index.mjs.map +1 -0
- package/es/directives/click-longpress/index.d.ts +2 -0
- package/es/directives/click-longpress/index.mjs +42 -0
- package/es/directives/click-longpress/index.mjs.map +1 -0
- package/es/directives/click-throttle/index.d.ts +2 -0
- package/es/directives/click-throttle/index.mjs +31 -0
- package/es/directives/click-throttle/index.mjs.map +1 -0
- package/es/directives/index.d.ts +6 -0
- package/es/directives/index.mjs +15 -0
- package/es/directives/index.mjs.map +1 -0
- package/es/element-plus.d.ts +2 -0
- package/es/element-plus.mjs +304 -0
- package/es/element-plus.mjs.map +1 -0
- package/es/hooks/index.d.ts +3 -0
- package/es/hooks/index.mjs +9 -0
- package/es/hooks/index.mjs.map +1 -0
- package/es/hooks/use-loading/index.d.ts +4 -0
- package/es/hooks/use-loading/index.mjs +34 -0
- package/es/hooks/use-loading/index.mjs.map +1 -0
- package/es/hooks/use-overlay/index.d.ts +4 -0
- package/es/hooks/use-overlay/index.mjs +26 -0
- package/es/hooks/use-overlay/index.mjs.map +1 -0
- package/es/hooks/use-screenFull/index.d.ts +7 -0
- package/es/hooks/use-screenFull/index.mjs +45 -0
- package/es/hooks/use-screenFull/index.mjs.map +1 -0
- package/es/index.d.ts +14 -0
- package/es/index.es.d.ts +6 -0
- package/es/index.mjs +138 -0
- package/es/index.mjs.map +1 -0
- package/es/make-installer.d.ts +6 -0
- package/es/make-installer.mjs +27 -0
- package/es/make-installer.mjs.map +1 -0
- package/es/version.d.ts +1 -0
- package/es/version.mjs +5 -0
- package/es/version.mjs.map +1 -0
- package/global.d.ts +2 -0
- package/lib/component.d.ts +3 -0
- package/lib/component.js +2 -0
- package/lib/component.js.map +1 -0
- package/lib/components/avatar/index.d.ts +14 -0
- package/lib/components/avatar/index.js +2 -0
- package/lib/components/avatar/index.js.map +1 -0
- package/lib/components/avatar/src/avatar.d.ts +96 -0
- package/lib/components/avatar/src/avatar.js +2 -0
- package/lib/components/avatar/src/avatar.js.map +1 -0
- package/lib/components/button/index.d.ts +15 -0
- package/lib/components/button/index.js +2 -0
- package/lib/components/button/index.js.map +1 -0
- package/lib/components/button/src/button.d.ts +173 -0
- package/lib/components/button/src/button.js +2 -0
- package/lib/components/button/src/button.js.map +1 -0
- package/lib/components/carNumber/index.d.ts +9 -0
- package/lib/components/carNumber/index.js +2 -0
- package/lib/components/carNumber/index.js.map +1 -0
- package/lib/components/carNumber/src/carNumber.d.ts +217 -0
- package/lib/components/carNumber/src/carNumber.js +2 -0
- package/lib/components/carNumber/src/carNumber.js.map +1 -0
- package/lib/components/carNumber/src/common.d.ts +15 -0
- package/lib/components/carNumber/src/common.js +2 -0
- package/lib/components/carNumber/src/common.js.map +1 -0
- package/lib/components/contextMenu/index.d.ts +9 -0
- package/lib/components/contextMenu/index.js +2 -0
- package/lib/components/contextMenu/index.js.map +1 -0
- package/lib/components/contextMenu/src/contextMenu.d.ts +32 -0
- package/lib/components/contextMenu/src/contextMenu.js +2 -0
- package/lib/components/contextMenu/src/contextMenu.js.map +1 -0
- package/lib/components/contextMenu/src/contextMenu.type.d.ts +33 -0
- package/lib/components/contextMenu/src/contextMenu.type.js +2 -0
- package/lib/components/contextMenu/src/contextMenu.type.js.map +1 -0
- package/lib/components/dialog/index.d.ts +14 -0
- package/lib/components/dialog/index.js +2 -0
- package/lib/components/dialog/index.js.map +1 -0
- package/lib/components/dialog/src/dialog.d.ts +454 -0
- package/lib/components/dialog/src/dialog.js +2 -0
- package/lib/components/dialog/src/dialog.js.map +1 -0
- package/lib/components/drawer/index.d.ts +14 -0
- package/lib/components/drawer/index.js +2 -0
- package/lib/components/drawer/index.js.map +1 -0
- package/lib/components/drawer/src/drawer.d.ts +449 -0
- package/lib/components/drawer/src/drawer.js +2 -0
- package/lib/components/drawer/src/drawer.js.map +1 -0
- package/lib/components/form/index.d.ts +23 -0
- package/lib/components/form/index.js +2 -0
- package/lib/components/form/index.js.map +1 -0
- package/lib/components/form/src/form.d.ts +194 -0
- package/lib/components/form/src/form.js +2 -0
- package/lib/components/form/src/form.js.map +1 -0
- package/lib/components/form/src/formItem.d.ts +190 -0
- package/lib/components/form/src/formItem.js +2 -0
- package/lib/components/form/src/formItem.js.map +1 -0
- package/lib/components/form/utils/form.d.ts +81 -0
- package/lib/components/form/utils/form.js +2 -0
- package/lib/components/form/utils/form.js.map +1 -0
- package/lib/components/formItemTip/index.d.ts +12 -0
- package/lib/components/formItemTip/index.js +2 -0
- package/lib/components/formItemTip/index.js.map +1 -0
- package/lib/components/formItemTip/src/formItemTip.d.ts +22 -0
- package/lib/components/formItemTip/src/formItemTip.js +2 -0
- package/lib/components/formItemTip/src/formItemTip.js.map +1 -0
- package/lib/components/icon/index.d.ts +12 -0
- package/lib/components/icon/index.js +2 -0
- package/lib/components/icon/index.js.map +1 -0
- package/lib/components/icon/src/icon.d.ts +39 -0
- package/lib/components/icon/src/icon.js +2 -0
- package/lib/components/icon/src/icon.js.map +1 -0
- package/lib/components/iconSelector/index.d.ts +7 -0
- package/lib/components/iconSelector/index.js +2 -0
- package/lib/components/iconSelector/index.js.map +1 -0
- package/lib/components/iconSelector/src/iconSelector.d.ts +23 -0
- package/lib/components/iconSelector/src/iconSelector.js +2 -0
- package/lib/components/iconSelector/src/iconSelector.js.map +1 -0
- package/lib/components/image/index.d.ts +12 -0
- package/lib/components/image/index.js +2 -0
- package/lib/components/image/index.js.map +1 -0
- package/lib/components/image/src/image.d.ts +225 -0
- package/lib/components/image/src/image.js +2 -0
- package/lib/components/image/src/image.js.map +1 -0
- package/lib/components/index.d.ts +21 -0
- package/lib/components/index.js +2 -0
- package/lib/components/index.js.map +1 -0
- package/lib/components/layoutGrid/index.d.ts +16 -0
- package/lib/components/layoutGrid/index.js +2 -0
- package/lib/components/layoutGrid/index.js.map +1 -0
- package/lib/components/layoutGrid/src/layoutGrid.d.ts +60 -0
- package/lib/components/layoutGrid/src/layoutGrid.js +2 -0
- package/lib/components/layoutGrid/src/layoutGrid.js.map +1 -0
- package/lib/components/layoutGrid/src/layoutGrid.type.d.ts +12 -0
- package/lib/components/layoutGrid/src/layoutGrid.type.js +2 -0
- package/lib/components/layoutGrid/src/layoutGrid.type.js.map +1 -0
- package/lib/components/layoutGrid/src/layoutGridItem.d.ts +100 -0
- package/lib/components/layoutGrid/src/layoutGridItem.js +2 -0
- package/lib/components/layoutGrid/src/layoutGridItem.js.map +1 -0
- package/lib/components/select/index.d.ts +22 -0
- package/lib/components/select/index.js +2 -0
- package/lib/components/select/index.js.map +1 -0
- package/lib/components/select/src/select.d.ts +1201 -0
- package/lib/components/select/src/select.js +2 -0
- package/lib/components/select/src/select.js.map +1 -0
- package/lib/components/select/src/select.type.d.ts +28 -0
- package/lib/components/select/src/select.type.js +2 -0
- package/lib/components/select/src/select.type.js.map +1 -0
- package/lib/components/select/src/selectOption.d.ts +99 -0
- package/lib/components/select/src/selectOption.js +2 -0
- package/lib/components/select/src/selectOption.js.map +1 -0
- package/lib/components/selectPage/index.d.ts +14 -0
- package/lib/components/selectPage/index.js +2 -0
- package/lib/components/selectPage/index.js.map +1 -0
- package/lib/components/selectPage/src/selectPage.d.ts +595 -0
- package/lib/components/selectPage/src/selectPage.js +2 -0
- package/lib/components/selectPage/src/selectPage.js.map +1 -0
- package/lib/components/selectV2/index.d.ts +14 -0
- package/lib/components/selectV2/index.js +2 -0
- package/lib/components/selectV2/index.js.map +1 -0
- package/lib/components/selectV2/src/selectV2.d.ts +1407 -0
- package/lib/components/selectV2/src/selectV2.js +2 -0
- package/lib/components/selectV2/src/selectV2.js.map +1 -0
- package/lib/components/table/images/artwork.png.js +2 -0
- package/lib/components/table/images/artwork.png.js.map +1 -0
- package/lib/components/table/images/index.d.ts +4 -0
- package/lib/components/table/images/notImage.png.js +2 -0
- package/lib/components/table/images/notImage.png.js.map +1 -0
- package/lib/components/table/index.d.ts +35 -0
- package/lib/components/table/index.js +2 -0
- package/lib/components/table/index.js.map +1 -0
- package/lib/components/table/src/page.type.d.ts +145 -0
- package/lib/components/table/src/page.type.js +2 -0
- package/lib/components/table/src/page.type.js.map +1 -0
- package/lib/components/table/src/table.d.ts +1382 -0
- package/lib/components/table/src/table.js +2 -0
- package/lib/components/table/src/table.js.map +1 -0
- package/lib/components/table/src/table.state.d.ts +115 -0
- package/lib/components/table/src/table.state.js +2 -0
- package/lib/components/table/src/table.state.js.map +1 -0
- package/lib/components/table/src/table.type.d.ts +316 -0
- package/lib/components/table/src/table.type.js +2 -0
- package/lib/components/table/src/table.type.js.map +1 -0
- package/lib/components/table/src/tableColumn.d.ts +644 -0
- package/lib/components/table/src/tableColumn.js +2 -0
- package/lib/components/table/src/tableColumn.js.map +1 -0
- package/lib/components/table/src/tableColumnSettingDialog.d.ts +18 -0
- package/lib/components/table/src/tableColumnSettingDialog.js +2 -0
- package/lib/components/table/src/tableColumnSettingDialog.js.map +1 -0
- package/lib/components/table/src/tablePagination.d.ts +24 -0
- package/lib/components/table/src/tablePagination.js +2 -0
- package/lib/components/table/src/tablePagination.js.map +1 -0
- package/lib/components/table/src/tableSearchForm.d.ts +88 -0
- package/lib/components/table/src/tableSearchForm.js +2 -0
- package/lib/components/table/src/tableSearchForm.js.map +1 -0
- package/lib/components/table/src/tableSearchFormItem.d.ts +37 -0
- package/lib/components/table/src/tableSearchFormItem.js +2 -0
- package/lib/components/table/src/tableSearchFormItem.js.map +1 -0
- package/lib/components/table/src/useTable.d.ts +32 -0
- package/lib/components/table/src/useTable.js +2 -0
- package/lib/components/table/src/useTable.js.map +1 -0
- package/lib/components/table/utils/table.d.ts +45 -0
- package/lib/components/table/utils/table.js +2 -0
- package/lib/components/table/utils/table.js.map +1 -0
- package/lib/components/tree/index.d.ts +15 -0
- package/lib/components/tree/index.js +2 -0
- package/lib/components/tree/index.js.map +1 -0
- package/lib/components/tree/src/tree.d.ts +668 -0
- package/lib/components/tree/src/tree.js +2 -0
- package/lib/components/tree/src/tree.js.map +1 -0
- package/lib/components/tree/src/tree.props.d.ts +81 -0
- package/lib/components/tree/src/tree.props.js +2 -0
- package/lib/components/tree/src/tree.props.js.map +1 -0
- package/lib/components/tree/src/tree.type.d.ts +36 -0
- package/lib/components/tree/src/tree.type.js +2 -0
- package/lib/components/tree/src/tree.type.js.map +1 -0
- package/lib/components/treeSelect/index.d.ts +14 -0
- package/lib/components/treeSelect/index.js +2 -0
- package/lib/components/treeSelect/index.js.map +1 -0
- package/lib/components/treeSelect/src/treeSelect.d.ts +1063 -0
- package/lib/components/treeSelect/src/treeSelect.js +2 -0
- package/lib/components/treeSelect/src/treeSelect.js.map +1 -0
- package/lib/components/upload/index.d.ts +15 -0
- package/lib/components/upload/index.js +2 -0
- package/lib/components/upload/index.js.map +1 -0
- package/lib/components/upload/src/upload.d.ts +525 -0
- package/lib/components/upload/src/upload.js +2 -0
- package/lib/components/upload/src/upload.js.map +1 -0
- package/lib/components/upload/src/useUpload.d.ts +65 -0
- package/lib/components/upload/src/useUpload.js +2 -0
- package/lib/components/upload/src/useUpload.js.map +1 -0
- package/lib/components/upload/utils/upload.d.ts +30 -0
- package/lib/components/upload/utils/upload.js +2 -0
- package/lib/components/upload/utils/upload.js.map +1 -0
- package/lib/components/uploadImage/index.d.ts +14 -0
- package/lib/components/uploadImage/index.js +2 -0
- package/lib/components/uploadImage/index.js.map +1 -0
- package/lib/components/uploadImage/src/uploadImage.d.ts +575 -0
- package/lib/components/uploadImage/src/uploadImage.js +2 -0
- package/lib/components/uploadImage/src/uploadImage.js.map +1 -0
- package/lib/components/uploadImages/index.d.ts +14 -0
- package/lib/components/uploadImages/index.js +2 -0
- package/lib/components/uploadImages/index.js.map +1 -0
- package/lib/components/uploadImages/src/uploadImages.d.ts +544 -0
- package/lib/components/uploadImages/src/uploadImages.js +2 -0
- package/lib/components/uploadImages/src/uploadImages.js.map +1 -0
- package/lib/constants/index.d.ts +2 -0
- package/lib/constants/index.js +2 -0
- package/lib/constants/index.js.map +1 -0
- package/lib/constants/mime.d.ts +61 -0
- package/lib/constants/mime.js +2 -0
- package/lib/constants/mime.js.map +1 -0
- package/lib/constants/regex.d.ts +78 -0
- package/lib/constants/regex.js +2 -0
- package/lib/constants/regex.js.map +1 -0
- package/lib/directive.d.ts +2 -0
- package/lib/directive.js +2 -0
- package/lib/directive.js.map +1 -0
- package/lib/directives/click-copy/index.d.ts +2 -0
- package/lib/directives/click-copy/index.js +2 -0
- package/lib/directives/click-copy/index.js.map +1 -0
- package/lib/directives/click-debounce/index.d.ts +2 -0
- package/lib/directives/click-debounce/index.js +2 -0
- package/lib/directives/click-debounce/index.js.map +1 -0
- package/lib/directives/click-draggable/index.d.ts +2 -0
- package/lib/directives/click-draggable/index.js +2 -0
- package/lib/directives/click-draggable/index.js.map +1 -0
- package/lib/directives/click-icon-copy/index.d.ts +2 -0
- package/lib/directives/click-icon-copy/index.js +2 -0
- package/lib/directives/click-icon-copy/index.js.map +1 -0
- package/lib/directives/click-longpress/index.d.ts +2 -0
- package/lib/directives/click-longpress/index.js +2 -0
- package/lib/directives/click-longpress/index.js.map +1 -0
- package/lib/directives/click-throttle/index.d.ts +2 -0
- package/lib/directives/click-throttle/index.js +2 -0
- package/lib/directives/click-throttle/index.js.map +1 -0
- package/lib/directives/index.d.ts +6 -0
- package/lib/directives/index.js +2 -0
- package/lib/directives/index.js.map +1 -0
- package/lib/element-plus.d.ts +2 -0
- package/lib/element-plus.js +2 -0
- package/lib/element-plus.js.map +1 -0
- package/lib/hooks/index.d.ts +3 -0
- package/lib/hooks/index.js +2 -0
- package/lib/hooks/index.js.map +1 -0
- package/lib/hooks/use-loading/index.d.ts +4 -0
- package/lib/hooks/use-loading/index.js +2 -0
- package/lib/hooks/use-loading/index.js.map +1 -0
- package/lib/hooks/use-overlay/index.d.ts +4 -0
- package/lib/hooks/use-overlay/index.js +2 -0
- package/lib/hooks/use-overlay/index.js.map +1 -0
- package/lib/hooks/use-screenFull/index.d.ts +7 -0
- package/lib/hooks/use-screenFull/index.js +2 -0
- package/lib/hooks/use-screenFull/index.js.map +1 -0
- package/lib/index.d.ts +14 -0
- package/lib/index.es.d.ts +6 -0
- package/lib/index.js +2 -0
- package/lib/index.js.map +1 -0
- package/lib/make-installer.d.ts +6 -0
- package/lib/make-installer.js +2 -0
- package/lib/make-installer.js.map +1 -0
- package/lib/version.d.ts +1 -0
- package/lib/version.js +2 -0
- package/lib/version.js.map +1 -0
- package/package.json +139 -26
- package/styles/common/animation.scss +46 -0
- package/styles/common/common.scss +44 -0
- package/styles/common/loading.scss +29 -0
- package/styles/common/overlay.scss +12 -0
- package/styles/components/carNumber.scss +44 -0
- package/styles/components/contextMenu.scss +34 -0
- package/styles/components/dialog.scss +88 -0
- package/styles/components/drawer.scss +87 -0
- package/styles/components/form.scss +44 -0
- package/styles/components/formItemTip.scss +7 -0
- package/styles/components/image.scss +19 -0
- package/styles/components/selectPage.scss +74 -0
- package/styles/components/selectV2.scss +22 -0
- package/styles/components/table.scss +439 -0
- package/styles/components/tree.scss +100 -0
- package/styles/components/uploadImage.scss +61 -0
- package/styles/components/uploadImages.scss +9 -0
- package/styles/index.scss +18 -0
- package/types/components.d.ts +36 -0
- package/types/env.d.ts +17 -0
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
import { defineComponent, computed, ref, withDirectives, createVNode, mergeProps, Fragment, createTextVNode, resolveDirective } from "vue";
|
|
2
|
+
import { uploadProps, ElUpload, ElIcon } from "element-plus";
|
|
3
|
+
import { UploadFilled } from "@element-plus/icons-vue";
|
|
4
|
+
import { definePropType, useProps, useRender, useExpose, makeSlots } from "@fast-china/utils";
|
|
5
|
+
import { isString, isArray, isNull } from "lodash-unified";
|
|
6
|
+
import { useUpload } from "./useUpload.mjs";
|
|
7
|
+
const faUploadProps = {
|
|
8
|
+
...uploadProps,
|
|
9
|
+
/** @description whether to activate drag and drop mode */
|
|
10
|
+
drag: {
|
|
11
|
+
type: Boolean,
|
|
12
|
+
default: true
|
|
13
|
+
},
|
|
14
|
+
/** @description maximum number of uploads allowed */
|
|
15
|
+
limit: {
|
|
16
|
+
type: Number,
|
|
17
|
+
default: 1
|
|
18
|
+
},
|
|
19
|
+
/** @description v-model绑定值 */
|
|
20
|
+
modelValue: definePropType([String, Array]),
|
|
21
|
+
/** @description 大小限制,单位kb */
|
|
22
|
+
maxSize: {
|
|
23
|
+
type: definePropType([String, Number]),
|
|
24
|
+
default: 5120
|
|
25
|
+
},
|
|
26
|
+
/** @description 图片上传接口,优先级最高 */
|
|
27
|
+
uploadApi: {
|
|
28
|
+
type: definePropType(Function)
|
|
29
|
+
},
|
|
30
|
+
/** @description 图片上传地址 */
|
|
31
|
+
uploadUrl: String
|
|
32
|
+
};
|
|
33
|
+
const faUploadEmits = {
|
|
34
|
+
/** @description v-model 回调 */
|
|
35
|
+
"update:modelValue": (value) => isString(value) || isArray(value) || isNull(value),
|
|
36
|
+
/** @description v-model:fileList 回调 */
|
|
37
|
+
"update:fileList": (value) => isArray(value),
|
|
38
|
+
/** @description 改变 */
|
|
39
|
+
change: (value) => isString(value) || isArray(value) || isNull(value)
|
|
40
|
+
};
|
|
41
|
+
const Upload = /* @__PURE__ */ defineComponent({
|
|
42
|
+
name: "FaUpload",
|
|
43
|
+
props: faUploadProps,
|
|
44
|
+
emits: faUploadEmits,
|
|
45
|
+
slots: makeSlots(),
|
|
46
|
+
setup(props, {
|
|
47
|
+
attrs,
|
|
48
|
+
slots,
|
|
49
|
+
emit,
|
|
50
|
+
expose
|
|
51
|
+
}) {
|
|
52
|
+
const {
|
|
53
|
+
fileList,
|
|
54
|
+
loading,
|
|
55
|
+
formContext,
|
|
56
|
+
maxSizeMB,
|
|
57
|
+
handleHttpRequest,
|
|
58
|
+
handleOnSuccess,
|
|
59
|
+
handleOnError,
|
|
60
|
+
handleOnExceed,
|
|
61
|
+
handleOnUpload
|
|
62
|
+
} = useUpload("FaUpload", "文件", props, emit, {
|
|
63
|
+
maxSize: props.maxSize,
|
|
64
|
+
uploadApi: props.uploadApi,
|
|
65
|
+
uploadUrl: props.uploadUrl
|
|
66
|
+
});
|
|
67
|
+
const disabled = computed(() => {
|
|
68
|
+
return props.disabled || formContext?.disabled;
|
|
69
|
+
});
|
|
70
|
+
const uploadRef = ref();
|
|
71
|
+
const handleOnChange = (uploadFile, uploadFiles) => {
|
|
72
|
+
if (uploadFile.status !== "ready") return;
|
|
73
|
+
if (!handleOnUpload(uploadFile)) {
|
|
74
|
+
fileList.value = fileList.value.slice(0, -1);
|
|
75
|
+
} else {
|
|
76
|
+
props.onChange && props.onChange(uploadFile, uploadFiles);
|
|
77
|
+
}
|
|
78
|
+
};
|
|
79
|
+
const elUploadProps = useProps(props, uploadProps, ["fileList", "disabled", "httpRequest", "onExceed", "onSuccess", "onError", "onChange"]);
|
|
80
|
+
useRender(() => withDirectives(createVNode(ElUpload, mergeProps(elUploadProps.value, {
|
|
81
|
+
"ref": uploadRef,
|
|
82
|
+
"class": "fa-upload",
|
|
83
|
+
"fileList": fileList.value,
|
|
84
|
+
"onUpdate:fileList": ($event) => fileList.value = $event,
|
|
85
|
+
"disabled": disabled.value,
|
|
86
|
+
"httpRequest": handleHttpRequest,
|
|
87
|
+
"onExceed": handleOnExceed,
|
|
88
|
+
"onSuccess": handleOnSuccess,
|
|
89
|
+
"onError": handleOnError,
|
|
90
|
+
"onChange": handleOnChange
|
|
91
|
+
}), {
|
|
92
|
+
default: () => slots.default ? slots.default() : createVNode(Fragment, null, [createVNode(ElIcon, {
|
|
93
|
+
"class": "el-icon--upload"
|
|
94
|
+
}, {
|
|
95
|
+
default: () => [createVNode(UploadFilled, null, null)]
|
|
96
|
+
}), createVNode("div", {
|
|
97
|
+
"class": "el-upload__text"
|
|
98
|
+
}, [createTextVNode("Drop file here or "), createVNode("em", null, [createTextVNode("click to upload")])])]),
|
|
99
|
+
...slots.trigger && {
|
|
100
|
+
trigger: () => slots.trigger()
|
|
101
|
+
},
|
|
102
|
+
tip: () => slots.tip ? slots.tip() : createVNode(Fragment, null, [createVNode("div", {
|
|
103
|
+
"class": "el-upload__tip"
|
|
104
|
+
}, [createTextVNode("files with a size less than "), maxSizeMB.toString(), createTextVNode("MB")]), !props.showFileList && fileList.value.length > 0 && createVNode("div", {
|
|
105
|
+
"class": "el-upload__tip"
|
|
106
|
+
}, [fileList.value.map((item, index) => createVNode(Fragment, null, [item.name, fileList.value.length <= index && createVNode("br", null, null)]))])]),
|
|
107
|
+
...slots.file && {
|
|
108
|
+
file: ({
|
|
109
|
+
file,
|
|
110
|
+
index
|
|
111
|
+
}) => slots.file({
|
|
112
|
+
file,
|
|
113
|
+
index
|
|
114
|
+
})
|
|
115
|
+
}
|
|
116
|
+
}), [[resolveDirective("loading"), loading.value]]));
|
|
117
|
+
return useExpose(expose, {
|
|
118
|
+
/** @description 取消上传请求 */
|
|
119
|
+
abort: computed(() => uploadRef.value?.abort),
|
|
120
|
+
/** @description 手动上传文件列表 */
|
|
121
|
+
submit: computed(() => uploadRef.value?.submit),
|
|
122
|
+
/** @description 清空已上传的文件列表(该方法不支持在 before-upload 中调用) */
|
|
123
|
+
clearFiles: computed(() => uploadRef.value?.clearFiles),
|
|
124
|
+
/** @description 手动选择文件 */
|
|
125
|
+
handleStart: computed(() => uploadRef.value?.handleStart),
|
|
126
|
+
/** @description 手动移除文件。 file 和rawFile 已被合并。 rawFile 将在 v2.2.0 中移除 */
|
|
127
|
+
handleRemove: computed(() => uploadRef.value?.handleRemove),
|
|
128
|
+
/** @description 加载状态 */
|
|
129
|
+
loading,
|
|
130
|
+
/** @description 文件集合 */
|
|
131
|
+
fileList
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
});
|
|
135
|
+
export {
|
|
136
|
+
Upload as default,
|
|
137
|
+
faUploadEmits,
|
|
138
|
+
faUploadProps
|
|
139
|
+
};
|
|
140
|
+
//# sourceMappingURL=upload.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"upload.mjs","sources":["../../../../../packages/components/upload/src/upload.tsx"],"sourcesContent":["import { Fragment, computed, defineComponent, ref } from \"vue\";\nimport { ElIcon, ElUpload, uploadProps } from \"element-plus\";\nimport { UploadFilled } from \"@element-plus/icons-vue\";\nimport { definePropType, makeSlots, useExpose, useProps, useRender } from \"@fast-china/utils\";\nimport { isArray, isNull, isString } from \"lodash-unified\";\nimport { useUpload } from \"./useUpload\";\nimport type { UploadFile, UploadInstance, UploadProps, UploadUserFile } from \"element-plus\";\nimport type { VNode } from \"vue\";\n\nexport const faUploadProps = {\n\t...uploadProps,\n\t/** @description whether to activate drag and drop mode */\n\tdrag: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description maximum number of uploads allowed */\n\tlimit: {\n\t\ttype: Number,\n\t\tdefault: 1,\n\t},\n\t/** @description v-model绑定值 */\n\tmodelValue: definePropType<string | string[]>([String, Array]),\n\t/** @description 大小限制,单位kb */\n\tmaxSize: {\n\t\ttype: definePropType<string | number>([String, Number]),\n\t\tdefault: 5120,\n\t},\n\t/** @description 图片上传接口,优先级最高 */\n\tuploadApi: {\n\t\ttype: definePropType<(formData: FormData) => Promise<string>>(Function),\n\t},\n\t/** @description 图片上传地址 */\n\tuploadUrl: String,\n};\n\nexport const faUploadEmits = {\n\t/** @description v-model 回调 */\n\t\"update:modelValue\": (value: string | string[]): boolean => isString(value) || isArray(value) || isNull(value),\n\t/** @description v-model:fileList 回调 */\n\t\"update:fileList\": (value: UploadUserFile[]): boolean => isArray(value),\n\t/** @description 改变 */\n\tchange: (value: string | string[]): boolean => isString(value) || isArray(value) || isNull(value),\n};\n\ntype FaUploadSlots = {\n\t/** @description 默认内容插槽 */\n\tdefault: never;\n\t/** @description 触发文件选择框的内容 */\n\ttrigger: never;\n\t/** @description 提示说明文字 */\n\ttip: never;\n\t/** @description 缩略图模板的内容 */\n\tfile: { file: UploadFile; index: number };\n};\n\nexport default defineComponent({\n\tname: \"FaUpload\",\n\tprops: faUploadProps,\n\temits: faUploadEmits,\n\tslots: makeSlots<FaUploadSlots>(),\n\tsetup(props, { attrs, slots, emit, expose }) {\n\t\tconst { fileList, loading, formContext, maxSizeMB, handleHttpRequest, handleOnSuccess, handleOnError, handleOnExceed, handleOnUpload } =\n\t\t\tuseUpload(\"FaUpload\", \"文件\", props, emit, {\n\t\t\t\tmaxSize: props.maxSize,\n\t\t\t\tuploadApi: props.uploadApi,\n\t\t\t\tuploadUrl: props.uploadUrl,\n\t\t\t});\n\n\t\tconst disabled = computed(() => {\n\t\t\treturn props.disabled || formContext?.disabled;\n\t\t});\n\n\t\tconst uploadRef = ref<UploadInstance>();\n\n\t\tconst handleOnChange: UploadProps[\"onChange\"] = (uploadFile, uploadFiles) => {\n\t\t\tif (uploadFile.status !== \"ready\") return;\n\n\t\t\tif (!handleOnUpload(uploadFile)) {\n\t\t\t\tfileList.value = fileList.value.slice(0, -1);\n\t\t\t} else {\n\t\t\t\tprops.onChange && props.onChange(uploadFile, uploadFiles);\n\t\t\t}\n\t\t};\n\n\t\tconst elUploadProps = useProps(props, uploadProps, [\"fileList\", \"disabled\", \"httpRequest\", \"onExceed\", \"onSuccess\", \"onError\", \"onChange\"]);\n\n\t\tuseRender(() => (\n\t\t\t<ElUpload\n\t\t\t\t{...elUploadProps.value}\n\t\t\t\tref={uploadRef}\n\t\t\t\tclass=\"fa-upload\"\n\t\t\t\tvLoading={loading.value}\n\t\t\t\tvModel:fileList={fileList.value}\n\t\t\t\tdisabled={disabled.value}\n\t\t\t\thttpRequest={handleHttpRequest}\n\t\t\t\tonExceed={handleOnExceed}\n\t\t\t\tonSuccess={handleOnSuccess}\n\t\t\t\tonError={handleOnError}\n\t\t\t\tonChange={handleOnChange}\n\t\t\t>\n\t\t\t\t{{\n\t\t\t\t\tdefault: () =>\n\t\t\t\t\t\tslots.default ? (\n\t\t\t\t\t\t\tslots.default()\n\t\t\t\t\t\t) : (\n\t\t\t\t\t\t\t<Fragment>\n\t\t\t\t\t\t\t\t<ElIcon class=\"el-icon--upload\">\n\t\t\t\t\t\t\t\t\t<UploadFilled />\n\t\t\t\t\t\t\t\t</ElIcon>\n\t\t\t\t\t\t\t\t<div class=\"el-upload__text\">\n\t\t\t\t\t\t\t\t\tDrop file here or <em>click to upload</em>\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t</Fragment>\n\t\t\t\t\t\t),\n\t\t\t\t\t...(slots.trigger && { trigger: (): VNode | VNode[] => slots.trigger() }),\n\t\t\t\t\ttip: () =>\n\t\t\t\t\t\tslots.tip ? (\n\t\t\t\t\t\t\tslots.tip()\n\t\t\t\t\t\t) : (\n\t\t\t\t\t\t\t<Fragment>\n\t\t\t\t\t\t\t\t<div class=\"el-upload__tip\">files with a size less than {maxSizeMB.toString()}MB</div>\n\t\t\t\t\t\t\t\t{!props.showFileList && fileList.value.length > 0 && (\n\t\t\t\t\t\t\t\t\t<div class=\"el-upload__tip\">\n\t\t\t\t\t\t\t\t\t\t{fileList.value.map((item, index) => (\n\t\t\t\t\t\t\t\t\t\t\t<Fragment>\n\t\t\t\t\t\t\t\t\t\t\t\t{item.name}\n\t\t\t\t\t\t\t\t\t\t\t\t{fileList.value.length <= index && <br />}\n\t\t\t\t\t\t\t\t\t\t\t</Fragment>\n\t\t\t\t\t\t\t\t\t\t))}\n\t\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t</Fragment>\n\t\t\t\t\t\t),\n\t\t\t\t\t...(slots.file && {\n\t\t\t\t\t\tfile: ({ file, index }: { file: UploadFile; index: number }): VNode | VNode[] => slots.file({ file, index }),\n\t\t\t\t\t}),\n\t\t\t\t}}\n\t\t\t</ElUpload>\n\t\t));\n\n\t\treturn useExpose(expose, {\n\t\t\t/** @description 取消上传请求 */\n\t\t\tabort: computed(() => uploadRef.value?.abort),\n\t\t\t/** @description 手动上传文件列表 */\n\t\t\tsubmit: computed(() => uploadRef.value?.submit),\n\t\t\t/** @description 清空已上传的文件列表(该方法不支持在 before-upload 中调用) */\n\t\t\tclearFiles: computed(() => uploadRef.value?.clearFiles),\n\t\t\t/** @description 手动选择文件 */\n\t\t\thandleStart: computed(() => uploadRef.value?.handleStart),\n\t\t\t/** @description 手动移除文件。 file 和rawFile 已被合并。 rawFile 将在 v2.2.0 中移除 */\n\t\t\thandleRemove: computed(() => uploadRef.value?.handleRemove),\n\t\t\t/** @description 加载状态 */\n\t\t\tloading,\n\t\t\t/** @description 文件集合 */\n\t\t\tfileList,\n\t\t});\n\t},\n});\n"],"names":["faUploadProps","uploadProps","drag","type","Boolean","default","limit","Number","modelValue","definePropType","String","Array","maxSize","uploadApi","Function","uploadUrl","faUploadEmits","value","isString","isArray","isNull","change","name","props","emits","slots","makeSlots","setup","attrs","emit","expose","fileList","loading","formContext","maxSizeMB","handleHttpRequest","handleOnSuccess","handleOnError","handleOnExceed","handleOnUpload","useUpload","disabled","computed","uploadRef","ref","handleOnChange","uploadFile","uploadFiles","status","slice","onChange","elUploadProps","useProps","useRender","_withDirectives","_createVNode","ElUpload","_mergeProps","$event","_Fragment","ElIcon","UploadFilled","_createTextVNode","trigger","tip","toString","showFileList","length","map","item","index","file","_resolveDirective","useExpose","abort","submit","clearFiles","handleStart","handleRemove"],"mappings":"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"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { Decimal } from 'decimal.js';
|
|
2
|
+
import { UploadFile, UploadFiles, UploadProps, UploadRawFile, UploadRequestOptions, UploadUserFile } from 'element-plus';
|
|
3
|
+
export declare const useUpload: <T extends string | string[]>(componentName: string, fileTypeName: string, props: UploadProps & {
|
|
4
|
+
modelValue: T;
|
|
5
|
+
}, emit: ((event: "update:fileList", value: UploadUserFile[]) => void) & ((event: "update:modelValue", value: T) => void) & ((event: "change", value: T) => void), data?: {
|
|
6
|
+
maxSize?: string | number;
|
|
7
|
+
uploadApi?: (formData: FormData) => Promise<string>;
|
|
8
|
+
uploadUrl?: string;
|
|
9
|
+
}) => {
|
|
10
|
+
fileList: import('vue').Ref<{
|
|
11
|
+
raw?: {
|
|
12
|
+
uid: number;
|
|
13
|
+
isDirectory?: boolean;
|
|
14
|
+
readonly lastModified: number;
|
|
15
|
+
readonly name: string;
|
|
16
|
+
readonly webkitRelativePath: string;
|
|
17
|
+
readonly size: number;
|
|
18
|
+
readonly type: string;
|
|
19
|
+
arrayBuffer: () => Promise<ArrayBuffer>;
|
|
20
|
+
bytes: () => Promise<Uint8Array<ArrayBuffer>>;
|
|
21
|
+
slice: (start?: number, end?: number, contentType?: string) => Blob;
|
|
22
|
+
stream: () => ReadableStream<Uint8Array<ArrayBuffer>>;
|
|
23
|
+
text: () => Promise<string>;
|
|
24
|
+
};
|
|
25
|
+
size?: number;
|
|
26
|
+
name: string;
|
|
27
|
+
url?: string;
|
|
28
|
+
percentage?: number;
|
|
29
|
+
response?: unknown;
|
|
30
|
+
status?: import('element-plus').UploadStatus;
|
|
31
|
+
uid?: number;
|
|
32
|
+
}[], {
|
|
33
|
+
raw?: {
|
|
34
|
+
uid: number;
|
|
35
|
+
isDirectory?: boolean;
|
|
36
|
+
readonly lastModified: number;
|
|
37
|
+
readonly name: string;
|
|
38
|
+
readonly webkitRelativePath: string;
|
|
39
|
+
readonly size: number;
|
|
40
|
+
readonly type: string;
|
|
41
|
+
arrayBuffer: () => Promise<ArrayBuffer>;
|
|
42
|
+
bytes: () => Promise<Uint8Array<ArrayBuffer>>;
|
|
43
|
+
slice: (start?: number, end?: number, contentType?: string) => Blob;
|
|
44
|
+
stream: () => ReadableStream<Uint8Array<ArrayBuffer>>;
|
|
45
|
+
text: () => Promise<string>;
|
|
46
|
+
};
|
|
47
|
+
size?: number;
|
|
48
|
+
name: string;
|
|
49
|
+
url?: string;
|
|
50
|
+
percentage?: number;
|
|
51
|
+
response?: unknown;
|
|
52
|
+
status?: import('element-plus').UploadStatus;
|
|
53
|
+
uid?: number;
|
|
54
|
+
}[]>;
|
|
55
|
+
loading: import('vue').Ref<boolean, boolean>;
|
|
56
|
+
formContext: import('element-plus').FormContext;
|
|
57
|
+
formItemContext: import('element-plus').FormItemContext;
|
|
58
|
+
maxSizeMB: Decimal;
|
|
59
|
+
handleValue: () => void;
|
|
60
|
+
handleHttpRequest: (options: UploadRequestOptions) => Promise<void>;
|
|
61
|
+
handleOnSuccess: (fileUrl: string, uploadFile: UploadFile, uploadFiles: UploadFiles) => void;
|
|
62
|
+
handleOnError: (error: Error, uploadFile: UploadFile, uploadFiles: UploadFiles) => void;
|
|
63
|
+
handleOnExceed: (files: File[], uploadFiles: UploadUserFile[]) => void;
|
|
64
|
+
handleOnUpload: (file: UploadFile | UploadRawFile) => boolean;
|
|
65
|
+
};
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
import { ref, inject, onMounted, watch } from "vue";
|
|
2
|
+
import { formContextKey, formItemContextKey, ElMessage, ElNotification, genFileId } from "element-plus";
|
|
3
|
+
import { consoleWarn, consoleError } from "@fast-china/utils";
|
|
4
|
+
import { useVModel } from "@vueuse/core";
|
|
5
|
+
import { Decimal } from "decimal.js";
|
|
6
|
+
import { isNumber, isString, isArray } from "lodash-unified";
|
|
7
|
+
import { uploadUtil } from "../utils/upload.mjs";
|
|
8
|
+
const useUpload = (componentName, fileTypeName, props, emit, data) => {
|
|
9
|
+
const fileList = useVModel(props, "fileList", emit, { passive: true });
|
|
10
|
+
const loading = ref(false);
|
|
11
|
+
const formContext = inject(formContextKey, void 0);
|
|
12
|
+
const formItemContext = inject(formItemContextKey, void 0);
|
|
13
|
+
const mbNum = new Decimal(1024);
|
|
14
|
+
const maxSizeKB = new Decimal(isNumber(data?.maxSize) ? data?.maxSize : Number(data?.maxSize));
|
|
15
|
+
const maxSizeMB = maxSizeKB.div(mbNum);
|
|
16
|
+
onMounted(() => {
|
|
17
|
+
if (props.autoUpload && !data.uploadApi && !data.uploadUrl) {
|
|
18
|
+
consoleWarn(componentName, "['uploadApi', 'uploadUrl'] 属性必须二选一。");
|
|
19
|
+
}
|
|
20
|
+
});
|
|
21
|
+
const handleValue = () => {
|
|
22
|
+
if (fileList.value.length > 0) {
|
|
23
|
+
if (isString(props.modelValue)) {
|
|
24
|
+
emit("update:modelValue", fileList.value[0].url);
|
|
25
|
+
emit("change", fileList.value[0].url);
|
|
26
|
+
} else {
|
|
27
|
+
if (props.multiple) {
|
|
28
|
+
const value = fileList.value.map((m) => m.url);
|
|
29
|
+
emit("update:modelValue", value);
|
|
30
|
+
emit("change", value);
|
|
31
|
+
} else {
|
|
32
|
+
emit("update:modelValue", fileList.value[0].url);
|
|
33
|
+
emit("change", fileList.value[0].url);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
} else {
|
|
37
|
+
emit("update:modelValue", null);
|
|
38
|
+
emit("change", null);
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
const handleHttpRequest = async (options) => {
|
|
42
|
+
let propsData;
|
|
43
|
+
if (props.data) {
|
|
44
|
+
propsData = uploadUtil.getPropsData(options.file, props.data);
|
|
45
|
+
}
|
|
46
|
+
if (!data?.uploadApi && !data?.uploadUrl) {
|
|
47
|
+
ElMessage.error(`上传${fileTypeName}Api或地址不能为空`);
|
|
48
|
+
consoleError(componentName, `上传${fileTypeName}接口 “uploadApi” 或地址 “uploadUrl” 不能为空`);
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
loading.value = true;
|
|
52
|
+
try {
|
|
53
|
+
let fileUrl;
|
|
54
|
+
if (data.uploadApi) {
|
|
55
|
+
fileUrl = await uploadUtil.uploadFileByApi(data.uploadApi, options.file, options.filename, propsData);
|
|
56
|
+
} else {
|
|
57
|
+
fileUrl = await uploadUtil.uploadFile(data.uploadUrl, options.file, options.filename, propsData);
|
|
58
|
+
}
|
|
59
|
+
options.onSuccess(fileUrl);
|
|
60
|
+
} finally {
|
|
61
|
+
loading.value = false;
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
const handleOnSuccess = (fileUrl, uploadFile, uploadFiles) => {
|
|
65
|
+
if (!fileUrl) return;
|
|
66
|
+
if (!props.multiple && uploadFiles.length > 1) {
|
|
67
|
+
uploadFiles.shift();
|
|
68
|
+
}
|
|
69
|
+
uploadFile.url = fileUrl;
|
|
70
|
+
handleValue();
|
|
71
|
+
formItemContext?.prop && formContext?.validateField([formItemContext.prop]);
|
|
72
|
+
ElMessage.success("上传成功");
|
|
73
|
+
props.onSuccess && props.onSuccess(fileUrl, uploadFile, uploadFiles);
|
|
74
|
+
};
|
|
75
|
+
const handleOnError = (error, uploadFile, uploadFiles) => {
|
|
76
|
+
ElNotification({
|
|
77
|
+
message: `【${uploadFile.name}】${fileTypeName}上传失败,请您重新上传`,
|
|
78
|
+
type: "error"
|
|
79
|
+
});
|
|
80
|
+
props.onError && props.onError(error, uploadFile, uploadFiles);
|
|
81
|
+
};
|
|
82
|
+
const handleOnExceed = (files, uploadFiles) => {
|
|
83
|
+
ElMessage.warning(`最多只能上传 ${props.limit} 个${fileTypeName},请移除后再进行上传`);
|
|
84
|
+
props.onExceed && props.onExceed(files, uploadFiles);
|
|
85
|
+
};
|
|
86
|
+
const handleOnUpload = (file) => {
|
|
87
|
+
const fileSizeKB = new Decimal(file.size).div(mbNum);
|
|
88
|
+
if (fileSizeKB.greaterThan(maxSizeKB)) {
|
|
89
|
+
consoleWarn(componentName, `【${file.name}】${fileTypeName}上传大小不能超过 ${maxSizeMB.toString()}MB`);
|
|
90
|
+
ElMessage.warning(`【${file.name}】${fileTypeName}上传大小不能超过 ${maxSizeMB.toString()}MB`);
|
|
91
|
+
return false;
|
|
92
|
+
}
|
|
93
|
+
const fileType = "type" in file ? file.type : file.raw.type;
|
|
94
|
+
if (props.accept && props.accept.split(",").every((e) => e !== fileType)) {
|
|
95
|
+
const uploadFileNames = uploadUtil.detectFileType(props.accept);
|
|
96
|
+
consoleError(componentName, `只允许上传【${uploadFileNames}】格式的${fileTypeName}`);
|
|
97
|
+
ElMessage.error(`只允许上传【${uploadFileNames}】格式的${fileTypeName}`);
|
|
98
|
+
return false;
|
|
99
|
+
}
|
|
100
|
+
return true;
|
|
101
|
+
};
|
|
102
|
+
watch(
|
|
103
|
+
() => props.modelValue,
|
|
104
|
+
(newValue) => {
|
|
105
|
+
if (newValue) {
|
|
106
|
+
if (isArray(newValue)) {
|
|
107
|
+
fileList.value = newValue.map((m) => {
|
|
108
|
+
const find = fileList.value.find((f) => f.url === m);
|
|
109
|
+
return {
|
|
110
|
+
name: "",
|
|
111
|
+
status: "success",
|
|
112
|
+
uid: find?.uid ?? genFileId(),
|
|
113
|
+
url: m
|
|
114
|
+
};
|
|
115
|
+
});
|
|
116
|
+
} else {
|
|
117
|
+
const find = fileList.value.find((f) => f.url === newValue);
|
|
118
|
+
fileList.value = [
|
|
119
|
+
{
|
|
120
|
+
name: "",
|
|
121
|
+
status: "success",
|
|
122
|
+
uid: find?.uid ?? genFileId(),
|
|
123
|
+
url: newValue
|
|
124
|
+
}
|
|
125
|
+
];
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
},
|
|
129
|
+
{
|
|
130
|
+
immediate: true
|
|
131
|
+
}
|
|
132
|
+
);
|
|
133
|
+
return {
|
|
134
|
+
fileList,
|
|
135
|
+
loading,
|
|
136
|
+
formContext,
|
|
137
|
+
formItemContext,
|
|
138
|
+
maxSizeMB,
|
|
139
|
+
handleValue,
|
|
140
|
+
handleHttpRequest,
|
|
141
|
+
handleOnSuccess,
|
|
142
|
+
handleOnError,
|
|
143
|
+
handleOnExceed,
|
|
144
|
+
handleOnUpload
|
|
145
|
+
};
|
|
146
|
+
};
|
|
147
|
+
export {
|
|
148
|
+
useUpload
|
|
149
|
+
};
|
|
150
|
+
//# sourceMappingURL=useUpload.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useUpload.mjs","sources":["../../../../../packages/components/upload/src/useUpload.ts"],"sourcesContent":["import { inject, onMounted, ref, watch } from \"vue\";\nimport { ElMessage, ElNotification, formContextKey, formItemContextKey, genFileId } from \"element-plus\";\nimport { consoleError, consoleWarn } from \"@fast-china/utils\";\nimport { useVModel } from \"@vueuse/core\";\nimport { Decimal } from \"decimal.js\";\nimport { isArray, isNumber, isString } from \"lodash-unified\";\nimport { uploadUtil } from \"../utils/upload\";\nimport type { UploadFile, UploadFiles, UploadProps, UploadRawFile, UploadRequestOptions, UploadUserFile } from \"element-plus\";\n\nexport const useUpload = <T extends string | string[]>(\n\tcomponentName: string,\n\tfileTypeName: string,\n\tprops: UploadProps & {\n\t\tmodelValue: T;\n\t},\n\temit: ((event: \"update:fileList\", value: UploadUserFile[]) => void) &\n\t\t((event: \"update:modelValue\", value: T) => void) &\n\t\t((event: \"change\", value: T) => void),\n\tdata?: {\n\t\tmaxSize?: string | number;\n\t\tuploadApi?: (formData: FormData) => Promise<string>;\n\t\tuploadUrl?: string;\n\t}\n\t// eslint-disable-next-line @typescript-eslint/explicit-function-return-type, @typescript-eslint/explicit-module-boundary-types\n) => {\n\tconst fileList = useVModel(props, \"fileList\", emit, { passive: true });\n\n\tconst loading = ref(false);\n\n\t// 获取 el-form 组件上下文\n\tconst formContext = inject(formContextKey, undefined);\n\t// 获取 el-form-item 组件上下文\n\tconst formItemContext = inject(formItemContextKey, undefined);\n\n\tconst mbNum = new Decimal(1024);\n\tconst maxSizeKB = new Decimal(isNumber(data?.maxSize) ? data?.maxSize : Number(data?.maxSize));\n\tconst maxSizeMB = maxSizeKB.div(mbNum);\n\n\tonMounted(() => {\n\t\tif (props.autoUpload && !data.uploadApi && !data.uploadUrl) {\n\t\t\tconsoleWarn(componentName, \"['uploadApi', 'uploadUrl'] 属性必须二选一。\");\n\t\t}\n\t});\n\n\tconst handleValue = (): void => {\n\t\tif (fileList.value.length > 0) {\n\t\t\tif (isString(props.modelValue)) {\n\t\t\t\temit(\"update:modelValue\", fileList.value[0].url as T);\n\t\t\t\temit(\"change\", fileList.value[0].url as T);\n\t\t\t} else {\n\t\t\t\tif (props.multiple) {\n\t\t\t\t\tconst value = fileList.value.map((m) => m.url);\n\t\t\t\t\temit(\"update:modelValue\", value as T);\n\t\t\t\t\temit(\"change\", value as T);\n\t\t\t\t} else {\n\t\t\t\t\temit(\"update:modelValue\", fileList.value[0].url as T);\n\t\t\t\t\temit(\"change\", fileList.value[0].url as T);\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\temit(\"update:modelValue\", null);\n\t\t\temit(\"change\", null);\n\t\t}\n\t};\n\n\tconst handleHttpRequest = async (options: UploadRequestOptions): Promise<void> => {\n\t\tlet propsData;\n\t\tif (props.data) {\n\t\t\tpropsData = uploadUtil.getPropsData(options.file, props.data);\n\t\t}\n\t\tif (!data?.uploadApi && !data?.uploadUrl) {\n\t\t\tElMessage.error(`上传${fileTypeName}Api或地址不能为空`);\n\t\t\tconsoleError(componentName, `上传${fileTypeName}接口 “uploadApi” 或地址 “uploadUrl” 不能为空`);\n\t\t\treturn;\n\t\t}\n\t\tloading.value = true;\n\t\ttry {\n\t\t\tlet fileUrl: string;\n\t\t\tif (data.uploadApi) {\n\t\t\t\tfileUrl = await uploadUtil.uploadFileByApi(data.uploadApi, options.file, options.filename, propsData);\n\t\t\t} else {\n\t\t\t\tfileUrl = await uploadUtil.uploadFile(data.uploadUrl, options.file, options.filename, propsData);\n\t\t\t}\n\t\t\toptions.onSuccess(fileUrl);\n\t\t} finally {\n\t\t\tloading.value = false;\n\t\t}\n\t};\n\n\tconst handleOnSuccess = (fileUrl: string, uploadFile: UploadFile, uploadFiles: UploadFiles): void => {\n\t\tif (!fileUrl) return;\n\t\tif (!props.multiple && uploadFiles.length > 1) {\n\t\t\tuploadFiles.shift();\n\t\t}\n\t\tuploadFile.url = fileUrl;\n\t\thandleValue();\n\t\t// 调用 el-form 内部的校验方法(可自动校验)\n\t\tformItemContext?.prop && formContext?.validateField([formItemContext.prop as string]);\n\t\tElMessage.success(\"上传成功\");\n\t\tprops.onSuccess && props.onSuccess(fileUrl, uploadFile, uploadFiles);\n\t};\n\n\tconst handleOnError = (error: Error, uploadFile: UploadFile, uploadFiles: UploadFiles): void => {\n\t\tElNotification({\n\t\t\tmessage: `【${uploadFile.name}】${fileTypeName}上传失败,请您重新上传`,\n\t\t\ttype: \"error\",\n\t\t});\n\t\tprops.onError && props.onError(error, uploadFile, uploadFiles);\n\t};\n\n\tconst handleOnExceed = (files: File[], uploadFiles: UploadUserFile[]): void => {\n\t\tElMessage.warning(`最多只能上传 ${props.limit} 个${fileTypeName},请移除后再进行上传`);\n\t\tprops.onExceed && props.onExceed(files, uploadFiles);\n\t};\n\n\tconst handleOnUpload = (file: UploadFile | UploadRawFile): boolean => {\n\t\tconst fileSizeKB = new Decimal(file.size).div(mbNum);\n\n\t\tif (fileSizeKB.greaterThan(maxSizeKB)) {\n\t\t\tconsoleWarn(componentName, `【${file.name}】${fileTypeName}上传大小不能超过 ${maxSizeMB.toString()}MB`);\n\t\t\tElMessage.warning(`【${file.name}】${fileTypeName}上传大小不能超过 ${maxSizeMB.toString()}MB`);\n\t\t\treturn false;\n\t\t}\n\n\t\tconst fileType = \"type\" in file ? file.type : file.raw.type;\n\n\t\tif (props.accept && props.accept.split(\",\").every((e) => e !== fileType)) {\n\t\t\tconst uploadFileNames = uploadUtil.detectFileType(props.accept);\n\t\t\tconsoleError(componentName, `只允许上传【${uploadFileNames}】格式的${fileTypeName}`);\n\t\t\tElMessage.error(`只允许上传【${uploadFileNames}】格式的${fileTypeName}`);\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t};\n\n\t/**\n\t * 监听 v-model 绑定数据\n\t */\n\twatch(\n\t\t() => props.modelValue,\n\t\t(newValue) => {\n\t\t\tif (newValue) {\n\t\t\t\tif (isArray(newValue)) {\n\t\t\t\t\tfileList.value = newValue.map((m) => {\n\t\t\t\t\t\tconst find = fileList.value.find((f) => f.url === m);\n\t\t\t\t\t\treturn {\n\t\t\t\t\t\t\tname: \"\",\n\t\t\t\t\t\t\tstatus: \"success\",\n\t\t\t\t\t\t\tuid: find?.uid ?? genFileId(),\n\t\t\t\t\t\t\turl: m,\n\t\t\t\t\t\t};\n\t\t\t\t\t});\n\t\t\t\t} else {\n\t\t\t\t\tconst find = fileList.value.find((f) => f.url === newValue);\n\t\t\t\t\tfileList.value = [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tname: \"\",\n\t\t\t\t\t\t\tstatus: \"success\",\n\t\t\t\t\t\t\tuid: find?.uid ?? genFileId(),\n\t\t\t\t\t\t\turl: newValue,\n\t\t\t\t\t\t},\n\t\t\t\t\t];\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t\t{\n\t\t\timmediate: true,\n\t\t}\n\t);\n\n\treturn {\n\t\tfileList,\n\t\tloading,\n\t\tformContext,\n\t\tformItemContext,\n\t\tmaxSizeMB,\n\t\thandleValue,\n\t\thandleHttpRequest,\n\t\thandleOnSuccess,\n\t\thandleOnError,\n\t\thandleOnExceed,\n\t\thandleOnUpload,\n\t};\n};\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { UploadRawFile } from 'element-plus';
|
|
2
|
+
/**
|
|
3
|
+
* 上传工具类
|
|
4
|
+
*/
|
|
5
|
+
export declare const uploadUtil: {
|
|
6
|
+
/**
|
|
7
|
+
* 识别文件类型
|
|
8
|
+
*/
|
|
9
|
+
detectFileType(accept: string): string;
|
|
10
|
+
/**
|
|
11
|
+
* 获取props data属性值
|
|
12
|
+
*/
|
|
13
|
+
getPropsData(rawFile: UploadRawFile, data: any | any[] | ((rawFile: UploadRawFile) => any[])): any;
|
|
14
|
+
/**
|
|
15
|
+
* 文件上传
|
|
16
|
+
* @param url 地址
|
|
17
|
+
* @param file 文件
|
|
18
|
+
* @param fileName 文件名称
|
|
19
|
+
* @param params 参数
|
|
20
|
+
*/
|
|
21
|
+
uploadFile(url: string, file: File, fileName: string, params?: unknown): Promise<string>;
|
|
22
|
+
/**
|
|
23
|
+
* 文件上传
|
|
24
|
+
* @param url 地址
|
|
25
|
+
* @param file 文件
|
|
26
|
+
* @param fileName 文件名称
|
|
27
|
+
* @param params 参数
|
|
28
|
+
*/
|
|
29
|
+
uploadFileByApi(api: (formData: FormData) => Promise<string>, file: File, fileName: string, params?: unknown): Promise<string>;
|
|
30
|
+
};
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
import { ElMessage } from "element-plus";
|
|
2
|
+
import "../../../constants/index.mjs";
|
|
3
|
+
import { consoleError, consoleWarn } from "@fast-china/utils";
|
|
4
|
+
import { isFunction, isArray } from "lodash-unified";
|
|
5
|
+
import { FaMimeType } from "../../../constants/mime.mjs";
|
|
6
|
+
const FaMimeTypeNames = {};
|
|
7
|
+
for (const [kName, vAccept] of Object.entries(FaMimeType)) {
|
|
8
|
+
vAccept.split(",").forEach((tItem) => {
|
|
9
|
+
FaMimeTypeNames[tItem.trim()] = kName;
|
|
10
|
+
});
|
|
11
|
+
}
|
|
12
|
+
const uploadUtil = {
|
|
13
|
+
/**
|
|
14
|
+
* 识别文件类型
|
|
15
|
+
*/
|
|
16
|
+
detectFileType(accept) {
|
|
17
|
+
const detectTypes = /* @__PURE__ */ new Set();
|
|
18
|
+
accept.split(",").forEach((mimeType) => {
|
|
19
|
+
detectTypes.add(FaMimeTypeNames[mimeType] ?? mimeType);
|
|
20
|
+
});
|
|
21
|
+
return Array.from(detectTypes).join(",");
|
|
22
|
+
},
|
|
23
|
+
/**
|
|
24
|
+
* 获取props data属性值
|
|
25
|
+
*/
|
|
26
|
+
getPropsData(rawFile, data) {
|
|
27
|
+
let propsData;
|
|
28
|
+
if (isFunction(data)) {
|
|
29
|
+
propsData = data(rawFile);
|
|
30
|
+
} else {
|
|
31
|
+
propsData = data;
|
|
32
|
+
}
|
|
33
|
+
const result = {};
|
|
34
|
+
if (isArray(data)) {
|
|
35
|
+
data.forEach((item) => {
|
|
36
|
+
Object.assign(result, item);
|
|
37
|
+
});
|
|
38
|
+
} else {
|
|
39
|
+
Object.assign(result, propsData);
|
|
40
|
+
}
|
|
41
|
+
return result;
|
|
42
|
+
},
|
|
43
|
+
/**
|
|
44
|
+
* 文件上传
|
|
45
|
+
* @param url 地址
|
|
46
|
+
* @param file 文件
|
|
47
|
+
* @param fileName 文件名称
|
|
48
|
+
* @param params 参数
|
|
49
|
+
*/
|
|
50
|
+
async uploadFile(url, file, fileName, params) {
|
|
51
|
+
if (!url) {
|
|
52
|
+
consoleError("uploadUtil", "文件上传地址为空!");
|
|
53
|
+
ElMessage.error("文件上传地址为空!");
|
|
54
|
+
return Promise.reject();
|
|
55
|
+
}
|
|
56
|
+
const formData = new FormData();
|
|
57
|
+
formData.append("file", file);
|
|
58
|
+
formData.append("fileName", fileName);
|
|
59
|
+
if (params) {
|
|
60
|
+
Object.keys(params).forEach((key) => {
|
|
61
|
+
formData.append(key, params[key]);
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
try {
|
|
65
|
+
const response = await fetch(url, {
|
|
66
|
+
headers: {
|
|
67
|
+
"Content-Type": "multipart/form-data"
|
|
68
|
+
},
|
|
69
|
+
method: "POST",
|
|
70
|
+
body: formData
|
|
71
|
+
});
|
|
72
|
+
if (!response.ok) {
|
|
73
|
+
consoleWarn("uploadUtil", "文件上传失败!");
|
|
74
|
+
ElMessage.error("文件上传失败!");
|
|
75
|
+
return Promise.reject();
|
|
76
|
+
}
|
|
77
|
+
return await response.text();
|
|
78
|
+
} catch (error) {
|
|
79
|
+
consoleWarn("uploadUtil", "文件上传失败!");
|
|
80
|
+
consoleError("uploadUtil", error);
|
|
81
|
+
ElMessage.error("文件上传失败!");
|
|
82
|
+
return Promise.reject();
|
|
83
|
+
}
|
|
84
|
+
},
|
|
85
|
+
/**
|
|
86
|
+
* 文件上传
|
|
87
|
+
* @param url 地址
|
|
88
|
+
* @param file 文件
|
|
89
|
+
* @param fileName 文件名称
|
|
90
|
+
* @param params 参数
|
|
91
|
+
*/
|
|
92
|
+
async uploadFileByApi(api, file, fileName, params) {
|
|
93
|
+
if (!api) {
|
|
94
|
+
consoleError("uploadUtil", "文件上传接口为空!");
|
|
95
|
+
ElMessage.error("文件上传接口为空!");
|
|
96
|
+
return Promise.reject();
|
|
97
|
+
}
|
|
98
|
+
const formData = new FormData();
|
|
99
|
+
formData.append("file", file);
|
|
100
|
+
formData.append("fileName", fileName);
|
|
101
|
+
if (params) {
|
|
102
|
+
Object.keys(params).forEach((key) => {
|
|
103
|
+
formData.append(key, params[key]);
|
|
104
|
+
});
|
|
105
|
+
}
|
|
106
|
+
try {
|
|
107
|
+
return Promise.resolve(await api(formData));
|
|
108
|
+
} catch (error) {
|
|
109
|
+
consoleWarn("uploadUtil", "文件上传失败!");
|
|
110
|
+
consoleError("uploadUtil", error);
|
|
111
|
+
ElMessage.error("文件上传失败!");
|
|
112
|
+
return Promise.reject();
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
};
|
|
116
|
+
export {
|
|
117
|
+
uploadUtil
|
|
118
|
+
};
|
|
119
|
+
//# sourceMappingURL=upload.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"upload.mjs","sources":["../../../../../packages/components/upload/utils/upload.ts"],"sourcesContent":["import { ElMessage } from \"element-plus\";\nimport { FaMimeType } from \"@fast-element-plus/constants\";\nimport { consoleError, consoleWarn } from \"@fast-china/utils\";\nimport { isArray, isFunction } from \"lodash-unified\";\nimport type { UploadRawFile } from \"element-plus\";\n\nconst FaMimeTypeNames: Record<string, keyof typeof FaMimeType> = {};\n\nfor (const [kName, vAccept] of Object.entries(FaMimeType)) {\n\tvAccept.split(\",\").forEach((tItem) => {\n\t\tFaMimeTypeNames[tItem.trim()] = kName as keyof typeof FaMimeType;\n\t});\n}\n\n/**\n * 上传工具类\n */\nexport const uploadUtil = {\n\t/**\n\t * 识别文件类型\n\t */\n\tdetectFileType(accept: string): string {\n\t\tconst detectTypes = new Set<string>();\n\t\taccept.split(\",\").forEach((mimeType) => {\n\t\t\tdetectTypes.add(FaMimeTypeNames[mimeType] ?? mimeType);\n\t\t});\n\t\treturn Array.from(detectTypes).join(\",\");\n\t},\n\t/**\n\t * 获取props data属性值\n\t */\n\tgetPropsData(rawFile: UploadRawFile, data: any | any[] | ((rawFile: UploadRawFile) => any[])): any {\n\t\tlet propsData;\n\t\tif (isFunction(data)) {\n\t\t\tpropsData = data(rawFile);\n\t\t} else {\n\t\t\tpropsData = data;\n\t\t}\n\n\t\tconst result = {};\n\t\tif (isArray(data)) {\n\t\t\tdata.forEach((item) => {\n\t\t\t\tObject.assign(result, item);\n\t\t\t});\n\t\t} else {\n\t\t\tObject.assign(result, propsData);\n\t\t}\n\n\t\treturn result;\n\t},\n\t/**\n\t * 文件上传\n\t * @param url 地址\n\t * @param file 文件\n\t * @param fileName 文件名称\n\t * @param params 参数\n\t */\n\tasync uploadFile(url: string, file: File, fileName: string, params?: unknown): Promise<string> {\n\t\tif (!url) {\n\t\t\tconsoleError(\"uploadUtil\", \"文件上传地址为空!\");\n\t\t\tElMessage.error(\"文件上传地址为空!\");\n\t\t\treturn Promise.reject();\n\t\t}\n\t\tconst formData = new FormData();\n\t\tformData.append(\"file\", file);\n\t\tformData.append(\"fileName\", fileName);\n\t\tif (params) {\n\t\t\tObject.keys(params).forEach((key) => {\n\t\t\t\tformData.append(key, params[key]);\n\t\t\t});\n\t\t}\n\t\ttry {\n\t\t\tconst response = await fetch(url, {\n\t\t\t\theaders: {\n\t\t\t\t\t\"Content-Type\": \"multipart/form-data\",\n\t\t\t\t},\n\t\t\t\tmethod: \"POST\",\n\t\t\t\tbody: formData,\n\t\t\t});\n\t\t\tif (!response.ok) {\n\t\t\t\tconsoleWarn(\"uploadUtil\", \"文件上传失败!\");\n\t\t\t\tElMessage.error(\"文件上传失败!\");\n\t\t\t\treturn Promise.reject();\n\t\t\t}\n\t\t\treturn await response.text();\n\t\t} catch (error) {\n\t\t\tconsoleWarn(\"uploadUtil\", \"文件上传失败!\");\n\t\t\tconsoleError(\"uploadUtil\", error);\n\t\t\tElMessage.error(\"文件上传失败!\");\n\t\t\treturn Promise.reject();\n\t\t}\n\t},\n\t/**\n\t * 文件上传\n\t * @param url 地址\n\t * @param file 文件\n\t * @param fileName 文件名称\n\t * @param params 参数\n\t */\n\tasync uploadFileByApi(api: (formData: FormData) => Promise<string>, file: File, fileName: string, params?: unknown): Promise<string> {\n\t\tif (!api) {\n\t\t\tconsoleError(\"uploadUtil\", \"文件上传接口为空!\");\n\t\t\tElMessage.error(\"文件上传接口为空!\");\n\t\t\treturn Promise.reject();\n\t\t}\n\t\tconst formData = new FormData();\n\t\tformData.append(\"file\", file);\n\t\tformData.append(\"fileName\", fileName);\n\t\tif (params) {\n\t\t\tObject.keys(params).forEach((key) => {\n\t\t\t\tformData.append(key, params[key]);\n\t\t\t});\n\t\t}\n\t\ttry {\n\t\t\treturn Promise.resolve<string>(await api(formData));\n\t\t} catch (error) {\n\t\t\tconsoleWarn(\"uploadUtil\", \"文件上传失败!\");\n\t\t\tconsoleError(\"uploadUtil\", error);\n\t\t\tElMessage.error(\"文件上传失败!\");\n\t\t\treturn Promise.reject();\n\t\t}\n\t},\n};\n"],"names":[],"mappings":";;;;;AAMA,MAAM,kBAA2D,CAAA;AAEjE,WAAW,CAAC,OAAO,OAAO,KAAK,OAAO,QAAQ,UAAU,GAAG;AAC1D,UAAQ,MAAM,GAAG,EAAE,QAAQ,CAAC,UAAU;AACrC,oBAAgB,MAAM,KAAA,CAAM,IAAI;AAAA,EACjC,CAAC;AACF;AAKO,MAAM,aAAa;AAAA;AAAA;AAAA;AAAA,EAIzB,eAAe,QAAwB;AACtC,UAAM,kCAAkB,IAAA;AACxB,WAAO,MAAM,GAAG,EAAE,QAAQ,CAAC,aAAa;AACvC,kBAAY,IAAI,gBAAgB,QAAQ,KAAK,QAAQ;AAAA,IACtD,CAAC;AACD,WAAO,MAAM,KAAK,WAAW,EAAE,KAAK,GAAG;AAAA,EACxC;AAAA;AAAA;AAAA;AAAA,EAIA,aAAa,SAAwB,MAA8D;AAClG,QAAI;AACJ,QAAI,WAAW,IAAI,GAAG;AACrB,kBAAY,KAAK,OAAO;AAAA,IACzB,OAAO;AACN,kBAAY;AAAA,IACb;AAEA,UAAM,SAAS,CAAA;AACf,QAAI,QAAQ,IAAI,GAAG;AAClB,WAAK,QAAQ,CAAC,SAAS;AACtB,eAAO,OAAO,QAAQ,IAAI;AAAA,MAC3B,CAAC;AAAA,IACF,OAAO;AACN,aAAO,OAAO,QAAQ,SAAS;AAAA,IAChC;AAEA,WAAO;AAAA,EACR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAM,WAAW,KAAa,MAAY,UAAkB,QAAmC;AAC9F,QAAI,CAAC,KAAK;AACT,mBAAa,cAAc,WAAW;AACtC,gBAAU,MAAM,WAAW;AAC3B,aAAO,QAAQ,OAAA;AAAA,IAChB;AACA,UAAM,WAAW,IAAI,SAAA;AACrB,aAAS,OAAO,QAAQ,IAAI;AAC5B,aAAS,OAAO,YAAY,QAAQ;AACpC,QAAI,QAAQ;AACX,aAAO,KAAK,MAAM,EAAE,QAAQ,CAAC,QAAQ;AACpC,iBAAS,OAAO,KAAK,OAAO,GAAG,CAAC;AAAA,MACjC,CAAC;AAAA,IACF;AACA,QAAI;AACH,YAAM,WAAW,MAAM,MAAM,KAAK;AAAA,QACjC,SAAS;AAAA,UACR,gBAAgB;AAAA,QAAA;AAAA,QAEjB,QAAQ;AAAA,QACR,MAAM;AAAA,MAAA,CACN;AACD,UAAI,CAAC,SAAS,IAAI;AACjB,oBAAY,cAAc,SAAS;AACnC,kBAAU,MAAM,SAAS;AACzB,eAAO,QAAQ,OAAA;AAAA,MAChB;AACA,aAAO,MAAM,SAAS,KAAA;AAAA,IACvB,SAAS,OAAO;AACf,kBAAY,cAAc,SAAS;AACnC,mBAAa,cAAc,KAAK;AAChC,gBAAU,MAAM,SAAS;AACzB,aAAO,QAAQ,OAAA;AAAA,IAChB;AAAA,EACD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,MAAM,gBAAgB,KAA8C,MAAY,UAAkB,QAAmC;AACpI,QAAI,CAAC,KAAK;AACT,mBAAa,cAAc,WAAW;AACtC,gBAAU,MAAM,WAAW;AAC3B,aAAO,QAAQ,OAAA;AAAA,IAChB;AACA,UAAM,WAAW,IAAI,SAAA;AACrB,aAAS,OAAO,QAAQ,IAAI;AAC5B,aAAS,OAAO,YAAY,QAAQ;AACpC,QAAI,QAAQ;AACX,aAAO,KAAK,MAAM,EAAE,QAAQ,CAAC,QAAQ;AACpC,iBAAS,OAAO,KAAK,OAAO,GAAG,CAAC;AAAA,MACjC,CAAC;AAAA,IACF;AACA,QAAI;AACH,aAAO,QAAQ,QAAgB,MAAM,IAAI,QAAQ,CAAC;AAAA,IACnD,SAAS,OAAO;AACf,kBAAY,cAAc,SAAS;AACnC,mBAAa,cAAc,KAAK;AAChC,gBAAU,MAAM,SAAS;AACzB,aAAO,QAAQ,OAAA;AAAA,IAChB;AAAA,EACD;AACD;"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { TSXWithInstall } from "@fast-china/utils";
|
|
2
|
+
import type { default as UploadImage, faUploadImageEmits, faUploadImageProps } from "./src/uploadImage";
|
|
3
|
+
import type { ExtractPropTypes } from "vue";
|
|
4
|
+
|
|
5
|
+
export declare const FaUploadImage: TSXWithInstall<typeof UploadImage>;
|
|
6
|
+
export default FaUploadImage;
|
|
7
|
+
|
|
8
|
+
export { faUploadImageProps, faUploadImageEmits };
|
|
9
|
+
|
|
10
|
+
export type FaUploadImageInstance = InstanceType<typeof UploadImage>;
|
|
11
|
+
|
|
12
|
+
export type FaUploadImageProps = ExtractPropTypes<typeof faUploadImageProps>;
|
|
13
|
+
|
|
14
|
+
export type FaUploadImageEmits = typeof faUploadImageEmits;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { withInstall } from "@fast-china/utils";
|
|
2
|
+
import UploadImage from "./src/uploadImage.mjs";
|
|
3
|
+
import { faUploadImageEmits, faUploadImageProps } from "./src/uploadImage.mjs";
|
|
4
|
+
const FaUploadImage = withInstall(UploadImage);
|
|
5
|
+
export {
|
|
6
|
+
FaUploadImage,
|
|
7
|
+
FaUploadImage as default,
|
|
8
|
+
faUploadImageEmits,
|
|
9
|
+
faUploadImageProps
|
|
10
|
+
};
|
|
11
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../../../../packages/components/uploadImage/index.ts"],"sourcesContent":["import { withInstall } from \"@fast-china/utils\";\nimport UploadImage, { faUploadImageEmits, faUploadImageProps } from \"./src/uploadImage\";\nimport type { ExtractPropTypes } from \"vue\";\n\nexport const FaUploadImage = withInstall(UploadImage);\nexport default FaUploadImage;\n\nexport { faUploadImageProps, faUploadImageEmits };\n\nexport type FaUploadImageInstance = InstanceType<typeof UploadImage>;\n\nexport type FaUploadImageProps = ExtractPropTypes<typeof faUploadImageProps>;\n\nexport type FaUploadImageEmits = typeof faUploadImageEmits;\n"],"names":[],"mappings":";;;AAIO,MAAM,gBAAgB,YAAY,WAAW;"}
|