123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396 |
- "use strict";
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
- var _typeof = require("@babel/runtime/helpers/typeof");
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.default = void 0;
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
- var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
- var _classnames = _interopRequireDefault(require("classnames"));
- var _KeyCode = _interopRequireDefault(require("rc-util/lib/KeyCode"));
- var _useMemo = _interopRequireDefault(require("rc-util/lib/hooks/useMemo"));
- var _omit = _interopRequireDefault(require("rc-util/lib/omit"));
- var _pickAttrs = _interopRequireDefault(require("rc-util/lib/pickAttrs"));
- var _rcVirtualList = _interopRequireDefault(require("rc-virtual-list"));
- var _react = _interopRequireWildcard(require("react"));
- var React = _react;
- var _SelectContext = _interopRequireDefault(require("./SelectContext"));
- var _TransBtn = _interopRequireDefault(require("./TransBtn"));
- var _useBaseProps2 = _interopRequireDefault(require("./hooks/useBaseProps"));
- var _platformUtil = require("./utils/platformUtil");
- var _valueUtil = require("./utils/valueUtil");
- var _excluded = ["disabled", "title", "children", "style", "className"];
- function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
- function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
- // export interface OptionListProps<OptionsType extends object[]> {
- function isTitleType(content) {
- return typeof content === 'string' || typeof content === 'number';
- }
- /**
- * Using virtual list of option display.
- * Will fallback to dom if use customize render.
- */
- var OptionList = function OptionList(_, ref) {
- var _useBaseProps = (0, _useBaseProps2.default)(),
- prefixCls = _useBaseProps.prefixCls,
- id = _useBaseProps.id,
- open = _useBaseProps.open,
- multiple = _useBaseProps.multiple,
- mode = _useBaseProps.mode,
- searchValue = _useBaseProps.searchValue,
- toggleOpen = _useBaseProps.toggleOpen,
- notFoundContent = _useBaseProps.notFoundContent,
- onPopupScroll = _useBaseProps.onPopupScroll;
- var _React$useContext = React.useContext(_SelectContext.default),
- maxCount = _React$useContext.maxCount,
- flattenOptions = _React$useContext.flattenOptions,
- onActiveValue = _React$useContext.onActiveValue,
- defaultActiveFirstOption = _React$useContext.defaultActiveFirstOption,
- onSelect = _React$useContext.onSelect,
- menuItemSelectedIcon = _React$useContext.menuItemSelectedIcon,
- rawValues = _React$useContext.rawValues,
- fieldNames = _React$useContext.fieldNames,
- virtual = _React$useContext.virtual,
- direction = _React$useContext.direction,
- listHeight = _React$useContext.listHeight,
- listItemHeight = _React$useContext.listItemHeight,
- optionRender = _React$useContext.optionRender;
- var itemPrefixCls = "".concat(prefixCls, "-item");
- var memoFlattenOptions = (0, _useMemo.default)(function () {
- return flattenOptions;
- }, [open, flattenOptions], function (prev, next) {
- return next[0] && prev[1] !== next[1];
- });
- // =========================== List ===========================
- var listRef = React.useRef(null);
- var overMaxCount = React.useMemo(function () {
- return multiple && (0, _valueUtil.isValidCount)(maxCount) && (rawValues === null || rawValues === void 0 ? void 0 : rawValues.size) >= maxCount;
- }, [multiple, maxCount, rawValues === null || rawValues === void 0 ? void 0 : rawValues.size]);
- var onListMouseDown = function onListMouseDown(event) {
- event.preventDefault();
- };
- var scrollIntoView = function scrollIntoView(args) {
- var _listRef$current;
- (_listRef$current = listRef.current) === null || _listRef$current === void 0 || _listRef$current.scrollTo(typeof args === 'number' ? {
- index: args
- } : args);
- };
- // https://github.com/ant-design/ant-design/issues/34975
- var isSelected = React.useCallback(function (value) {
- if (mode === 'combobox') {
- return false;
- }
- return rawValues.has(value);
- }, [mode, (0, _toConsumableArray2.default)(rawValues).toString(), rawValues.size]);
- // ========================== Active ==========================
- var getEnabledActiveIndex = function getEnabledActiveIndex(index) {
- var offset = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;
- var len = memoFlattenOptions.length;
- for (var i = 0; i < len; i += 1) {
- var current = (index + i * offset + len) % len;
- var _ref = memoFlattenOptions[current] || {},
- group = _ref.group,
- data = _ref.data;
- if (!group && !(data !== null && data !== void 0 && data.disabled) && (isSelected(data.value) || !overMaxCount)) {
- return current;
- }
- }
- return -1;
- };
- var _React$useState = React.useState(function () {
- return getEnabledActiveIndex(0);
- }),
- _React$useState2 = (0, _slicedToArray2.default)(_React$useState, 2),
- activeIndex = _React$useState2[0],
- setActiveIndex = _React$useState2[1];
- var setActive = function setActive(index) {
- var fromKeyboard = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
- setActiveIndex(index);
- var info = {
- source: fromKeyboard ? 'keyboard' : 'mouse'
- };
- // Trigger active event
- var flattenItem = memoFlattenOptions[index];
- if (!flattenItem) {
- onActiveValue(null, -1, info);
- return;
- }
- onActiveValue(flattenItem.value, index, info);
- };
- // Auto active first item when list length or searchValue changed
- (0, _react.useEffect)(function () {
- setActive(defaultActiveFirstOption !== false ? getEnabledActiveIndex(0) : -1);
- }, [memoFlattenOptions.length, searchValue]);
- // https://github.com/ant-design/ant-design/issues/48036
- var isAriaSelected = React.useCallback(function (value) {
- if (mode === 'combobox') {
- return String(value).toLowerCase() === searchValue.toLowerCase();
- }
- return rawValues.has(value);
- }, [mode, searchValue, (0, _toConsumableArray2.default)(rawValues).toString(), rawValues.size]);
- // Auto scroll to item position in single mode
- (0, _react.useEffect)(function () {
- /**
- * React will skip `onChange` when component update.
- * `setActive` function will call root accessibility state update which makes re-render.
- * So we need to delay to let Input component trigger onChange first.
- */
- var timeoutId = setTimeout(function () {
- if (!multiple && open && rawValues.size === 1) {
- var value = Array.from(rawValues)[0];
- // Scroll to the option closest to the searchValue if searching.
- var index = memoFlattenOptions.findIndex(function (_ref2) {
- var data = _ref2.data;
- return searchValue ? String(data.value).startsWith(searchValue) : data.value === value;
- });
- if (index !== -1) {
- setActive(index);
- scrollIntoView(index);
- }
- }
- });
- // Force trigger scrollbar visible when open
- if (open) {
- var _listRef$current2;
- (_listRef$current2 = listRef.current) === null || _listRef$current2 === void 0 || _listRef$current2.scrollTo(undefined);
- }
- return function () {
- return clearTimeout(timeoutId);
- };
- }, [open, searchValue]);
- // ========================== Values ==========================
- var onSelectValue = function onSelectValue(value) {
- if (value !== undefined) {
- onSelect(value, {
- selected: !rawValues.has(value)
- });
- }
- // Single mode should always close by select
- if (!multiple) {
- toggleOpen(false);
- }
- };
- // ========================= Keyboard =========================
- React.useImperativeHandle(ref, function () {
- return {
- onKeyDown: function onKeyDown(event) {
- var which = event.which,
- ctrlKey = event.ctrlKey;
- switch (which) {
- // >>> Arrow keys & ctrl + n/p on Mac
- case _KeyCode.default.N:
- case _KeyCode.default.P:
- case _KeyCode.default.UP:
- case _KeyCode.default.DOWN:
- {
- var offset = 0;
- if (which === _KeyCode.default.UP) {
- offset = -1;
- } else if (which === _KeyCode.default.DOWN) {
- offset = 1;
- } else if ((0, _platformUtil.isPlatformMac)() && ctrlKey) {
- if (which === _KeyCode.default.N) {
- offset = 1;
- } else if (which === _KeyCode.default.P) {
- offset = -1;
- }
- }
- if (offset !== 0) {
- var nextActiveIndex = getEnabledActiveIndex(activeIndex + offset, offset);
- scrollIntoView(nextActiveIndex);
- setActive(nextActiveIndex, true);
- }
- break;
- }
- // >>> Select (Tab / Enter)
- case _KeyCode.default.TAB:
- case _KeyCode.default.ENTER:
- {
- var _item$data;
- // value
- var item = memoFlattenOptions[activeIndex];
- if (item && !(item !== null && item !== void 0 && (_item$data = item.data) !== null && _item$data !== void 0 && _item$data.disabled) && !overMaxCount) {
- onSelectValue(item.value);
- } else {
- onSelectValue(undefined);
- }
- if (open) {
- event.preventDefault();
- }
- break;
- }
- // >>> Close
- case _KeyCode.default.ESC:
- {
- toggleOpen(false);
- if (open) {
- event.stopPropagation();
- }
- }
- }
- },
- onKeyUp: function onKeyUp() {},
- scrollTo: function scrollTo(index) {
- scrollIntoView(index);
- }
- };
- });
- // ========================== Render ==========================
- if (memoFlattenOptions.length === 0) {
- return /*#__PURE__*/React.createElement("div", {
- role: "listbox",
- id: "".concat(id, "_list"),
- className: "".concat(itemPrefixCls, "-empty"),
- onMouseDown: onListMouseDown
- }, notFoundContent);
- }
- var omitFieldNameList = Object.keys(fieldNames).map(function (key) {
- return fieldNames[key];
- });
- var getLabel = function getLabel(item) {
- return item.label;
- };
- function getItemAriaProps(item, index) {
- var group = item.group;
- return {
- role: group ? 'presentation' : 'option',
- id: "".concat(id, "_list_").concat(index)
- };
- }
- var renderItem = function renderItem(index) {
- var item = memoFlattenOptions[index];
- if (!item) {
- return null;
- }
- var itemData = item.data || {};
- var value = itemData.value;
- var group = item.group;
- var attrs = (0, _pickAttrs.default)(itemData, true);
- var mergedLabel = getLabel(item);
- return item ? /*#__PURE__*/React.createElement("div", (0, _extends2.default)({
- "aria-label": typeof mergedLabel === 'string' && !group ? mergedLabel : null
- }, attrs, {
- key: index
- }, getItemAriaProps(item, index), {
- "aria-selected": isAriaSelected(value)
- }), value) : null;
- };
- var a11yProps = {
- role: 'listbox',
- id: "".concat(id, "_list")
- };
- return /*#__PURE__*/React.createElement(React.Fragment, null, virtual && /*#__PURE__*/React.createElement("div", (0, _extends2.default)({}, a11yProps, {
- style: {
- height: 0,
- width: 0,
- overflow: 'hidden'
- }
- }), renderItem(activeIndex - 1), renderItem(activeIndex), renderItem(activeIndex + 1)), /*#__PURE__*/React.createElement(_rcVirtualList.default, {
- itemKey: "key",
- ref: listRef,
- data: memoFlattenOptions,
- height: listHeight,
- itemHeight: listItemHeight,
- fullHeight: false,
- onMouseDown: onListMouseDown,
- onScroll: onPopupScroll,
- virtual: virtual,
- direction: direction,
- innerProps: virtual ? null : a11yProps
- }, function (item, itemIndex) {
- var group = item.group,
- groupOption = item.groupOption,
- data = item.data,
- label = item.label,
- value = item.value;
- var key = data.key;
- // Group
- if (group) {
- var _data$title;
- var groupTitle = (_data$title = data.title) !== null && _data$title !== void 0 ? _data$title : isTitleType(label) ? label.toString() : undefined;
- return /*#__PURE__*/React.createElement("div", {
- className: (0, _classnames.default)(itemPrefixCls, "".concat(itemPrefixCls, "-group"), data.className),
- title: groupTitle
- }, label !== undefined ? label : key);
- }
- var disabled = data.disabled,
- title = data.title,
- children = data.children,
- style = data.style,
- className = data.className,
- otherProps = (0, _objectWithoutProperties2.default)(data, _excluded);
- var passedProps = (0, _omit.default)(otherProps, omitFieldNameList);
- // Option
- var selected = isSelected(value);
- var mergedDisabled = disabled || !selected && overMaxCount;
- var optionPrefixCls = "".concat(itemPrefixCls, "-option");
- var optionClassName = (0, _classnames.default)(itemPrefixCls, optionPrefixCls, className, (0, _defineProperty2.default)((0, _defineProperty2.default)((0, _defineProperty2.default)((0, _defineProperty2.default)({}, "".concat(optionPrefixCls, "-grouped"), groupOption), "".concat(optionPrefixCls, "-active"), activeIndex === itemIndex && !mergedDisabled), "".concat(optionPrefixCls, "-disabled"), mergedDisabled), "".concat(optionPrefixCls, "-selected"), selected));
- var mergedLabel = getLabel(item);
- var iconVisible = !menuItemSelectedIcon || typeof menuItemSelectedIcon === 'function' || selected;
- // https://github.com/ant-design/ant-design/issues/34145
- var content = typeof mergedLabel === 'number' ? mergedLabel : mergedLabel || value;
- // https://github.com/ant-design/ant-design/issues/26717
- var optionTitle = isTitleType(content) ? content.toString() : undefined;
- if (title !== undefined) {
- optionTitle = title;
- }
- return /*#__PURE__*/React.createElement("div", (0, _extends2.default)({}, (0, _pickAttrs.default)(passedProps), !virtual ? getItemAriaProps(item, itemIndex) : {}, {
- "aria-selected": isAriaSelected(value),
- className: optionClassName,
- title: optionTitle,
- onMouseMove: function onMouseMove() {
- if (activeIndex === itemIndex || mergedDisabled) {
- return;
- }
- setActive(itemIndex);
- },
- onClick: function onClick() {
- if (!mergedDisabled) {
- onSelectValue(value);
- }
- },
- style: style
- }), /*#__PURE__*/React.createElement("div", {
- className: "".concat(optionPrefixCls, "-content")
- }, typeof optionRender === 'function' ? optionRender(item, {
- index: itemIndex
- }) : content), /*#__PURE__*/React.isValidElement(menuItemSelectedIcon) || selected, iconVisible && /*#__PURE__*/React.createElement(_TransBtn.default, {
- className: "".concat(itemPrefixCls, "-option-state"),
- customizeIcon: menuItemSelectedIcon,
- customizeIconProps: {
- value: value,
- disabled: mergedDisabled,
- isSelected: selected
- }
- }, selected ? '✓' : null));
- }));
- };
- var RefOptionList = /*#__PURE__*/React.forwardRef(OptionList);
- if (process.env.NODE_ENV !== 'production') {
- RefOptionList.displayName = 'OptionList';
- }
- var _default = exports.default = RefOptionList;
|