2021-12-14 15:50:22 +00:00
|
|
|
import type { PropType } from 'vue';
|
|
|
|
import { computed, ref, defineComponent } from 'vue';
|
2020-08-31 08:53:19 +00:00
|
|
|
import classNames from '../_util/classNames';
|
2019-01-12 03:33:27 +00:00
|
|
|
import Input from './Input';
|
2020-03-26 03:53:51 +00:00
|
|
|
import SearchOutlined from '@ant-design/icons-vue/SearchOutlined';
|
2019-01-12 03:33:27 +00:00
|
|
|
import inputProps from './inputProps';
|
|
|
|
import Button from '../button';
|
|
|
|
import { cloneElement } from '../_util/vnode';
|
|
|
|
import PropTypes from '../_util/vue-types';
|
2020-09-02 14:44:16 +00:00
|
|
|
import isPlainObject from 'lodash-es/isPlainObject';
|
2021-12-14 15:50:22 +00:00
|
|
|
import type { ChangeEvent, MouseEventHandler } from '../_util/EventInterface';
|
|
|
|
import useConfigInject from '../_util/hooks/useConfigInject';
|
|
|
|
import omit from '../_util/omit';
|
|
|
|
import isMobile from '../_util/isMobile';
|
2017-12-06 10:54:20 +00:00
|
|
|
|
2020-10-16 06:24:14 +00:00
|
|
|
export default defineComponent({
|
2022-09-26 13:33:41 +00:00
|
|
|
compatConfig: { MODE: 3 },
|
2018-04-08 13:17:20 +00:00
|
|
|
name: 'AInputSearch',
|
2019-05-25 07:10:28 +00:00
|
|
|
inheritAttrs: false,
|
2017-12-06 10:54:20 +00:00
|
|
|
props: {
|
2022-03-26 14:52:54 +00:00
|
|
|
...inputProps(),
|
|
|
|
inputPrefixCls: String,
|
2020-03-21 09:29:53 +00:00
|
|
|
// 不能设置默认值 https://github.com/vueComponent/ant-design-vue/issues/1916
|
2021-12-14 15:50:22 +00:00
|
|
|
enterButton: PropTypes.any,
|
|
|
|
onSearch: {
|
|
|
|
type: Function as PropType<
|
|
|
|
(value: string, event?: ChangeEvent | MouseEvent | KeyboardEvent) => void
|
|
|
|
>,
|
|
|
|
},
|
2017-12-06 10:54:20 +00:00
|
|
|
},
|
2021-12-14 15:50:22 +00:00
|
|
|
setup(props, { slots, attrs, expose, emit }) {
|
|
|
|
const inputRef = ref();
|
|
|
|
const focus = () => {
|
|
|
|
inputRef.value?.focus();
|
2020-06-27 06:02:30 +00:00
|
|
|
};
|
2021-12-14 15:50:22 +00:00
|
|
|
const blur = () => {
|
|
|
|
inputRef.value?.blur();
|
|
|
|
};
|
|
|
|
expose({
|
|
|
|
focus,
|
|
|
|
blur,
|
|
|
|
});
|
|
|
|
|
|
|
|
const onChange = (e: ChangeEvent) => {
|
|
|
|
emit('update:value', (e.target as HTMLInputElement).value);
|
2020-03-07 11:45:13 +00:00
|
|
|
if (e && e.target && e.type === 'click') {
|
2021-12-14 15:50:22 +00:00
|
|
|
emit('search', e.target.value, e);
|
2020-03-07 11:45:13 +00:00
|
|
|
}
|
2021-12-14 15:50:22 +00:00
|
|
|
emit('change', e);
|
|
|
|
};
|
2018-06-10 01:29:18 +00:00
|
|
|
|
2021-12-14 15:50:22 +00:00
|
|
|
const onMousedown: MouseEventHandler = e => {
|
2021-12-15 12:48:24 +00:00
|
|
|
if (document.activeElement === inputRef.value?.input) {
|
2021-12-14 15:50:22 +00:00
|
|
|
e.preventDefault();
|
2020-03-07 11:45:13 +00:00
|
|
|
}
|
2021-12-14 15:50:22 +00:00
|
|
|
};
|
2020-03-07 11:45:13 +00:00
|
|
|
|
2021-12-14 15:50:22 +00:00
|
|
|
const onSearch = (e: MouseEvent | KeyboardEvent) => {
|
|
|
|
emit('search', inputRef.value?.stateValue, e);
|
|
|
|
if (!isMobile.tablet) {
|
|
|
|
inputRef.value.focus();
|
2019-04-07 09:19:18 +00:00
|
|
|
}
|
2021-12-14 15:50:22 +00:00
|
|
|
};
|
2019-04-07 09:19:18 +00:00
|
|
|
|
2021-12-14 15:50:22 +00:00
|
|
|
const { prefixCls, getPrefixCls, direction, size } = useConfigInject('input-search', props);
|
|
|
|
const inputPrefixCls = computed(() => getPrefixCls('input', props.inputPrefixCls));
|
|
|
|
return () => {
|
|
|
|
const {
|
|
|
|
disabled,
|
|
|
|
loading,
|
|
|
|
addonAfter = slots.addonAfter?.(),
|
|
|
|
suffix = slots.suffix?.(),
|
|
|
|
...restProps
|
|
|
|
} = props;
|
2021-12-16 14:55:28 +00:00
|
|
|
let { enterButton = slots.enterButton?.() ?? false } = props;
|
2020-03-07 11:45:13 +00:00
|
|
|
enterButton = enterButton || enterButton === '';
|
2021-12-16 14:55:28 +00:00
|
|
|
const searchIcon = typeof enterButton === 'boolean' ? <SearchOutlined /> : null;
|
2021-12-14 15:50:22 +00:00
|
|
|
const btnClassName = `${prefixCls.value}-button`;
|
|
|
|
|
2019-01-12 03:33:27 +00:00
|
|
|
const enterButtonAsElement = Array.isArray(enterButton) ? enterButton[0] : enterButton;
|
2020-10-16 06:24:14 +00:00
|
|
|
let button: any;
|
2020-03-07 11:45:13 +00:00
|
|
|
const isAntdButton =
|
2020-06-27 06:02:30 +00:00
|
|
|
enterButtonAsElement.type &&
|
|
|
|
isPlainObject(enterButtonAsElement.type) &&
|
|
|
|
enterButtonAsElement.type.__ANT_BUTTON;
|
2021-12-14 15:50:22 +00:00
|
|
|
if (isAntdButton || enterButtonAsElement.tagName === 'button') {
|
2021-12-15 12:48:24 +00:00
|
|
|
button = cloneElement(
|
|
|
|
enterButtonAsElement,
|
|
|
|
{
|
|
|
|
onMousedown,
|
|
|
|
onClick: onSearch,
|
|
|
|
key: 'enterButton',
|
|
|
|
...(isAntdButton
|
|
|
|
? {
|
|
|
|
class: btnClassName,
|
|
|
|
size: size.value,
|
|
|
|
}
|
|
|
|
: {}),
|
|
|
|
},
|
|
|
|
false,
|
|
|
|
);
|
2018-09-05 13:28:54 +00:00
|
|
|
} else {
|
2021-12-16 14:55:28 +00:00
|
|
|
const iconOnly = searchIcon && !enterButton;
|
2019-04-07 09:19:18 +00:00
|
|
|
button = (
|
2018-09-05 13:28:54 +00:00
|
|
|
<Button
|
2019-04-07 09:19:18 +00:00
|
|
|
class={btnClassName}
|
2021-12-14 15:50:22 +00:00
|
|
|
type={enterButton ? 'primary' : undefined}
|
|
|
|
size={size.value}
|
2018-09-05 13:28:54 +00:00
|
|
|
disabled={disabled}
|
2019-01-12 03:33:27 +00:00
|
|
|
key="enterButton"
|
2021-12-14 15:50:22 +00:00
|
|
|
onMousedown={onMousedown}
|
|
|
|
onClick={onSearch}
|
|
|
|
loading={loading}
|
2021-12-16 14:55:28 +00:00
|
|
|
icon={iconOnly ? searchIcon : null}
|
2018-09-05 13:28:54 +00:00
|
|
|
>
|
2021-12-16 14:55:28 +00:00
|
|
|
{iconOnly ? null : searchIcon || enterButton}
|
2018-09-05 13:28:54 +00:00
|
|
|
</Button>
|
2019-01-12 03:33:27 +00:00
|
|
|
);
|
2018-04-07 06:29:59 +00:00
|
|
|
}
|
2019-04-07 09:19:18 +00:00
|
|
|
if (addonAfter) {
|
2021-12-14 15:50:22 +00:00
|
|
|
button = [button, addonAfter];
|
2019-04-07 09:19:18 +00:00
|
|
|
}
|
2021-12-14 15:50:22 +00:00
|
|
|
const cls = classNames(
|
|
|
|
prefixCls.value,
|
|
|
|
{
|
|
|
|
[`${prefixCls.value}-rtl`]: direction.value === 'rtl',
|
|
|
|
[`${prefixCls.value}-${size.value}`]: !!size.value,
|
|
|
|
[`${prefixCls.value}-with-button`]: !!enterButton,
|
|
|
|
},
|
|
|
|
attrs.class,
|
|
|
|
);
|
|
|
|
return (
|
|
|
|
<Input
|
|
|
|
ref={inputRef}
|
2021-12-15 14:27:07 +00:00
|
|
|
{...omit(restProps, ['onUpdate:value', 'onSearch', 'enterButton'])}
|
2021-12-14 15:50:22 +00:00
|
|
|
{...attrs}
|
|
|
|
onPressEnter={onSearch}
|
|
|
|
size={size.value}
|
|
|
|
prefixCls={inputPrefixCls.value}
|
|
|
|
addonAfter={button}
|
|
|
|
suffix={suffix}
|
|
|
|
onChange={onChange}
|
|
|
|
class={cls}
|
|
|
|
disabled={disabled}
|
|
|
|
v-slots={slots}
|
|
|
|
/>
|
|
|
|
);
|
2019-01-12 03:33:27 +00:00
|
|
|
};
|
2017-12-06 10:54:20 +00:00
|
|
|
},
|
2020-10-16 06:24:14 +00:00
|
|
|
});
|