fast-element-plus 1.0.20 → 1.0.21
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/index.full.js +27739 -28664
- package/dist/index.full.js.map +1 -1
- package/dist/index.full.min.js +11042 -2
- package/dist/index.full.min.js.map +1 -1
- package/dist/index.full.min.mjs +11033 -2
- package/dist/index.full.min.mjs.map +1 -1
- package/dist/index.full.mjs +27730 -28662
- package/dist/index.full.mjs.map +1 -1
- package/es/_virtual/_rolldown/runtime.mjs +1 -0
- package/es/component.mjs +2 -2
- package/es/component.mjs.map +1 -1
- package/es/components/avatar/index.mjs +2 -2
- package/es/components/avatar/index.mjs.map +1 -1
- package/es/components/avatar/src/avatar.d.ts +10 -10
- package/es/components/avatar/src/avatar.mjs +2 -2
- package/es/components/avatar/src/avatar.mjs.map +1 -1
- package/es/components/button/index.mjs +2 -2
- package/es/components/button/index.mjs.map +1 -1
- package/es/components/button/src/button.d.ts +21 -17
- package/es/components/button/src/button.mjs +2 -2
- package/es/components/button/src/button.mjs.map +1 -1
- package/es/components/carNumber/index.mjs +2 -2
- package/es/components/carNumber/index.mjs.map +1 -1
- package/es/components/carNumber/src/carNumber.d.ts +36 -33
- package/es/components/carNumber/src/carNumber.mjs +2 -2
- package/es/components/carNumber/src/carNumber.mjs.map +1 -1
- package/es/components/carNumber/src/common.mjs +2 -2
- package/es/components/carNumber/src/common.mjs.map +1 -1
- package/es/components/contextMenu/index.mjs +2 -2
- package/es/components/contextMenu/index.mjs.map +1 -1
- package/es/components/contextMenu/src/contextMenu.mjs +2 -2
- package/es/components/contextMenu/src/contextMenu.mjs.map +1 -1
- package/es/components/contextMenu/src/contextMenu.type.mjs +0 -2
- package/es/components/dialog/index.mjs +2 -2
- package/es/components/dialog/index.mjs.map +1 -1
- package/es/components/dialog/src/dialog.d.ts +11 -11
- package/es/components/dialog/src/dialog.mjs +2 -2
- package/es/components/dialog/src/dialog.mjs.map +1 -1
- package/es/components/drawer/index.mjs +2 -2
- package/es/components/drawer/index.mjs.map +1 -1
- package/es/components/drawer/src/drawer.d.ts +10 -18
- package/es/components/drawer/src/drawer.mjs +2 -2
- package/es/components/drawer/src/drawer.mjs.map +1 -1
- package/es/components/form/index.mjs +2 -2
- package/es/components/form/index.mjs.map +1 -1
- package/es/components/form/src/form.d.ts +15 -15
- package/es/components/form/src/form.mjs +2 -2
- package/es/components/form/src/form.mjs.map +1 -1
- package/es/components/form/src/formItem.d.ts +14 -14
- package/es/components/form/src/formItem.mjs +2 -2
- package/es/components/form/src/formItem.mjs.map +1 -1
- package/es/components/form/utils/form.mjs +2 -2
- package/es/components/form/utils/form.mjs.map +1 -1
- package/es/components/formItemTip/index.mjs +2 -2
- package/es/components/formItemTip/index.mjs.map +1 -1
- package/es/components/formItemTip/src/formItemTip.mjs +2 -2
- package/es/components/formItemTip/src/formItemTip.mjs.map +1 -1
- package/es/components/icon/index.mjs +2 -2
- package/es/components/icon/index.mjs.map +1 -1
- package/es/components/icon/src/icon.mjs +2 -2
- package/es/components/icon/src/icon.mjs.map +1 -1
- package/es/components/iconSelector/index.mjs +2 -2
- package/es/components/iconSelector/index.mjs.map +1 -1
- package/es/components/iconSelector/src/iconSelector.mjs +2 -2
- package/es/components/iconSelector/src/iconSelector.mjs.map +1 -1
- package/es/components/image/index.mjs +2 -2
- package/es/components/image/index.mjs.map +1 -1
- package/es/components/image/src/image.d.ts +13 -13
- package/es/components/image/src/image.mjs +2 -2
- package/es/components/image/src/image.mjs.map +1 -1
- package/es/components/index.mjs +2 -2
- package/es/components/index.mjs.map +1 -1
- package/es/components/inputDialogPage/index.mjs +2 -2
- package/es/components/inputDialogPage/index.mjs.map +1 -1
- package/es/components/inputDialogPage/src/inputDialogPage.mjs +2 -2
- package/es/components/inputDialogPage/src/inputDialogPage.mjs.map +1 -1
- package/es/components/layoutGrid/index.mjs +2 -2
- package/es/components/layoutGrid/index.mjs.map +1 -1
- package/es/components/layoutGrid/src/layoutGrid.mjs +2 -2
- package/es/components/layoutGrid/src/layoutGrid.mjs.map +1 -1
- package/es/components/layoutGrid/src/layoutGrid.type.mjs +0 -2
- package/es/components/layoutGrid/src/layoutGridItem.mjs +2 -2
- package/es/components/layoutGrid/src/layoutGridItem.mjs.map +1 -1
- package/es/components/select/index.mjs +2 -2
- package/es/components/select/index.mjs.map +1 -1
- package/es/components/select/src/select.d.ts +21 -21
- package/es/components/select/src/select.mjs +2 -2
- package/es/components/select/src/select.mjs.map +1 -1
- package/es/components/select/src/select.type.mjs +0 -2
- package/es/components/select/src/selectOption.mjs +2 -2
- package/es/components/select/src/selectOption.mjs.map +1 -1
- package/es/components/selectPage/index.mjs +2 -2
- package/es/components/selectPage/index.mjs.map +1 -1
- package/es/components/selectPage/src/selectPage.d.ts +27 -27
- package/es/components/selectPage/src/selectPage.mjs +2 -2
- package/es/components/selectPage/src/selectPage.mjs.map +1 -1
- package/es/components/selectV2/index.mjs +2 -2
- package/es/components/selectV2/index.mjs.map +1 -1
- package/es/components/selectV2/src/selectV2.d.ts +19 -19
- package/es/components/selectV2/src/selectV2.mjs +2 -2
- package/es/components/selectV2/src/selectV2.mjs.map +1 -1
- package/es/components/table/images/artwork.mjs +2 -0
- package/es/components/table/images/artwork.mjs.map +1 -0
- package/es/components/table/images/notImage.mjs +2 -0
- package/es/components/table/images/notImage.mjs.map +1 -0
- package/es/components/table/index.mjs +2 -2
- package/es/components/table/index.mjs.map +1 -1
- package/es/components/table/src/page.type.mjs +2 -2
- package/es/components/table/src/page.type.mjs.map +1 -1
- package/es/components/table/src/table.d.ts +20 -4
- package/es/components/table/src/table.mjs +2 -2
- package/es/components/table/src/table.mjs.map +1 -1
- package/es/components/table/src/table.state.mjs +0 -2
- package/es/components/table/src/table.type.d.ts +1 -1
- package/es/components/table/src/table.type.mjs +2 -2
- package/es/components/table/src/table.type.mjs.map +1 -1
- package/es/components/table/src/tableColumn.mjs +2 -2
- package/es/components/table/src/tableColumn.mjs.map +1 -1
- package/es/components/table/src/tableColumnSettingDialog.mjs +2 -2
- package/es/components/table/src/tableColumnSettingDialog.mjs.map +1 -1
- package/es/components/table/src/tablePagination.mjs +2 -2
- package/es/components/table/src/tablePagination.mjs.map +1 -1
- package/es/components/table/src/tableSearchForm.mjs +2 -2
- package/es/components/table/src/tableSearchForm.mjs.map +1 -1
- package/es/components/table/src/tableSearchFormItem.mjs +2 -2
- package/es/components/table/src/tableSearchFormItem.mjs.map +1 -1
- package/es/components/table/src/useTable.mjs +2 -2
- package/es/components/table/src/useTable.mjs.map +1 -1
- package/es/components/table/utils/table.mjs +2 -2
- package/es/components/table/utils/table.mjs.map +1 -1
- package/es/components/tree/index.mjs +2 -2
- package/es/components/tree/index.mjs.map +1 -1
- package/es/components/tree/src/tree.d.ts +40 -40
- package/es/components/tree/src/tree.mjs +2 -2
- package/es/components/tree/src/tree.mjs.map +1 -1
- package/es/components/tree/src/tree.props.mjs +2 -2
- package/es/components/tree/src/tree.props.mjs.map +1 -1
- package/es/components/tree/src/tree.type.mjs +0 -2
- package/es/components/treeSelect/index.mjs +2 -2
- package/es/components/treeSelect/index.mjs.map +1 -1
- package/es/components/treeSelect/src/treeSelect.d.ts +60 -60
- package/es/components/treeSelect/src/treeSelect.mjs +2 -2
- package/es/components/treeSelect/src/treeSelect.mjs.map +1 -1
- package/es/components/upload/index.mjs +2 -2
- package/es/components/upload/index.mjs.map +1 -1
- package/es/components/upload/src/upload.d.ts +73 -73
- package/es/components/upload/src/upload.mjs +2 -2
- package/es/components/upload/src/upload.mjs.map +1 -1
- package/es/components/upload/src/useUpload.mjs +2 -2
- package/es/components/upload/src/useUpload.mjs.map +1 -1
- package/es/components/upload/utils/upload.mjs +2 -2
- package/es/components/upload/utils/upload.mjs.map +1 -1
- package/es/components/uploadImage/index.mjs +2 -2
- package/es/components/uploadImage/index.mjs.map +1 -1
- package/es/components/uploadImage/src/uploadImage.d.ts +69 -69
- package/es/components/uploadImage/src/uploadImage.mjs +2 -2
- package/es/components/uploadImage/src/uploadImage.mjs.map +1 -1
- package/es/components/uploadImages/index.mjs +2 -2
- package/es/components/uploadImages/index.mjs.map +1 -1
- package/es/components/uploadImages/src/uploadImages.d.ts +70 -70
- package/es/components/uploadImages/src/uploadImages.mjs +2 -2
- package/es/components/uploadImages/src/uploadImages.mjs.map +1 -1
- package/es/constants/index.mjs +1 -2
- package/es/constants/mime.mjs +2 -2
- package/es/constants/mime.mjs.map +1 -1
- package/es/constants/regex.mjs +2 -2
- package/es/constants/regex.mjs.map +1 -1
- package/es/directive.mjs +2 -2
- package/es/directive.mjs.map +1 -1
- package/es/directives/click-copy/index.mjs +2 -2
- package/es/directives/click-copy/index.mjs.map +1 -1
- package/es/directives/click-debounce/index.mjs +2 -2
- package/es/directives/click-debounce/index.mjs.map +1 -1
- package/es/directives/click-draggable/index.mjs +2 -2
- package/es/directives/click-draggable/index.mjs.map +1 -1
- package/es/directives/click-icon-copy/index.mjs +2 -2
- package/es/directives/click-icon-copy/index.mjs.map +1 -1
- package/es/directives/click-longpress/index.mjs +2 -2
- package/es/directives/click-longpress/index.mjs.map +1 -1
- package/es/directives/click-throttle/index.mjs +2 -2
- package/es/directives/click-throttle/index.mjs.map +1 -1
- package/es/directives/index.mjs +1 -2
- package/es/element-plus.mjs +2 -2
- package/es/element-plus.mjs.map +1 -1
- package/es/hooks/index.mjs +1 -2
- package/es/hooks/use-loading/index.mjs +2 -2
- package/es/hooks/use-loading/index.mjs.map +1 -1
- package/es/hooks/use-overlay/index.mjs +2 -2
- package/es/hooks/use-overlay/index.mjs.map +1 -1
- package/es/hooks/use-screenFull/index.mjs +2 -2
- package/es/hooks/use-screenFull/index.mjs.map +1 -1
- package/es/index.mjs +2 -2
- package/es/index.mjs.map +1 -1
- package/es/make-installer.mjs +2 -2
- package/es/make-installer.mjs.map +1 -1
- package/es/version.d.ts +1 -1
- package/es/version.mjs +2 -2
- package/es/version.mjs.map +1 -1
- package/lib/_virtual/_rolldown/runtime.js +1 -0
- package/lib/component.js +2 -2
- package/lib/component.js.map +1 -1
- package/lib/components/avatar/index.js +2 -2
- package/lib/components/avatar/index.js.map +1 -1
- package/lib/components/avatar/src/avatar.d.ts +10 -10
- package/lib/components/avatar/src/avatar.js +2 -2
- package/lib/components/avatar/src/avatar.js.map +1 -1
- package/lib/components/button/index.js +2 -2
- package/lib/components/button/index.js.map +1 -1
- package/lib/components/button/src/button.d.ts +21 -17
- package/lib/components/button/src/button.js +2 -2
- package/lib/components/button/src/button.js.map +1 -1
- package/lib/components/carNumber/index.js +2 -2
- package/lib/components/carNumber/index.js.map +1 -1
- package/lib/components/carNumber/src/carNumber.d.ts +36 -33
- package/lib/components/carNumber/src/carNumber.js +2 -2
- package/lib/components/carNumber/src/carNumber.js.map +1 -1
- package/lib/components/carNumber/src/common.js +2 -2
- package/lib/components/carNumber/src/common.js.map +1 -1
- package/lib/components/contextMenu/index.js +2 -2
- package/lib/components/contextMenu/index.js.map +1 -1
- package/lib/components/contextMenu/src/contextMenu.js +2 -2
- package/lib/components/contextMenu/src/contextMenu.js.map +1 -1
- package/lib/components/contextMenu/src/contextMenu.type.js +0 -2
- package/lib/components/dialog/index.js +2 -2
- package/lib/components/dialog/index.js.map +1 -1
- package/lib/components/dialog/src/dialog.d.ts +11 -11
- package/lib/components/dialog/src/dialog.js +2 -2
- package/lib/components/dialog/src/dialog.js.map +1 -1
- package/lib/components/drawer/index.js +2 -2
- package/lib/components/drawer/index.js.map +1 -1
- package/lib/components/drawer/src/drawer.d.ts +10 -18
- package/lib/components/drawer/src/drawer.js +2 -2
- package/lib/components/drawer/src/drawer.js.map +1 -1
- package/lib/components/form/index.js +2 -2
- package/lib/components/form/index.js.map +1 -1
- package/lib/components/form/src/form.d.ts +15 -15
- package/lib/components/form/src/form.js +2 -2
- package/lib/components/form/src/form.js.map +1 -1
- package/lib/components/form/src/formItem.d.ts +14 -14
- package/lib/components/form/src/formItem.js +2 -2
- package/lib/components/form/src/formItem.js.map +1 -1
- package/lib/components/form/utils/form.js +2 -2
- package/lib/components/form/utils/form.js.map +1 -1
- package/lib/components/formItemTip/index.js +2 -2
- package/lib/components/formItemTip/index.js.map +1 -1
- package/lib/components/formItemTip/src/formItemTip.js +2 -2
- package/lib/components/formItemTip/src/formItemTip.js.map +1 -1
- package/lib/components/icon/index.js +2 -2
- package/lib/components/icon/index.js.map +1 -1
- package/lib/components/icon/src/icon.js +2 -2
- package/lib/components/icon/src/icon.js.map +1 -1
- package/lib/components/iconSelector/index.js +2 -2
- package/lib/components/iconSelector/index.js.map +1 -1
- package/lib/components/iconSelector/src/iconSelector.js +2 -2
- package/lib/components/iconSelector/src/iconSelector.js.map +1 -1
- package/lib/components/image/index.js +2 -2
- package/lib/components/image/index.js.map +1 -1
- package/lib/components/image/src/image.d.ts +13 -13
- package/lib/components/image/src/image.js +2 -2
- package/lib/components/image/src/image.js.map +1 -1
- package/lib/components/index.js +2 -2
- package/lib/components/index.js.map +1 -1
- package/lib/components/inputDialogPage/index.js +2 -2
- package/lib/components/inputDialogPage/index.js.map +1 -1
- package/lib/components/inputDialogPage/src/inputDialogPage.js +2 -2
- package/lib/components/inputDialogPage/src/inputDialogPage.js.map +1 -1
- package/lib/components/layoutGrid/index.js +2 -2
- package/lib/components/layoutGrid/index.js.map +1 -1
- package/lib/components/layoutGrid/src/layoutGrid.js +2 -2
- package/lib/components/layoutGrid/src/layoutGrid.js.map +1 -1
- package/lib/components/layoutGrid/src/layoutGrid.type.js +0 -2
- package/lib/components/layoutGrid/src/layoutGridItem.js +2 -2
- package/lib/components/layoutGrid/src/layoutGridItem.js.map +1 -1
- package/lib/components/select/index.js +2 -2
- package/lib/components/select/index.js.map +1 -1
- package/lib/components/select/src/select.d.ts +21 -21
- package/lib/components/select/src/select.js +2 -2
- package/lib/components/select/src/select.js.map +1 -1
- package/lib/components/select/src/select.type.js +0 -2
- package/lib/components/select/src/selectOption.js +2 -2
- package/lib/components/select/src/selectOption.js.map +1 -1
- package/lib/components/selectPage/index.js +2 -2
- package/lib/components/selectPage/index.js.map +1 -1
- package/lib/components/selectPage/src/selectPage.d.ts +27 -27
- package/lib/components/selectPage/src/selectPage.js +2 -2
- package/lib/components/selectPage/src/selectPage.js.map +1 -1
- package/lib/components/selectV2/index.js +2 -2
- package/lib/components/selectV2/index.js.map +1 -1
- package/lib/components/selectV2/src/selectV2.d.ts +19 -19
- package/lib/components/selectV2/src/selectV2.js +2 -2
- package/lib/components/selectV2/src/selectV2.js.map +1 -1
- package/lib/components/table/images/artwork.js +2 -0
- package/lib/components/table/images/artwork.js.map +1 -0
- package/lib/components/table/images/notImage.js +2 -0
- package/lib/components/table/images/notImage.js.map +1 -0
- package/lib/components/table/index.js +2 -2
- package/lib/components/table/index.js.map +1 -1
- package/lib/components/table/src/page.type.js +2 -2
- package/lib/components/table/src/page.type.js.map +1 -1
- package/lib/components/table/src/table.d.ts +20 -4
- package/lib/components/table/src/table.js +2 -2
- package/lib/components/table/src/table.js.map +1 -1
- package/lib/components/table/src/table.state.js +0 -2
- package/lib/components/table/src/table.type.d.ts +1 -1
- package/lib/components/table/src/table.type.js +2 -2
- package/lib/components/table/src/table.type.js.map +1 -1
- package/lib/components/table/src/tableColumn.js +2 -2
- package/lib/components/table/src/tableColumn.js.map +1 -1
- package/lib/components/table/src/tableColumnSettingDialog.js +2 -2
- package/lib/components/table/src/tableColumnSettingDialog.js.map +1 -1
- package/lib/components/table/src/tablePagination.js +2 -2
- package/lib/components/table/src/tablePagination.js.map +1 -1
- package/lib/components/table/src/tableSearchForm.js +2 -2
- package/lib/components/table/src/tableSearchForm.js.map +1 -1
- package/lib/components/table/src/tableSearchFormItem.js +2 -2
- package/lib/components/table/src/tableSearchFormItem.js.map +1 -1
- package/lib/components/table/src/useTable.js +2 -2
- package/lib/components/table/src/useTable.js.map +1 -1
- package/lib/components/table/utils/table.js +2 -2
- package/lib/components/table/utils/table.js.map +1 -1
- package/lib/components/tree/index.js +2 -2
- package/lib/components/tree/index.js.map +1 -1
- package/lib/components/tree/src/tree.d.ts +40 -40
- package/lib/components/tree/src/tree.js +2 -2
- package/lib/components/tree/src/tree.js.map +1 -1
- package/lib/components/tree/src/tree.props.js +2 -2
- package/lib/components/tree/src/tree.props.js.map +1 -1
- package/lib/components/tree/src/tree.type.js +0 -2
- package/lib/components/treeSelect/index.js +2 -2
- package/lib/components/treeSelect/index.js.map +1 -1
- package/lib/components/treeSelect/src/treeSelect.d.ts +60 -60
- package/lib/components/treeSelect/src/treeSelect.js +2 -2
- package/lib/components/treeSelect/src/treeSelect.js.map +1 -1
- package/lib/components/upload/index.js +2 -2
- package/lib/components/upload/index.js.map +1 -1
- package/lib/components/upload/src/upload.d.ts +73 -73
- package/lib/components/upload/src/upload.js +2 -2
- package/lib/components/upload/src/upload.js.map +1 -1
- package/lib/components/upload/src/useUpload.js +2 -2
- package/lib/components/upload/src/useUpload.js.map +1 -1
- package/lib/components/upload/utils/upload.js +2 -2
- package/lib/components/upload/utils/upload.js.map +1 -1
- package/lib/components/uploadImage/index.js +2 -2
- package/lib/components/uploadImage/index.js.map +1 -1
- package/lib/components/uploadImage/src/uploadImage.d.ts +69 -69
- package/lib/components/uploadImage/src/uploadImage.js +2 -2
- package/lib/components/uploadImage/src/uploadImage.js.map +1 -1
- package/lib/components/uploadImages/index.js +2 -2
- package/lib/components/uploadImages/index.js.map +1 -1
- package/lib/components/uploadImages/src/uploadImages.d.ts +70 -70
- package/lib/components/uploadImages/src/uploadImages.js +2 -2
- package/lib/components/uploadImages/src/uploadImages.js.map +1 -1
- package/lib/constants/index.js +1 -2
- package/lib/constants/mime.js +2 -2
- package/lib/constants/mime.js.map +1 -1
- package/lib/constants/regex.js +2 -2
- package/lib/constants/regex.js.map +1 -1
- package/lib/directive.js +2 -2
- package/lib/directive.js.map +1 -1
- package/lib/directives/click-copy/index.js +2 -2
- package/lib/directives/click-copy/index.js.map +1 -1
- package/lib/directives/click-debounce/index.js +2 -2
- package/lib/directives/click-debounce/index.js.map +1 -1
- package/lib/directives/click-draggable/index.js +2 -2
- package/lib/directives/click-draggable/index.js.map +1 -1
- package/lib/directives/click-icon-copy/index.js +2 -2
- package/lib/directives/click-icon-copy/index.js.map +1 -1
- package/lib/directives/click-longpress/index.js +2 -2
- package/lib/directives/click-longpress/index.js.map +1 -1
- package/lib/directives/click-throttle/index.js +2 -2
- package/lib/directives/click-throttle/index.js.map +1 -1
- package/lib/directives/index.js +1 -2
- package/lib/element-plus.js +2 -2
- package/lib/element-plus.js.map +1 -1
- package/lib/hooks/index.js +1 -2
- package/lib/hooks/use-loading/index.js +2 -2
- package/lib/hooks/use-loading/index.js.map +1 -1
- package/lib/hooks/use-overlay/index.js +2 -2
- package/lib/hooks/use-overlay/index.js.map +1 -1
- package/lib/hooks/use-screenFull/index.js +2 -2
- package/lib/hooks/use-screenFull/index.js.map +1 -1
- package/lib/index.js +2 -2
- package/lib/index.js.map +1 -1
- package/lib/make-installer.js +2 -2
- package/lib/make-installer.js.map +1 -1
- package/lib/version.d.ts +1 -1
- package/lib/version.js +2 -2
- package/lib/version.js.map +1 -1
- package/package.json +7 -7
- package/es/components/contextMenu/src/contextMenu.type.mjs.map +0 -1
- package/es/components/layoutGrid/src/layoutGrid.type.mjs.map +0 -1
- package/es/components/select/src/select.type.mjs.map +0 -1
- package/es/components/table/images/artwork.png.mjs +0 -2
- package/es/components/table/images/artwork.png.mjs.map +0 -1
- package/es/components/table/images/notImage.png.mjs +0 -2
- package/es/components/table/images/notImage.png.mjs.map +0 -1
- package/es/components/table/src/table.state.mjs.map +0 -1
- package/es/components/tree/src/tree.type.mjs.map +0 -1
- package/es/constants/index.mjs.map +0 -1
- package/es/directives/index.mjs.map +0 -1
- package/es/hooks/index.mjs.map +0 -1
- package/lib/components/contextMenu/src/contextMenu.type.js.map +0 -1
- package/lib/components/layoutGrid/src/layoutGrid.type.js.map +0 -1
- package/lib/components/select/src/select.type.js.map +0 -1
- package/lib/components/table/images/artwork.png.js +0 -2
- package/lib/components/table/images/artwork.png.js.map +0 -1
- package/lib/components/table/images/notImage.png.js +0 -2
- package/lib/components/table/images/notImage.png.js.map +0 -1
- package/lib/components/table/src/table.state.js.map +0 -1
- package/lib/components/tree/src/tree.type.js.map +0 -1
- package/lib/constants/index.js.map +0 -1
- package/lib/directives/index.js.map +0 -1
- package/lib/hooks/index.js.map +0 -1
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"
|
|
2
|
-
//# sourceMappingURL=layoutGrid.js.map
|
|
1
|
+
require("../../../_virtual/_rolldown/runtime.js");let e=require("@fast-china/utils"),r=require("vue"),o=require("lodash-unified");var t=(0,r.defineComponent)({name:"FaLayoutGrid",props:{cols:{type:(0,e.definePropType)([String,Number,Object]),default:()=>({xs:1,sm:2,md:3,lg:4,xl:5})},collapsed:Boolean,collapsedRows:{type:[String,Number],default:1},gap:{type:(0,e.definePropType)([Number,Array]),default:0}},emits:{breakPointChange:({breakPoint:e})=>!0},slots:(0,e.makeSlots)(),setup(t,{attrs:s,slots:a,emit:l,expose:n}){const p=(0,r.ref)();(0,r.provide)("gap",(0,o.isArray)(t.gap)?t.gap[0]:t.gap);const i=(0,r.ref)("xl");(0,r.provide)("breakPoint",i);const u=(0,r.ref)(-1);(0,r.provide)("shouldHiddenIndex",u);const d=(0,r.computed)(()=>(0,o.isObject)(t.cols)?t.cols[i.value]??t.cols:t.cols);(0,r.provide)("cols",d);const c=(0,o.isNumber)(t.collapsedRows)?t.collapsedRows:Number(t.collapsedRows),m={xs:{min:0,max:479},sm:{min:480,max:768},md:{min:768,max:1024},lg:{min:1024,max:1440},xl:{min:1440,max:1/0}},f=e=>{if(1!==e.length)throw new Error("未知的多个El");const r=e[0].target.scrollWidth;for(const[o,{min:t,max:s}]of Object.entries(m))if(r>=t&&r<=s){i.value=o;break}};let v=null;(0,r.onMounted)(()=>{(0,r.nextTick)(()=>{v=new ResizeObserver(f),v.observe(p.value)}),(0,r.watch)(()=>i.value,e=>{l("breakPointChange",{breakPoint:e})},{immediate:!0})}),(0,r.onActivated)(()=>{(0,r.nextTick)(()=>{v=new ResizeObserver(f),v.observe(p.value)})}),(0,r.onUnmounted)(()=>{v?.disconnect()}),(0,r.onDeactivated)(()=>{v?.disconnect()});const b=(0,r.computed)(()=>(0,o.isNumber)(t.gap)?`${t.gap}px`:(0,o.isArray)(t.gap)?`${t.gap[1]}px ${t.gap[0]}px`:"unset"),x=(0,r.computed)(()=>({display:"grid",gridGap:b.value,gridTemplateColumns:`repeat(${d.value}, minmax(0, 1fr))`}));return(0,e.useRender)(()=>{const e=a?.default()??[];if(t.collapsed){const r=[];let o=null;e.forEach(e=>{"object"==typeof e.type&&"FaLayoutGridItem"===e.type.name&&void 0!==e.props?.suffix&&(o=e),"symbol"==typeof e.type&&Array.isArray(e?.children)&&r.push(...e.children)});let t=0;o&&(t=(o.props[i.value]?.span??o.props?.span??1)+(o.props[i.value]?.offset??o.props?.offset??0));try{let e=!1;r.reduce((r=0,o,s)=>{if(r+=(o.props[i.value]?.span??o.props?.span??1)+(o.props[i.value]?.offset??o.props?.offset??0),Number(r)>c*Number(d.value)-t)throw u.value=s,e=!0,"find it";return r},0),e||(u.value=-1)}catch{}}else u.value=-1;return(0,r.createVNode)("div",{ref:p,style:x.value},[e])}),(0,e.useExpose)(n,{breakPoint:i})}});exports.default=t;
|
|
2
|
+
//# sourceMappingURL=layoutGrid.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"layoutGrid.js","sources":["../../../../../packages/components/layoutGrid/src/layoutGrid.tsx"],"sourcesContent":["import { computed, defineComponent, nextTick, onActivated, onDeactivated, onMounted, onUnmounted, provide, ref, watch } from \"vue\";\nimport { definePropType, makeSlots, useExpose, useRender } from \"@fast-china/utils\";\nimport { isArray, isNumber, isObject } from \"lodash-unified\";\nimport type { FaLayoutGridBreakPoint } from \"./layoutGrid.type\";\nimport type { VNode, VNodeArrayChildren } from \"vue\";\n\ntype FaLayoutGridSlots = {\n\t/** @description 默认内容插槽 */\n\tdefault: never;\n};\n\nexport default defineComponent({\n\tname: \"FaLayoutGrid\",\n\tprops: {\n\t\t/** @description Grid布局列配置 */\n\t\tcols: {\n\t\t\ttype: definePropType<string | number | Record<FaLayoutGridBreakPoint, number>>([String, Number, Object]),\n\t\t\tdefault: (): Record<FaLayoutGridBreakPoint, number> => ({ xs: 1, sm: 2, md: 3, lg: 4, xl: 5 }),\n\t\t},\n\t\t/** @description 折叠 */\n\t\tcollapsed: Boolean,\n\t\t/** @description 折叠行数 */\n\t\tcollapsedRows: {\n\t\t\ttype: [String, Number],\n\t\t\tdefault: 1,\n\t\t},\n\t\t/** @description 间距,偏移 */\n\t\tgap: {\n\t\t\ttype: definePropType<number | [number, number]>([Number, Array]),\n\t\t\tdefault: 0,\n\t\t},\n\t},\n\temits: {\n\t\t/** @description 断点变化事件 */\n\t\tbreakPointChange: ({ breakPoint }: { breakPoint: FaLayoutGridBreakPoint }) => true,\n\t},\n\tslots: makeSlots<FaLayoutGridSlots>(),\n\tsetup(props, { attrs, slots, emit, expose }) {\n\t\tconst divElRef = ref<HTMLElement>();\n\n\t\t// 注入 gap 间距\n\t\tprovide(\"gap\", isArray(props.gap) ? props.gap[0] : props.gap);\n\n\t\t// 注入响应式断点\n\t\tconst breakPoint = ref<FaLayoutGridBreakPoint>(\"xl\");\n\t\tprovide(\"breakPoint\", breakPoint);\n\n\t\t// 注入要开始折叠的 index\n\t\tconst hiddenIndex = ref(-1);\n\t\tprovide(\"shouldHiddenIndex\", hiddenIndex);\n\n\t\t// 注入 cols\n\t\tconst cols = computed(() => {\n\t\t\tif (isObject(props.cols)) return props.cols[breakPoint.value] ?? props.cols;\n\t\t\treturn props.cols;\n\t\t});\n\t\tprovide(\"cols\", cols);\n\n\t\tconst collapsedRows = isNumber(props.collapsedRows) ? props.collapsedRows : Number(props.collapsedRows);\n\n\t\t// 断点映射\n\t\tconst breakpoints = {\n\t\t\t// 小于480屏幕(如手机)\n\t\t\txs: { min: 0, max: 479 },\n\t\t\t// 平板竖屏\n\t\t\tsm: { min: 480, max: 768 },\n\t\t\t// 平板横屏\n\t\t\tmd: { min: 768, max: 1024 },\n\t\t\t// 小型桌面\n\t\t\tlg: { min: 1024, max: 1440 },\n\t\t\t// 大型桌面\n\t\t\txl: { min: 1440, max: Infinity },\n\t\t};\n\n\t\t// 监听屏幕变化\n\t\tconst resize = (e: ResizeObserverEntry[]): void => {\n\t\t\t// 这里肯定只有一个\n\t\t\tif (e.length !== 1) throw new Error(\"未知的多个El\");\n\t\t\tconst curEl = e[0];\n\t\t\tconst width = curEl.target.scrollWidth;\n\n\t\t\tfor (const [key, { min, max }] of Object.entries(breakpoints)) {\n\t\t\t\tif (width >= min && width <= max) {\n\t\t\t\t\tbreakPoint.value = key as FaLayoutGridBreakPoint;\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\n\t\tlet resizeObserver: ResizeObserver = null;\n\n\t\tonMounted(() => {\n\t\t\tnextTick(() => {\n\t\t\t\tresizeObserver = new ResizeObserver(resize);\n\t\t\t\tresizeObserver.observe(divElRef.value);\n\t\t\t});\n\n\t\t\t// 断点变化时 执行 findIndex\n\t\t\twatch(\n\t\t\t\t() => breakPoint.value,\n\t\t\t\t(newValue) => {\n\t\t\t\t\temit(\"breakPointChange\", { breakPoint: newValue });\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\timmediate: true,\n\t\t\t\t}\n\t\t\t);\n\t\t});\n\n\t\tonActivated(() => {\n\t\t\tnextTick(() => {\n\t\t\t\tresizeObserver = new ResizeObserver(resize);\n\t\t\t\tresizeObserver.observe(divElRef.value);\n\t\t\t});\n\t\t});\n\n\t\tonUnmounted(() => {\n\t\t\tresizeObserver?.disconnect();\n\t\t});\n\n\t\tonDeactivated(() => {\n\t\t\tresizeObserver?.disconnect();\n\t\t});\n\n\t\t// 设置间距\n\t\tconst gap = computed(() => {\n\t\t\tif (isNumber(props.gap)) return `${props.gap}px`;\n\t\t\tif (isArray(props.gap)) return `${props.gap[1]}px ${props.gap[0]}px`;\n\t\t\treturn \"unset\";\n\t\t});\n\n\t\t// 设置 style\n\t\tconst style = computed(() => {\n\t\t\treturn {\n\t\t\t\tdisplay: \"grid\",\n\t\t\t\tgridGap: gap.value,\n\t\t\t\tgridTemplateColumns: `repeat(${cols.value}, minmax(0, 1fr))`,\n\t\t\t};\n\t\t});\n\n\t\tuseRender(() => {\n\t\t\tconst defaultSlot = slots?.default() ?? [];\n\n\t\t\tif (props.collapsed) {\n\t\t\t\tconst fields: VNodeArrayChildren = [];\n\t\t\t\tlet suffix: VNode = null;\n\n\t\t\t\tdefaultSlot.forEach((slot: any) => {\n\t\t\t\t\t// suffix\n\t\t\t\t\tif (typeof slot.type === \"object\" && slot.type.name === \"FaLayoutGridItem\" && slot.props?.suffix !== undefined) suffix = slot;\n\t\t\t\t\t// slot children\n\t\t\t\t\tif (typeof slot.type === \"symbol\" && Array.isArray(slot?.children)) fields.push(...slot.children);\n\t\t\t\t});\n\n\t\t\t\t// 计算 suffix 所占用的列\n\t\t\t\tlet suffixCols = 0;\n\t\t\t\tif (suffix) {\n\t\t\t\t\tsuffixCols =\n\t\t\t\t\t\t(suffix.props[breakPoint.value]?.span ?? suffix.props?.span ?? 1) +\n\t\t\t\t\t\t(suffix.props[breakPoint.value]?.offset ?? suffix.props?.offset ?? 0);\n\t\t\t\t}\n\n\t\t\t\ttry {\n\t\t\t\t\tlet find = false;\n\t\t\t\t\tfields.reduce((prev = 0, current, index) => {\n\t\t\t\t\t\tprev +=\n\t\t\t\t\t\t\t((current as VNode).props[breakPoint.value]?.span ?? (current as VNode).props?.span ?? 1) +\n\t\t\t\t\t\t\t((current as VNode).props[breakPoint.value]?.offset ?? (current as VNode).props?.offset ?? 0);\n\t\t\t\t\t\tif (Number(prev) > collapsedRows * Number(cols.value) - suffixCols) {\n\t\t\t\t\t\t\thiddenIndex.value = index;\n\t\t\t\t\t\t\tfind = true;\n\t\t\t\t\t\t\tthrow \"find it\";\n\t\t\t\t\t\t}\n\t\t\t\t\t\treturn prev;\n\t\t\t\t\t}, 0);\n\t\t\t\t\tif (!find) hiddenIndex.value = -1;\n\t\t\t\t} catch {}\n\t\t\t} else {\n\t\t\t\thiddenIndex.value = -1;\n\t\t\t}\n\n\t\t\treturn (\n\t\t\t\t<div ref={divElRef} style={style.value}>\n\t\t\t\t\t{defaultSlot}\n\t\t\t\t</div>\n\t\t\t);\n\t\t});\n\n\t\treturn useExpose(expose, {\n\t\t\t/** @description 响应式断点 */\n\t\t\tbreakPoint,\n\t\t});\n\t},\n});\n"],"
|
|
1
|
+
{"version":3,"file":"layoutGrid.js","names":["computed","defineComponent","nextTick","onActivated","onDeactivated","onMounted","onUnmounted","provide","ref","watch","createVNode","_createVNode","definePropType","makeSlots","useExpose","useRender","isArray","isNumber","isObject","name","props","cols","type","String","Number","Object","default","xs","sm","md","lg","xl","collapsed","Boolean","collapsedRows","gap","Array","emits","breakPointChange","breakPoint","slots","setup","attrs","emit","expose","divElRef","hiddenIndex","value","breakpoints","min","max","Infinity","resize","e","length","Error","curEl","width","target","scrollWidth","key","entries","resizeObserver","ResizeObserver","observe","newValue","immediate","disconnect","style","display","gridGap","gridTemplateColumns","defaultSlot","fields","suffix","forEach","slot","undefined","children","push","suffixCols","span","offset","find","reduce","prev","current","index"],"sources":["../../../../../packages/components/layoutGrid/src/layoutGrid.tsx"],"sourcesContent":["import { computed, defineComponent, nextTick, onActivated, onDeactivated, onMounted, onUnmounted, provide, ref, watch } from \"vue\";\nimport { definePropType, makeSlots, useExpose, useRender } from \"@fast-china/utils\";\nimport { isArray, isNumber, isObject } from \"lodash-unified\";\nimport type { FaLayoutGridBreakPoint } from \"./layoutGrid.type\";\nimport type { VNode, VNodeArrayChildren } from \"vue\";\n\ntype FaLayoutGridSlots = {\n\t/** @description 默认内容插槽 */\n\tdefault: never;\n};\n\nexport default defineComponent({\n\tname: \"FaLayoutGrid\",\n\tprops: {\n\t\t/** @description Grid布局列配置 */\n\t\tcols: {\n\t\t\ttype: definePropType<string | number | Record<FaLayoutGridBreakPoint, number>>([String, Number, Object]),\n\t\t\tdefault: (): Record<FaLayoutGridBreakPoint, number> => ({ xs: 1, sm: 2, md: 3, lg: 4, xl: 5 }),\n\t\t},\n\t\t/** @description 折叠 */\n\t\tcollapsed: Boolean,\n\t\t/** @description 折叠行数 */\n\t\tcollapsedRows: {\n\t\t\ttype: [String, Number],\n\t\t\tdefault: 1,\n\t\t},\n\t\t/** @description 间距,偏移 */\n\t\tgap: {\n\t\t\ttype: definePropType<number | [number, number]>([Number, Array]),\n\t\t\tdefault: 0,\n\t\t},\n\t},\n\temits: {\n\t\t/** @description 断点变化事件 */\n\t\tbreakPointChange: ({ breakPoint }: { breakPoint: FaLayoutGridBreakPoint }) => true,\n\t},\n\tslots: makeSlots<FaLayoutGridSlots>(),\n\tsetup(props, { attrs, slots, emit, expose }) {\n\t\tconst divElRef = ref<HTMLElement>();\n\n\t\t// 注入 gap 间距\n\t\tprovide(\"gap\", isArray(props.gap) ? props.gap[0] : props.gap);\n\n\t\t// 注入响应式断点\n\t\tconst breakPoint = ref<FaLayoutGridBreakPoint>(\"xl\");\n\t\tprovide(\"breakPoint\", breakPoint);\n\n\t\t// 注入要开始折叠的 index\n\t\tconst hiddenIndex = ref(-1);\n\t\tprovide(\"shouldHiddenIndex\", hiddenIndex);\n\n\t\t// 注入 cols\n\t\tconst cols = computed(() => {\n\t\t\tif (isObject(props.cols)) return props.cols[breakPoint.value] ?? props.cols;\n\t\t\treturn props.cols;\n\t\t});\n\t\tprovide(\"cols\", cols);\n\n\t\tconst collapsedRows = isNumber(props.collapsedRows) ? props.collapsedRows : Number(props.collapsedRows);\n\n\t\t// 断点映射\n\t\tconst breakpoints = {\n\t\t\t// 小于480屏幕(如手机)\n\t\t\txs: { min: 0, max: 479 },\n\t\t\t// 平板竖屏\n\t\t\tsm: { min: 480, max: 768 },\n\t\t\t// 平板横屏\n\t\t\tmd: { min: 768, max: 1024 },\n\t\t\t// 小型桌面\n\t\t\tlg: { min: 1024, max: 1440 },\n\t\t\t// 大型桌面\n\t\t\txl: { min: 1440, max: Infinity },\n\t\t};\n\n\t\t// 监听屏幕变化\n\t\tconst resize = (e: ResizeObserverEntry[]): void => {\n\t\t\t// 这里肯定只有一个\n\t\t\tif (e.length !== 1) throw new Error(\"未知的多个El\");\n\t\t\tconst curEl = e[0];\n\t\t\tconst width = curEl.target.scrollWidth;\n\n\t\t\tfor (const [key, { min, max }] of Object.entries(breakpoints)) {\n\t\t\t\tif (width >= min && width <= max) {\n\t\t\t\t\tbreakPoint.value = key as FaLayoutGridBreakPoint;\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\n\t\tlet resizeObserver: ResizeObserver = null;\n\n\t\tonMounted(() => {\n\t\t\tnextTick(() => {\n\t\t\t\tresizeObserver = new ResizeObserver(resize);\n\t\t\t\tresizeObserver.observe(divElRef.value);\n\t\t\t});\n\n\t\t\t// 断点变化时 执行 findIndex\n\t\t\twatch(\n\t\t\t\t() => breakPoint.value,\n\t\t\t\t(newValue) => {\n\t\t\t\t\temit(\"breakPointChange\", { breakPoint: newValue });\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\timmediate: true,\n\t\t\t\t}\n\t\t\t);\n\t\t});\n\n\t\tonActivated(() => {\n\t\t\tnextTick(() => {\n\t\t\t\tresizeObserver = new ResizeObserver(resize);\n\t\t\t\tresizeObserver.observe(divElRef.value);\n\t\t\t});\n\t\t});\n\n\t\tonUnmounted(() => {\n\t\t\tresizeObserver?.disconnect();\n\t\t});\n\n\t\tonDeactivated(() => {\n\t\t\tresizeObserver?.disconnect();\n\t\t});\n\n\t\t// 设置间距\n\t\tconst gap = computed(() => {\n\t\t\tif (isNumber(props.gap)) return `${props.gap}px`;\n\t\t\tif (isArray(props.gap)) return `${props.gap[1]}px ${props.gap[0]}px`;\n\t\t\treturn \"unset\";\n\t\t});\n\n\t\t// 设置 style\n\t\tconst style = computed(() => {\n\t\t\treturn {\n\t\t\t\tdisplay: \"grid\",\n\t\t\t\tgridGap: gap.value,\n\t\t\t\tgridTemplateColumns: `repeat(${cols.value}, minmax(0, 1fr))`,\n\t\t\t};\n\t\t});\n\n\t\tuseRender(() => {\n\t\t\tconst defaultSlot = slots?.default() ?? [];\n\n\t\t\tif (props.collapsed) {\n\t\t\t\tconst fields: VNodeArrayChildren = [];\n\t\t\t\tlet suffix: VNode = null;\n\n\t\t\t\tdefaultSlot.forEach((slot: any) => {\n\t\t\t\t\t// suffix\n\t\t\t\t\tif (typeof slot.type === \"object\" && slot.type.name === \"FaLayoutGridItem\" && slot.props?.suffix !== undefined) suffix = slot;\n\t\t\t\t\t// slot children\n\t\t\t\t\tif (typeof slot.type === \"symbol\" && Array.isArray(slot?.children)) fields.push(...slot.children);\n\t\t\t\t});\n\n\t\t\t\t// 计算 suffix 所占用的列\n\t\t\t\tlet suffixCols = 0;\n\t\t\t\tif (suffix) {\n\t\t\t\t\tsuffixCols =\n\t\t\t\t\t\t(suffix.props[breakPoint.value]?.span ?? suffix.props?.span ?? 1) +\n\t\t\t\t\t\t(suffix.props[breakPoint.value]?.offset ?? suffix.props?.offset ?? 0);\n\t\t\t\t}\n\n\t\t\t\ttry {\n\t\t\t\t\tlet find = false;\n\t\t\t\t\tfields.reduce((prev = 0, current, index) => {\n\t\t\t\t\t\tprev +=\n\t\t\t\t\t\t\t((current as VNode).props[breakPoint.value]?.span ?? (current as VNode).props?.span ?? 1) +\n\t\t\t\t\t\t\t((current as VNode).props[breakPoint.value]?.offset ?? (current as VNode).props?.offset ?? 0);\n\t\t\t\t\t\tif (Number(prev) > collapsedRows * Number(cols.value) - suffixCols) {\n\t\t\t\t\t\t\thiddenIndex.value = index;\n\t\t\t\t\t\t\tfind = true;\n\t\t\t\t\t\t\tthrow \"find it\";\n\t\t\t\t\t\t}\n\t\t\t\t\t\treturn prev;\n\t\t\t\t\t}, 0);\n\t\t\t\t\tif (!find) hiddenIndex.value = -1;\n\t\t\t\t} catch {}\n\t\t\t} else {\n\t\t\t\thiddenIndex.value = -1;\n\t\t\t}\n\n\t\t\treturn (\n\t\t\t\t<div ref={divElRef} style={style.value}>\n\t\t\t\t\t{defaultSlot}\n\t\t\t\t</div>\n\t\t\t);\n\t\t});\n\n\t\treturn useExpose(expose, {\n\t\t\t/** @description 响应式断点 */\n\t\t\tbreakPoint,\n\t\t});\n\t},\n});\n"],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"
|
|
2
|
-
//# sourceMappingURL=layoutGridItem.js.map
|
|
1
|
+
require("../../../_virtual/_rolldown/runtime.js");let e=require("@fast-china/utils"),t=require("vue"),a=require("lodash-unified");var s=(0,t.defineComponent)({name:"FaLayoutGridItem",props:{offset:{type:[String,Number],default:0},span:{type:[String,Number],default:1},suffix:{type:Boolean,default:!1},xs:{type:(0,e.definePropType)(Object),default:void 0},sm:{type:(0,e.definePropType)(Object),default:void 0},md:{type:(0,e.definePropType)(Object),default:void 0},lg:{type:(0,e.definePropType)(Object),default:void 0},xl:{type:(0,e.definePropType)(Object),default:void 0}},slots:(0,e.makeSlots)(),setup(s,{attrs:u,slots:i,emit:r,expose:n}){const o=(0,t.reactive)({show:!0}),d=u,l=(0,t.inject)("breakPoint",(0,t.ref)("xl")),f=(0,t.inject)("shouldHiddenIndex",(0,t.ref)(-1));(0,t.watch)(()=>[f.value,l.value],e=>{~~d.index&&(o.show=!(-1!==e[0]&&parseInt(d.index)>=Number(e[0])))},{immediate:!0});const p=(0,t.inject)("gap",0),c=(0,t.inject)("cols",(0,t.ref)(5)),m=(0,t.computed)(()=>{const e=s[l.value],t=e?.span??((0,a.isNumber)(s.span)?s.span:Number(s.span)),u=e?.offset??((0,a.isNumber)(s.offset)?s.offset:Number(s.offset));return s.suffix?{gridColumnStart:c.value-t-u+1,gridColumnEnd:`span ${t+u}`,marginLeft:0!==u?`calc(((100% + ${p}px) / ${t+u}) * ${u})`:"unset"}:{gridColumn:`span ${t+u>c.value?c.value:t+u}/span ${t+u>c.value?c.value:t+u}`,marginLeft:0!==u?`calc(((100% + ${p}px) / ${t+u}) * ${u})`:"unset"}});return(0,e.useRender)(()=>(0,t.withDirectives)((0,t.createVNode)("div",{style:m.value},[i.default&&i.default()]),[[t.vShow,o.show]])),(0,e.useExpose)(n,{show:o.show})}});exports.default=s;
|
|
2
|
+
//# sourceMappingURL=layoutGridItem.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"layoutGridItem.js","sources":["../../../../../packages/components/layoutGrid/src/layoutGridItem.tsx"],"sourcesContent":["import { computed, defineComponent, inject, reactive, ref, watch } from \"vue\";\nimport { definePropType, makeSlots, useExpose, useRender } from \"@fast-china/utils\";\nimport { isNumber } from \"lodash-unified\";\nimport type { FaLayoutGridItemResponsive } from \"./layoutGrid.type\";\nimport type { FaLayoutGridBreakPoint } from \"@fast-element-plus/components/layoutGrid\";\nimport type { Ref } from \"vue\";\n\ntype FaLayoutGridItemSlots = {\n\t/** @description 默认内容插槽 */\n\tdefault: never;\n};\n\nexport default defineComponent({\n\tname: \"FaLayoutGridItem\",\n\tprops: {\n\t\t/** @description 偏移 */\n\t\toffset: {\n\t\t\ttype: [String, Number],\n\t\t\tdefault: 0,\n\t\t},\n\t\t/** @description 占位 */\n\t\tspan: {\n\t\t\ttype: [String, Number],\n\t\t\tdefault: 1,\n\t\t},\n\t\t/** @description 后缀 */\n\t\tsuffix: { type: Boolean, default: false },\n\t\t/** @description 响应式,小于480px屏幕配置 */\n\t\txs: {\n\t\t\ttype: definePropType<FaLayoutGridItemResponsive>(Object),\n\t\t\tdefault: undefined as FaLayoutGridItemResponsive,\n\t\t},\n\t\t/** @description 响应式,平板竖屏配置 */\n\t\tsm: {\n\t\t\ttype: definePropType<FaLayoutGridItemResponsive>(Object),\n\t\t\tdefault: undefined as FaLayoutGridItemResponsive,\n\t\t},\n\t\t/** @description 响应式,平板横屏配置 */\n\t\tmd: {\n\t\t\ttype: definePropType<FaLayoutGridItemResponsive>(Object),\n\t\t\tdefault: undefined as FaLayoutGridItemResponsive,\n\t\t},\n\t\t/** @description 响应式,小型桌面配置 */\n\t\tlg: {\n\t\t\ttype: definePropType<FaLayoutGridItemResponsive>(Object),\n\t\t\tdefault: undefined as FaLayoutGridItemResponsive,\n\t\t},\n\t\t/** @description 响应式,大型桌面配置 */\n\t\txl: {\n\t\t\ttype: definePropType<FaLayoutGridItemResponsive>(Object),\n\t\t\tdefault: undefined as FaLayoutGridItemResponsive,\n\t\t},\n\t},\n\tslots: makeSlots<FaLayoutGridItemSlots>(),\n\tsetup(props, { attrs, slots, emit, expose }) {\n\t\tconst state = reactive({\n\t\t\tshow: true,\n\t\t});\n\n\t\tconst attrsObj = attrs as any;\n\n\t\t// 注入断点\n\t\tconst breakPoint = inject<Ref<FaLayoutGridBreakPoint>>(\"breakPoint\", ref(\"xl\"));\n\t\tconst shouldHiddenIndex = inject<Ref<number>>(\"shouldHiddenIndex\", ref(-1));\n\n\t\twatch(\n\t\t\t() => [shouldHiddenIndex.value, breakPoint.value],\n\t\t\t(n) => {\n\t\t\t\tif (~~attrsObj.index) {\n\t\t\t\t\tstate.show = !(n[0] !== -1 && parseInt(attrsObj.index) >= Number(n[0]));\n\t\t\t\t}\n\t\t\t},\n\t\t\t{ immediate: true }\n\t\t);\n\n\t\tconst gap = inject(\"gap\", 0);\n\t\tconst cols = inject<Ref<number>>(\"cols\", ref(5));\n\n\t\tconst style = computed(() => {\n\t\t\tconst breakPointObk = props[breakPoint.value] as FaLayoutGridItemResponsive;\n\t\t\tconst span = breakPointObk?.span ?? (isNumber(props.span) ? props.span : Number(props.span));\n\t\t\tconst offset = breakPointObk?.offset ?? (isNumber(props.offset) ? props.offset : Number(props.offset));\n\t\t\tif (props.suffix) {\n\t\t\t\treturn {\n\t\t\t\t\tgridColumnStart: cols.value - span - offset + 1,\n\t\t\t\t\tgridColumnEnd: `span ${span + offset}`,\n\t\t\t\t\tmarginLeft: offset !== 0 ? `calc(((100% + ${gap}px) / ${span + offset}) * ${offset})` : \"unset\",\n\t\t\t\t};\n\t\t\t} else {\n\t\t\t\treturn {\n\t\t\t\t\tgridColumn: `span ${span + offset > cols.value ? cols.value : span + offset}/span ${\n\t\t\t\t\t\tspan + offset > cols.value ? cols.value : span + offset\n\t\t\t\t\t}`,\n\t\t\t\t\tmarginLeft: offset !== 0 ? `calc(((100% + ${gap}px) / ${span + offset}) * ${offset})` : \"unset\",\n\t\t\t\t};\n\t\t\t}\n\t\t});\n\n\t\tuseRender(() => (\n\t\t\t<div style={style.value} vShow={state.show}>\n\t\t\t\t{slots.default && slots.default()}\n\t\t\t</div>\n\t\t));\n\n\t\treturn useExpose(expose, {\n\t\t\tshow: state.show,\n\t\t});\n\t},\n});\n"],"
|
|
1
|
+
{"version":3,"file":"layoutGridItem.js","names":["computed","defineComponent","inject","reactive","ref","watch","vShow","_vShow","createVNode","_createVNode","withDirectives","_withDirectives","definePropType","makeSlots","useExpose","useRender","isNumber","name","props","offset","type","String","Number","default","span","suffix","Boolean","xs","Object","undefined","sm","md","lg","xl","slots","setup","attrs","emit","expose","state","show","attrsObj","breakPoint","shouldHiddenIndex","value","n","index","parseInt","immediate","gap","cols","style","breakPointObk","gridColumnStart","gridColumnEnd","marginLeft","gridColumn"],"sources":["../../../../../packages/components/layoutGrid/src/layoutGridItem.tsx"],"sourcesContent":["import { computed, defineComponent, inject, reactive, ref, watch } from \"vue\";\nimport { definePropType, makeSlots, useExpose, useRender } from \"@fast-china/utils\";\nimport { isNumber } from \"lodash-unified\";\nimport type { FaLayoutGridItemResponsive } from \"./layoutGrid.type\";\nimport type { FaLayoutGridBreakPoint } from \"@fast-element-plus/components/layoutGrid\";\nimport type { Ref } from \"vue\";\n\ntype FaLayoutGridItemSlots = {\n\t/** @description 默认内容插槽 */\n\tdefault: never;\n};\n\nexport default defineComponent({\n\tname: \"FaLayoutGridItem\",\n\tprops: {\n\t\t/** @description 偏移 */\n\t\toffset: {\n\t\t\ttype: [String, Number],\n\t\t\tdefault: 0,\n\t\t},\n\t\t/** @description 占位 */\n\t\tspan: {\n\t\t\ttype: [String, Number],\n\t\t\tdefault: 1,\n\t\t},\n\t\t/** @description 后缀 */\n\t\tsuffix: { type: Boolean, default: false },\n\t\t/** @description 响应式,小于480px屏幕配置 */\n\t\txs: {\n\t\t\ttype: definePropType<FaLayoutGridItemResponsive>(Object),\n\t\t\tdefault: undefined as FaLayoutGridItemResponsive,\n\t\t},\n\t\t/** @description 响应式,平板竖屏配置 */\n\t\tsm: {\n\t\t\ttype: definePropType<FaLayoutGridItemResponsive>(Object),\n\t\t\tdefault: undefined as FaLayoutGridItemResponsive,\n\t\t},\n\t\t/** @description 响应式,平板横屏配置 */\n\t\tmd: {\n\t\t\ttype: definePropType<FaLayoutGridItemResponsive>(Object),\n\t\t\tdefault: undefined as FaLayoutGridItemResponsive,\n\t\t},\n\t\t/** @description 响应式,小型桌面配置 */\n\t\tlg: {\n\t\t\ttype: definePropType<FaLayoutGridItemResponsive>(Object),\n\t\t\tdefault: undefined as FaLayoutGridItemResponsive,\n\t\t},\n\t\t/** @description 响应式,大型桌面配置 */\n\t\txl: {\n\t\t\ttype: definePropType<FaLayoutGridItemResponsive>(Object),\n\t\t\tdefault: undefined as FaLayoutGridItemResponsive,\n\t\t},\n\t},\n\tslots: makeSlots<FaLayoutGridItemSlots>(),\n\tsetup(props, { attrs, slots, emit, expose }) {\n\t\tconst state = reactive({\n\t\t\tshow: true,\n\t\t});\n\n\t\tconst attrsObj = attrs as any;\n\n\t\t// 注入断点\n\t\tconst breakPoint = inject<Ref<FaLayoutGridBreakPoint>>(\"breakPoint\", ref(\"xl\"));\n\t\tconst shouldHiddenIndex = inject<Ref<number>>(\"shouldHiddenIndex\", ref(-1));\n\n\t\twatch(\n\t\t\t() => [shouldHiddenIndex.value, breakPoint.value],\n\t\t\t(n) => {\n\t\t\t\tif (~~attrsObj.index) {\n\t\t\t\t\tstate.show = !(n[0] !== -1 && parseInt(attrsObj.index) >= Number(n[0]));\n\t\t\t\t}\n\t\t\t},\n\t\t\t{ immediate: true }\n\t\t);\n\n\t\tconst gap = inject(\"gap\", 0);\n\t\tconst cols = inject<Ref<number>>(\"cols\", ref(5));\n\n\t\tconst style = computed(() => {\n\t\t\tconst breakPointObk = props[breakPoint.value] as FaLayoutGridItemResponsive;\n\t\t\tconst span = breakPointObk?.span ?? (isNumber(props.span) ? props.span : Number(props.span));\n\t\t\tconst offset = breakPointObk?.offset ?? (isNumber(props.offset) ? props.offset : Number(props.offset));\n\t\t\tif (props.suffix) {\n\t\t\t\treturn {\n\t\t\t\t\tgridColumnStart: cols.value - span - offset + 1,\n\t\t\t\t\tgridColumnEnd: `span ${span + offset}`,\n\t\t\t\t\tmarginLeft: offset !== 0 ? `calc(((100% + ${gap}px) / ${span + offset}) * ${offset})` : \"unset\",\n\t\t\t\t};\n\t\t\t} else {\n\t\t\t\treturn {\n\t\t\t\t\tgridColumn: `span ${span + offset > cols.value ? cols.value : span + offset}/span ${\n\t\t\t\t\t\tspan + offset > cols.value ? cols.value : span + offset\n\t\t\t\t\t}`,\n\t\t\t\t\tmarginLeft: offset !== 0 ? `calc(((100% + ${gap}px) / ${span + offset}) * ${offset})` : \"unset\",\n\t\t\t\t};\n\t\t\t}\n\t\t});\n\n\t\tuseRender(() => (\n\t\t\t<div style={style.value} vShow={state.show}>\n\t\t\t\t{slots.default && slots.default()}\n\t\t\t</div>\n\t\t));\n\n\t\treturn useExpose(expose, {\n\t\t\tshow: state.show,\n\t\t});\n\t},\n});\n"],"mappings":"kIAYA,IAAA,GAAeC,EAAAA,EAAAA,iBAAgB,CAC9BgB,KAAM,mBACNC,MAAO,CAENC,OAAQ,CACPC,KAAM,CAACC,OAAQC,QACfC,QAAS,GAGVC,KAAM,CACLJ,KAAM,CAACC,OAAQC,QACfC,QAAS,GAGVE,OAAQ,CAAEL,KAAMM,QAASH,SAAS,GAElCI,GAAI,CACHP,MAAAA,EAAAA,EAAAA,gBAAiDQ,QACjDL,aAASM,GAGVC,GAAI,CACHV,MAAAA,EAAAA,EAAAA,gBAAiDQ,QACjDL,aAASM,GAGVE,GAAI,CACHX,MAAAA,EAAAA,EAAAA,gBAAiDQ,QACjDL,aAASM,GAGVG,GAAI,CACHZ,MAAAA,EAAAA,EAAAA,gBAAiDQ,QACjDL,aAASM,GAGVI,GAAI,CACHb,MAAAA,EAAAA,EAAAA,gBAAiDQ,QACjDL,aAASM,IAGXK,OAAAA,EAAAA,EAAAA,aACAC,KAAAA,CAAMjB,GAAO,MAAEkB,EAAAA,MAAOF,EAAAA,KAAOG,EAAAA,OAAMC,IAClC,MAAMC,GAAAA,EAAAA,EAAAA,UAAiB,CACtBC,MAAM,IAGDC,EAAWL,EAGXM,GAAAA,EAAAA,EAAAA,QAAiD,cAAA,EAAA,EAAA,KAAkB,OACnEC,GAAAA,EAAAA,EAAAA,QAAwC,qBAAA,EAAA,EAAA,MAA0B,KAExEtC,EAAAA,EAAAA,OAAAA,IACO,CAACsC,EAAkBC,MAAOF,EAAWE,OAC1CC,MACMJ,EAASK,QACdP,EAAMC,QAAmB,IAAVK,EAAE,IAAaE,SAASN,EAASK,QAAUxB,OAAOuB,EAAE,OAGrE,CAAEG,WAAW,IAGd,MAAMC,GAAAA,EAAAA,EAAAA,QAAa,MAAO,GACpBC,GAAAA,EAAAA,EAAAA,QAA2B,QAAA,EAAA,EAAA,KAAY,IAEvCC,GAAAA,EAAAA,EAAAA,UAAAA,KACL,MAAMC,EAAgBlC,EAAMwB,EAAWE,OACjCpB,EAAO4B,GAAe5B,QAAAA,EAAAA,EAAAA,UAAkBN,EAAMM,MAAQN,EAAMM,KAAOF,OAAOJ,EAAMM,OAChFL,EAASiC,GAAejC,UAAAA,EAAAA,EAAAA,UAAoBD,EAAMC,QAAUD,EAAMC,OAASG,OAAOJ,EAAMC,SAC9F,OAAID,EAAMO,OACF,CACN4B,gBAAiBH,EAAKN,MAAQpB,EAAOL,EAAS,EAC9CmC,cAAe,QAAQ9B,EAAOL,IAC9BoC,WAAuB,IAAXpC,EAAe,iBAAiB8B,UAAYzB,EAAOL,QAAaA,KAAY,SAGlF,CACNqC,WAAY,QAAQhC,EAAOL,EAAS+B,EAAKN,MAAQM,EAAKN,MAAQpB,EAAOL,UACpEK,EAAOL,EAAS+B,EAAKN,MAAQM,EAAKN,MAAQpB,EAAOL,IAElDoC,WAAuB,IAAXpC,EAAe,iBAAiB8B,UAAYzB,EAAOL,QAAaA,KAAY,WAW3F,OANAJ,EAAAA,EAAAA,WAAAA,KAAAA,EAAAA,EAAAA,iBAAAA,EAAAA,EAAAA,aAAU,MAAA,CAAA,MACGoC,EAAMP,OAAK,CACrBV,EAAMX,SAAWW,EAAMX,YAAS,CAAA,CAAAhB,EAAAA,MADFgC,EAAMC,UAKvC,EAAA,EAAA,WAAiBF,EAAQ,CACxBE,KAAMD,EAAMC"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"
|
|
2
|
-
//# sourceMappingURL=index.js.map
|
|
1
|
+
require("../../_virtual/_rolldown/runtime.js");const e=require("./src/selectOption.js"),t=require("./src/select.js");require("./src/select.type.js");let r=require("@fast-china/utils");var l=(0,r.withInstall)(t.default,{SelectOption:e.default}),s=(0,r.withNoopInstall)(e.default);exports.FaSelectOption=s,exports.default=l;
|
|
2
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../../../../packages/components/select/index.ts"],"sourcesContent":["import { withInstall, withNoopInstall } from \"@fast-china/utils\";\nimport Select, { SelectProps, faSelectProps } from \"./src/select\";\nimport SelectOption from \"./src/selectOption\";\nimport type { faSelectEmits } from \"./src/select\";\nimport type { ExtractPropTypes } from \"vue\";\n\nexport const FaSelect = withInstall(Select, {\n\tSelectOption,\n});\nexport default FaSelect;\n\nexport const FaSelectOption = withNoopInstall(SelectOption);\n\nexport { SelectProps, faSelectProps };\nexport * from \"./src/select.type\";\n\nexport type FaSelectInstance = InstanceType<typeof Select>;\n\nexport type FaSelectProps = ExtractPropTypes<typeof faSelectProps>;\n\nexport type FaSelectEmits = typeof faSelectEmits;\n\nexport type FaSelectOptionInstance = InstanceType<typeof SelectOption>;\n"],"
|
|
1
|
+
{"version":3,"file":"index.js","names":[],"sources":["../../../../packages/components/select/index.ts"],"sourcesContent":["import { withInstall, withNoopInstall } from \"@fast-china/utils\";\nimport Select, { SelectProps, faSelectProps } from \"./src/select\";\nimport SelectOption from \"./src/selectOption\";\nimport type { faSelectEmits } from \"./src/select\";\nimport type { ExtractPropTypes } from \"vue\";\n\nexport const FaSelect = withInstall(Select, {\n\tSelectOption,\n});\nexport default FaSelect;\n\nexport const FaSelectOption = withNoopInstall(SelectOption);\n\nexport { SelectProps, faSelectProps };\nexport * from \"./src/select.type\";\n\nexport type FaSelectInstance = InstanceType<typeof Select>;\n\nexport type FaSelectProps = ExtractPropTypes<typeof faSelectProps>;\n\nexport type FaSelectEmits = typeof faSelectEmits;\n\nexport type FaSelectOptionInstance = InstanceType<typeof SelectOption>;\n"],"mappings":"wLAMA,IAAa,GAAA,EAAA,EAAA,aAAuB,EAAA,QAAQ,CAC3C,aAAA,EAAA,UAIY,GAAA,EAAA,EAAA,iBAAiC,EAAA"}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { ElSelectorOutput } from './select.type';
|
|
2
|
-
import { Options } from 'element-plus';
|
|
2
|
+
import { Options, Placement } from 'element-plus';
|
|
3
3
|
import { Component } from 'vue';
|
|
4
4
|
export declare const SelectProps: {
|
|
5
5
|
ariaLabel: StringConstructor;
|
|
6
6
|
emptyValues: ArrayConstructor;
|
|
7
|
-
valueOnClear: import('element-plus/es/utils/index.mjs').EpPropFinalized<(new (...args: any[]) => string | number | boolean | Function) | (() => string | number | boolean | Function | null) | ((new (...args: any[]) => string | number | boolean | Function) | (() => string | number | boolean | Function | null))[], unknown, unknown, undefined, boolean>;
|
|
7
|
+
valueOnClear: import('element-plus/es/utils/index.mjs').EpPropFinalized<(new (...args: any[]) => string | number | boolean | Function) | (() => string | number | boolean | Function | null) | (((new (...args: any[]) => string | number | boolean | Function) | (() => string | number | boolean | Function | null)) | null)[], unknown, unknown, undefined, boolean>;
|
|
8
8
|
/**
|
|
9
9
|
* @description the name attribute of select input
|
|
10
10
|
*/
|
|
@@ -35,7 +35,7 @@ export declare const SelectProps: {
|
|
|
35
35
|
* @description size of Input
|
|
36
36
|
*/
|
|
37
37
|
size: {
|
|
38
|
-
readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "" | "
|
|
38
|
+
readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "" | "default" | "small" | "large", never>>;
|
|
39
39
|
readonly required: false;
|
|
40
40
|
readonly validator: ((val: unknown) => boolean) | undefined;
|
|
41
41
|
__epPropKey: true;
|
|
@@ -78,7 +78,7 @@ export declare const SelectProps: {
|
|
|
78
78
|
* @description [popper.js](https://popper.js.org/docs/v2/) parameters
|
|
79
79
|
*/
|
|
80
80
|
popperOptions: {
|
|
81
|
-
type: import('vue').PropType<Options
|
|
81
|
+
type: import('vue').PropType<Partial<Options>>;
|
|
82
82
|
default: () => Partial<Options>;
|
|
83
83
|
};
|
|
84
84
|
/**
|
|
@@ -189,7 +189,7 @@ export declare const SelectProps: {
|
|
|
189
189
|
*/
|
|
190
190
|
tagType: {
|
|
191
191
|
default: string;
|
|
192
|
-
type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "
|
|
192
|
+
type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "info" | "primary" | "success" | "warning" | "danger", unknown>>;
|
|
193
193
|
required: false;
|
|
194
194
|
validator: ((val: unknown) => boolean) | undefined;
|
|
195
195
|
__epPropKey: true;
|
|
@@ -318,7 +318,7 @@ export declare const faSelectProps: {
|
|
|
318
318
|
initParam: import('vue').PropType<any>;
|
|
319
319
|
ariaLabel: StringConstructor;
|
|
320
320
|
emptyValues: ArrayConstructor;
|
|
321
|
-
valueOnClear: import('element-plus/es/utils/index.mjs').EpPropFinalized<(new (...args: any[]) => string | number | boolean | Function) | (() => string | number | boolean | Function | null) | ((new (...args: any[]) => string | number | boolean | Function) | (() => string | number | boolean | Function | null))[], unknown, unknown, undefined, boolean>;
|
|
321
|
+
valueOnClear: import('element-plus/es/utils/index.mjs').EpPropFinalized<(new (...args: any[]) => string | number | boolean | Function) | (() => string | number | boolean | Function | null) | (((new (...args: any[]) => string | number | boolean | Function) | (() => string | number | boolean | Function | null)) | null)[], unknown, unknown, undefined, boolean>;
|
|
322
322
|
/**
|
|
323
323
|
* @description the name attribute of select input
|
|
324
324
|
*/
|
|
@@ -342,7 +342,7 @@ export declare const faSelectProps: {
|
|
|
342
342
|
* @description size of Input
|
|
343
343
|
*/
|
|
344
344
|
size: {
|
|
345
|
-
readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "" | "
|
|
345
|
+
readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "" | "default" | "small" | "large", never>>;
|
|
346
346
|
readonly required: false;
|
|
347
347
|
readonly validator: ((val: unknown) => boolean) | undefined;
|
|
348
348
|
__epPropKey: true;
|
|
@@ -381,7 +381,7 @@ export declare const faSelectProps: {
|
|
|
381
381
|
* @description [popper.js](https://popper.js.org/docs/v2/) parameters
|
|
382
382
|
*/
|
|
383
383
|
popperOptions: {
|
|
384
|
-
type: import('vue').PropType<Options
|
|
384
|
+
type: import('vue').PropType<Partial<Options>>;
|
|
385
385
|
default: () => Partial<Options>;
|
|
386
386
|
};
|
|
387
387
|
/**
|
|
@@ -472,7 +472,7 @@ export declare const faSelectProps: {
|
|
|
472
472
|
*/
|
|
473
473
|
tagType: {
|
|
474
474
|
default: string;
|
|
475
|
-
type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "
|
|
475
|
+
type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "info" | "primary" | "success" | "warning" | "danger", unknown>>;
|
|
476
476
|
required: false;
|
|
477
477
|
validator: ((val: unknown) => boolean) | undefined;
|
|
478
478
|
__epPropKey: true;
|
|
@@ -522,7 +522,7 @@ export declare const faSelectEmits: {
|
|
|
522
522
|
dataChangeCallBack: (data: ElSelectorOutput[] | any[]) => boolean;
|
|
523
523
|
/** @description 改变 */
|
|
524
524
|
change: (data: ElSelectorOutput | ElSelectorOutput[] | any | any[], value?: string | number | boolean | object | (string | number | boolean | object)[]) => boolean;
|
|
525
|
-
'popup-scroll': ({ scrollTop, scrollLeft
|
|
525
|
+
'popup-scroll': ({ scrollTop, scrollLeft }: {
|
|
526
526
|
scrollTop: number;
|
|
527
527
|
scrollLeft: number;
|
|
528
528
|
}) => boolean;
|
|
@@ -631,7 +631,7 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
|
|
|
631
631
|
initParam: import('vue').PropType<any>;
|
|
632
632
|
ariaLabel: StringConstructor;
|
|
633
633
|
emptyValues: ArrayConstructor;
|
|
634
|
-
valueOnClear: import('element-plus/es/utils/index.mjs').EpPropFinalized<(new (...args: any[]) => string | number | boolean | Function) | (() => string | number | boolean | Function | null) | ((new (...args: any[]) => string | number | boolean | Function) | (() => string | number | boolean | Function | null))[], unknown, unknown, undefined, boolean>;
|
|
634
|
+
valueOnClear: import('element-plus/es/utils/index.mjs').EpPropFinalized<(new (...args: any[]) => string | number | boolean | Function) | (() => string | number | boolean | Function | null) | (((new (...args: any[]) => string | number | boolean | Function) | (() => string | number | boolean | Function | null)) | null)[], unknown, unknown, undefined, boolean>;
|
|
635
635
|
/**
|
|
636
636
|
* @description the name attribute of select input
|
|
637
637
|
*/
|
|
@@ -655,7 +655,7 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
|
|
|
655
655
|
* @description size of Input
|
|
656
656
|
*/
|
|
657
657
|
size: {
|
|
658
|
-
readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "" | "
|
|
658
|
+
readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "" | "default" | "small" | "large", never>>;
|
|
659
659
|
readonly required: false;
|
|
660
660
|
readonly validator: ((val: unknown) => boolean) | undefined;
|
|
661
661
|
__epPropKey: true;
|
|
@@ -694,7 +694,7 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
|
|
|
694
694
|
* @description [popper.js](https://popper.js.org/docs/v2/) parameters
|
|
695
695
|
*/
|
|
696
696
|
popperOptions: {
|
|
697
|
-
type: import('vue').PropType<Options
|
|
697
|
+
type: import('vue').PropType<Partial<Options>>;
|
|
698
698
|
default: () => Partial<Options>;
|
|
699
699
|
};
|
|
700
700
|
/**
|
|
@@ -785,7 +785,7 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
|
|
|
785
785
|
*/
|
|
786
786
|
tagType: {
|
|
787
787
|
default: string;
|
|
788
|
-
type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "
|
|
788
|
+
type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "info" | "primary" | "success" | "warning" | "danger", unknown>>;
|
|
789
789
|
required: false;
|
|
790
790
|
validator: ((val: unknown) => boolean) | undefined;
|
|
791
791
|
__epPropKey: true;
|
|
@@ -849,7 +849,7 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
|
|
|
849
849
|
dataChangeCallBack: (data: ElSelectorOutput[] | any[]) => boolean;
|
|
850
850
|
/** @description 改变 */
|
|
851
851
|
change: (data: ElSelectorOutput | ElSelectorOutput[] | any | any[], value?: string | number | boolean | object | (string | number | boolean | object)[]) => boolean;
|
|
852
|
-
'popup-scroll': ({ scrollTop, scrollLeft
|
|
852
|
+
'popup-scroll': ({ scrollTop, scrollLeft }: {
|
|
853
853
|
scrollTop: number;
|
|
854
854
|
scrollLeft: number;
|
|
855
855
|
}) => boolean;
|
|
@@ -936,7 +936,7 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
|
|
|
936
936
|
initParam: import('vue').PropType<any>;
|
|
937
937
|
ariaLabel: StringConstructor;
|
|
938
938
|
emptyValues: ArrayConstructor;
|
|
939
|
-
valueOnClear: import('element-plus/es/utils/index.mjs').EpPropFinalized<(new (...args: any[]) => string | number | boolean | Function) | (() => string | number | boolean | Function | null) | ((new (...args: any[]) => string | number | boolean | Function) | (() => string | number | boolean | Function | null))[], unknown, unknown, undefined, boolean>;
|
|
939
|
+
valueOnClear: import('element-plus/es/utils/index.mjs').EpPropFinalized<(new (...args: any[]) => string | number | boolean | Function) | (() => string | number | boolean | Function | null) | (((new (...args: any[]) => string | number | boolean | Function) | (() => string | number | boolean | Function | null)) | null)[], unknown, unknown, undefined, boolean>;
|
|
940
940
|
/**
|
|
941
941
|
* @description the name attribute of select input
|
|
942
942
|
*/
|
|
@@ -960,7 +960,7 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
|
|
|
960
960
|
* @description size of Input
|
|
961
961
|
*/
|
|
962
962
|
size: {
|
|
963
|
-
readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "" | "
|
|
963
|
+
readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "" | "default" | "small" | "large", never>>;
|
|
964
964
|
readonly required: false;
|
|
965
965
|
readonly validator: ((val: unknown) => boolean) | undefined;
|
|
966
966
|
__epPropKey: true;
|
|
@@ -999,7 +999,7 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
|
|
|
999
999
|
* @description [popper.js](https://popper.js.org/docs/v2/) parameters
|
|
1000
1000
|
*/
|
|
1001
1001
|
popperOptions: {
|
|
1002
|
-
type: import('vue').PropType<Options
|
|
1002
|
+
type: import('vue').PropType<Partial<Options>>;
|
|
1003
1003
|
default: () => Partial<Options>;
|
|
1004
1004
|
};
|
|
1005
1005
|
/**
|
|
@@ -1090,7 +1090,7 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
|
|
|
1090
1090
|
*/
|
|
1091
1091
|
tagType: {
|
|
1092
1092
|
default: string;
|
|
1093
|
-
type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "
|
|
1093
|
+
type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "info" | "primary" | "success" | "warning" | "danger", unknown>>;
|
|
1094
1094
|
required: false;
|
|
1095
1095
|
validator: ((val: unknown) => boolean) | undefined;
|
|
1096
1096
|
__epPropKey: true;
|
|
@@ -1173,7 +1173,7 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
|
|
|
1173
1173
|
clearIcon: import('vue').DefineComponent<{}, void, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any>;
|
|
1174
1174
|
suffixIcon: import('vue').DefineComponent<{}, void, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any>;
|
|
1175
1175
|
validateEvent: boolean;
|
|
1176
|
-
popperOptions: Options
|
|
1176
|
+
popperOptions: Partial<Options>;
|
|
1177
1177
|
popperClass: string;
|
|
1178
1178
|
effect: string | (string & {});
|
|
1179
1179
|
teleported: import('element-plus/es/utils/index.mjs').EpPropMergeType<BooleanConstructor, unknown, unknown>;
|
|
@@ -1199,7 +1199,7 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
|
|
|
1199
1199
|
valueKey: string;
|
|
1200
1200
|
maxCollapseTags: number;
|
|
1201
1201
|
fitInputWidth: boolean;
|
|
1202
|
-
tagType: import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "
|
|
1202
|
+
tagType: import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "info" | "primary" | "success" | "warning" | "danger", unknown>;
|
|
1203
1203
|
tagEffect: import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "plain" | "dark" | "light", unknown>;
|
|
1204
1204
|
remoteShowSuffix: boolean;
|
|
1205
1205
|
}, import('vue').SlotsType<Partial<import('@fast-china/utils').MakeSlots<FaSelectSlots>>>, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any>;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"
|
|
2
|
-
//# sourceMappingURL=select.js.map
|
|
1
|
+
require("../../../_virtual/_rolldown/runtime.js");const e=require("./selectOption.js");let l=require("@fast-china/utils"),a=require("vue"),t=require("element-plus"),o=require("@element-plus/icons-vue"),r=require("lodash-unified"),i=require("@vueuse/core");var n={name:String,id:String,modelValue:{type:[Array,String,Number,Boolean,Object],default:void 0},autocomplete:{type:String,default:"off"},automaticDropdown:Boolean,size:t.useSizeProp,effect:{type:(0,l.definePropType)(String),default:"light"},disabled:Boolean,clearable:Boolean,filterable:Boolean,allowCreate:Boolean,loading:Boolean,popperClass:{type:String,default:""},popperOptions:{type:(0,l.definePropType)(Object),default:()=>({})},remote:Boolean,loadingText:String,noMatchText:String,noDataText:String,remoteMethod:Function,filterMethod:Function,multiple:Boolean,multipleLimit:{type:Number,default:0},placeholder:{type:String},defaultFirstOption:Boolean,reserveKeyword:{type:Boolean,default:!0},valueKey:{type:String,default:"value"},collapseTags:Boolean,collapseTagsTooltip:Boolean,maxCollapseTags:{type:Number,default:1},teleported:t.useTooltipContentProps.teleported,persistent:{type:Boolean,default:!0},clearIcon:{type:(0,l.definePropType)([String,Object,Function]),default:o.CircleClose},fitInputWidth:Boolean,suffixIcon:{type:(0,l.definePropType)([String,Object,Function]),default:o.ArrowDown},tagType:{...t.tagProps.type,default:"info"},tagEffect:{...t.tagProps.effect,default:"light"},validateEvent:{type:Boolean,default:!0},remoteShowSuffix:Boolean,placement:{type:(0,l.definePropType)(String),default:"bottom-start"},fallbackPlacements:{type:(0,l.definePropType)(Array),default:["bottom-start","top-start","right","left"]},...t.useEmptyValuesProps,...(0,t.useAriaProps)(["ariaLabel"])},u={...n,disabled:{type:Boolean,default:void 0},loadingText:{type:String,default:"加载中..."},noMatchText:{type:String,default:"暂无匹配的数据"},noDataText:{type:String,default:"暂无数据"},collapseTags:{type:Boolean,default:!0},collapseTagsTooltip:{type:Boolean,default:!0},modelValue:{type:(0,l.definePropType)([String,Number,Boolean,Object,Array]),default:void 0},label:(0,l.definePropType)([String,Array]),width:{type:[String,Number],default:"100%"},moreDetail:Boolean,lazy:{type:Boolean,default:!0},defaultSelected:Boolean,props:{type:(0,l.definePropType)(Object),default:()=>({label:"label",hide:"hide",disabled:"disabled",children:"children"})},data:{type:(0,l.definePropType)(Array),default:()=>[]},requestApi:{type:(0,l.definePropType)(Function)},initParam:(0,l.definePropType)([String,Number,Object])},d={...t.selectEmits,"update:modelValue":e=>(0,r.isString)(e)||(0,r.isNumber)(e)||(0,r.isBoolean)(e)||(0,r.isObject)(e)||(0,r.isArray)(e)||(0,r.isNull)(e),"update:label":e=>(0,r.isString)(e)||(0,r.isArray)(e)||(0,r.isNull)(e),dataChangeCallBack:e=>(0,r.isArray)(e),change:(e,l)=>!0},s=(0,a.defineComponent)({name:"FaSelect",props:u,emits:d,slots:(0,l.makeSlots)(),setup(o,{attrs:u,slots:d,emit:s,expose:p}){const c=(0,i.useVModel)(o,"label",s,{passive:!0}),f=(0,t.useGlobalSize)(),m=(0,a.reactive)({value:(0,l.withDefineType)(),loading:!1,selectorData:(0,l.withDefineType)([]),debut:!0,echo:!(o.data?.length>0),nextRefresh:!1}),y=(0,a.ref)(),g=e=>e?.map(e=>({...e,value:e[o.valueKey],label:(0,r.isFunction)(o.props.label)?o.props.label(e):e[o.props.label??"label"],hide:(0,r.isFunction)(o.props.hide)?o.props.hide(e):e[o.props.hide??"hide"],disabled:(0,r.isFunction)(o.props.disabled)?o.props.disabled(e):e[o.props.disabled??"disabled"],children:(0,r.isFunction)(o.props.children)?g(o.props.children(e)):g(e[o.props.children??"children"])})).filter(e=>!e.hide),b=async()=>{if(o.requestApi){m.loading=!0;const a=o.initParam??{};try{const e=await o.requestApi(a);m.echo=!1,m.selectorData=g(e),s("dataChangeCallBack",m.selectorData)}catch(e){(0,l.consoleError)("FaSelect",e),m.selectorData=[]}finally{m.loading=!1}}else m.echo=!1,m.selectorData=g(o.data)},h=e=>{if(o.multiple){const l=e;if(0===l?.length)return m.value=null,c.value=null,s("update:modelValue",null),void s("change",null,null);const a=m.selectorData.filter(e=>l.includes(e.value));m.value=e,c.value=a.map(e=>e.label),s("update:modelValue",e),s("change",a,e)}else{if((0,r.isNil)(e))return m.value=null,c.value=null,s("update:modelValue",null),void s("change",null,null);const l=m.selectorData.find(l=>l.value===e);m.value=e,c.value=l.label,s("update:modelValue",e),s("change",l,e)}},v=()=>{m.value=null,c.value=null,s("update:modelValue",null),s("clear")},S=async e=>{e&&(m.debut?(m.debut=!1,!o.defaultSelected&&o.lazy&&await b()):m.nextRefresh&&(m.nextRefresh=!1,await b())),s("visible-change",e)};(0,a.watch)(()=>o.modelValue,e=>{if(m.echo&&!(0,r.isNil)(e)){const a=!(0,r.isNil)(o.label);if(o.multiple){if(!(0,r.isArray)(e))return void(0,l.consoleError)("FaSelect","当启用 multiple 时,传入的 modelValue 必须是Array。");if(a&&!(0,r.isArray)(o.label))return void(0,l.consoleError)("FaSelect","当启用 multiple 时,传入的 modelValue:label 必须是Array。");m.selectorData=e.slice(0,o.multipleLimit>0?o.multipleLimit:e.length).map((e,l)=>({value:e,label:a?o.label[l]:void 0}))}else{if((0,r.isArray)(e))return void(0,l.consoleError)("FaSelect","当禁用 multiple 时,传入的 modelValue 不能是Array。");if(a&&(0,r.isArray)(o.label))return void(0,l.consoleError)("FaSelect","当禁用 multiple 时,传入的 modelValue:label 不能是Array。");m.selectorData=[{value:e,label:o.label}]}}m.value=e},{immediate:!0}),(0,a.onMounted)(async()=>{o.defaultSelected?(await b(),m.selectorData.length>0&&h(o.multiple?[m.selectorData[0].value]:m.selectorData[0].value)):!o.requestApi&&o.data?.length>0?(m.debut=!1,await b()):o.lazy||await b(),(0,a.watch)(()=>o.initParam,(e,l)=>{(0,r.isEqual)(e,l)||(m.nextRefresh=!0,(0,r.isNil)(m.value)||h())}),(0,a.watch)(()=>o.data,async()=>{o.requestApi||await b()},{deep:!0})});const T=(0,l.useProps)(o,n,["modelValue","popperClass","loading"]),B=(0,l.useEmits)(t.selectEmits,s,["update:modelValue","change","clear","visible-change"]),P=(0,a.computed)(()=>{let e=`fa-select-dropdown ${o.popperClass}`;return o.moreDetail&&(e+=` fa-select-dropdown__more-detail fa-select-dropdown__more-detail-${f.value}`),e});return(0,l.useRender)(()=>(0,a.createVNode)(t.ElSelect,(0,a.mergeProps)(T.value,B.value,{ref:y,class:"fa-select",popperClass:P.value,style:{width:(0,l.addUnit)(o.width)},modelValue:m.value,"onUpdate:modelValue":e=>m.value=e,loading:m.loading,onChange:h,onClear:v,onVisibleChange:S}),{default:()=>m.selectorData.map(l=>(0,a.createVNode)(e.default,{data:l,moreDetail:o.moreDetail},{default:d.default})),...d.header&&{header:()=>d.header()},...d.footer&&{footer:()=>d.footer()},...d.prefix&&{prefix:()=>d.prefix()},...d.empty&&{empty:()=>d.empty()},...d.tag&&{tag:()=>d.tag()},...d.loading&&{loading:()=>d.loading()},...d.label&&{label:({label:e,value:l})=>d.label({label:e,value:l})}})),(0,l.useExpose)(p,{focus:(0,a.computed)(()=>y.value?.focus),blur:(0,a.computed)(()=>y.value?.blur),selectedLabel:(0,a.computed)(()=>y.value?.selectedLabel),loading:(0,a.computed)(()=>m.loading),refresh:b,setSelection:e=>h(e),clearSelection:()=>h(null)})}});exports.SelectProps=n,exports.default=s,exports.faSelectProps=u;
|
|
2
|
+
//# sourceMappingURL=select.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"select.js","sources":["../../../../../packages/components/select/src/select.tsx"],"sourcesContent":["import { computed, defineComponent, onMounted, reactive, ref, watch } from \"vue\";\nimport { ElSelect, selectEmits, tagProps, useAriaProps, useEmptyValuesProps, useGlobalSize, useSizeProp, useTooltipContentProps } from \"element-plus\";\nimport { ArrowDown, CircleClose } from \"@element-plus/icons-vue\";\nimport { addUnit, consoleError, definePropType, makeSlots, useEmits, useExpose, useProps, useRender, withDefineType } from \"@fast-china/utils\";\nimport { useVModel } from \"@vueuse/core\";\nimport { isArray, isBoolean, isEqual, isFunction, isNil, isNull, isNumber, isObject, isString } from \"lodash-unified\";\nimport FaSelectOption from \"./selectOption\";\nimport type { ElSelectorOutput } from \"./select.type\";\nimport type { Options, Placement, PopperEffect } from \"element-plus\";\nimport type { Component, VNode } from \"vue\";\n\nexport const SelectProps = {\n\t/**\n\t * @description the name attribute of select input\n\t */\n\tname: String,\n\t/**\n\t * @description native input id\n\t */\n\tid: String,\n\t/**\n\t * @description binding value\n\t */\n\tmodelValue: {\n\t\ttype: [Array, String, Number, Boolean, Object],\n\t\tdefault: undefined,\n\t},\n\t/**\n\t * @description the autocomplete attribute of select input\n\t */\n\tautocomplete: {\n\t\ttype: String,\n\t\tdefault: \"off\",\n\t},\n\t/**\n\t * @description for non-filterable Select, this prop decides if the option menu pops up when the input is focused\n\t */\n\tautomaticDropdown: Boolean,\n\t/**\n\t * @description size of Input\n\t */\n\tsize: useSizeProp,\n\t/**\n\t * @description tooltip theme, built-in theme: `dark` / `light`\n\t */\n\teffect: {\n\t\ttype: definePropType<PopperEffect | string>(String),\n\t\tdefault: \"light\",\n\t},\n\t/**\n\t * @description whether Select is disabled\n\t */\n\tdisabled: Boolean,\n\t/**\n\t * @description whether select can be cleared\n\t */\n\tclearable: Boolean,\n\t/**\n\t * @description whether Select is filterable\n\t */\n\tfilterable: Boolean,\n\t/**\n\t * @description whether creating new items is allowed. To use this, `filterable` must be true\n\t */\n\tallowCreate: Boolean,\n\t/**\n\t * @description whether Select is loading data from server\n\t */\n\tloading: Boolean,\n\t/**\n\t * @description custom class name for Select's dropdown\n\t */\n\tpopperClass: {\n\t\ttype: String,\n\t\tdefault: \"\",\n\t},\n\t/**\n\t * @description [popper.js](https://popper.js.org/docs/v2/) parameters\n\t */\n\tpopperOptions: {\n\t\ttype: definePropType<Partial<Options>>(Object),\n\t\tdefault: (): Partial<Options> => ({}),\n\t},\n\t/**\n\t * @description whether options are loaded from server\n\t */\n\tremote: Boolean,\n\t/**\n\t * @description displayed text while loading data from server, default is 'Loading'\n\t */\n\tloadingText: String,\n\t/**\n\t * @description displayed text when no data matches the filtering query, you can also use slot `empty`, default is 'No matching data'\n\t */\n\tnoMatchText: String,\n\t/**\n\t * @description displayed text when there is no options, you can also use slot `empty`, default is 'No data'\n\t */\n\tnoDataText: String,\n\t/**\n\t * @description custom remote search method\n\t */\n\tremoteMethod: Function,\n\t/**\n\t * @description custom filter method\n\t */\n\tfilterMethod: Function,\n\t/**\n\t * @description whether multiple-select is activated\n\t */\n\tmultiple: Boolean,\n\t/**\n\t * @description maximum number of options user can select when `multiple` is `true`. No limit when set to 0\n\t */\n\tmultipleLimit: {\n\t\ttype: Number,\n\t\tdefault: 0,\n\t},\n\t/**\n\t * @description placeholder, default is 'Select'\n\t */\n\tplaceholder: {\n\t\ttype: String,\n\t},\n\t/**\n\t * @description select first matching option on enter key. Use with `filterable` or `remote`\n\t */\n\tdefaultFirstOption: Boolean,\n\t/**\n\t * @description when `multiple` and `filter` is true, whether to reserve current keyword after selecting an option\n\t */\n\treserveKeyword: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/**\n\t * @description unique identity key name for value, required when value is an object\n\t */\n\tvalueKey: {\n\t\ttype: String,\n\t\tdefault: \"value\",\n\t},\n\t/**\n\t * @description whether to collapse tags to a text when multiple selecting\n\t */\n\tcollapseTags: Boolean,\n\t/**\n\t * @description whether show all selected tags when mouse hover text of collapse-tags. To use this, `collapse-tags` must be true\n\t */\n\tcollapseTagsTooltip: Boolean,\n\t/**\n\t * @description the max tags number to be shown. To use this, `collapse-tags` must be true\n\t */\n\tmaxCollapseTags: {\n\t\ttype: Number,\n\t\tdefault: 1,\n\t},\n\t/**\n\t * @description whether select dropdown is teleported to the body\n\t */\n\tteleported: useTooltipContentProps.teleported,\n\t/**\n\t * @description when select dropdown is inactive and `persistent` is `false`, select dropdown will be destroyed\n\t */\n\tpersistent: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/**\n\t * @description custom clear icon component\n\t */\n\tclearIcon: {\n\t\ttype: definePropType<string | Component>([String, Object, Function]),\n\t\tdefault: CircleClose,\n\t},\n\t/**\n\t * @description whether the width of the dropdown is the same as the input\n\t */\n\tfitInputWidth: Boolean,\n\t/**\n\t * @description custom suffix icon component\n\t */\n\tsuffixIcon: {\n\t\ttype: definePropType<string | Component>([String, Object, Function]),\n\t\tdefault: ArrowDown,\n\t},\n\t/**\n\t * @description tag type\n\t */\n\n\ttagType: { ...tagProps.type, default: \"info\" },\n\t/**\n\t * @description tag effect\n\t */\n\ttagEffect: { ...tagProps.effect, default: \"light\" },\n\t/**\n\t * @description whether to trigger form validation\n\t */\n\tvalidateEvent: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/**\n\t * @description in remote search method show suffix icon\n\t */\n\tremoteShowSuffix: Boolean,\n\t/**\n\t * @description position of dropdown\n\t */\n\tplacement: {\n\t\ttype: definePropType<Placement>(String),\n\t\tdefault: \"bottom-start\",\n\t},\n\t/**\n\t * @description list of possible positions for dropdown\n\t */\n\tfallbackPlacements: {\n\t\ttype: definePropType<Placement[]>(Array),\n\t\tdefault: [\"bottom-start\", \"top-start\", \"right\", \"left\"],\n\t},\n\t...useEmptyValuesProps,\n\t...useAriaProps([\"ariaLabel\"]),\n};\n\nexport type SelectComponentProps = {\n\t/** @description 指定标签为节点的某个属性值 */\n\tlabel?: string | ((data: any) => string);\n\t/** @description 指定是否隐藏为节点的某个属性值 */\n\thide?: string | ((data: any) => boolean);\n\t/** @description 指定是否禁用为节点的某个属性值 */\n\tdisabled?: string | ((data: any) => boolean);\n\t/** @description 指定子节点对象为节点的某个属性值 */\n\tchildren?: string;\n};\n\nexport const faSelectProps = {\n\t...SelectProps,\n\t/** @description whether Select is disabled 重载使其支持 ElForm*/\n\tdisabled: {\n\t\ttype: Boolean,\n\t\tdefault: undefined,\n\t},\n\t/** @description displayed text while loading data from server, default is 'Loading' */\n\tloadingText: {\n\t\ttype: String,\n\t\tdefault: \"加载中...\",\n\t},\n\t/** @description displayed text when no data matches the filtering query, you can also use slot `empty`, default is 'No matching data' */\n\tnoMatchText: {\n\t\ttype: String,\n\t\tdefault: \"暂无匹配的数据\",\n\t},\n\t/** @description displayed text when there is no options, you can also use slot `empty`, default is 'No data' */\n\tnoDataText: {\n\t\ttype: String,\n\t\tdefault: \"暂无数据\",\n\t},\n\t/** @description whether to collapse tags to a text when multiple selecting */\n\tcollapseTags: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description whether show all selected tags when mouse hover text of collapse-tags. To use this, `collapse-tags` must be true */\n\tcollapseTagsTooltip: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description v-model绑定值 */\n\tmodelValue: {\n\t\ttype: definePropType<string | number | boolean | object | (string | number | boolean | object)[]>([String, Number, Boolean, Object, Array]),\n\t\tdefault: undefined,\n\t},\n\t/** @description v-model:label绑定值 */\n\tlabel: definePropType<string | string[]>([String, Array]),\n\t/** @description 宽度 */\n\twidth: {\n\t\ttype: [String, Number],\n\t\tdefault: \"100%\",\n\t},\n\t/** @description 更多细节,只有使用slot的时候有用 */\n\tmoreDetail: Boolean,\n\t/** @description 懒加载远程数据,默认 true。当下拉框第一次显示的时候才会加载远程数据*/\n\tlazy: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description 默认选中。不能和懒加载一起使用 */\n\tdefaultSelected: Boolean,\n\t/** @description 配置选项 */\n\tprops: {\n\t\ttype: definePropType<SelectComponentProps>(Object),\n\t\tdefault: (): Partial<SelectComponentProps> => ({\n\t\t\tlabel: \"label\",\n\t\t\thide: \"hide\",\n\t\t\tdisabled: \"disabled\",\n\t\t\tchildren: \"children\",\n\t\t}),\n\t},\n\t/** @description 下拉框数据 */\n\tdata: {\n\t\ttype: definePropType<ElSelectorOutput[]>(Array),\n\t\tdefault: (): ElSelectorOutput[] => [],\n\t},\n\t/** @description 请求api */\n\trequestApi: {\n\t\ttype: definePropType<(params?: any) => Promise<ElSelectorOutput[]>>(Function),\n\t},\n\t/** 初始化参数 */\n\tinitParam: definePropType<string | number | any>([String, Number, Object]),\n};\n\nexport const faSelectEmits = {\n\t...selectEmits,\n\t/** @description v-model 回调 */\n\t\"update:modelValue\": (value: string | number | boolean | object | (string | number | boolean | object)[]): boolean =>\n\t\tisString(value) || isNumber(value) || isBoolean(value) || isObject(value) || isArray(value) || isNull(value),\n\t/** @description v-model:label 回调 */\n\t\"update:label\": (value: string | string[]): boolean => isString(value) || isArray(value) || isNull(value),\n\t/** @description 数据改变 */\n\tdataChangeCallBack: (data: ElSelectorOutput[] | any[]): boolean => isArray(data),\n\t/** @description 改变 */\n\tchange: (\n\t\tdata: ElSelectorOutput | ElSelectorOutput[] | any | any[],\n\t\tvalue?: string | number | boolean | object | (string | number | boolean | object)[]\n\t): boolean => true,\n};\n\ntype FaSelectSlots = {\n\t/** @description FaSelectOption 默认内容插槽 */\n\tdefault: ElSelectorOutput;\n\t/** @description 下拉列表顶部的内容 */\n\theader: never;\n\t/** @description 下拉列表底部的内容 */\n\tfooter: never;\n\t/** @description Select 组件头部内容 */\n\tprefix: never;\n\t/** @description 无选项时的列表 */\n\tempty: never;\n\t/** @description select 组件自定义标签内容 */\n\ttag: never;\n\t/** @description select 组件自定义 loading内容 */\n\tloading: never;\n\t/** @description select 组件自定义标签内容 */\n\tlabel: { label: string; value: string | number | boolean | object };\n};\n\nexport default defineComponent({\n\tname: \"FaSelect\",\n\tprops: faSelectProps,\n\temits: faSelectEmits,\n\tslots: makeSlots<FaSelectSlots>(),\n\tsetup(props, { attrs, slots, emit, expose }) {\n\t\tconst selectedLabel = useVModel(props, \"label\", emit, { passive: true });\n\t\tconst _globalSize = useGlobalSize();\n\n\t\tconst state = reactive({\n\t\t\tvalue: withDefineType<string | number | boolean | object | (string | number | boolean | object)[]>(),\n\t\t\tloading: false,\n\t\t\tselectorData: withDefineType<ElSelectorOutput[]>([]),\n\t\t\t/** 首次出现 */\n\t\t\tdebut: true,\n\t\t\t/** 回显 */\n\t\t\techo: props.data?.length > 0 ? false : true,\n\t\t\t/** 下次刷新 */\n\t\t\tnextRefresh: false,\n\t\t});\n\n\t\tconst selectRef = ref<InstanceType<typeof ElSelect>>();\n\n\t\tconst handleData = (data: ElSelectorOutput[]): ElSelectorOutput[] => {\n\t\t\treturn data\n\t\t\t\t?.map((m) => ({\n\t\t\t\t\t...m,\n\t\t\t\t\tvalue: m[props.valueKey],\n\t\t\t\t\tlabel: isFunction(props.props.label) ? props.props.label(m) : m[props.props.label ?? \"label\"],\n\t\t\t\t\thide: isFunction(props.props.hide) ? props.props.hide(m) : m[props.props.hide ?? \"hide\"],\n\t\t\t\t\tdisabled: isFunction(props.props.disabled) ? props.props.disabled(m) : m[props.props.disabled ?? \"disabled\"],\n\t\t\t\t\tchildren: isFunction(props.props.children)\n\t\t\t\t\t\t? handleData(props.props.children(m))\n\t\t\t\t\t\t: handleData(m[props.props.children ?? \"children\"]),\n\t\t\t\t}))\n\t\t\t\t.filter((f) => !f.hide);\n\t\t};\n\n\t\tconst loadData = async (): Promise<void> => {\n\t\t\t// 判断是否需要自动请求\n\t\t\tif (props.requestApi) {\n\t\t\t\tstate.loading = true;\n\t\t\t\tconst params = props.initParam ?? {};\n\t\t\t\ttry {\n\t\t\t\t\tconst resData = await props.requestApi(params);\n\t\t\t\t\t// 这里不允许回显了\n\t\t\t\t\tstate.echo = false;\n\t\t\t\t\tstate.selectorData = handleData(resData);\n\t\t\t\t\temit(\"dataChangeCallBack\", state.selectorData);\n\t\t\t\t} catch (error) {\n\t\t\t\t\tconsoleError(\"FaSelect\", error);\n\t\t\t\t\tstate.selectorData = [];\n\t\t\t\t} finally {\n\t\t\t\t\tstate.loading = false;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// 这里不允许回显了\n\t\t\t\tstate.echo = false;\n\t\t\t\tstate.selectorData = handleData(props.data);\n\t\t\t}\n\t\t};\n\n\t\tconst handleChange = (value?: string | number | boolean | object | (string | number | boolean | object)[]): void => {\n\t\t\t// 判断是否为多选\n\t\t\tif (props.multiple) {\n\t\t\t\t// value 必然是数组\n\t\t\t\tconst valueArr = value as (string | number | boolean | object)[];\n\t\t\t\tif (valueArr?.length === 0) {\n\t\t\t\t\tstate.value = null;\n\t\t\t\t\tselectedLabel.value = null;\n\t\t\t\t\temit(\"update:modelValue\", null);\n\t\t\t\t\temit(\"change\", null, null);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tconst dataList = state.selectorData.filter((f) => valueArr.includes(f.value));\n\t\t\t\tstate.value = value;\n\t\t\t\tselectedLabel.value = dataList.map((m) => m.label);\n\t\t\t\temit(\"update:modelValue\", value);\n\t\t\t\temit(\"change\", dataList, value);\n\t\t\t} else {\n\t\t\t\t// value 必然不是数组\n\t\t\t\tif (isNil(value)) {\n\t\t\t\t\tstate.value = null;\n\t\t\t\t\tselectedLabel.value = null;\n\t\t\t\t\temit(\"update:modelValue\", null);\n\t\t\t\t\temit(\"change\", null, null);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tconst data = state.selectorData.find((f) => f.value === value);\n\t\t\t\tstate.value = value;\n\t\t\t\tselectedLabel.value = data.label;\n\t\t\t\temit(\"update:modelValue\", value);\n\t\t\t\temit(\"change\", data, value);\n\t\t\t}\n\t\t};\n\n\t\tconst handleClear = (): void => {\n\t\t\tstate.value = null;\n\t\t\tselectedLabel.value = null;\n\t\t\temit(\"update:modelValue\", null);\n\t\t\temit(\"clear\");\n\t\t};\n\n\t\tconst handleVisibleChange = async (visible: boolean): Promise<void> => {\n\t\t\tif (visible) {\n\t\t\t\tif (state.debut) {\n\t\t\t\t\t// 首次出现\n\t\t\t\t\tstate.debut = false;\n\t\t\t\t\t// 懒加载\n\t\t\t\t\t!props.defaultSelected && props.lazy && (await loadData());\n\t\t\t\t} else {\n\t\t\t\t\t// 判断再次出现是否需要刷新数据\n\t\t\t\t\tif (state.nextRefresh) {\n\t\t\t\t\t\tstate.nextRefresh = false;\n\t\t\t\t\t\tawait loadData();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\temit(\"visible-change\", visible);\n\t\t};\n\n\t\twatch(\n\t\t\t() => props.modelValue,\n\t\t\t(newValue) => {\n\t\t\t\tif (state.echo && !isNil(newValue)) {\n\t\t\t\t\tconst hasLabel = !isNil(props.label);\n\t\t\t\t\t// 判断是否为多选\n\t\t\t\t\tif (props.multiple) {\n\t\t\t\t\t\t// 判断是否为数组\n\t\t\t\t\t\tif (!isArray(newValue)) {\n\t\t\t\t\t\t\tconsoleError(\"FaSelect\", \"当启用 multiple 时,传入的 modelValue 必须是Array。\");\n\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif (hasLabel && !isArray(props.label)) {\n\t\t\t\t\t\t\tconsoleError(\"FaSelect\", \"当启用 multiple 时,传入的 modelValue:label 必须是Array。\");\n\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tstate.selectorData = newValue\n\t\t\t\t\t\t\t// 最大选项截取\n\t\t\t\t\t\t\t.slice(0, props.multipleLimit > 0 ? props.multipleLimit : newValue.length)\n\t\t\t\t\t\t\t.map((item, index) => ({\n\t\t\t\t\t\t\t\tvalue: item,\n\t\t\t\t\t\t\t\tlabel: hasLabel ? props.label[index] : undefined,\n\t\t\t\t\t\t\t}));\n\t\t\t\t\t} else {\n\t\t\t\t\t\tif (isArray(newValue)) {\n\t\t\t\t\t\t\tconsoleError(\"FaSelect\", \"当禁用 multiple 时,传入的 modelValue 不能是Array。\");\n\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif (hasLabel && isArray(props.label)) {\n\t\t\t\t\t\t\tconsoleError(\"FaSelect\", \"当禁用 multiple 时,传入的 modelValue:label 不能是Array。\");\n\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tstate.selectorData = [\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tvalue: newValue,\n\t\t\t\t\t\t\t\tlabel: props.label,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t];\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tstate.value = newValue;\n\t\t\t},\n\t\t\t{\n\t\t\t\timmediate: true,\n\t\t\t}\n\t\t);\n\n\t\tonMounted(async () => {\n\t\t\tif (props.defaultSelected) {\n\t\t\t\tawait loadData();\n\t\t\t\tif (state.selectorData.length > 0) {\n\t\t\t\t\thandleChange(props.multiple ? [state.selectorData[0].value] : state.selectorData[0].value);\n\t\t\t\t}\n\t\t\t}\n\t\t\t// 判断是否为本地数据\n\t\t\telse if (!props.requestApi && props.data?.length > 0) {\n\t\t\t\tstate.debut = false;\n\t\t\t\tawait loadData();\n\t\t\t}\n\t\t\t// 判断是否非默认选中,且未启用懒加载\n\t\t\telse if (!props.lazy) {\n\t\t\t\tawait loadData();\n\t\t\t}\n\t\t\twatch(\n\t\t\t\t() => props.initParam,\n\t\t\t\t(newValue, oldValue) => {\n\t\t\t\t\tif (!isEqual(newValue, oldValue)) {\n\t\t\t\t\t\tstate.nextRefresh = true;\n\t\t\t\t\t\tif (!isNil(state.value)) {\n\t\t\t\t\t\t\thandleChange();\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\twatch(\n\t\t\t\t() => props.data,\n\t\t\t\tasync () => {\n\t\t\t\t\tif (!props.requestApi) {\n\t\t\t\t\t\tawait loadData();\n\t\t\t\t\t}\n\t\t\t\t},\n\t\t\t\t{ deep: true }\n\t\t\t);\n\t\t});\n\n\t\tconst elSelectProps = useProps(props, SelectProps, [\"modelValue\", \"popperClass\", \"loading\"]);\n\t\tconst elSelectEmits = useEmits(selectEmits, emit, [\"update:modelValue\", \"change\", \"clear\", \"visible-change\"]);\n\t\tconst elPopperClass = computed(() => {\n\t\t\tlet localClass = `fa-select-dropdown ${props.popperClass}`;\n\t\t\tif (props.moreDetail) {\n\t\t\t\tlocalClass += ` fa-select-dropdown__more-detail fa-select-dropdown__more-detail-${_globalSize.value}`;\n\t\t\t}\n\t\t\treturn localClass;\n\t\t});\n\n\t\tuseRender(() => (\n\t\t\t<ElSelect\n\t\t\t\t{...elSelectProps.value}\n\t\t\t\t{...elSelectEmits.value}\n\t\t\t\tref={selectRef}\n\t\t\t\tclass=\"fa-select\"\n\t\t\t\tpopperClass={elPopperClass.value}\n\t\t\t\tstyle={{ width: addUnit(props.width) }}\n\t\t\t\tvModel={state.value}\n\t\t\t\tloading={state.loading}\n\t\t\t\tonChange={handleChange}\n\t\t\t\tonClear={handleClear}\n\t\t\t\tonVisibleChange={handleVisibleChange}\n\t\t\t>\n\t\t\t\t{{\n\t\t\t\t\tdefault: (): VNode[] =>\n\t\t\t\t\t\tstate.selectorData.map((item) => (\n\t\t\t\t\t\t\t<FaSelectOption vSlots={{ default: slots.default }} data={item} moreDetail={props.moreDetail} />\n\t\t\t\t\t\t)),\n\t\t\t\t\t...(slots.header && { header: (): VNode[] => slots.header() }),\n\t\t\t\t\t...(slots.footer && { footer: (): VNode[] => slots.footer() }),\n\t\t\t\t\t...(slots.prefix && { prefix: (): VNode[] => slots.prefix() }),\n\t\t\t\t\t...(slots.empty && { empty: (): VNode[] => slots.empty() }),\n\t\t\t\t\t...(slots.tag && { tag: (): VNode[] => slots.tag() }),\n\t\t\t\t\t...(slots.loading && { loading: (): VNode[] => slots.loading() }),\n\t\t\t\t\t...(slots.label && {\n\t\t\t\t\t\tlabel: ({ label, value }: { label: string; value: string | number | boolean | object }): VNode[] =>\n\t\t\t\t\t\t\tslots.label({ label, value }),\n\t\t\t\t\t}),\n\t\t\t\t}}\n\t\t\t</ElSelect>\n\t\t));\n\n\t\treturn useExpose(expose, {\n\t\t\t/** @description 使选择器的输入框获取焦点 */\n\t\t\tfocus: computed(() => selectRef.value?.focus),\n\t\t\t/** @description 使选择器的输入框失去焦点,并隐藏下拉框 */\n\t\t\tblur: computed(() => selectRef.value?.blur),\n\t\t\t/** @description 获取当前选中的标签 */\n\t\t\tselectedLabel: computed(() => selectRef.value?.selectedLabel),\n\t\t\t/** @description 加载状态 */\n\t\t\tloading: computed(() => state.loading),\n\t\t\t/** @description 刷新 */\n\t\t\trefresh: loadData,\n\t\t\t/** @description 设置选择 */\n\t\t\tsetSelection: (value: string | number | boolean | object | (string | number | boolean | object)[]) => handleChange(value),\n\t\t\t/** @description 清除选择 */\n\t\t\tclearSelection: () => handleChange(null),\n\t\t});\n\t},\n});\n"],"names":["SelectProps","name","String","id","modelValue","type","Array","Number","Boolean","Object","default","undefined","autocomplete","automaticDropdown","size","useSizeProp","effect","definePropType","disabled","clearable","filterable","allowCreate","loading","popperClass","popperOptions","remote","loadingText","noMatchText","noDataText","remoteMethod","Function","filterMethod","multiple","multipleLimit","placeholder","defaultFirstOption","reserveKeyword","valueKey","collapseTags","collapseTagsTooltip","maxCollapseTags","teleported","useTooltipContentProps","persistent","clearIcon","CircleClose","fitInputWidth","suffixIcon","ArrowDown","tagType","tagProps","tagEffect","validateEvent","remoteShowSuffix","placement","fallbackPlacements","useEmptyValuesProps","useAriaProps","faSelectProps","label","width","moreDetail","lazy","defaultSelected","props","hide","children","data","requestApi","initParam","faSelectEmits","selectEmits","value","isString","isNumber","isBoolean","isObject","isArray","isNull","dataChangeCallBack","change","Select","emits","slots","makeSlots","setup","attrs","emit","expose","selectedLabel","useVModel","passive","_globalSize","useGlobalSize","state","reactive","withDefineType","selectorData","debut","echo","length","nextRefresh","selectRef","ref","handleData","map","m","isFunction","filter","f","loadData","async","params","resData","error","consoleError","handleChange","valueArr","dataList","includes","isNil","find","handleClear","handleVisibleChange","visible","watch","newValue","hasLabel","slice","item","index","immediate","onMounted","oldValue","isEqual","deep","elSelectProps","useProps","elSelectEmits","useEmits","elPopperClass","computed","localClass","useRender","_createVNode","ElSelect","_mergeProps","class","style","addUnit","$event","onChange","onClear","onVisibleChange","FaSelectOption","header","footer","prefix","empty","tag","useExpose","focus","blur","refresh","setSelection","clearSelection"],"mappings":"sTAWaA,EAAc,CAI1BC,KAAMC,OAINC,GAAID,OAIJE,WAAY,CACXC,KAAM,CAACC,MAAOJ,OAAQK,OAAQC,QAASC,QACvCC,aAASC,GAKVC,aAAc,CACbP,KAAMH,OACNQ,QAAS,OAKVG,kBAAmBL,QAInBM,KAAMC,EAAAA,YAINC,OAAQ,CACPX,KAAMY,EAAAA,eAAsCf,QAC5CQ,QAAS,SAKVQ,SAAUV,QAIVW,UAAWX,QAIXY,WAAYZ,QAIZa,YAAab,QAIbc,QAASd,QAITe,YAAa,CACZlB,KAAMH,OACNQ,QAAS,IAKVc,cAAe,CACdnB,KAAMY,EAAAA,eAAiCR,QACvCC,QAASA,MAAyB,IAKnCe,OAAQjB,QAIRkB,YAAaxB,OAIbyB,YAAazB,OAIb0B,WAAY1B,OAIZ2B,aAAcC,SAIdC,aAAcD,SAIdE,SAAUxB,QAIVyB,cAAe,CACd5B,KAAME,OACNG,QAAS,GAKVwB,YAAa,CACZ7B,KAAMH,QAKPiC,mBAAoB3B,QAIpB4B,eAAgB,CACf/B,KAAMG,QACNE,SAAS,GAKV2B,SAAU,CACThC,KAAMH,OACNQ,QAAS,SAKV4B,aAAc9B,QAId+B,oBAAqB/B,QAIrBgC,gBAAiB,CAChBnC,KAAME,OACNG,QAAS,GAKV+B,WAAYC,EAAAA,uBAAuBD,WAInCE,WAAY,CACXtC,KAAMG,QACNE,SAAS,GAKVkC,UAAW,CACVvC,KAAMY,EAAAA,eAAmC,CAACf,OAAQO,OAAQqB,WAC1DpB,QAASmC,EAAAA,aAKVC,cAAetC,QAIfuC,WAAY,CACX1C,KAAMY,EAAAA,eAAmC,CAACf,OAAQO,OAAQqB,WAC1DpB,QAASsC,EAAAA,WAMVC,QAAS,IAAKC,EAAAA,SAAS7C,KAAMK,QAAS,QAItCyC,UAAW,IAAKD,EAAAA,SAASlC,OAAQN,QAAS,SAI1C0C,cAAe,CACd/C,KAAMG,QACNE,SAAS,GAKV2C,iBAAkB7C,QAIlB8C,UAAW,CACVjD,KAAMY,EAAAA,eAA0Bf,QAChCQ,QAAS,gBAKV6C,mBAAoB,CACnBlD,KAAMY,EAAAA,eAA4BX,OAClCI,QAAS,CAAC,eAAgB,YAAa,QAAS,YAE9C8C,EAAAA,uBACAC,EAAAA,aAAa,CAAC,eAcLC,EAAgB,IACzB1D,EAEHkB,SAAU,CACTb,KAAMG,QACNE,aAASC,GAGVe,YAAa,CACZrB,KAAMH,OACNQ,QAAS,UAGViB,YAAa,CACZtB,KAAMH,OACNQ,QAAS,WAGVkB,WAAY,CACXvB,KAAMH,OACNQ,QAAS,QAGV4B,aAAc,CACbjC,KAAMG,QACNE,SAAS,GAGV6B,oBAAqB,CACpBlC,KAAMG,QACNE,SAAS,GAGVN,WAAY,CACXC,KAAMY,EAAAA,eAA4F,CAACf,OAAQK,OAAQC,QAASC,OAAQH,QACpII,aAASC,GAGVgD,MAAO1C,EAAAA,eAAkC,CAACf,OAAQI,QAElDsD,MAAO,CACNvD,KAAM,CAACH,OAAQK,QACfG,QAAS,QAGVmD,WAAYrD,QAEZsD,KAAM,CACLzD,KAAMG,QACNE,SAAS,GAGVqD,gBAAiBvD,QAEjBwD,MAAO,CACN3D,KAAMY,EAAAA,eAAqCR,QAC3CC,QAASA,KAAAA,CACRiD,MAAO,QACPM,KAAM,OACN/C,SAAU,WACVgD,SAAU,cAIZC,KAAM,CACL9D,KAAMY,EAAAA,eAAmCX,OACzCI,QAASA,IAA0B,IAGpC0D,WAAY,CACX/D,KAAMY,EAAAA,eAA8Da,WAGrEuC,UAAWpD,EAAAA,eAAsC,CAACf,OAAQK,OAAQE,UAGtD6D,EAAgB,IACzBC,EAAAA,YAEH,oBAAsBC,GACrBC,WAASD,IAAUE,EAAAA,SAASF,IAAUG,EAAAA,UAAUH,IAAUI,EAAAA,SAASJ,IAAUK,EAAAA,QAAQL,IAAUM,EAAAA,OAAON,GAEvG,eAAiBA,GAAsCC,EAAAA,SAASD,IAAUK,EAAAA,QAAQL,IAAUM,EAAAA,OAAON,GAEnGO,mBAAqBZ,GAA8CU,EAAAA,QAAQV,GAE3Ea,OAAQA,CACPb,EACAK,KACa,GAsBfS,oBAA+B,CAC9BhF,KAAM,WACN+D,MAAON,EACPwB,MAAOZ,EACPa,MAAOC,EAAAA,YACPC,KAAAA,CAAMrB,GAAOsB,MAAEA,EAAAA,MAAOH,EAAAA,KAAOI,EAAAA,OAAMC,IAClC,MAAMC,EAAgBC,EAAAA,UAAU1B,EAAO,QAASuB,EAAM,CAAEI,SAAS,IAC3DC,EAAcC,EAAAA,gBAEdC,EAAQC,EAAAA,SAAS,CACtBvB,MAAOwB,EAAAA,iBACP1E,SAAS,EACT2E,aAAcD,EAAAA,eAAmC,IAEjDE,OAAO,EAEPC,OAAMnC,EAAMG,MAAMiC,OAAS,GAE3BC,aAAa,IAGRC,EAAYC,EAAAA,MAEZC,EAAcrC,GACZA,GACJsC,IAAKC,IAAAA,IACHA,EACHlC,MAAOkC,EAAE1C,EAAM3B,UACfsB,MAAOgD,EAAAA,WAAW3C,EAAMA,MAAML,OAASK,EAAMA,MAAML,MAAM+C,GAAKA,EAAE1C,EAAMA,MAAML,OAAS,SACrFM,KAAM0C,EAAAA,WAAW3C,EAAMA,MAAMC,MAAQD,EAAMA,MAAMC,KAAKyC,GAAKA,EAAE1C,EAAMA,MAAMC,MAAQ,QACjF/C,SAAUyF,EAAAA,WAAW3C,EAAMA,MAAM9C,UAAY8C,EAAMA,MAAM9C,SAASwF,GAAKA,EAAE1C,EAAMA,MAAM9C,UAAY,YACjGgD,SAAUyC,EAAAA,WAAW3C,EAAMA,MAAME,UAC9BsC,EAAWxC,EAAMA,MAAME,SAASwC,IAChCF,EAAWE,EAAE1C,EAAMA,MAAME,UAAY,gBAExC0C,OAAQC,IAAOA,EAAE5C,MAGd6C,EAAWC,UAEhB,GAAI/C,EAAMI,WAAY,CACrB0B,EAAMxE,SAAU,EAChB,MAAM0F,EAAShD,EAAMK,WAAa,CAAA,EAClC,IACC,MAAM4C,QAAgBjD,EAAMI,WAAW4C,GAEvClB,EAAMK,MAAO,EACbL,EAAMG,aAAeO,EAAWS,GAChC1B,EAAK,qBAAsBO,EAAMG,aAClC,OAASiB,GACRC,EAAAA,aAAa,WAAYD,GACzBpB,EAAMG,aAAe,EACtB,CAAA,QACCH,EAAMxE,SAAU,CACjB,CACD,MAECwE,EAAMK,MAAO,EACbL,EAAMG,aAAeO,EAAWxC,EAAMG,OAIlCiD,EAAgB5C,IAErB,GAAIR,EAAMhC,SAAU,CAEnB,MAAMqF,EAAW7C,EACjB,GAAyB,IAArB6C,GAAUjB,OAKb,OAJAN,EAAMtB,MAAQ,KACdiB,EAAcjB,MAAQ,KACtBe,EAAK,oBAAqB,WAC1BA,EAAK,SAAU,KAAM,MAGtB,MAAM+B,EAAWxB,EAAMG,aAAaW,UAAcS,EAASE,SAASV,EAAErC,QACtEsB,EAAMtB,MAAQA,EACdiB,EAAcjB,MAAQ8C,EAASb,IAAKC,GAAMA,EAAE/C,OAC5C4B,EAAK,oBAAqBf,GAC1Be,EAAK,SAAU+B,EAAU9C,EAC1B,KAAO,CAEN,GAAIgD,EAAAA,MAAMhD,GAKT,OAJAsB,EAAMtB,MAAQ,KACdiB,EAAcjB,MAAQ,KACtBe,EAAK,oBAAqB,WAC1BA,EAAK,SAAU,KAAM,MAGtB,MAAMpB,EAAO2B,EAAMG,aAAawB,KAAMZ,GAAMA,EAAErC,QAAUA,GACxDsB,EAAMtB,MAAQA,EACdiB,EAAcjB,MAAQL,EAAKR,MAC3B4B,EAAK,oBAAqBf,GAC1Be,EAAK,SAAUpB,EAAMK,EACtB,GAGKkD,EAAcA,KACnB5B,EAAMtB,MAAQ,KACdiB,EAAcjB,MAAQ,KACtBe,EAAK,oBAAqB,MAC1BA,EAAK,UAGAoC,EAAsBZ,MAAOa,IAC9BA,IACC9B,EAAMI,OAETJ,EAAMI,OAAQ,GAEblC,EAAMD,iBAAmBC,EAAMF,YAAegD,KAG3ChB,EAAMO,cACTP,EAAMO,aAAc,QACdS,MAITvB,EAAK,iBAAkBqC,IAGxBC,EAAAA,MACC,IAAM7D,EAAM5D,WACX0H,IACA,GAAIhC,EAAMK,OAASqB,EAAAA,MAAMM,GAAW,CACnC,MAAMC,GAAYP,QAAMxD,EAAML,OAE9B,GAAIK,EAAMhC,SAAU,CAEnB,IAAK6C,EAAAA,QAAQiD,GAEZ,YADAX,EAAAA,aAAa,WAAY,2CAG1B,GAAIY,IAAalD,EAAAA,QAAQb,EAAML,OAE9B,YADAwD,EAAAA,aAAa,WAAY,iDAG1BrB,EAAMG,aAAe6B,EAEnBE,MAAM,EAAGhE,EAAM/B,cAAgB,EAAI+B,EAAM/B,cAAgB6F,EAAS1B,QAClEK,IAAI,CAACwB,EAAMC,KAAAA,CACX1D,MAAOyD,EACPtE,MAAOoE,EAAW/D,EAAML,MAAMuE,QAASvH,IAE1C,KAAO,CACN,GAAIkE,EAAAA,QAAQiD,GAEX,YADAX,EAAAA,aAAa,WAAY,2CAG1B,GAAIY,GAAYlD,EAAAA,QAAQb,EAAML,OAE7B,YADAwD,EAAAA,aAAa,WAAY,iDAG1BrB,EAAMG,aAAe,CACpB,CACCzB,MAAOsD,EACPnE,MAAOK,EAAML,OAGhB,CACD,CACAmC,EAAMtB,MAAQsD,GAEf,CACCK,WAAW,IAIbC,EAAAA,UAAUrB,UACL/C,EAAMD,uBACH+C,IACFhB,EAAMG,aAAaG,OAAS,GAC/BgB,EAAapD,EAAMhC,SAAW,CAAC8D,EAAMG,aAAa,GAAGzB,OAASsB,EAAMG,aAAa,GAAGzB,SAI5ER,EAAMI,YAAcJ,EAAMG,MAAMiC,OAAS,GAClDN,EAAMI,OAAQ,QACRY,KAGG9C,EAAMF,YACTgD,IAEPe,EAAAA,MACC,IAAM7D,EAAMK,UACZ,CAACyD,EAAUO,KACLC,EAAAA,QAAQR,EAAUO,KACtBvC,EAAMO,aAAc,EACfmB,EAAAA,MAAM1B,EAAMtB,QAChB4C,OAKJS,QACC,IAAM7D,EAAMG,KACZ4C,UACM/C,EAAMI,kBACJ0C,KAGR,CAAEyB,MAAM,MAIV,MAAMC,EAAgBC,EAAAA,SAASzE,EAAOhE,EAAa,CAAC,aAAc,cAAe,YAC3E0I,EAAgBC,WAASpE,EAAAA,YAAagB,EAAM,CAAC,oBAAqB,SAAU,QAAS,mBACrFqD,EAAgBC,EAAAA,SAAS,KAC9B,IAAIC,EAAa,sBAAsB9E,EAAMzC,cAI7C,OAHIyC,EAAMH,aACTiF,GAAc,oEAAoElD,EAAYpB,SAExFsE,IAoCR,OAjCAC,YAAU,IAAAC,EAAAA,YAAAC,WAAAC,EAAAA,WAEJV,EAAchE,MACdkE,EAAclE,MAAK,CAAA+B,IAClBD,EAAS6C,MAAA,YAAA5H,YAEDqH,EAAcpE,MAAK4E,MACzB,CAAExF,MAAOyF,EAAAA,QAAQrF,EAAMJ,QAAQxD,WAC9B0F,EAAMtB,MAAK,sBAAA8E,GAAXxD,EAAMtB,MAAK8E,EAAAhI,QACVwE,EAAMxE,QAAOiI,SACZnC,EAAYoC,QACb9B,EAAW+B,gBACH9B,IAAmB,CAGnCjH,QAASA,IACRoF,EAAMG,aAAaQ,IAAKwB,GAAIe,EAAAA,YAAAU,UAAA,CAAAvF,KAC+B8D,EAAIpE,WAAcG,EAAMH,YAA1D,CAAEnD,QAASyE,EAAMzE,cAEvCyE,EAAMwE,QAAU,CAAEA,OAAQA,IAAexE,EAAMwE,aAC/CxE,EAAMyE,QAAU,CAAEA,OAAQA,IAAezE,EAAMyE,aAC/CzE,EAAM0E,QAAU,CAAEA,OAAQA,IAAe1E,EAAM0E,aAC/C1E,EAAM2E,OAAS,CAAEA,MAAOA,IAAe3E,EAAM2E,YAC7C3E,EAAM4E,KAAO,CAAEA,IAAKA,IAAe5E,EAAM4E,UACzC5E,EAAM7D,SAAW,CAAEA,QAASA,IAAe6D,EAAM7D,cACjD6D,EAAMxB,OAAS,CAClBA,MAAOA,EAAGA,QAAOa,WAChBW,EAAMxB,MAAM,CAAEA,QAAOa,cAMnBwF,EAAAA,UAAUxE,EAAQ,CAExByE,MAAOpB,EAAAA,SAAS,IAAMvC,EAAU9B,OAAOyF,OAEvCC,KAAMrB,EAAAA,SAAS,IAAMvC,EAAU9B,OAAO0F,MAEtCzE,cAAeoD,EAAAA,SAAS,IAAMvC,EAAU9B,OAAOiB,eAE/CnE,QAASuH,EAAAA,SAAS,IAAM/C,EAAMxE,SAE9B6I,QAASrD,EAETsD,aAAe5F,GAAuF4C,EAAa5C,GAEnH6F,eAAgBA,IAAMjD,EAAa,OAErC"}
|
|
1
|
+
{"version":3,"file":"select.js","names":["computed","defineComponent","onMounted","reactive","ref","watch","createVNode","_createVNode","mergeProps","_mergeProps","ElSelect","selectEmits","tagProps","useAriaProps","useEmptyValuesProps","useGlobalSize","useSizeProp","useTooltipContentProps","ArrowDown","CircleClose","addUnit","consoleError","definePropType","makeSlots","useEmits","useExpose","useProps","useRender","withDefineType","useVModel","isArray","isBoolean","isEqual","isFunction","isNil","isNull","isNumber","isObject","isString","FaSelectOption","SelectProps","name","String","id","modelValue","type","Array","Number","Boolean","Object","default","undefined","autocomplete","automaticDropdown","size","effect","disabled","clearable","filterable","allowCreate","loading","popperClass","popperOptions","remote","loadingText","noMatchText","noDataText","remoteMethod","Function","filterMethod","multiple","multipleLimit","placeholder","defaultFirstOption","reserveKeyword","valueKey","collapseTags","collapseTagsTooltip","maxCollapseTags","teleported","persistent","clearIcon","fitInputWidth","suffixIcon","tagType","tagEffect","validateEvent","remoteShowSuffix","placement","fallbackPlacements","faSelectProps","label","width","moreDetail","lazy","defaultSelected","props","hide","children","data","requestApi","initParam","faSelectEmits","value","dataChangeCallBack","change","emits","slots","setup","attrs","emit","expose","selectedLabel","passive","_globalSize","state","selectorData","debut","echo","length","nextRefresh","selectRef","handleData","map","m","filter","f","loadData","params","resData","error","handleChange","valueArr","dataList","includes","find","handleClear","handleVisibleChange","visible","newValue","hasLabel","slice","item","index","immediate","oldValue","deep","elSelectProps","elSelectEmits","elPopperClass","localClass","$event","header","footer","prefix","empty","tag","focus","blur","refresh","setSelection","clearSelection"],"sources":["../../../../../packages/components/select/src/select.tsx"],"sourcesContent":["import { computed, defineComponent, onMounted, reactive, ref, watch } from \"vue\";\nimport { ElSelect, selectEmits, tagProps, useAriaProps, useEmptyValuesProps, useGlobalSize, useSizeProp, useTooltipContentProps } from \"element-plus\";\nimport { ArrowDown, CircleClose } from \"@element-plus/icons-vue\";\nimport { addUnit, consoleError, definePropType, makeSlots, useEmits, useExpose, useProps, useRender, withDefineType } from \"@fast-china/utils\";\nimport { useVModel } from \"@vueuse/core\";\nimport { isArray, isBoolean, isEqual, isFunction, isNil, isNull, isNumber, isObject, isString } from \"lodash-unified\";\nimport FaSelectOption from \"./selectOption\";\nimport type { ElSelectorOutput } from \"./select.type\";\nimport type { Options, Placement, PopperEffect } from \"element-plus\";\nimport type { Component, VNode } from \"vue\";\n\nexport const SelectProps = {\n\t/**\n\t * @description the name attribute of select input\n\t */\n\tname: String,\n\t/**\n\t * @description native input id\n\t */\n\tid: String,\n\t/**\n\t * @description binding value\n\t */\n\tmodelValue: {\n\t\ttype: [Array, String, Number, Boolean, Object],\n\t\tdefault: undefined,\n\t},\n\t/**\n\t * @description the autocomplete attribute of select input\n\t */\n\tautocomplete: {\n\t\ttype: String,\n\t\tdefault: \"off\",\n\t},\n\t/**\n\t * @description for non-filterable Select, this prop decides if the option menu pops up when the input is focused\n\t */\n\tautomaticDropdown: Boolean,\n\t/**\n\t * @description size of Input\n\t */\n\tsize: useSizeProp,\n\t/**\n\t * @description tooltip theme, built-in theme: `dark` / `light`\n\t */\n\teffect: {\n\t\ttype: definePropType<PopperEffect | string>(String),\n\t\tdefault: \"light\",\n\t},\n\t/**\n\t * @description whether Select is disabled\n\t */\n\tdisabled: Boolean,\n\t/**\n\t * @description whether select can be cleared\n\t */\n\tclearable: Boolean,\n\t/**\n\t * @description whether Select is filterable\n\t */\n\tfilterable: Boolean,\n\t/**\n\t * @description whether creating new items is allowed. To use this, `filterable` must be true\n\t */\n\tallowCreate: Boolean,\n\t/**\n\t * @description whether Select is loading data from server\n\t */\n\tloading: Boolean,\n\t/**\n\t * @description custom class name for Select's dropdown\n\t */\n\tpopperClass: {\n\t\ttype: String,\n\t\tdefault: \"\",\n\t},\n\t/**\n\t * @description [popper.js](https://popper.js.org/docs/v2/) parameters\n\t */\n\tpopperOptions: {\n\t\ttype: definePropType<Partial<Options>>(Object),\n\t\tdefault: (): Partial<Options> => ({}),\n\t},\n\t/**\n\t * @description whether options are loaded from server\n\t */\n\tremote: Boolean,\n\t/**\n\t * @description displayed text while loading data from server, default is 'Loading'\n\t */\n\tloadingText: String,\n\t/**\n\t * @description displayed text when no data matches the filtering query, you can also use slot `empty`, default is 'No matching data'\n\t */\n\tnoMatchText: String,\n\t/**\n\t * @description displayed text when there is no options, you can also use slot `empty`, default is 'No data'\n\t */\n\tnoDataText: String,\n\t/**\n\t * @description custom remote search method\n\t */\n\tremoteMethod: Function,\n\t/**\n\t * @description custom filter method\n\t */\n\tfilterMethod: Function,\n\t/**\n\t * @description whether multiple-select is activated\n\t */\n\tmultiple: Boolean,\n\t/**\n\t * @description maximum number of options user can select when `multiple` is `true`. No limit when set to 0\n\t */\n\tmultipleLimit: {\n\t\ttype: Number,\n\t\tdefault: 0,\n\t},\n\t/**\n\t * @description placeholder, default is 'Select'\n\t */\n\tplaceholder: {\n\t\ttype: String,\n\t},\n\t/**\n\t * @description select first matching option on enter key. Use with `filterable` or `remote`\n\t */\n\tdefaultFirstOption: Boolean,\n\t/**\n\t * @description when `multiple` and `filter` is true, whether to reserve current keyword after selecting an option\n\t */\n\treserveKeyword: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/**\n\t * @description unique identity key name for value, required when value is an object\n\t */\n\tvalueKey: {\n\t\ttype: String,\n\t\tdefault: \"value\",\n\t},\n\t/**\n\t * @description whether to collapse tags to a text when multiple selecting\n\t */\n\tcollapseTags: Boolean,\n\t/**\n\t * @description whether show all selected tags when mouse hover text of collapse-tags. To use this, `collapse-tags` must be true\n\t */\n\tcollapseTagsTooltip: Boolean,\n\t/**\n\t * @description the max tags number to be shown. To use this, `collapse-tags` must be true\n\t */\n\tmaxCollapseTags: {\n\t\ttype: Number,\n\t\tdefault: 1,\n\t},\n\t/**\n\t * @description whether select dropdown is teleported to the body\n\t */\n\tteleported: useTooltipContentProps.teleported,\n\t/**\n\t * @description when select dropdown is inactive and `persistent` is `false`, select dropdown will be destroyed\n\t */\n\tpersistent: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/**\n\t * @description custom clear icon component\n\t */\n\tclearIcon: {\n\t\ttype: definePropType<string | Component>([String, Object, Function]),\n\t\tdefault: CircleClose,\n\t},\n\t/**\n\t * @description whether the width of the dropdown is the same as the input\n\t */\n\tfitInputWidth: Boolean,\n\t/**\n\t * @description custom suffix icon component\n\t */\n\tsuffixIcon: {\n\t\ttype: definePropType<string | Component>([String, Object, Function]),\n\t\tdefault: ArrowDown,\n\t},\n\t/**\n\t * @description tag type\n\t */\n\n\ttagType: { ...tagProps.type, default: \"info\" },\n\t/**\n\t * @description tag effect\n\t */\n\ttagEffect: { ...tagProps.effect, default: \"light\" },\n\t/**\n\t * @description whether to trigger form validation\n\t */\n\tvalidateEvent: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/**\n\t * @description in remote search method show suffix icon\n\t */\n\tremoteShowSuffix: Boolean,\n\t/**\n\t * @description position of dropdown\n\t */\n\tplacement: {\n\t\ttype: definePropType<Placement>(String),\n\t\tdefault: \"bottom-start\",\n\t},\n\t/**\n\t * @description list of possible positions for dropdown\n\t */\n\tfallbackPlacements: {\n\t\ttype: definePropType<Placement[]>(Array),\n\t\tdefault: [\"bottom-start\", \"top-start\", \"right\", \"left\"],\n\t},\n\t...useEmptyValuesProps,\n\t...useAriaProps([\"ariaLabel\"]),\n};\n\nexport type SelectComponentProps = {\n\t/** @description 指定标签为节点的某个属性值 */\n\tlabel?: string | ((data: any) => string);\n\t/** @description 指定是否隐藏为节点的某个属性值 */\n\thide?: string | ((data: any) => boolean);\n\t/** @description 指定是否禁用为节点的某个属性值 */\n\tdisabled?: string | ((data: any) => boolean);\n\t/** @description 指定子节点对象为节点的某个属性值 */\n\tchildren?: string;\n};\n\nexport const faSelectProps = {\n\t...SelectProps,\n\t/** @description whether Select is disabled 重载使其支持 ElForm*/\n\tdisabled: {\n\t\ttype: Boolean,\n\t\tdefault: undefined,\n\t},\n\t/** @description displayed text while loading data from server, default is 'Loading' */\n\tloadingText: {\n\t\ttype: String,\n\t\tdefault: \"加载中...\",\n\t},\n\t/** @description displayed text when no data matches the filtering query, you can also use slot `empty`, default is 'No matching data' */\n\tnoMatchText: {\n\t\ttype: String,\n\t\tdefault: \"暂无匹配的数据\",\n\t},\n\t/** @description displayed text when there is no options, you can also use slot `empty`, default is 'No data' */\n\tnoDataText: {\n\t\ttype: String,\n\t\tdefault: \"暂无数据\",\n\t},\n\t/** @description whether to collapse tags to a text when multiple selecting */\n\tcollapseTags: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description whether show all selected tags when mouse hover text of collapse-tags. To use this, `collapse-tags` must be true */\n\tcollapseTagsTooltip: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description v-model绑定值 */\n\tmodelValue: {\n\t\ttype: definePropType<string | number | boolean | object | (string | number | boolean | object)[]>([String, Number, Boolean, Object, Array]),\n\t\tdefault: undefined,\n\t},\n\t/** @description v-model:label绑定值 */\n\tlabel: definePropType<string | string[]>([String, Array]),\n\t/** @description 宽度 */\n\twidth: {\n\t\ttype: [String, Number],\n\t\tdefault: \"100%\",\n\t},\n\t/** @description 更多细节,只有使用slot的时候有用 */\n\tmoreDetail: Boolean,\n\t/** @description 懒加载远程数据,默认 true。当下拉框第一次显示的时候才会加载远程数据*/\n\tlazy: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description 默认选中。不能和懒加载一起使用 */\n\tdefaultSelected: Boolean,\n\t/** @description 配置选项 */\n\tprops: {\n\t\ttype: definePropType<SelectComponentProps>(Object),\n\t\tdefault: (): Partial<SelectComponentProps> => ({\n\t\t\tlabel: \"label\",\n\t\t\thide: \"hide\",\n\t\t\tdisabled: \"disabled\",\n\t\t\tchildren: \"children\",\n\t\t}),\n\t},\n\t/** @description 下拉框数据 */\n\tdata: {\n\t\ttype: definePropType<ElSelectorOutput[]>(Array),\n\t\tdefault: (): ElSelectorOutput[] => [],\n\t},\n\t/** @description 请求api */\n\trequestApi: {\n\t\ttype: definePropType<(params?: any) => Promise<ElSelectorOutput[]>>(Function),\n\t},\n\t/** 初始化参数 */\n\tinitParam: definePropType<string | number | any>([String, Number, Object]),\n};\n\nexport const faSelectEmits = {\n\t...selectEmits,\n\t/** @description v-model 回调 */\n\t\"update:modelValue\": (value: string | number | boolean | object | (string | number | boolean | object)[]): boolean =>\n\t\tisString(value) || isNumber(value) || isBoolean(value) || isObject(value) || isArray(value) || isNull(value),\n\t/** @description v-model:label 回调 */\n\t\"update:label\": (value: string | string[]): boolean => isString(value) || isArray(value) || isNull(value),\n\t/** @description 数据改变 */\n\tdataChangeCallBack: (data: ElSelectorOutput[] | any[]): boolean => isArray(data),\n\t/** @description 改变 */\n\tchange: (\n\t\tdata: ElSelectorOutput | ElSelectorOutput[] | any | any[],\n\t\tvalue?: string | number | boolean | object | (string | number | boolean | object)[]\n\t): boolean => true,\n};\n\ntype FaSelectSlots = {\n\t/** @description FaSelectOption 默认内容插槽 */\n\tdefault: ElSelectorOutput;\n\t/** @description 下拉列表顶部的内容 */\n\theader: never;\n\t/** @description 下拉列表底部的内容 */\n\tfooter: never;\n\t/** @description Select 组件头部内容 */\n\tprefix: never;\n\t/** @description 无选项时的列表 */\n\tempty: never;\n\t/** @description select 组件自定义标签内容 */\n\ttag: never;\n\t/** @description select 组件自定义 loading内容 */\n\tloading: never;\n\t/** @description select 组件自定义标签内容 */\n\tlabel: { label: string; value: string | number | boolean | object };\n};\n\nexport default defineComponent({\n\tname: \"FaSelect\",\n\tprops: faSelectProps,\n\temits: faSelectEmits,\n\tslots: makeSlots<FaSelectSlots>(),\n\tsetup(props, { attrs, slots, emit, expose }) {\n\t\tconst selectedLabel = useVModel(props, \"label\", emit, { passive: true });\n\t\tconst _globalSize = useGlobalSize();\n\n\t\tconst state = reactive({\n\t\t\tvalue: withDefineType<string | number | boolean | object | (string | number | boolean | object)[]>(),\n\t\t\tloading: false,\n\t\t\tselectorData: withDefineType<ElSelectorOutput[]>([]),\n\t\t\t/** 首次出现 */\n\t\t\tdebut: true,\n\t\t\t/** 回显 */\n\t\t\techo: props.data?.length > 0 ? false : true,\n\t\t\t/** 下次刷新 */\n\t\t\tnextRefresh: false,\n\t\t});\n\n\t\tconst selectRef = ref<InstanceType<typeof ElSelect>>();\n\n\t\tconst handleData = (data: ElSelectorOutput[]): ElSelectorOutput[] => {\n\t\t\treturn data\n\t\t\t\t?.map((m) => ({\n\t\t\t\t\t...m,\n\t\t\t\t\tvalue: m[props.valueKey],\n\t\t\t\t\tlabel: isFunction(props.props.label) ? props.props.label(m) : m[props.props.label ?? \"label\"],\n\t\t\t\t\thide: isFunction(props.props.hide) ? props.props.hide(m) : m[props.props.hide ?? \"hide\"],\n\t\t\t\t\tdisabled: isFunction(props.props.disabled) ? props.props.disabled(m) : m[props.props.disabled ?? \"disabled\"],\n\t\t\t\t\tchildren: isFunction(props.props.children)\n\t\t\t\t\t\t? handleData(props.props.children(m))\n\t\t\t\t\t\t: handleData(m[props.props.children ?? \"children\"]),\n\t\t\t\t}))\n\t\t\t\t.filter((f) => !f.hide);\n\t\t};\n\n\t\tconst loadData = async (): Promise<void> => {\n\t\t\t// 判断是否需要自动请求\n\t\t\tif (props.requestApi) {\n\t\t\t\tstate.loading = true;\n\t\t\t\tconst params = props.initParam ?? {};\n\t\t\t\ttry {\n\t\t\t\t\tconst resData = await props.requestApi(params);\n\t\t\t\t\t// 这里不允许回显了\n\t\t\t\t\tstate.echo = false;\n\t\t\t\t\tstate.selectorData = handleData(resData);\n\t\t\t\t\temit(\"dataChangeCallBack\", state.selectorData);\n\t\t\t\t} catch (error) {\n\t\t\t\t\tconsoleError(\"FaSelect\", error);\n\t\t\t\t\tstate.selectorData = [];\n\t\t\t\t} finally {\n\t\t\t\t\tstate.loading = false;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t// 这里不允许回显了\n\t\t\t\tstate.echo = false;\n\t\t\t\tstate.selectorData = handleData(props.data);\n\t\t\t}\n\t\t};\n\n\t\tconst handleChange = (value?: string | number | boolean | object | (string | number | boolean | object)[]): void => {\n\t\t\t// 判断是否为多选\n\t\t\tif (props.multiple) {\n\t\t\t\t// value 必然是数组\n\t\t\t\tconst valueArr = value as (string | number | boolean | object)[];\n\t\t\t\tif (valueArr?.length === 0) {\n\t\t\t\t\tstate.value = null;\n\t\t\t\t\tselectedLabel.value = null;\n\t\t\t\t\temit(\"update:modelValue\", null);\n\t\t\t\t\temit(\"change\", null, null);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tconst dataList = state.selectorData.filter((f) => valueArr.includes(f.value));\n\t\t\t\tstate.value = value;\n\t\t\t\tselectedLabel.value = dataList.map((m) => m.label);\n\t\t\t\temit(\"update:modelValue\", value);\n\t\t\t\temit(\"change\", dataList, value);\n\t\t\t} else {\n\t\t\t\t// value 必然不是数组\n\t\t\t\tif (isNil(value)) {\n\t\t\t\t\tstate.value = null;\n\t\t\t\t\tselectedLabel.value = null;\n\t\t\t\t\temit(\"update:modelValue\", null);\n\t\t\t\t\temit(\"change\", null, null);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tconst data = state.selectorData.find((f) => f.value === value);\n\t\t\t\tstate.value = value;\n\t\t\t\tselectedLabel.value = data.label;\n\t\t\t\temit(\"update:modelValue\", value);\n\t\t\t\temit(\"change\", data, value);\n\t\t\t}\n\t\t};\n\n\t\tconst handleClear = (): void => {\n\t\t\tstate.value = null;\n\t\t\tselectedLabel.value = null;\n\t\t\temit(\"update:modelValue\", null);\n\t\t\temit(\"clear\");\n\t\t};\n\n\t\tconst handleVisibleChange = async (visible: boolean): Promise<void> => {\n\t\t\tif (visible) {\n\t\t\t\tif (state.debut) {\n\t\t\t\t\t// 首次出现\n\t\t\t\t\tstate.debut = false;\n\t\t\t\t\t// 懒加载\n\t\t\t\t\t!props.defaultSelected && props.lazy && (await loadData());\n\t\t\t\t} else {\n\t\t\t\t\t// 判断再次出现是否需要刷新数据\n\t\t\t\t\tif (state.nextRefresh) {\n\t\t\t\t\t\tstate.nextRefresh = false;\n\t\t\t\t\t\tawait loadData();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\temit(\"visible-change\", visible);\n\t\t};\n\n\t\twatch(\n\t\t\t() => props.modelValue,\n\t\t\t(newValue) => {\n\t\t\t\tif (state.echo && !isNil(newValue)) {\n\t\t\t\t\tconst hasLabel = !isNil(props.label);\n\t\t\t\t\t// 判断是否为多选\n\t\t\t\t\tif (props.multiple) {\n\t\t\t\t\t\t// 判断是否为数组\n\t\t\t\t\t\tif (!isArray(newValue)) {\n\t\t\t\t\t\t\tconsoleError(\"FaSelect\", \"当启用 multiple 时,传入的 modelValue 必须是Array。\");\n\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif (hasLabel && !isArray(props.label)) {\n\t\t\t\t\t\t\tconsoleError(\"FaSelect\", \"当启用 multiple 时,传入的 modelValue:label 必须是Array。\");\n\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tstate.selectorData = newValue\n\t\t\t\t\t\t\t// 最大选项截取\n\t\t\t\t\t\t\t.slice(0, props.multipleLimit > 0 ? props.multipleLimit : newValue.length)\n\t\t\t\t\t\t\t.map((item, index) => ({\n\t\t\t\t\t\t\t\tvalue: item,\n\t\t\t\t\t\t\t\tlabel: hasLabel ? props.label[index] : undefined,\n\t\t\t\t\t\t\t}));\n\t\t\t\t\t} else {\n\t\t\t\t\t\tif (isArray(newValue)) {\n\t\t\t\t\t\t\tconsoleError(\"FaSelect\", \"当禁用 multiple 时,传入的 modelValue 不能是Array。\");\n\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif (hasLabel && isArray(props.label)) {\n\t\t\t\t\t\t\tconsoleError(\"FaSelect\", \"当禁用 multiple 时,传入的 modelValue:label 不能是Array。\");\n\t\t\t\t\t\t\treturn;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tstate.selectorData = [\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tvalue: newValue,\n\t\t\t\t\t\t\t\tlabel: props.label,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t];\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tstate.value = newValue;\n\t\t\t},\n\t\t\t{\n\t\t\t\timmediate: true,\n\t\t\t}\n\t\t);\n\n\t\tonMounted(async () => {\n\t\t\tif (props.defaultSelected) {\n\t\t\t\tawait loadData();\n\t\t\t\tif (state.selectorData.length > 0) {\n\t\t\t\t\thandleChange(props.multiple ? [state.selectorData[0].value] : state.selectorData[0].value);\n\t\t\t\t}\n\t\t\t}\n\t\t\t// 判断是否为本地数据\n\t\t\telse if (!props.requestApi && props.data?.length > 0) {\n\t\t\t\tstate.debut = false;\n\t\t\t\tawait loadData();\n\t\t\t}\n\t\t\t// 判断是否非默认选中,且未启用懒加载\n\t\t\telse if (!props.lazy) {\n\t\t\t\tawait loadData();\n\t\t\t}\n\t\t\twatch(\n\t\t\t\t() => props.initParam,\n\t\t\t\t(newValue, oldValue) => {\n\t\t\t\t\tif (!isEqual(newValue, oldValue)) {\n\t\t\t\t\t\tstate.nextRefresh = true;\n\t\t\t\t\t\tif (!isNil(state.value)) {\n\t\t\t\t\t\t\thandleChange();\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\twatch(\n\t\t\t\t() => props.data,\n\t\t\t\tasync () => {\n\t\t\t\t\tif (!props.requestApi) {\n\t\t\t\t\t\tawait loadData();\n\t\t\t\t\t}\n\t\t\t\t},\n\t\t\t\t{ deep: true }\n\t\t\t);\n\t\t});\n\n\t\tconst elSelectProps = useProps(props, SelectProps, [\"modelValue\", \"popperClass\", \"loading\"]);\n\t\tconst elSelectEmits = useEmits(selectEmits, emit, [\"update:modelValue\", \"change\", \"clear\", \"visible-change\"]);\n\t\tconst elPopperClass = computed(() => {\n\t\t\tlet localClass = `fa-select-dropdown ${props.popperClass}`;\n\t\t\tif (props.moreDetail) {\n\t\t\t\tlocalClass += ` fa-select-dropdown__more-detail fa-select-dropdown__more-detail-${_globalSize.value}`;\n\t\t\t}\n\t\t\treturn localClass;\n\t\t});\n\n\t\tuseRender(() => (\n\t\t\t<ElSelect\n\t\t\t\t{...elSelectProps.value}\n\t\t\t\t{...elSelectEmits.value}\n\t\t\t\tref={selectRef}\n\t\t\t\tclass=\"fa-select\"\n\t\t\t\tpopperClass={elPopperClass.value}\n\t\t\t\tstyle={{ width: addUnit(props.width) }}\n\t\t\t\tvModel={state.value}\n\t\t\t\tloading={state.loading}\n\t\t\t\tonChange={handleChange}\n\t\t\t\tonClear={handleClear}\n\t\t\t\tonVisibleChange={handleVisibleChange}\n\t\t\t>\n\t\t\t\t{{\n\t\t\t\t\tdefault: (): VNode[] =>\n\t\t\t\t\t\tstate.selectorData.map((item) => (\n\t\t\t\t\t\t\t<FaSelectOption vSlots={{ default: slots.default }} data={item} moreDetail={props.moreDetail} />\n\t\t\t\t\t\t)),\n\t\t\t\t\t...(slots.header && { header: (): VNode[] => slots.header() }),\n\t\t\t\t\t...(slots.footer && { footer: (): VNode[] => slots.footer() }),\n\t\t\t\t\t...(slots.prefix && { prefix: (): VNode[] => slots.prefix() }),\n\t\t\t\t\t...(slots.empty && { empty: (): VNode[] => slots.empty() }),\n\t\t\t\t\t...(slots.tag && { tag: (): VNode[] => slots.tag() }),\n\t\t\t\t\t...(slots.loading && { loading: (): VNode[] => slots.loading() }),\n\t\t\t\t\t...(slots.label && {\n\t\t\t\t\t\tlabel: ({ label, value }: { label: string; value: string | number | boolean | object }): VNode[] =>\n\t\t\t\t\t\t\tslots.label({ label, value }),\n\t\t\t\t\t}),\n\t\t\t\t}}\n\t\t\t</ElSelect>\n\t\t));\n\n\t\treturn useExpose(expose, {\n\t\t\t/** @description 使选择器的输入框获取焦点 */\n\t\t\tfocus: computed(() => selectRef.value?.focus),\n\t\t\t/** @description 使选择器的输入框失去焦点,并隐藏下拉框 */\n\t\t\tblur: computed(() => selectRef.value?.blur),\n\t\t\t/** @description 获取当前选中的标签 */\n\t\t\tselectedLabel: computed(() => selectRef.value?.selectedLabel),\n\t\t\t/** @description 加载状态 */\n\t\t\tloading: computed(() => state.loading),\n\t\t\t/** @description 刷新 */\n\t\t\trefresh: loadData,\n\t\t\t/** @description 设置选择 */\n\t\t\tsetSelection: (value: string | number | boolean | object | (string | number | boolean | object)[]) => handleChange(value),\n\t\t\t/** @description 清除选择 */\n\t\t\tclearSelection: () => handleChange(null),\n\t\t});\n\t},\n});\n"],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"
|
|
2
|
-
//# sourceMappingURL=selectOption.js.map
|
|
1
|
+
require("../../../_virtual/_rolldown/runtime.js");let e=require("@fast-china/utils"),l=require("vue"),a=require("element-plus"),t=require("lodash-unified");var d=(0,l.defineComponent)({name:"FaSelectOption",props:{value:{type:(0,e.definePropType)([String,Number,Boolean,Object]),default:void 0},label:String,disabled:{type:Boolean,default:void 0},children:{type:(0,e.definePropType)(Array)},data:{type:(0,e.definePropType)(Object),default:()=>({})},moreDetail:Boolean},slots:(0,e.makeSlots)(),setup(d,{attrs:i,slots:o,emit:r,expose:n}){const u=(0,l.reactive)({value:(0,l.computed)(()=>(0,t.isUndefined)(d.value)?d.data.value:d.value),label:(0,l.computed)(()=>(0,t.isUndefined)(d.label)?d.data.label:d.label),disabled:(0,l.computed)(()=>((0,t.isUndefined)(d.disabled)?d.data.disabled:d.disabled)??!1),children:(0,l.computed)(()=>((0,t.isUndefined)(d.children)?d.data.children:d.children)??[])});(0,e.useRender)(()=>{let e;return(0,l.createVNode)(l.Fragment,null,[u.children.length>0?(0,l.createVNode)(a.ElOptionGroup,{label:u.label,disabled:u.disabled},(t=e=u.children.map(e=>(0,l.h)((0,l.resolveComponent)("FaSelectOption"),{moreDetail:d.moreDetail,data:e},o)),"function"==typeof t||"[object Object]"===Object.prototype.toString.call(t)&&!(0,l.isVNode)(t)?e:{default:()=>[e]})):(0,l.createVNode)(a.ElOption,{class:{"fa-select-dropdown__selector__more-detail":d.moreDetail&&o.default},value:u.value,label:u.label,disabled:u.disabled},{default:()=>[o.default&&o.default(d.data)]})]);var t})}});exports.default=d;
|
|
2
|
+
//# sourceMappingURL=selectOption.js.map
|