Select.js
3.66 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
"use strict";
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _createSuper2 = _interopRequireDefault(require("@babel/runtime/helpers/createSuper"));
var React = _interopRequireWildcard(require("react"));
var _OptionList = _interopRequireDefault(require("./OptionList"));
var _Option = _interopRequireDefault(require("./Option"));
var _OptGroup = _interopRequireDefault(require("./OptGroup"));
var _legacyUtil = require("./utils/legacyUtil");
var _valueUtil = require("./utils/valueUtil");
var _generate = _interopRequireDefault(require("./generate"));
var _warningPropsUtil = _interopRequireDefault(require("./utils/warningPropsUtil"));
/**
* To match accessibility requirement, we always provide an input in the component.
* Other element will not set `tabIndex` to avoid `onBlur` sequence problem.
* For focused select, we set `aria-live="polite"` to update the accessibility content.
*
* ref:
* - keyboard: https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Roles/listbox_role#Keyboard_interactions
*
* New api:
* - listHeight
* - listItemHeight
* - component
*
* Remove deprecated api:
* - multiple
* - tags
* - combobox
* - firstActiveValue
* - dropdownMenuStyle
* - openClassName (Not list in api)
*
* Update:
* - `backfill` only support `combobox` mode
* - `combobox` mode not support `labelInValue` since it's meaningless
* - `getInputElement` only support `combobox` mode
* - `onChange` return OptionData instead of ReactNode
* - `filterOption` `onChange` `onSelect` accept OptionData instead of ReactNode
* - `combobox` mode trigger `onChange` will get `undefined` if no `value` match in Option
* - `combobox` mode not support `optionLabelProp`
*/
var RefSelect = (0, _generate.default)({
prefixCls: 'rc-select',
components: {
optionList: _OptionList.default
},
convertChildrenToData: _legacyUtil.convertChildrenToData,
flattenOptions: _valueUtil.flattenOptions,
getLabeledValue: _valueUtil.getLabeledValue,
filterOptions: _valueUtil.filterOptions,
isValueDisabled: _valueUtil.isValueDisabled,
findValueOption: _valueUtil.findValueOption,
warningProps: _warningPropsUtil.default,
fillOptionsWithMissingValue: _valueUtil.fillOptionsWithMissingValue
});
/**
* Typescript not support generic with function component,
* we have to wrap an class component to handle this.
*/
var Select = /*#__PURE__*/function (_React$Component) {
(0, _inherits2.default)(Select, _React$Component);
var _super = (0, _createSuper2.default)(Select);
function Select() {
var _this;
(0, _classCallCheck2.default)(this, Select);
_this = _super.apply(this, arguments);
_this.selectRef = React.createRef();
_this.focus = function () {
_this.selectRef.current.focus();
};
_this.blur = function () {
_this.selectRef.current.blur();
};
return _this;
}
(0, _createClass2.default)(Select, [{
key: "render",
value: function render() {
return React.createElement(RefSelect, Object.assign({
ref: this.selectRef
}, this.props));
}
}]);
return Select;
}(React.Component);
Select.Option = _Option.default;
Select.OptGroup = _OptGroup.default;
var _default = Select;
exports.default = _default;