92 lines
2.7 KiB
JavaScript
92 lines
2.7 KiB
JavaScript
|
export function hasAddon(props) {
|
|||
|
return !!(props.addonBefore || props.addonAfter);
|
|||
|
}
|
|||
|
export function hasPrefixSuffix(props) {
|
|||
|
return !!(props.prefix || props.suffix || props.allowClear);
|
|||
|
}
|
|||
|
|
|||
|
// TODO: It's better to use `Proxy` replace the `element.value`. But we still need support IE11.
|
|||
|
function cloneEvent(event, target, value) {
|
|||
|
// A bug report filed on WebKit's Bugzilla tracker, dating back to 2009, specifically addresses the issue of cloneNode() not copying files of <input type="file"> elements.
|
|||
|
// As of the last update, this bug was still marked as "NEW," indicating that it might not have been resolved yet.
|
|||
|
// https://bugs.webkit.org/show_bug.cgi?id=28123
|
|||
|
var currentTarget = target.cloneNode(true);
|
|||
|
|
|||
|
// click clear icon
|
|||
|
var newEvent = Object.create(event, {
|
|||
|
target: {
|
|||
|
value: currentTarget
|
|||
|
},
|
|||
|
currentTarget: {
|
|||
|
value: currentTarget
|
|||
|
}
|
|||
|
});
|
|||
|
|
|||
|
// Fill data
|
|||
|
currentTarget.value = value;
|
|||
|
|
|||
|
// Fill selection. Some type like `email` not support selection
|
|||
|
// https://github.com/ant-design/ant-design/issues/47833
|
|||
|
if (typeof target.selectionStart === 'number' && typeof target.selectionEnd === 'number') {
|
|||
|
currentTarget.selectionStart = target.selectionStart;
|
|||
|
currentTarget.selectionEnd = target.selectionEnd;
|
|||
|
}
|
|||
|
currentTarget.setSelectionRange = function () {
|
|||
|
target.setSelectionRange.apply(target, arguments);
|
|||
|
};
|
|||
|
return newEvent;
|
|||
|
}
|
|||
|
export function resolveOnChange(target, e, onChange, targetValue) {
|
|||
|
if (!onChange) {
|
|||
|
return;
|
|||
|
}
|
|||
|
var event = e;
|
|||
|
if (e.type === 'click') {
|
|||
|
// Clone a new target for event.
|
|||
|
// Avoid the following usage, the setQuery method gets the original value.
|
|||
|
//
|
|||
|
// const [query, setQuery] = React.useState('');
|
|||
|
// <Input
|
|||
|
// allowClear
|
|||
|
// value={query}
|
|||
|
// onChange={(e)=> {
|
|||
|
// setQuery((prevStatus) => e.target.value);
|
|||
|
// }}
|
|||
|
// />
|
|||
|
|
|||
|
event = cloneEvent(e, target, '');
|
|||
|
onChange(event);
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
// Trigger by composition event, this means we need force change the input value
|
|||
|
// https://github.com/ant-design/ant-design/issues/45737
|
|||
|
// https://github.com/ant-design/ant-design/issues/46598
|
|||
|
if (target.type !== 'file' && targetValue !== undefined) {
|
|||
|
event = cloneEvent(e, target, targetValue);
|
|||
|
onChange(event);
|
|||
|
return;
|
|||
|
}
|
|||
|
onChange(event);
|
|||
|
}
|
|||
|
export function triggerFocus(element, option) {
|
|||
|
if (!element) return;
|
|||
|
element.focus(option);
|
|||
|
|
|||
|
// Selection content
|
|||
|
var _ref = option || {},
|
|||
|
cursor = _ref.cursor;
|
|||
|
if (cursor) {
|
|||
|
var len = element.value.length;
|
|||
|
switch (cursor) {
|
|||
|
case 'start':
|
|||
|
element.setSelectionRange(0, 0);
|
|||
|
break;
|
|||
|
case 'end':
|
|||
|
element.setSelectionRange(len, len);
|
|||
|
break;
|
|||
|
default:
|
|||
|
element.setSelectionRange(0, len);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|