antd-mobile
Version:
<div align="center">
131 lines (130 loc) • 5.99 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.VirtualInput = void 0;
var _ahooks = require("ahooks");
var _antdMobileIcons = require("antd-mobile-icons");
var _classnames = _interopRequireDefault(require("classnames"));
var _react = _interopRequireWildcard(require("react"));
var _nativeProps = require("../../utils/native-props");
var _usePropsValue = require("../../utils/use-props-value");
var _withDefaultProps = require("../../utils/with-default-props");
var _configProvider = require("../config-provider");
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
const classPrefix = 'adm-virtual-input';
const defaultProps = {
defaultValue: ''
};
const VirtualInput = (0, _react.forwardRef)((props, ref) => {
const {
locale,
input: componentConfig = {}
} = (0, _configProvider.useConfig)();
const mergedProps = (0, _withDefaultProps.mergeProps)(defaultProps, componentConfig, props);
const [value, setValue] = (0, _usePropsValue.usePropsValue)(mergedProps);
const rootRef = (0, _react.useRef)(null);
const contentRef = (0, _react.useRef)(null);
const [hasFocus, setHasFocus] = (0, _react.useState)(false);
const clearIcon = (0, _withDefaultProps.mergeProp)(_react.default.createElement(_antdMobileIcons.CloseCircleFill, null), componentConfig.clearIcon, props.clearIcon);
function scrollToEnd() {
const root = rootRef.current;
if (!root) return;
if (document.activeElement !== root) {
return;
}
const content = contentRef.current;
if (!content) return;
content.scrollLeft = content.clientWidth;
}
(0, _ahooks.useIsomorphicLayoutEffect)(() => {
scrollToEnd();
}, [value]);
(0, _react.useEffect)(() => {
if (hasFocus) {
scrollToEnd();
}
}, [hasFocus]);
(0, _react.useImperativeHandle)(ref, () => ({
focus: () => {
var _a;
(_a = rootRef.current) === null || _a === void 0 ? void 0 : _a.focus();
},
blur: () => {
var _a;
(_a = rootRef.current) === null || _a === void 0 ? void 0 : _a.blur();
}
}));
function onFocus() {
var _a;
setHasFocus(true);
(_a = mergedProps.onFocus) === null || _a === void 0 ? void 0 : _a.call(mergedProps);
}
function onBlur() {
var _a;
setHasFocus(false);
(_a = mergedProps.onBlur) === null || _a === void 0 ? void 0 : _a.call(mergedProps);
}
const keyboard = mergedProps.keyboard;
const keyboardElement = keyboard && _react.default.cloneElement(keyboard, {
onInput: v => {
var _a, _b;
setValue(value + v);
(_b = (_a = keyboard.props).onInput) === null || _b === void 0 ? void 0 : _b.call(_a, v);
},
onDelete: () => {
var _a, _b;
setValue(value.slice(0, -1));
(_b = (_a = keyboard.props).onDelete) === null || _b === void 0 ? void 0 : _b.call(_a);
},
visible: hasFocus,
onClose: () => {
var _a, _b, _c, _d;
const activeElement = document.activeElement;
// Long press makes `activeElement` to be the child of rootRef
// We will trigger blur on the child element instead
if (activeElement && ((_a = rootRef.current) === null || _a === void 0 ? void 0 : _a.contains(activeElement))) {
activeElement.blur();
} else {
(_b = rootRef.current) === null || _b === void 0 ? void 0 : _b.blur();
}
(_d = (_c = keyboard.props).onClose) === null || _d === void 0 ? void 0 : _d.call(_c);
},
getContainer: null
});
return (0, _nativeProps.withNativeProps)(mergedProps, _react.default.createElement("div", {
ref: rootRef,
className: (0, _classnames.default)(classPrefix, {
[`${classPrefix}-disabled`]: mergedProps.disabled
}),
tabIndex: mergedProps.disabled ? undefined : 0,
role: 'textbox',
onFocus: onFocus,
onBlur: onBlur,
onClick: mergedProps.onClick
}, _react.default.createElement("div", {
className: `${classPrefix}-content`,
ref: contentRef,
"aria-disabled": mergedProps.disabled,
"aria-label": mergedProps.placeholder
}, value, _react.default.createElement("div", {
className: `${classPrefix}-caret-container`
}, hasFocus && _react.default.createElement("div", {
className: `${classPrefix}-caret`
}))), mergedProps.clearable && !!value && hasFocus && _react.default.createElement("div", {
className: `${classPrefix}-clear`,
onClick: e => {
var _a;
e.stopPropagation();
setValue('');
(_a = mergedProps.onClear) === null || _a === void 0 ? void 0 : _a.call(mergedProps);
},
role: 'button',
"aria-label": locale.Input.clear
}, clearIcon), [undefined, null, ''].includes(value) && _react.default.createElement("div", {
className: `${classPrefix}-placeholder`
}, mergedProps.placeholder), keyboardElement));
});
exports.VirtualInput = VirtualInput;
;