@fle-ui/next 1.0.0 → 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.
Files changed (198) hide show
  1. package/.history/.gitignore_20210922213827 +27 -0
  2. package/.history/.gitignore_20211029154108 +29 -0
  3. package/.history/.gitignore_20211029154109 +29 -0
  4. package/.history/.gitignore_20211029173434 +29 -0
  5. package/.history/.umirc_20210922213827.ts +153 -0
  6. package/.history/.umirc_20211018162341.ts +153 -0
  7. package/.history/{package_20211018113630.json → package_20211213140100.json} +7 -3
  8. package/.history/{package_20211018113634.json → package_20211223145956.json} +8 -3
  9. package/.history/{package_20211013165524.json → package_20211223211341.json} +9 -4
  10. package/.history/{package_20211018101440.json → package_20211223220710.json} +9 -4
  11. package/.history/package_20211223221147.json +146 -0
  12. package/.history/package_20211223221328.json +146 -0
  13. package/.history/package_20211223221445.json +146 -0
  14. package/.umirc.ts +2 -0
  15. package/dist/@fle-ui/next.css +2304 -2261
  16. package/dist/@fle-ui/next.css.map +1 -1
  17. package/dist/@fle-ui/next.js +1166 -1248
  18. package/dist/@fle-ui/next.js.map +1 -1
  19. package/dist/@fle-ui/next.min.css +3 -3
  20. package/dist/@fle-ui/next.min.css.map +1 -1
  21. package/dist/@fle-ui/next.min.js +3 -3
  22. package/dist/@fle-ui/next.min.js.map +1 -1
  23. package/docs-dist/{components__affix__affix.md~components__alert__alert.md~components__anchor__anchor.md~components__au~00d1741d.js → components__affix__affix.md~components__alert__alert.md~components__anchor__anchor.md~components__au~31d645aa.js} +2690 -1940
  24. package/docs-dist/components__avatar__avatar.md.js +227 -372
  25. package/docs-dist/components__button__button.md.js +27 -27
  26. package/docs-dist/components__form__form.md.js +1 -1
  27. package/docs-dist/components__layout__layout.md.js +1 -1
  28. package/docs-dist/components__modal__modal.md.js +17 -11
  29. package/docs-dist/components__popconfirm__popconfirm.md.js +51 -51
  30. package/docs-dist/components__skeleton__skeleton.md.chunk.css +1 -0
  31. package/docs-dist/components__skeleton__skeleton.md.js +1080 -0
  32. package/docs-dist/components__slider__slider.md.js +1 -1
  33. package/docs-dist/components__space__space.md.js +1 -1
  34. package/docs-dist/components__spin__spin.md.js +1 -1
  35. package/docs-dist/components__statistic__statistic.md.js +1 -1
  36. package/docs-dist/components__steps__steps.md.js +1 -1
  37. package/docs-dist/components__switch__switch.md.js +1 -1
  38. package/docs-dist/components__table__table.md.js +1 -1
  39. package/docs-dist/components__tabs__tabs.md.js +1 -1
  40. package/docs-dist/components__tag__tag.md.js +1 -1
  41. package/docs-dist/components__time-picker__time-picker.md.js +1 -1
  42. package/docs-dist/components__timeline__timeline.md.js +1 -1
  43. package/docs-dist/components__tooltip__tooltip.md.js +1 -1
  44. package/docs-dist/components__transfer__transfer.md.js +1 -1
  45. package/docs-dist/components__tree-select__tree-select.md.js +1 -1
  46. package/docs-dist/components__tree__tree.md.chunk.css +1 -0
  47. package/docs-dist/components__tree__tree.md.js +1775 -0
  48. package/docs-dist/components__typography__typography.md.js +1 -1
  49. package/docs-dist/components__upload__upload.md.js +7 -11
  50. package/docs-dist/demos_bmurcdaerb.js +1 -1
  51. package/docs-dist/demos_bmurcdaerb~demos_citsitats~demos_dirg~demos_drac~demos_ecaps~demos_eert~demos_egami~demos_egas~1a5cf206.chunk.css +2 -0
  52. package/docs-dist/{demos_bmurcdaerb~demos_citsitats~demos_dirg~demos_drac~demos_ecaps~demos_egami~demos_egassem~demos_e~57973d2f.js → demos_bmurcdaerb~demos_citsitats~demos_dirg~demos_drac~demos_ecaps~demos_eert~demos_egami~demos_egas~1a5cf206.js} +1536 -1843
  53. package/docs-dist/demos_citsitats.js +1 -1
  54. package/docs-dist/demos_daolpu.chunk.css +2 -2
  55. package/docs-dist/demos_daolpu.js +2598 -2905
  56. package/docs-dist/demos_dirg.js +1 -1
  57. package/docs-dist/demos_drac.js +1 -1
  58. package/docs-dist/demos_ecaps.js +1 -1
  59. package/docs-dist/demos_eert.chunk.css +1 -0
  60. package/docs-dist/demos_eert.js +1203 -0
  61. package/docs-dist/demos_egami.js +1 -1
  62. package/docs-dist/demos_egassem.js +1 -1
  63. package/docs-dist/demos_egdab.js +1 -1
  64. package/docs-dist/demos_elbat.chunk.css +2 -2
  65. package/docs-dist/demos_elbat.js +649 -956
  66. package/docs-dist/demos_enilemit.js +1 -1
  67. package/docs-dist/demos_espalloc.js +1 -1
  68. package/docs-dist/demos_etar.js +75 -70
  69. package/docs-dist/demos_etelpmoc-otua.js +1 -1
  70. package/docs-dist/demos_gat.js +1 -1
  71. package/docs-dist/demos_hctiws.js +1 -1
  72. package/docs-dist/demos_ladom.js +1 -1
  73. package/docs-dist/demos_lesuorac.js +1 -1
  74. package/docs-dist/demos_mrifnocpop.js +2 -2
  75. package/docs-dist/demos_mrof.js +1 -2
  76. package/docs-dist/demos_nips.js +1 -1
  77. package/docs-dist/demos_noitacifiton.js +2 -2
  78. package/docs-dist/demos_noitanigap.js +1 -1
  79. package/docs-dist/demos_noteleks.js +691 -0
  80. package/docs-dist/demos_nottub.js +1 -1
  81. package/docs-dist/demos_nwodpord.js +1 -1
  82. package/docs-dist/demos_oidar.js +1 -1
  83. package/docs-dist/demos_pitloot.js +1 -1
  84. package/docs-dist/demos_pot-kcab.js +10 -10
  85. package/docs-dist/demos_radnelac.js +1 -1
  86. package/docs-dist/demos_ratava.js +4 -4
  87. package/docs-dist/demos_rebmun-tupni.js +1 -1
  88. package/docs-dist/demos_redacsac.js +1 -1
  89. package/docs-dist/demos_redaeh-egap.js +1 -1
  90. package/docs-dist/demos_redils.js +1 -1
  91. package/docs-dist/demos_redivid.js +1 -1
  92. package/docs-dist/demos_redivorp-gifnoc.js +6 -6
  93. package/docs-dist/demos_refsnart.js +1 -1
  94. package/docs-dist/demos_rekcip-emit.js +1 -1
  95. package/docs-dist/demos_rekcip-etad.js +3 -3
  96. package/docs-dist/demos_revopop.js +1 -1
  97. package/docs-dist/demos_reward.js +1 -1
  98. package/docs-dist/demos_rohcna.js +1 -1
  99. package/docs-dist/demos_sbat.chunk.css +2 -2
  100. package/docs-dist/demos_sbat.js +2302 -2609
  101. package/docs-dist/demos_snoitnem.js +1 -1
  102. package/docs-dist/demos_snoitpircsed.js +1 -1
  103. package/docs-dist/demos_spets.js +1 -1
  104. package/docs-dist/demos_ssergorp.js +1 -1
  105. package/docs-dist/demos_tceles.js +1 -1
  106. package/docs-dist/demos_tluser.js +1 -1
  107. package/docs-dist/demos_tnemmoc.js +1 -1
  108. package/docs-dist/demos_trela.js +1 -1
  109. package/docs-dist/demos_tsil.js +1 -1
  110. package/docs-dist/demos_tuoyal.js +1 -1
  111. package/docs-dist/demos_tupni.js +2 -2
  112. package/docs-dist/demos_unem.js +1 -1
  113. package/docs-dist/demos_xiffa.js +1 -1
  114. package/docs-dist/demos_xobkcehc.js +1 -1
  115. package/docs-dist/demos_yhpargopyt.js +1 -1
  116. package/docs-dist/demos_ytpme.js +1 -1
  117. package/docs-dist/docs__document__getting-started.md.js +1 -1
  118. package/docs-dist/docs__document__introduce.md.js +1 -1
  119. package/docs-dist/docs__document__practical-projects.md.js +1 -1
  120. package/docs-dist/docs__index.md.js +1 -1
  121. package/docs-dist/docs__story__index.md.js +23 -1
  122. package/docs-dist/dumi_demos.js +1 -1
  123. package/docs-dist/umi.js +475 -242
  124. package/docs-dist/{vendors~components__affix__affix.md~components__alert__alert.md~components__anchor__anchor.md~compon~e29e5a37.chunk.css → vendors~components__affix__affix.md~components__alert__alert.md~components__anchor__anchor.md~compon~06d8f7d3.chunk.css} +0 -0
  125. package/docs-dist/{vendors~components__affix__affix.md~components__alert__alert.md~components__anchor__anchor.md~compon~e29e5a37.js → vendors~components__affix__affix.md~components__alert__alert.md~components__anchor__anchor.md~compon~06d8f7d3.js} +0 -0
  126. package/docs-dist/{vendors~components__affix__affix.md~components__alert__alert.md~components__anchor__anchor.md~compon~ac3aca9a.js → vendors~components__affix__affix.md~components__alert__alert.md~components__anchor__anchor.md~compon~11c8b8d8.js} +0 -0
  127. package/docs-dist/{vendors~components__affix__affix.md~components__alert__alert.md~components__anchor__anchor.md~compon~3ba4f4a1.js → vendors~components__affix__affix.md~components__alert__alert.md~components__anchor__anchor.md~compon~44483e31.js} +0 -0
  128. package/docs-dist/{vendors~demos_bmurcdaerb~demos_citsitats~demos_daolpu~demos_dirg~demos_drac~demos_ecaps~demos_egami~~4cc402e9.js → vendors~demos_bmurcdaerb~demos_citsitats~demos_daolpu~demos_dirg~demos_drac~demos_ecaps~demos_eert~d~f20ff6ec.js} +9204 -8936
  129. package/docs-dist/vendors~demos_gat.js +1 -1
  130. package/docs-dist/vendors~demos_ladom.js +1 -1
  131. package/docs-dist/vendors~demos_redivorp-gifnoc.js +1 -1
  132. package/docs-dist/vendors~demos_sbat.js +1 -1
  133. package/docs-dist/vendors~demos_trela.js +1 -1
  134. package/docs-dist/vendors~demos_tsil.js +1 -1
  135. package/docs-dist/vendors~demos_tuoyal.js +1 -1
  136. package/docs-dist/vendors~wrappers.js +1 -1
  137. package/docs-dist/wrappers.js +2 -2
  138. package/es/badge/style/index.css +5 -5
  139. package/es/cascader/index.d.ts +11 -129
  140. package/es/cascader/index.js +151 -534
  141. package/es/cascader/style/css.js +1 -1
  142. package/es/cascader/style/index.css +205 -180
  143. package/es/cascader/style/index.d.ts +1 -1
  144. package/es/cascader/style/index.js +1 -1
  145. package/es/cascader/style/index.less +66 -205
  146. package/es/cascader/style/rtl.less +10 -84
  147. package/es/drawer/style/index.css +1 -1
  148. package/es/input-number/style/index.css +18 -4
  149. package/es/input-number/style/index.less +15 -2
  150. package/es/input-number/style/rtl.less +24 -7
  151. package/es/modal/style/index.css +10 -9
  152. package/es/modal/style/modal.less +3 -2
  153. package/es/popover/style/index.css +2 -2
  154. package/es/progress/style/index.css +3 -3
  155. package/es/result/noFound.js +1 -1
  156. package/es/result/style/index.css +1 -1
  157. package/es/style/color/colors.less +3 -3
  158. package/es/style/theme.less +7 -4
  159. package/es/table/demo/drag-sorting/index.less +2 -2
  160. package/es/table/style/index.css +3 -0
  161. package/es/tag/style/index.css +5 -5
  162. package/es/tooltip/style/index.css +2 -2
  163. package/es/upload/style/index.css +2 -2
  164. package/es/upload/style/index.less +5 -3
  165. package/lib/badge/style/index.css +5 -5
  166. package/lib/cascader/index.d.ts +11 -129
  167. package/lib/cascader/index.js +153 -545
  168. package/lib/cascader/style/css.js +1 -1
  169. package/lib/cascader/style/index.css +205 -180
  170. package/lib/cascader/style/index.d.ts +1 -1
  171. package/lib/cascader/style/index.js +1 -1
  172. package/lib/cascader/style/index.less +66 -205
  173. package/lib/cascader/style/rtl.less +10 -84
  174. package/lib/drawer/style/index.css +1 -1
  175. package/lib/input-number/style/index.css +18 -4
  176. package/lib/input-number/style/index.less +15 -2
  177. package/lib/input-number/style/rtl.less +24 -7
  178. package/lib/modal/style/index.css +10 -9
  179. package/lib/modal/style/modal.less +3 -2
  180. package/lib/popover/style/index.css +2 -2
  181. package/lib/progress/style/index.css +3 -3
  182. package/lib/result/noFound.js +1 -1
  183. package/lib/result/style/index.css +1 -1
  184. package/lib/style/color/colors.less +3 -3
  185. package/lib/style/theme.less +7 -4
  186. package/lib/table/demo/drag-sorting/index.less +2 -2
  187. package/lib/table/style/index.css +3 -0
  188. package/lib/tag/style/index.css +5 -5
  189. package/lib/tooltip/style/index.css +2 -2
  190. package/lib/upload/style/index.css +2 -2
  191. package/lib/upload/style/index.less +5 -3
  192. package/package.json +3 -2
  193. package/report.html +2 -2
  194. package/.history/package_20211011190148.json +0 -141
  195. package/.history/package_20211011193053.json +0 -141
  196. package/.history/package_20211018113658.json +0 -141
  197. package/.history/package_20211018113740.json +0 -141
  198. package/docs-dist/demos_bmurcdaerb~demos_citsitats~demos_dirg~demos_drac~demos_ecaps~demos_egami~demos_egassem~demos_e~57973d2f.chunk.css +0 -2
@@ -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 { replaceElement } from '../_util/reactNode';
26
- import { getTransitionName } from '../_util/motion'; // We limit the filtered item count by default
27
-
28
- var defaultLimit = 50; // keep value when filtering
29
-
30
- var keepFilteredValueField = '__KEEP_FILTERED_OPTION_VALUE';
31
-
32
- function highlightKeyword(str, keyword, prefixCls) {
33
- return str.split(keyword).map(function (node, index) {
34
- return index === 0 ? node : [/*#__PURE__*/React.createElement("span", {
35
- className: "".concat(prefixCls, "-menu-item-keyword"),
36
- key: "seperator"
37
- }, keyword), node];
38
- });
39
- }
40
-
41
- function defaultFilterOption(inputValue, path, names) {
42
- return path.some(function (option) {
43
- return option[names.label].indexOf(inputValue) > -1;
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
- function defaultRenderFilteredOption(inputValue, path, prefixCls, names) {
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 defaultSortFilteredOption(a, b, inputValue, names) {
56
- function callback(elem) {
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
- function getFieldNames(_ref) {
64
- var fieldNames = _ref.fieldNames;
65
- return fieldNames;
66
- }
50
+ var lower = inputValue.toLowerCase();
51
+ path.forEach(function (node, index) {
52
+ if (index !== 0) {
53
+ optionList.push(' / ');
54
+ }
67
55
 
68
- function getFilledFieldNames(props) {
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
- function flattenTree(options, props) {
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 (props.changeOnSelect || !option[childrenName] || !option[childrenName].length) {
87
- flattenOptions.push(path);
60
+ if (type === 'string' || type === 'number') {
61
+ label = highlightKeyword(String(label), lower, prefixCls);
88
62
  }
89
63
 
90
- if (option[childrenName]) {
91
- flattenOptions = flattenOptions.concat(flattenTree(option[childrenName], props, path));
92
- }
64
+ optionList.push(label);
93
65
  });
94
- return flattenOptions;
95
- }
96
-
97
- var defaultDisplayRender = function defaultDisplayRender(label) {
98
- return label.join(' / ');
66
+ return optionList;
99
67
  };
100
68
 
101
- function warningValueNotExist(list) {
102
- var fieldNames = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
103
- (list || []).forEach(function (item) {
104
- var valueFieldName = fieldNames.value || 'value';
105
- devWarning(valueFieldName in item, 'Cascader', 'Not found `value` in `options`.');
106
- warningValueNotExist(item[fieldNames.children || 'children'], fieldNames);
107
- });
108
- }
109
-
110
- function getEmptyNode(renderEmpty, names, notFoundContent) {
111
- var _ref2;
112
-
113
- return _ref2 = {}, _defineProperty(_ref2, names.value, 'ANT_CASCADER_NOT_FOUND'), _defineProperty(_ref2, names.label, notFoundContent || renderEmpty('Cascader')), _defineProperty(_ref2, "disabled", true), _defineProperty(_ref2, "isEmptyNode", true), _ref2;
114
- }
115
-
116
- var Cascader = /*#__PURE__*/function (_React$Component) {
117
- _inherits(Cascader, _React$Component);
118
-
119
- var _super = _createSuper(Cascader);
120
-
121
- function Cascader(props) {
122
- var _this;
123
-
124
- _classCallCheck(this, Cascader);
125
-
126
- _this = _super.call(this, props);
127
- _this.cachedOptions = [];
128
-
129
- _this.setValue = function (value) {
130
- var selectedOptions = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
131
-
132
- if (!('value' in _this.props)) {
133
- _this.setState({
134
- value: value
135
- });
136
- }
137
-
138
- var onChange = _this.props.onChange;
139
- onChange === null || onChange === void 0 ? void 0 : onChange(value, selectedOptions);
140
- };
141
-
142
- _this.saveInput = function (node) {
143
- _this.input = node;
144
- };
145
-
146
- _this.handleChange = function (value, selectedOptions) {
147
- _this.setState({
148
- inputValue: ''
149
- });
150
-
151
- if (selectedOptions[0].__IS_FILTERED_OPTION) {
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
- _this.handleKeyDown = function (e) {
195
- // SPACE => https://github.com/ant-design/ant-design/issues/16871
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
- _this.handleInputChange = function (e) {
202
- var popupVisible = _this.state.popupVisible;
203
- var inputValue = e.target.value;
204
-
205
- if (!popupVisible) {
206
- _this.handlePopupVisibleChange(true);
207
- }
125
+ if (_typeof(showSearch) === 'object') {
126
+ searchConfig = _extends(_extends({}, searchConfig), showSearch);
127
+ }
208
128
 
209
- _this.setState({
210
- inputValue: inputValue
211
- });
212
- };
129
+ return searchConfig;
130
+ }, [showSearch]); // ===================== Size ======================
213
131
 
214
- _this.clearSelection = function (e) {
215
- var inputValue = _this.state.inputValue;
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
- _this.renderCascader = function (_ref3, locale) {
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
- _this.state = {
389
- value: props.value || props.defaultValue || [],
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
- _createClass(Cascader, [{
400
- key: "componentWillUnmount",
401
- value: function componentWillUnmount() {
402
- if (this.clearSelectionTimeout) {
403
- clearTimeout(this.clearSelectionTimeout);
404
- }
405
- }
406
- }, {
407
- key: "getLabel",
408
- value: function getLabel() {
409
- var _this$props = this.props,
410
- options = _this$props.options,
411
- _this$props$displayRe = _this$props.displayRender,
412
- displayRender = _this$props$displayRe === void 0 ? defaultDisplayRender : _this$props$displayRe;
413
- var names = getFilledFieldNames(this.props);
414
- var value = this.state.value;
415
- var unwrappedValue = Array.isArray(value[0]) ? value[0] : value;
416
- var selectedOptions = arrayTreeFilter(options, function (o, level) {
417
- return o[names.value] === unwrappedValue[level];
418
- }, {
419
- childrenKeyName: names.children
420
- });
421
- var label = selectedOptions.length ? selectedOptions.map(function (o) {
422
- return o[names.label];
423
- }) : value;
424
- return displayRender(label, selectedOptions);
425
- }
426
- }, {
427
- key: "generateFilteredOptions",
428
- value: function generateFilteredOptions(prefixCls, renderEmpty) {
429
- var _this2 = this;
430
-
431
- var _this$props2 = this.props,
432
- showSearch = _this$props2.showSearch,
433
- notFoundContent = _this$props2.notFoundContent;
434
- var names = getFilledFieldNames(this.props);
435
- var _showSearch$filter = showSearch.filter,
436
- filter = _showSearch$filter === void 0 ? defaultFilterOption : _showSearch$filter,
437
- _showSearch$render = showSearch.render,
438
- render = _showSearch$render === void 0 ? defaultRenderFilteredOption : _showSearch$render,
439
- _showSearch$sort = showSearch.sort,
440
- sort = _showSearch$sort === void 0 ? defaultSortFilteredOption : _showSearch$sort,
441
- _showSearch$limit = showSearch.limit,
442
- limit = _showSearch$limit === void 0 ? defaultLimit : _showSearch$limit;
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;