2020-10-07 14:49:01 +00:00
|
|
|
import { cloneElement } from '../../_util/vnode';
|
2021-12-16 09:20:18 +00:00
|
|
|
import type { VNode } from 'vue';
|
2021-06-26 01:35:40 +00:00
|
|
|
import { defineComponent, getCurrentInstance, inject, onMounted, withDirectives } from 'vue';
|
2020-10-07 14:49:01 +00:00
|
|
|
import PropTypes from '../../_util/vue-types';
|
2021-06-26 01:35:40 +00:00
|
|
|
import type { RefObject } from '../../_util/createRef';
|
2020-10-07 14:49:01 +00:00
|
|
|
import antInput from '../../_util/antInputDirective';
|
2021-06-22 05:26:19 +00:00
|
|
|
import classNames from '../../_util/classNames';
|
2021-08-29 02:44:24 +00:00
|
|
|
import type { EventHandler } from '../../_util/EventInterface';
|
2021-12-16 09:20:18 +00:00
|
|
|
import type { VueNode } from '../../_util/type';
|
2020-10-07 14:49:01 +00:00
|
|
|
|
|
|
|
interface InputProps {
|
|
|
|
prefixCls: string;
|
|
|
|
id: string;
|
2021-12-16 09:20:18 +00:00
|
|
|
inputElement: VueNode;
|
2020-10-07 14:49:01 +00:00
|
|
|
disabled: boolean;
|
|
|
|
autofocus: boolean;
|
|
|
|
autocomplete: string;
|
|
|
|
editable: boolean;
|
|
|
|
accessibilityIndex: number;
|
|
|
|
value: string;
|
|
|
|
open: boolean;
|
2021-06-07 09:35:03 +00:00
|
|
|
tabindex: number | string;
|
2020-10-07 14:49:01 +00:00
|
|
|
/** Pass accessibility props to input */
|
|
|
|
attrs: object;
|
|
|
|
inputRef: RefObject;
|
2021-08-29 02:44:24 +00:00
|
|
|
onKeydown: EventHandler;
|
|
|
|
onMousedown: EventHandler;
|
|
|
|
onChange: EventHandler;
|
|
|
|
onPaste: EventHandler;
|
|
|
|
onCompositionstart: EventHandler;
|
|
|
|
onCompositionend: EventHandler;
|
|
|
|
onFocus: EventHandler;
|
|
|
|
onBlur: EventHandler;
|
2020-10-07 14:49:01 +00:00
|
|
|
}
|
|
|
|
|
2021-08-29 02:44:24 +00:00
|
|
|
const Input = defineComponent({
|
2020-10-07 14:49:01 +00:00
|
|
|
name: 'Input',
|
|
|
|
inheritAttrs: false,
|
2021-08-29 02:44:24 +00:00
|
|
|
props: {
|
|
|
|
inputRef: PropTypes.any,
|
|
|
|
prefixCls: PropTypes.string,
|
|
|
|
id: PropTypes.string,
|
|
|
|
inputElement: PropTypes.any,
|
|
|
|
disabled: PropTypes.looseBool,
|
|
|
|
autofocus: PropTypes.looseBool,
|
|
|
|
autocomplete: PropTypes.string,
|
|
|
|
editable: PropTypes.looseBool,
|
|
|
|
accessibilityIndex: PropTypes.number,
|
|
|
|
value: PropTypes.string,
|
|
|
|
open: PropTypes.looseBool,
|
|
|
|
tabindex: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
|
|
|
|
/** Pass accessibility props to input */
|
|
|
|
attrs: PropTypes.object,
|
|
|
|
onKeydown: PropTypes.func,
|
|
|
|
onMousedown: PropTypes.func,
|
|
|
|
onChange: PropTypes.func,
|
|
|
|
onPaste: PropTypes.func,
|
|
|
|
onCompositionstart: PropTypes.func,
|
|
|
|
onCompositionend: PropTypes.func,
|
|
|
|
onFocus: PropTypes.func,
|
|
|
|
onBlur: PropTypes.func,
|
|
|
|
},
|
2020-10-26 14:14:00 +00:00
|
|
|
setup(props) {
|
|
|
|
if (process.env.NODE_ENV === 'test') {
|
|
|
|
onMounted(() => {
|
|
|
|
const ins = getCurrentInstance();
|
|
|
|
if (props.autofocus) {
|
|
|
|
if (ins.vnode && ins.vnode.el) {
|
|
|
|
ins.vnode.el.focus();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
2020-10-07 14:49:01 +00:00
|
|
|
return {
|
2020-11-01 10:07:23 +00:00
|
|
|
blurTimeout: null,
|
2021-08-29 02:44:24 +00:00
|
|
|
VCSelectContainerEvent: inject('VCSelectContainerEvent') as any,
|
2020-10-07 14:49:01 +00:00
|
|
|
};
|
|
|
|
},
|
|
|
|
render() {
|
|
|
|
const {
|
|
|
|
prefixCls,
|
|
|
|
id,
|
|
|
|
inputElement,
|
|
|
|
disabled,
|
|
|
|
tabindex,
|
|
|
|
autofocus,
|
|
|
|
autocomplete,
|
|
|
|
editable,
|
|
|
|
accessibilityIndex,
|
|
|
|
value,
|
|
|
|
onKeydown,
|
|
|
|
onMousedown,
|
|
|
|
onChange,
|
|
|
|
onPaste,
|
|
|
|
onCompositionstart,
|
|
|
|
onCompositionend,
|
2021-06-22 02:47:33 +00:00
|
|
|
onFocus,
|
|
|
|
onBlur,
|
2020-10-07 14:49:01 +00:00
|
|
|
open,
|
|
|
|
inputRef,
|
|
|
|
attrs,
|
|
|
|
} = this.$props as InputProps;
|
2021-08-10 06:36:28 +00:00
|
|
|
let inputNode: any = inputElement || withDirectives((<input />) as VNode, [[antInput]]);
|
2020-10-07 14:49:01 +00:00
|
|
|
|
|
|
|
const inputProps = inputNode.props || {};
|
|
|
|
const {
|
|
|
|
onKeydown: onOriginKeyDown,
|
|
|
|
onInput: onOriginInput,
|
2021-06-22 02:47:33 +00:00
|
|
|
onFocus: onOriginFocus,
|
|
|
|
onBlur: onOriginBlur,
|
2020-10-07 14:49:01 +00:00
|
|
|
onMousedown: onOriginMouseDown,
|
|
|
|
onCompositionstart: onOriginCompositionStart,
|
|
|
|
onCompositionend: onOriginCompositionEnd,
|
|
|
|
style,
|
|
|
|
} = inputProps;
|
2020-10-08 14:51:09 +00:00
|
|
|
inputNode = cloneElement(
|
|
|
|
inputNode,
|
|
|
|
Object.assign(
|
|
|
|
{
|
|
|
|
id,
|
|
|
|
ref: inputRef,
|
|
|
|
disabled,
|
|
|
|
tabindex,
|
|
|
|
autocomplete: autocomplete || 'off',
|
|
|
|
autofocus,
|
2021-06-22 02:47:33 +00:00
|
|
|
class: classNames(`${prefixCls}-selection-search-input`, inputNode?.props?.className),
|
2020-10-08 14:51:09 +00:00
|
|
|
style: { ...style, opacity: editable ? null : 0 },
|
|
|
|
role: 'combobox',
|
|
|
|
'aria-expanded': open,
|
|
|
|
'aria-haspopup': 'listbox',
|
|
|
|
'aria-owns': `${id}_list`,
|
|
|
|
'aria-autocomplete': 'list',
|
|
|
|
'aria-controls': `${id}_list`,
|
|
|
|
'aria-activedescendant': `${id}_list_${accessibilityIndex}`,
|
|
|
|
...attrs,
|
|
|
|
value: editable ? value : '',
|
|
|
|
readonly: !editable,
|
|
|
|
unselectable: !editable ? 'on' : null,
|
|
|
|
onKeydown: (event: KeyboardEvent) => {
|
|
|
|
onKeydown(event);
|
|
|
|
if (onOriginKeyDown) {
|
|
|
|
onOriginKeyDown(event);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
onMousedown: (event: MouseEvent) => {
|
|
|
|
onMousedown(event);
|
|
|
|
if (onOriginMouseDown) {
|
|
|
|
onOriginMouseDown(event);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
onInput: (event: Event) => {
|
|
|
|
onChange(event);
|
|
|
|
if (onOriginInput) {
|
|
|
|
onOriginInput(event);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
onCompositionstart(event: CompositionEvent) {
|
|
|
|
onCompositionstart(event);
|
|
|
|
if (onOriginCompositionStart) {
|
|
|
|
onOriginCompositionStart(event);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
onCompositionend(event: CompositionEvent) {
|
|
|
|
onCompositionend(event);
|
|
|
|
if (onOriginCompositionEnd) {
|
|
|
|
onOriginCompositionEnd(event);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
onPaste,
|
|
|
|
onFocus: (...args: any[]) => {
|
2020-11-01 10:07:23 +00:00
|
|
|
clearTimeout(this.blurTimeout);
|
2021-06-22 02:47:33 +00:00
|
|
|
onOriginFocus && onOriginFocus(args[0]);
|
|
|
|
onFocus && onFocus(args[0]);
|
2020-10-08 14:51:09 +00:00
|
|
|
this.VCSelectContainerEvent?.focus(args[0]);
|
|
|
|
},
|
|
|
|
onBlur: (...args: any[]) => {
|
2020-11-01 10:07:23 +00:00
|
|
|
this.blurTimeout = setTimeout(() => {
|
2021-06-22 02:47:33 +00:00
|
|
|
onOriginBlur && onOriginBlur(args[0]);
|
|
|
|
onBlur && onBlur(args[0]);
|
2020-11-01 10:07:23 +00:00
|
|
|
this.VCSelectContainerEvent?.blur(args[0]);
|
|
|
|
}, 200);
|
2020-10-08 14:51:09 +00:00
|
|
|
},
|
|
|
|
},
|
|
|
|
inputNode.type === 'textarea' ? {} : { type: 'search' },
|
|
|
|
),
|
|
|
|
true,
|
|
|
|
true,
|
|
|
|
) as VNode;
|
2020-10-07 14:49:01 +00:00
|
|
|
return inputNode;
|
|
|
|
},
|
|
|
|
});
|
|
|
|
|
2021-08-29 02:44:24 +00:00
|
|
|
// Input.props = {
|
|
|
|
// inputRef: PropTypes.any,
|
|
|
|
// prefixCls: PropTypes.string,
|
|
|
|
// id: PropTypes.string,
|
|
|
|
// inputElement: PropTypes.any,
|
|
|
|
// disabled: PropTypes.looseBool,
|
|
|
|
// autofocus: PropTypes.looseBool,
|
|
|
|
// autocomplete: PropTypes.string,
|
|
|
|
// editable: PropTypes.looseBool,
|
|
|
|
// accessibilityIndex: PropTypes.number,
|
|
|
|
// value: PropTypes.string,
|
|
|
|
// open: PropTypes.looseBool,
|
|
|
|
// tabindex: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
|
|
|
|
// /** Pass accessibility props to input */
|
|
|
|
// attrs: PropTypes.object,
|
|
|
|
// onKeydown: PropTypes.func,
|
|
|
|
// onMousedown: PropTypes.func,
|
|
|
|
// onChange: PropTypes.func,
|
|
|
|
// onPaste: PropTypes.func,
|
|
|
|
// onCompositionstart: PropTypes.func,
|
|
|
|
// onCompositionend: PropTypes.func,
|
|
|
|
// onFocus: PropTypes.func,
|
|
|
|
// onBlur: PropTypes.func,
|
|
|
|
// };
|
2020-10-07 14:49:01 +00:00
|
|
|
|
|
|
|
export default Input;
|