ant-design-vue/components/select/utils/iconUtil.tsx

67 lines
2.3 KiB
Vue
Raw Normal View History

2020-10-16 10:47:28 +00:00
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 = {}) {
2022-05-21 14:03:56 +00:00
const { loading, multiple, prefixCls, hasFeedback, feedbackIcon, showArrow } = props;
2020-10-19 08:43:10 +00:00
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());
2020-10-16 10:47:28 +00:00
// Clear Icon
let mergedClearIcon = clearIcon;
if (!clearIcon) {
mergedClearIcon = <CloseCircleFilled />;
}
2022-05-21 14:03:56 +00:00
// Validation Feedback Icon
const getSuffixIconNode = arrowIcon => (
<>
{showArrow !== false && arrowIcon}
{hasFeedback && feedbackIcon}
</>
);
2020-10-16 10:47:28 +00:00
// Arrow item icon
let mergedSuffixIcon = null;
if (suffixIcon !== undefined) {
2022-05-21 14:03:56 +00:00
mergedSuffixIcon = getSuffixIconNode(suffixIcon);
2020-10-16 10:47:28 +00:00
} else if (loading) {
2022-05-21 14:03:56 +00:00
mergedSuffixIcon = getSuffixIconNode(<LoadingOutlined spin />);
2020-10-16 10:47:28 +00:00
} else {
const iconCls = `${prefixCls}-suffix`;
mergedSuffixIcon = ({ open, showSearch }: { open: boolean; showSearch: boolean }) => {
if (open && showSearch) {
2022-05-21 14:03:56 +00:00
return getSuffixIconNode(<SearchOutlined class={iconCls} />);
2020-10-16 10:47:28 +00:00
}
2022-05-21 14:03:56 +00:00
return getSuffixIconNode(<DownOutlined class={iconCls} />);
2020-10-16 10:47:28 +00:00
};
}
// Checked item icon
let mergedItemIcon = null;
if (menuItemSelectedIcon !== undefined) {
mergedItemIcon = menuItemSelectedIcon;
} else if (multiple) {
mergedItemIcon = <CheckOutlined />;
} else {
mergedItemIcon = null;
}
let mergedRemoveIcon = null;
if (removeIcon !== undefined) {
mergedRemoveIcon = removeIcon;
} else {
mergedRemoveIcon = <CloseOutlined />;
}
return {
clearIcon: mergedClearIcon,
suffixIcon: mergedSuffixIcon,
itemIcon: mergedItemIcon,
removeIcon: mergedRemoveIcon,
};
}