@fle-ui/next 1.0.3 → 1.0.4-alpha.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.history/package_20211223145956.json +146 -0
- package/.history/package_20211223211341.json +146 -0
- package/.history/package_20211223220710.json +146 -0
- package/.history/package_20211223221147.json +146 -0
- package/.history/package_20211223221328.json +146 -0
- package/.history/package_20211223221445.json +146 -0
- package/dist/@fle-ui/next.css +2254 -2212
- package/dist/@fle-ui/next.css.map +1 -1
- package/dist/@fle-ui/next.js +1165 -1247
- package/dist/@fle-ui/next.js.map +1 -1
- package/dist/@fle-ui/next.min.css +2 -2
- package/dist/@fle-ui/next.min.css.map +1 -1
- package/dist/@fle-ui/next.min.js +3 -3
- package/dist/@fle-ui/next.min.js.map +1 -1
- package/docs-dist/components__affix__affix.md~components__alert__alert.md~components__anchor__anchor.md~components__au~31d645aa.js +13 -16
- package/docs-dist/components__avatar__avatar.md.js +227 -372
- package/docs-dist/components__button__button.md.js +27 -27
- package/docs-dist/components__form__form.md.js +1 -1
- package/docs-dist/components__layout__layout.md.js +1 -1
- package/docs-dist/components__modal__modal.md.js +17 -11
- package/docs-dist/components__popconfirm__popconfirm.md.js +51 -51
- package/docs-dist/components__upload__upload.md.js +6 -10
- package/docs-dist/demos_bmurcdaerb~demos_citsitats~demos_dirg~demos_drac~demos_ecaps~demos_eert~demos_egami~demos_egas~1a5cf206.chunk.css +2 -2
- package/docs-dist/demos_bmurcdaerb~demos_citsitats~demos_dirg~demos_drac~demos_ecaps~demos_eert~demos_egami~demos_egas~1a5cf206.js +1536 -1843
- package/docs-dist/demos_daolpu.chunk.css +2 -2
- package/docs-dist/demos_daolpu.js +2597 -2904
- package/docs-dist/demos_eert.js +1 -1
- package/docs-dist/demos_elbat.chunk.css +2 -2
- package/docs-dist/demos_elbat.js +645 -952
- package/docs-dist/demos_mrifnocpop.js +1 -1
- package/docs-dist/demos_mrof.js +0 -1
- package/docs-dist/demos_noitacifiton.js +1 -1
- package/docs-dist/demos_pot-kcab.js +9 -9
- package/docs-dist/demos_ratava.js +3 -3
- package/docs-dist/demos_redivorp-gifnoc.js +5 -5
- package/docs-dist/demos_rekcip-etad.js +2 -2
- package/docs-dist/demos_sbat.chunk.css +2 -2
- package/docs-dist/demos_sbat.js +2301 -2608
- package/docs-dist/demos_tupni.js +1 -1
- package/docs-dist/docs__story__index.md.js +22 -0
- package/docs-dist/umi.js +9 -8
- package/docs-dist/vendors~demos_bmurcdaerb~demos_citsitats~demos_daolpu~demos_dirg~demos_drac~demos_ecaps~demos_eert~d~f20ff6ec.js +9204 -8936
- package/es/cascader/index.d.ts +11 -129
- package/es/cascader/index.js +151 -534
- package/es/cascader/style/css.js +1 -1
- package/es/cascader/style/index.css +205 -180
- package/es/cascader/style/index.d.ts +1 -1
- package/es/cascader/style/index.js +1 -1
- package/es/cascader/style/index.less +66 -205
- package/es/cascader/style/rtl.less +10 -84
- package/es/input-number/style/index.css +18 -4
- package/es/input-number/style/index.less +15 -2
- package/es/input-number/style/rtl.less +24 -7
- package/es/table/style/index.css +3 -0
- package/lib/cascader/index.d.ts +11 -129
- package/lib/cascader/index.js +153 -545
- package/lib/cascader/style/css.js +1 -1
- package/lib/cascader/style/index.css +205 -180
- package/lib/cascader/style/index.d.ts +1 -1
- package/lib/cascader/style/index.js +1 -1
- package/lib/cascader/style/index.less +66 -205
- package/lib/cascader/style/rtl.less +10 -84
- package/lib/input-number/style/index.css +18 -4
- package/lib/input-number/style/index.less +15 -2
- package/lib/input-number/style/rtl.less +24 -7
- package/lib/table/style/index.css +3 -0
- package/package.json +3 -2
- package/report.html +2 -2
package/es/cascader/index.js
CHANGED
@@ -1,568 +1,185 @@
|
|
1
1
|
import _extends from "@babel/runtime/helpers/esm/extends";
|
2
|
-
import _classCallCheck from "@babel/runtime/helpers/esm/classCallCheck";
|
3
|
-
import _createClass from "@babel/runtime/helpers/esm/createClass";
|
4
|
-
import _assertThisInitialized from "@babel/runtime/helpers/esm/assertThisInitialized";
|
5
|
-
import _inherits from "@babel/runtime/helpers/esm/inherits";
|
6
|
-
import _createSuper from "@babel/runtime/helpers/esm/createSuper";
|
7
2
|
import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
|
3
|
+
import _typeof from "@babel/runtime/helpers/esm/typeof";
|
4
|
+
import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
|
8
5
|
import { __rest } from "tslib";
|
9
6
|
import * as React from 'react';
|
10
|
-
import RcCascader from 'rc-cascader';
|
11
|
-
import arrayTreeFilter from 'array-tree-filter';
|
12
7
|
import classNames from 'classnames';
|
8
|
+
import RcCascader from 'rc-cascader';
|
13
9
|
import omit from "rc-util/es/omit";
|
14
|
-
import KeyCode from "rc-util/es/KeyCode";
|
15
|
-
import CloseCircleFilled from "@ant-design/icons/es/icons/CloseCircleFilled";
|
16
|
-
import DownOutlined from "@ant-design/icons/es/icons/DownOutlined";
|
17
10
|
import RightOutlined from "@ant-design/icons/es/icons/RightOutlined";
|
18
11
|
import RedoOutlined from "@ant-design/icons/es/icons/RedoOutlined";
|
19
12
|
import LeftOutlined from "@ant-design/icons/es/icons/LeftOutlined";
|
20
|
-
import Input from '../input';
|
21
|
-
import { ConfigConsumer } from '../config-provider';
|
22
|
-
import LocaleReceiver from '../locale-provider/LocaleReceiver';
|
23
13
|
import devWarning from '../_util/devWarning';
|
14
|
+
import { ConfigContext } from '../config-provider';
|
24
15
|
import SizeContext from '../config-provider/SizeContext';
|
25
|
-
import
|
26
|
-
import { getTransitionName } from '../_util/motion';
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
|
45
|
-
|
16
|
+
import getIcons from '../select/utils/iconUtil';
|
17
|
+
import { getTransitionName } from '../_util/motion';
|
18
|
+
|
19
|
+
function highlightKeyword(str, lowerKeyword, prefixCls) {
|
20
|
+
var cells = str.toLowerCase().split(lowerKeyword) // @ts-ignore
|
21
|
+
.reduce( // @ts-ignore
|
22
|
+
function (list, cur, index) {
|
23
|
+
return (// @ts-ignore
|
24
|
+
index === 0 ? [cur] : [].concat(_toConsumableArray(list), [lowerKeyword, cur])
|
25
|
+
);
|
26
|
+
}, []);
|
27
|
+
var fillCells = [];
|
28
|
+
var start = 0; // @ts-ignore
|
29
|
+
|
30
|
+
cells.forEach(function (cell, index) {
|
31
|
+
var end = start + cell.length;
|
32
|
+
var originWorld = str.slice(start, end);
|
33
|
+
start = end;
|
34
|
+
|
35
|
+
if (index % 2 === 1) {
|
36
|
+
originWorld = /*#__PURE__*/React.createElement("span", {
|
37
|
+
className: "".concat(prefixCls, "-menu-item-keyword"),
|
38
|
+
key: "seperator"
|
39
|
+
}, originWorld);
|
40
|
+
}
|
46
41
|
|
47
|
-
|
48
|
-
return path.map(function (option, index) {
|
49
|
-
var label = option[names.label];
|
50
|
-
var node = label.indexOf(inputValue) > -1 ? highlightKeyword(label, inputValue, prefixCls) : label;
|
51
|
-
return index === 0 ? node : [' / ', node];
|
42
|
+
fillCells.push(originWorld);
|
52
43
|
});
|
44
|
+
return fillCells;
|
53
45
|
}
|
54
46
|
|
55
|
-
function
|
56
|
-
|
57
|
-
return elem[names.label].indexOf(inputValue) > -1;
|
58
|
-
}
|
59
|
-
|
60
|
-
return a.findIndex(callback) - b.findIndex(callback);
|
61
|
-
}
|
47
|
+
var defaultSearchRender = function defaultSearchRender(inputValue, path, prefixCls, fieldNames) {
|
48
|
+
var optionList = []; // We do lower here to save perf
|
62
49
|
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
50
|
+
var lower = inputValue.toLowerCase();
|
51
|
+
path.forEach(function (node, index) {
|
52
|
+
if (index !== 0) {
|
53
|
+
optionList.push(' / ');
|
54
|
+
}
|
67
55
|
|
68
|
-
|
69
|
-
var fieldNames = getFieldNames(props) || {};
|
70
|
-
var names = {
|
71
|
-
children: fieldNames.children || 'children',
|
72
|
-
label: fieldNames.label || 'label',
|
73
|
-
value: fieldNames.value || 'value'
|
74
|
-
};
|
75
|
-
return names;
|
76
|
-
}
|
56
|
+
var label = node[fieldNames.label];
|
77
57
|
|
78
|
-
|
79
|
-
var ancestor = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [];
|
80
|
-
var names = getFilledFieldNames(props);
|
81
|
-
var flattenOptions = [];
|
82
|
-
var childrenName = names.children;
|
83
|
-
options.forEach(function (option) {
|
84
|
-
var path = ancestor.concat(option);
|
58
|
+
var type = _typeof(label);
|
85
59
|
|
86
|
-
if (
|
87
|
-
|
60
|
+
if (type === 'string' || type === 'number') {
|
61
|
+
label = highlightKeyword(String(label), lower, prefixCls);
|
88
62
|
}
|
89
63
|
|
90
|
-
|
91
|
-
flattenOptions = flattenOptions.concat(flattenTree(option[childrenName], props, path));
|
92
|
-
}
|
64
|
+
optionList.push(label);
|
93
65
|
});
|
94
|
-
return
|
95
|
-
}
|
96
|
-
|
97
|
-
var defaultDisplayRender = function defaultDisplayRender(label) {
|
98
|
-
return label.join(' / ');
|
66
|
+
return optionList;
|
99
67
|
};
|
100
68
|
|
101
|
-
function
|
102
|
-
var
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
|
122
|
-
|
123
|
-
|
124
|
-
|
125
|
-
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
|
131
|
-
|
132
|
-
|
133
|
-
|
134
|
-
|
135
|
-
|
136
|
-
|
137
|
-
|
138
|
-
|
139
|
-
|
140
|
-
|
141
|
-
|
142
|
-
|
143
|
-
|
144
|
-
|
145
|
-
|
146
|
-
|
147
|
-
|
148
|
-
|
149
|
-
|
150
|
-
|
151
|
-
|
152
|
-
var unwrappedValue = selectedOptions[0][keepFilteredValueField] === undefined ? value[0] : selectedOptions[0][keepFilteredValueField];
|
153
|
-
var unwrappedSelectedOptions = selectedOptions[0].path;
|
154
|
-
|
155
|
-
_this.setValue(unwrappedValue, unwrappedSelectedOptions);
|
156
|
-
|
157
|
-
return;
|
158
|
-
}
|
159
|
-
|
160
|
-
_this.setValue(value, selectedOptions);
|
161
|
-
};
|
162
|
-
|
163
|
-
_this.handlePopupVisibleChange = function (popupVisible) {
|
164
|
-
if (!('popupVisible' in _this.props)) {
|
165
|
-
_this.setState(function (state) {
|
166
|
-
return {
|
167
|
-
popupVisible: popupVisible,
|
168
|
-
inputFocused: popupVisible,
|
169
|
-
inputValue: popupVisible ? state.inputValue : ''
|
170
|
-
};
|
171
|
-
});
|
172
|
-
}
|
173
|
-
|
174
|
-
var onPopupVisibleChange = _this.props.onPopupVisibleChange;
|
175
|
-
onPopupVisibleChange === null || onPopupVisibleChange === void 0 ? void 0 : onPopupVisibleChange(popupVisible);
|
176
|
-
};
|
177
|
-
|
178
|
-
_this.handleInputBlur = function () {
|
179
|
-
_this.setState({
|
180
|
-
inputFocused: false
|
181
|
-
});
|
182
|
-
};
|
183
|
-
|
184
|
-
_this.handleInputClick = function (e) {
|
185
|
-
var _this$state = _this.state,
|
186
|
-
inputFocused = _this$state.inputFocused,
|
187
|
-
popupVisible = _this$state.popupVisible; // Prevent `Trigger` behaviour.
|
188
|
-
|
189
|
-
if (inputFocused || popupVisible) {
|
190
|
-
e.stopPropagation();
|
191
|
-
}
|
192
|
-
};
|
69
|
+
var Cascader = /*#__PURE__*/React.forwardRef(function (props, ref) {
|
70
|
+
var _classNames2;
|
71
|
+
|
72
|
+
var customizePrefixCls = props.prefixCls,
|
73
|
+
customizeSize = props.size,
|
74
|
+
className = props.className,
|
75
|
+
multiple = props.multiple,
|
76
|
+
_props$bordered = props.bordered,
|
77
|
+
bordered = _props$bordered === void 0 ? true : _props$bordered,
|
78
|
+
transitionName = props.transitionName,
|
79
|
+
_props$choiceTransiti = props.choiceTransitionName,
|
80
|
+
choiceTransitionName = _props$choiceTransiti === void 0 ? '' : _props$choiceTransiti,
|
81
|
+
popupClassName = props.popupClassName,
|
82
|
+
dropdownClassName = props.dropdownClassName,
|
83
|
+
expandIcon = props.expandIcon,
|
84
|
+
showSearch = props.showSearch,
|
85
|
+
_props$allowClear = props.allowClear,
|
86
|
+
allowClear = _props$allowClear === void 0 ? true : _props$allowClear,
|
87
|
+
notFoundContent = props.notFoundContent,
|
88
|
+
direction = props.direction,
|
89
|
+
getPopupContainer = props.getPopupContainer,
|
90
|
+
rest = __rest(props, ["prefixCls", "size", "className", "multiple", "bordered", "transitionName", "choiceTransitionName", "popupClassName", "dropdownClassName", "expandIcon", "showSearch", "allowClear", "notFoundContent", "direction", "getPopupContainer"]);
|
91
|
+
|
92
|
+
var restProps = omit(rest, ['suffixIcon']);
|
93
|
+
|
94
|
+
var _React$useContext = React.useContext(ConfigContext),
|
95
|
+
getContextPopupContainer = _React$useContext.getPopupContainer,
|
96
|
+
getPrefixCls = _React$useContext.getPrefixCls,
|
97
|
+
renderEmpty = _React$useContext.renderEmpty,
|
98
|
+
rootDirection = _React$useContext.direction;
|
99
|
+
|
100
|
+
var mergedDirection = direction || rootDirection;
|
101
|
+
var isRtl = mergedDirection === 'rtl'; // =================== Warning =====================
|
102
|
+
|
103
|
+
if (process.env.NODE_ENV !== 'production') {
|
104
|
+
devWarning(popupClassName === undefined, 'Cascader', '`popupClassName` is deprecated. Please use `dropdownClassName` instead.');
|
105
|
+
} // =================== No Found ====================
|
106
|
+
|
107
|
+
|
108
|
+
var mergedNotFoundContent = notFoundContent || renderEmpty('Cascader'); // ==================== Prefix =====================
|
109
|
+
|
110
|
+
var rootPrefixCls = getPrefixCls();
|
111
|
+
var prefixCls = getPrefixCls('select', customizePrefixCls);
|
112
|
+
var cascaderPrefixCls = getPrefixCls('cascader', customizePrefixCls); // =================== Dropdown ====================
|
113
|
+
|
114
|
+
var mergedDropdownClassName = classNames(dropdownClassName || popupClassName, "".concat(cascaderPrefixCls, "-dropdown"), _defineProperty({}, "".concat(cascaderPrefixCls, "-dropdown-rtl"), mergedDirection === 'rtl')); // ==================== Search =====================
|
115
|
+
|
116
|
+
var mergedShowSearch = React.useMemo(function () {
|
117
|
+
if (!showSearch) {
|
118
|
+
return showSearch;
|
119
|
+
}
|
193
120
|
|
194
|
-
|
195
|
-
|
196
|
-
if (e.keyCode === KeyCode.BACKSPACE || e.keyCode === KeyCode.SPACE) {
|
197
|
-
e.stopPropagation();
|
198
|
-
}
|
121
|
+
var searchConfig = {
|
122
|
+
render: defaultSearchRender
|
199
123
|
};
|
200
124
|
|
201
|
-
|
202
|
-
|
203
|
-
|
204
|
-
|
205
|
-
if (!popupVisible) {
|
206
|
-
_this.handlePopupVisibleChange(true);
|
207
|
-
}
|
125
|
+
if (_typeof(showSearch) === 'object') {
|
126
|
+
searchConfig = _extends(_extends({}, searchConfig), showSearch);
|
127
|
+
}
|
208
128
|
|
209
|
-
|
210
|
-
|
211
|
-
});
|
212
|
-
};
|
129
|
+
return searchConfig;
|
130
|
+
}, [showSearch]); // ===================== Size ======================
|
213
131
|
|
214
|
-
|
215
|
-
|
216
|
-
e.preventDefault();
|
217
|
-
e.stopPropagation();
|
218
|
-
|
219
|
-
if (!inputValue) {
|
220
|
-
_this.handlePopupVisibleChange(false);
|
221
|
-
|
222
|
-
_this.clearSelectionTimeout = setTimeout(function () {
|
223
|
-
_this.setValue([]);
|
224
|
-
}, 200);
|
225
|
-
} else {
|
226
|
-
_this.setState({
|
227
|
-
inputValue: ''
|
228
|
-
});
|
229
|
-
}
|
230
|
-
};
|
132
|
+
var size = React.useContext(SizeContext);
|
133
|
+
var mergedSize = customizeSize || size; // ===================== Icon ======================
|
231
134
|
|
232
|
-
|
233
|
-
var getContextPopupContainer = _ref3.getPopupContainer,
|
234
|
-
getPrefixCls = _ref3.getPrefixCls,
|
235
|
-
renderEmpty = _ref3.renderEmpty,
|
236
|
-
direction = _ref3.direction;
|
237
|
-
return /*#__PURE__*/React.createElement(SizeContext.Consumer, null, function (size) {
|
238
|
-
var _classNames, _classNames2, _classNames3, _classNames5;
|
239
|
-
|
240
|
-
var _assertThisInitialize = _assertThisInitialized(_this),
|
241
|
-
props = _assertThisInitialize.props,
|
242
|
-
state = _assertThisInitialize.state;
|
243
|
-
|
244
|
-
var customizePrefixCls = props.prefixCls,
|
245
|
-
customizeInputPrefixCls = props.inputPrefixCls,
|
246
|
-
children = props.children,
|
247
|
-
_props$placeholder = props.placeholder,
|
248
|
-
placeholder = _props$placeholder === void 0 ? locale.placeholder || 'Please select' : _props$placeholder,
|
249
|
-
customizeSize = props.size,
|
250
|
-
disabled = props.disabled,
|
251
|
-
className = props.className,
|
252
|
-
style = props.style,
|
253
|
-
allowClear = props.allowClear,
|
254
|
-
_props$showSearch = props.showSearch,
|
255
|
-
showSearch = _props$showSearch === void 0 ? false : _props$showSearch,
|
256
|
-
suffixIcon = props.suffixIcon,
|
257
|
-
expandIcon = props.expandIcon,
|
258
|
-
notFoundContent = props.notFoundContent,
|
259
|
-
popupClassName = props.popupClassName,
|
260
|
-
bordered = props.bordered,
|
261
|
-
dropdownRender = props.dropdownRender,
|
262
|
-
otherProps = __rest(props, ["prefixCls", "inputPrefixCls", "children", "placeholder", "size", "disabled", "className", "style", "allowClear", "showSearch", "suffixIcon", "expandIcon", "notFoundContent", "popupClassName", "bordered", "dropdownRender"]);
|
263
|
-
|
264
|
-
var mergedSize = customizeSize || size;
|
265
|
-
var value = state.value,
|
266
|
-
inputFocused = state.inputFocused;
|
267
|
-
var isRtlLayout = direction === 'rtl';
|
268
|
-
var prefixCls = getPrefixCls('cascader', customizePrefixCls);
|
269
|
-
var inputPrefixCls = getPrefixCls('input', customizeInputPrefixCls);
|
270
|
-
var sizeCls = classNames((_classNames = {}, _defineProperty(_classNames, "".concat(inputPrefixCls, "-lg"), mergedSize === 'large'), _defineProperty(_classNames, "".concat(inputPrefixCls, "-sm"), mergedSize === 'small'), _classNames));
|
271
|
-
var clearIcon = allowClear && !disabled && value.length > 0 || state.inputValue ? /*#__PURE__*/React.createElement(CloseCircleFilled, {
|
272
|
-
className: "".concat(prefixCls, "-picker-clear"),
|
273
|
-
onClick: _this.clearSelection
|
274
|
-
}) : null;
|
275
|
-
var arrowCls = classNames((_classNames2 = {}, _defineProperty(_classNames2, "".concat(prefixCls, "-picker-arrow"), true), _defineProperty(_classNames2, "".concat(prefixCls, "-picker-arrow-expand"), state.popupVisible), _classNames2));
|
276
|
-
var pickerCls = classNames("".concat(prefixCls, "-picker"), (_classNames3 = {}, _defineProperty(_classNames3, "".concat(prefixCls, "-picker-rtl"), isRtlLayout), _defineProperty(_classNames3, "".concat(prefixCls, "-picker-with-value"), state.inputValue), _defineProperty(_classNames3, "".concat(prefixCls, "-picker-disabled"), disabled), _defineProperty(_classNames3, "".concat(prefixCls, "-picker-").concat(mergedSize), !!mergedSize), _defineProperty(_classNames3, "".concat(prefixCls, "-picker-show-search"), !!showSearch), _defineProperty(_classNames3, "".concat(prefixCls, "-picker-focused"), inputFocused), _defineProperty(_classNames3, "".concat(prefixCls, "-picker-borderless"), !bordered), _classNames3), className); // Fix bug of https://github.com/facebook/react/pull/5004
|
277
|
-
// and https://fb.me/react-unknown-prop
|
278
|
-
|
279
|
-
var inputProps = omit( // Not know why these props left
|
280
|
-
otherProps, ['onChange', 'options', 'popupPlacement', 'transitionName', 'displayRender', 'onPopupVisibleChange', 'changeOnSelect', 'expandTrigger', 'popupVisible', 'getPopupContainer', 'loadData', 'filterOption', 'renderFilteredOption', 'sortFilteredOption', 'fieldNames']);
|
281
|
-
var options = props.options;
|
282
|
-
var names = getFilledFieldNames(_this.props);
|
283
|
-
|
284
|
-
if (options && options.length > 0) {
|
285
|
-
if (state.inputValue) {
|
286
|
-
options = _this.generateFilteredOptions(prefixCls, renderEmpty);
|
287
|
-
}
|
288
|
-
} else {
|
289
|
-
options = [getEmptyNode(renderEmpty, names, notFoundContent)];
|
290
|
-
} // Dropdown menu should keep previous status until it is fully closed.
|
291
|
-
|
292
|
-
|
293
|
-
if (!state.popupVisible) {
|
294
|
-
options = _this.cachedOptions;
|
295
|
-
} else {
|
296
|
-
_this.cachedOptions = options;
|
297
|
-
}
|
298
|
-
|
299
|
-
var dropdownMenuColumnStyle = {};
|
300
|
-
var isNotFound = (options || []).length === 1 && options[0].isEmptyNode;
|
301
|
-
|
302
|
-
if (isNotFound) {
|
303
|
-
dropdownMenuColumnStyle.height = 'auto'; // Height of one row.
|
304
|
-
} // The default value of `matchInputWidth` is `true`
|
305
|
-
|
306
|
-
|
307
|
-
var resultListMatchInputWidth = showSearch.matchInputWidth !== false;
|
308
|
-
|
309
|
-
if (resultListMatchInputWidth && (state.inputValue || isNotFound) && _this.input) {
|
310
|
-
dropdownMenuColumnStyle.width = _this.input.input.offsetWidth;
|
311
|
-
}
|
312
|
-
|
313
|
-
var inputIcon;
|
314
|
-
|
315
|
-
if (suffixIcon) {
|
316
|
-
inputIcon = replaceElement(suffixIcon, /*#__PURE__*/React.createElement("span", {
|
317
|
-
className: "".concat(prefixCls, "-picker-arrow")
|
318
|
-
}, suffixIcon), function () {
|
319
|
-
var _classNames4;
|
320
|
-
|
321
|
-
return {
|
322
|
-
className: classNames((_classNames4 = {}, _defineProperty(_classNames4, suffixIcon.props.className, suffixIcon.props.className), _defineProperty(_classNames4, "".concat(prefixCls, "-picker-arrow"), true), _classNames4))
|
323
|
-
};
|
324
|
-
});
|
325
|
-
} else {
|
326
|
-
inputIcon = /*#__PURE__*/React.createElement(DownOutlined, {
|
327
|
-
className: arrowCls
|
328
|
-
});
|
329
|
-
}
|
330
|
-
|
331
|
-
var input = children || /*#__PURE__*/React.createElement("span", {
|
332
|
-
style: style,
|
333
|
-
className: pickerCls
|
334
|
-
}, /*#__PURE__*/React.createElement("span", {
|
335
|
-
className: "".concat(prefixCls, "-picker-label")
|
336
|
-
}, _this.getLabel()), /*#__PURE__*/React.createElement(Input, _extends({}, inputProps, {
|
337
|
-
tabIndex: -1,
|
338
|
-
ref: _this.saveInput,
|
339
|
-
prefixCls: inputPrefixCls,
|
340
|
-
placeholder: value && value.length > 0 ? undefined : placeholder,
|
341
|
-
className: "".concat(prefixCls, "-input ").concat(sizeCls),
|
342
|
-
value: state.inputValue,
|
343
|
-
disabled: disabled,
|
344
|
-
readOnly: !showSearch,
|
345
|
-
autoComplete: inputProps.autoComplete || 'off',
|
346
|
-
onClick: showSearch ? _this.handleInputClick : undefined,
|
347
|
-
onBlur: showSearch ? _this.handleInputBlur : undefined,
|
348
|
-
onKeyDown: _this.handleKeyDown,
|
349
|
-
onChange: showSearch ? _this.handleInputChange : undefined
|
350
|
-
})), clearIcon, inputIcon);
|
351
|
-
var expandIconNode;
|
352
|
-
|
353
|
-
if (expandIcon) {
|
354
|
-
expandIconNode = expandIcon;
|
355
|
-
} else {
|
356
|
-
expandIconNode = isRtlLayout ? /*#__PURE__*/React.createElement(LeftOutlined, null) : /*#__PURE__*/React.createElement(RightOutlined, null);
|
357
|
-
}
|
358
|
-
|
359
|
-
var loadingIcon = /*#__PURE__*/React.createElement("span", {
|
360
|
-
className: "".concat(prefixCls, "-menu-item-loading-icon")
|
361
|
-
}, /*#__PURE__*/React.createElement(RedoOutlined, {
|
362
|
-
spin: true
|
363
|
-
}));
|
364
|
-
var getPopupContainer = props.getPopupContainer || getContextPopupContainer;
|
365
|
-
var rest = omit(props, ['inputIcon', 'expandIcon', 'loadingIcon', 'bordered', 'className']);
|
366
|
-
var rcCascaderPopupClassName = classNames(popupClassName, (_classNames5 = {}, _defineProperty(_classNames5, "".concat(prefixCls, "-menu-").concat(direction), direction === 'rtl'), _defineProperty(_classNames5, "".concat(prefixCls, "-menu-empty"), options.length === 1 && options[0].value === 'ANT_CASCADER_NOT_FOUND'), _classNames5));
|
367
|
-
var rootPrefixCls = getPrefixCls();
|
368
|
-
return /*#__PURE__*/React.createElement(RcCascader, _extends({}, rest, {
|
369
|
-
prefixCls: prefixCls,
|
370
|
-
getPopupContainer: getPopupContainer,
|
371
|
-
options: options,
|
372
|
-
value: value,
|
373
|
-
popupVisible: state.popupVisible,
|
374
|
-
onPopupVisibleChange: _this.handlePopupVisibleChange,
|
375
|
-
onChange: _this.handleChange,
|
376
|
-
dropdownMenuColumnStyle: dropdownMenuColumnStyle,
|
377
|
-
expandIcon: expandIconNode,
|
378
|
-
loadingIcon: loadingIcon,
|
379
|
-
popupClassName: rcCascaderPopupClassName,
|
380
|
-
popupPlacement: _this.getPopupPlacement(direction),
|
381
|
-
// rc-cascader should update ts define to fix this case
|
382
|
-
dropdownRender: dropdownRender,
|
383
|
-
transitionName: getTransitionName(rootPrefixCls, 'slide-up', props.transitionName)
|
384
|
-
}), input);
|
385
|
-
});
|
386
|
-
};
|
135
|
+
var mergedExpandIcon = expandIcon;
|
387
136
|
|
388
|
-
|
389
|
-
|
390
|
-
inputValue: '',
|
391
|
-
inputFocused: false,
|
392
|
-
popupVisible: props.popupVisible,
|
393
|
-
flattenOptions: props.showSearch ? flattenTree(props.options, props) : undefined,
|
394
|
-
prevProps: props
|
395
|
-
};
|
396
|
-
return _this;
|
137
|
+
if (!expandIcon) {
|
138
|
+
mergedExpandIcon = isRtl ? /*#__PURE__*/React.createElement(LeftOutlined, null) : /*#__PURE__*/React.createElement(RightOutlined, null);
|
397
139
|
}
|
398
140
|
|
399
|
-
|
400
|
-
|
401
|
-
|
402
|
-
|
403
|
-
|
404
|
-
|
405
|
-
|
406
|
-
|
407
|
-
|
408
|
-
|
409
|
-
|
410
|
-
|
411
|
-
|
412
|
-
|
413
|
-
|
414
|
-
|
415
|
-
|
416
|
-
|
417
|
-
|
418
|
-
|
419
|
-
|
420
|
-
|
421
|
-
|
422
|
-
|
423
|
-
|
424
|
-
|
425
|
-
|
426
|
-
|
427
|
-
|
428
|
-
|
429
|
-
|
430
|
-
|
431
|
-
|
432
|
-
|
433
|
-
|
434
|
-
|
435
|
-
|
436
|
-
|
437
|
-
|
438
|
-
|
439
|
-
|
440
|
-
|
441
|
-
|
442
|
-
|
443
|
-
var _this$state2 = this.state,
|
444
|
-
_this$state2$flattenO = _this$state2.flattenOptions,
|
445
|
-
flattenOptions = _this$state2$flattenO === void 0 ? [] : _this$state2$flattenO,
|
446
|
-
inputValue = _this$state2.inputValue; // Limit the filter if needed
|
447
|
-
|
448
|
-
var filtered;
|
449
|
-
|
450
|
-
if (limit > 0) {
|
451
|
-
filtered = [];
|
452
|
-
var matchCount = 0; // Perf optimization to filter items only below the limit
|
453
|
-
|
454
|
-
flattenOptions.some(function (path) {
|
455
|
-
var match = filter(_this2.state.inputValue, path, names);
|
456
|
-
|
457
|
-
if (match) {
|
458
|
-
filtered.push(path);
|
459
|
-
matchCount += 1;
|
460
|
-
}
|
461
|
-
|
462
|
-
return matchCount >= limit;
|
463
|
-
});
|
464
|
-
} else {
|
465
|
-
devWarning(typeof limit !== 'number', 'Cascader', "'limit' of showSearch should be positive number or false.");
|
466
|
-
filtered = flattenOptions.filter(function (path) {
|
467
|
-
return filter(_this2.state.inputValue, path, names);
|
468
|
-
});
|
469
|
-
}
|
470
|
-
|
471
|
-
filtered = filtered.sort(function (a, b) {
|
472
|
-
return sort(a, b, inputValue, names);
|
473
|
-
});
|
474
|
-
|
475
|
-
if (filtered.length > 0) {
|
476
|
-
// Fix issue: https://github.com/ant-design/ant-design/issues/26554
|
477
|
-
var field = names.value === names.label ? keepFilteredValueField : names.value;
|
478
|
-
return filtered.map(function (path) {
|
479
|
-
var _ref4;
|
480
|
-
|
481
|
-
return _ref4 = {
|
482
|
-
__IS_FILTERED_OPTION: true,
|
483
|
-
path: path
|
484
|
-
}, _defineProperty(_ref4, field, path.map(function (o) {
|
485
|
-
return o[names.value];
|
486
|
-
})), _defineProperty(_ref4, names.label, render(inputValue, path, prefixCls, names)), _defineProperty(_ref4, "disabled", path.some(function (o) {
|
487
|
-
return !!o.disabled;
|
488
|
-
})), _defineProperty(_ref4, "isEmptyNode", true), _ref4;
|
489
|
-
});
|
490
|
-
}
|
491
|
-
|
492
|
-
return [getEmptyNode(renderEmpty, names, notFoundContent)];
|
493
|
-
}
|
494
|
-
}, {
|
495
|
-
key: "focus",
|
496
|
-
value: function focus() {
|
497
|
-
this.input.focus();
|
498
|
-
}
|
499
|
-
}, {
|
500
|
-
key: "blur",
|
501
|
-
value: function blur() {
|
502
|
-
this.input.blur();
|
503
|
-
}
|
504
|
-
}, {
|
505
|
-
key: "getPopupPlacement",
|
506
|
-
value: function getPopupPlacement() {
|
507
|
-
var direction = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'ltr';
|
508
|
-
var popupPlacement = this.props.popupPlacement;
|
509
|
-
|
510
|
-
if (popupPlacement !== undefined) {
|
511
|
-
return popupPlacement;
|
512
|
-
}
|
513
|
-
|
514
|
-
return direction === 'rtl' ? 'bottomRight' : 'bottomLeft';
|
515
|
-
}
|
516
|
-
}, {
|
517
|
-
key: "render",
|
518
|
-
value: function render() {
|
519
|
-
var _this3 = this;
|
520
|
-
|
521
|
-
return /*#__PURE__*/React.createElement(ConfigConsumer, null, function (configArgument) {
|
522
|
-
return (
|
523
|
-
/*#__PURE__*/
|
524
|
-
// @ts-ignore
|
525
|
-
React.createElement(LocaleReceiver, null, function (locale) {
|
526
|
-
return _this3.renderCascader(configArgument, locale);
|
527
|
-
})
|
528
|
-
);
|
529
|
-
});
|
530
|
-
}
|
531
|
-
}], [{
|
532
|
-
key: "getDerivedStateFromProps",
|
533
|
-
value: function getDerivedStateFromProps(nextProps, _ref5) {
|
534
|
-
var prevProps = _ref5.prevProps;
|
535
|
-
var newState = {
|
536
|
-
prevProps: nextProps
|
537
|
-
};
|
538
|
-
|
539
|
-
if ('value' in nextProps) {
|
540
|
-
newState.value = nextProps.value || [];
|
541
|
-
}
|
542
|
-
|
543
|
-
if ('popupVisible' in nextProps) {
|
544
|
-
newState.popupVisible = nextProps.popupVisible;
|
545
|
-
}
|
546
|
-
|
547
|
-
if (nextProps.showSearch && prevProps.options !== nextProps.options) {
|
548
|
-
newState.flattenOptions = flattenTree(nextProps.options, nextProps);
|
549
|
-
}
|
550
|
-
|
551
|
-
if (process.env.NODE_ENV !== 'production' && nextProps.options) {
|
552
|
-
warningValueNotExist(nextProps.options, getFieldNames(nextProps));
|
553
|
-
}
|
554
|
-
|
555
|
-
return newState;
|
556
|
-
}
|
557
|
-
}]);
|
558
|
-
|
559
|
-
return Cascader;
|
560
|
-
}(React.Component);
|
561
|
-
|
562
|
-
Cascader.defaultProps = {
|
563
|
-
options: [],
|
564
|
-
disabled: false,
|
565
|
-
allowClear: true,
|
566
|
-
bordered: true
|
567
|
-
};
|
141
|
+
var loadingIcon = /*#__PURE__*/React.createElement("span", {
|
142
|
+
className: "".concat(prefixCls, "-menu-item-loading-icon")
|
143
|
+
}, /*#__PURE__*/React.createElement(RedoOutlined, {
|
144
|
+
spin: true
|
145
|
+
})); // =================== Multiple ====================
|
146
|
+
|
147
|
+
var checkable = React.useMemo(function () {
|
148
|
+
return multiple ? /*#__PURE__*/React.createElement("span", {
|
149
|
+
className: "".concat(cascaderPrefixCls, "-checkbox-inner")
|
150
|
+
}) : false;
|
151
|
+
}, [multiple]); // ===================== Icons =====================
|
152
|
+
|
153
|
+
var _getIcons = getIcons(_extends(_extends({}, props), {
|
154
|
+
multiple: multiple,
|
155
|
+
prefixCls: prefixCls
|
156
|
+
})),
|
157
|
+
suffixIcon = _getIcons.suffixIcon,
|
158
|
+
removeIcon = _getIcons.removeIcon,
|
159
|
+
clearIcon = _getIcons.clearIcon; // ==================== Render =====================
|
160
|
+
|
161
|
+
|
162
|
+
return /*#__PURE__*/React.createElement(RcCascader, _extends({
|
163
|
+
prefixCls: prefixCls,
|
164
|
+
className: classNames(!customizePrefixCls && cascaderPrefixCls, (_classNames2 = {}, _defineProperty(_classNames2, "".concat(prefixCls, "-lg"), mergedSize === 'large'), _defineProperty(_classNames2, "".concat(prefixCls, "-sm"), mergedSize === 'small'), _defineProperty(_classNames2, "".concat(prefixCls, "-rtl"), isRtl), _defineProperty(_classNames2, "".concat(prefixCls, "-borderless"), !bordered), _classNames2), className)
|
165
|
+
}, restProps, {
|
166
|
+
direction: mergedDirection,
|
167
|
+
notFoundContent: mergedNotFoundContent,
|
168
|
+
allowClear: allowClear,
|
169
|
+
showSearch: mergedShowSearch,
|
170
|
+
expandIcon: mergedExpandIcon,
|
171
|
+
inputIcon: suffixIcon,
|
172
|
+
removeIcon: removeIcon,
|
173
|
+
clearIcon: clearIcon,
|
174
|
+
loadingIcon: loadingIcon,
|
175
|
+
checkable: checkable,
|
176
|
+
dropdownClassName: mergedDropdownClassName,
|
177
|
+
dropdownPrefixCls: customizePrefixCls || cascaderPrefixCls,
|
178
|
+
choiceTransitionName: getTransitionName(rootPrefixCls, '', choiceTransitionName),
|
179
|
+
transitionName: getTransitionName(rootPrefixCls, 'slide-up', transitionName),
|
180
|
+
getPopupContainer: getPopupContainer || getContextPopupContainer,
|
181
|
+
ref: ref
|
182
|
+
}));
|
183
|
+
});
|
184
|
+
Cascader.displayName = 'Cascader';
|
568
185
|
export default Cascader;
|