import DownOutlined from '@ant-design/icons-vue/DownOutlined'; import LoadingOutlined from '@ant-design/icons-vue/LoadingOutlined'; import CheckOutlined from '@ant-design/icons-vue/CheckOutlined'; import CloseOutlined from '@ant-design/icons-vue/CloseOutlined'; import CloseCircleFilled from '@ant-design/icons-vue/CloseCircleFilled'; import SearchOutlined from '@ant-design/icons-vue/SearchOutlined'; export default function getIcons(props: any, slots: any = {}) { const { loading, multiple, prefixCls, hasFeedback, feedbackIcon, showArrow } = props; const suffixIcon = props.suffixIcon || (slots.suffixIcon && slots.suffixIcon()); const clearIcon = props.clearIcon || (slots.clearIcon && slots.clearIcon()); const menuItemSelectedIcon = props.menuItemSelectedIcon || (slots.menuItemSelectedIcon && slots.menuItemSelectedIcon()); const removeIcon = props.removeIcon || (slots.removeIcon && slots.removeIcon()); // Clear Icon const mergedClearIcon = clearIcon ?? ; // Validation Feedback Icon const getSuffixIconNode = arrowIcon => ( <> {showArrow !== false && arrowIcon} {hasFeedback && feedbackIcon} ); // Arrow item icon let mergedSuffixIcon = null; if (suffixIcon !== undefined) { mergedSuffixIcon = getSuffixIconNode(suffixIcon); } else if (loading) { mergedSuffixIcon = getSuffixIconNode(); } else { const iconCls = `${prefixCls}-suffix`; mergedSuffixIcon = ({ open, showSearch }: { open: boolean; showSearch: boolean }) => { if (open && showSearch) { return getSuffixIconNode(); } return getSuffixIconNode(); }; } // Checked item icon let mergedItemIcon = null; if (menuItemSelectedIcon !== undefined) { mergedItemIcon = menuItemSelectedIcon; } else if (multiple) { mergedItemIcon = ; } else { mergedItemIcon = null; } let mergedRemoveIcon = null; if (removeIcon !== undefined) { mergedRemoveIcon = removeIcon; } else { mergedRemoveIcon = ; } return { clearIcon: mergedClearIcon, suffixIcon: mergedSuffixIcon, itemIcon: mergedItemIcon, removeIcon: mergedRemoveIcon, }; }