index.js 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248
  1. import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
  2. import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
  3. import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
  4. import _typeof from "@babel/runtime/helpers/esm/typeof";
  5. import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
  6. var _excluded = ["notFoundContent", "expandIcon", "multiple", "bordered", "allowClear", "choiceTransitionName", "transitionName", "id"];
  7. import { resolveDirective as _resolveDirective, createVNode as _createVNode } from "vue";
  8. import VcCascader, { cascaderProps as vcCascaderProps } from '../vc-cascader';
  9. import RightOutlined from "@ant-design/icons-vue/es/icons/RightOutlined";
  10. import LoadingOutlined from "@ant-design/icons-vue/es/icons/LoadingOutlined";
  11. import LeftOutlined from "@ant-design/icons-vue/es/icons/LeftOutlined";
  12. import getIcons from '../select/utils/iconUtil';
  13. import { withInstall } from '../_util/type';
  14. import omit from '../_util/omit';
  15. import { computed, defineComponent, ref, watchEffect } from 'vue';
  16. import PropTypes from '../_util/vue-types';
  17. import { initDefaultProps } from '../_util/props-util';
  18. import useConfigInject from '../_util/hooks/useConfigInject';
  19. import classNames from '../_util/classNames';
  20. import devWarning from '../vc-util/devWarning';
  21. import { getTransitionDirection, getTransitionName } from '../_util/transition';
  22. import { useInjectFormItemContext } from '../form';
  23. function highlightKeyword(str, lowerKeyword, prefixCls) {
  24. var cells = str.toLowerCase().split(lowerKeyword).reduce(function (list, cur, index) {
  25. return index === 0 ? [cur] : [].concat(_toConsumableArray(list), [lowerKeyword, cur]);
  26. }, []);
  27. var fillCells = [];
  28. var start = 0;
  29. cells.forEach(function (cell, index) {
  30. var end = start + cell.length;
  31. var originWorld = str.slice(start, end);
  32. start = end;
  33. if (index % 2 === 1) {
  34. var _originWorld = function () {
  35. return originWorld;
  36. }();
  37. originWorld = _createVNode("span", {
  38. "class": "".concat(prefixCls, "-menu-item-keyword"),
  39. "key": "seperator"
  40. }, [originWorld]);
  41. }
  42. fillCells.push(originWorld);
  43. });
  44. return fillCells;
  45. }
  46. var defaultSearchRender = function defaultSearchRender(_ref) {
  47. var inputValue = _ref.inputValue,
  48. path = _ref.path,
  49. prefixCls = _ref.prefixCls,
  50. fieldNames = _ref.fieldNames;
  51. var optionList = [];
  52. // We do lower here to save perf
  53. var lower = inputValue.toLowerCase();
  54. path.forEach(function (node, index) {
  55. if (index !== 0) {
  56. optionList.push(' / ');
  57. }
  58. var label = node[fieldNames.label];
  59. var type = _typeof(label);
  60. if (type === 'string' || type === 'number') {
  61. label = highlightKeyword(String(label), lower, prefixCls);
  62. }
  63. optionList.push(label);
  64. });
  65. return optionList;
  66. };
  67. export function cascaderProps() {
  68. return _objectSpread(_objectSpread({}, omit(vcCascaderProps(), ['customSlots', 'checkable', 'options'])), {}, {
  69. multiple: {
  70. type: Boolean,
  71. default: undefined
  72. },
  73. size: String,
  74. bordered: {
  75. type: Boolean,
  76. default: undefined
  77. },
  78. placement: {
  79. type: String
  80. },
  81. suffixIcon: PropTypes.any,
  82. options: Array,
  83. 'onUpdate:value': Function
  84. });
  85. }
  86. var Cascader = defineComponent({
  87. compatConfig: {
  88. MODE: 3
  89. },
  90. name: 'ACascader',
  91. inheritAttrs: false,
  92. props: initDefaultProps(cascaderProps(), {
  93. bordered: true,
  94. choiceTransitionName: '',
  95. allowClear: true
  96. }),
  97. setup: function setup(props, _ref2) {
  98. var attrs = _ref2.attrs,
  99. expose = _ref2.expose,
  100. slots = _ref2.slots,
  101. emit = _ref2.emit;
  102. var formItemContext = useInjectFormItemContext();
  103. var _useConfigInject = useConfigInject('cascader', props),
  104. cascaderPrefixCls = _useConfigInject.prefixCls,
  105. rootPrefixCls = _useConfigInject.rootPrefixCls,
  106. getPrefixCls = _useConfigInject.getPrefixCls,
  107. direction = _useConfigInject.direction,
  108. getPopupContainer = _useConfigInject.getPopupContainer,
  109. renderEmpty = _useConfigInject.renderEmpty,
  110. size = _useConfigInject.size;
  111. var prefixCls = computed(function () {
  112. return getPrefixCls('select', props.prefixCls);
  113. });
  114. var isRtl = computed(function () {
  115. return direction.value === 'rtl';
  116. });
  117. // =================== Warning =====================
  118. if (process.env.NODE_ENV !== 'production') {
  119. watchEffect(function () {
  120. devWarning(!props.multiple || !props.displayRender || !slots.displayRender, 'Cascader', '`displayRender` not work on `multiple`. Please use `tagRender` instead.');
  121. });
  122. }
  123. // ==================== Search =====================
  124. var mergedShowSearch = computed(function () {
  125. if (!props.showSearch) {
  126. return props.showSearch;
  127. }
  128. var searchConfig = {
  129. render: defaultSearchRender
  130. };
  131. if (_typeof(props.showSearch) === 'object') {
  132. searchConfig = _objectSpread(_objectSpread({}, searchConfig), props.showSearch);
  133. }
  134. return searchConfig;
  135. });
  136. // =================== Dropdown ====================
  137. var mergedDropdownClassName = computed(function () {
  138. return classNames(props.dropdownClassName || props.popupClassName, "".concat(cascaderPrefixCls.value, "-dropdown"), _defineProperty({}, "".concat(cascaderPrefixCls.value, "-dropdown-rtl"), isRtl.value));
  139. });
  140. var selectRef = ref();
  141. expose({
  142. focus: function focus() {
  143. var _selectRef$value;
  144. (_selectRef$value = selectRef.value) === null || _selectRef$value === void 0 ? void 0 : _selectRef$value.focus();
  145. },
  146. blur: function blur() {
  147. var _selectRef$value2;
  148. (_selectRef$value2 = selectRef.value) === null || _selectRef$value2 === void 0 ? void 0 : _selectRef$value2.blur();
  149. }
  150. });
  151. var handleChange = function handleChange() {
  152. for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
  153. args[_key] = arguments[_key];
  154. }
  155. emit('update:value', args[0]);
  156. emit.apply(void 0, ['change'].concat(args));
  157. formItemContext.onFieldChange();
  158. };
  159. var handleBlur = function handleBlur() {
  160. for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
  161. args[_key2] = arguments[_key2];
  162. }
  163. emit.apply(void 0, ['blur'].concat(args));
  164. formItemContext.onFieldBlur();
  165. };
  166. var mergedShowArrow = computed(function () {
  167. return props.showArrow !== undefined ? props.showArrow : props.loading || !props.multiple;
  168. });
  169. var placement = computed(function () {
  170. if (props.placement !== undefined) {
  171. return props.placement;
  172. }
  173. return direction.value === 'rtl' ? 'bottomRight' : 'bottomLeft';
  174. });
  175. return function () {
  176. var _slots$notFoundConten, _slots$expandIcon, _ref3;
  177. var _props$notFoundConten = props.notFoundContent,
  178. notFoundContent = _props$notFoundConten === void 0 ? (_slots$notFoundConten = slots.notFoundContent) === null || _slots$notFoundConten === void 0 ? void 0 : _slots$notFoundConten.call(slots) : _props$notFoundConten,
  179. _props$expandIcon = props.expandIcon,
  180. expandIcon = _props$expandIcon === void 0 ? (_slots$expandIcon = slots.expandIcon) === null || _slots$expandIcon === void 0 ? void 0 : _slots$expandIcon.call(slots) : _props$expandIcon,
  181. multiple = props.multiple,
  182. bordered = props.bordered,
  183. allowClear = props.allowClear,
  184. choiceTransitionName = props.choiceTransitionName,
  185. transitionName = props.transitionName,
  186. _props$id = props.id,
  187. id = _props$id === void 0 ? formItemContext.id.value : _props$id,
  188. restProps = _objectWithoutProperties(props, _excluded);
  189. // =================== No Found ====================
  190. var mergedNotFoundContent = notFoundContent || renderEmpty.value('Cascader');
  191. // ===================== Icon ======================
  192. var mergedExpandIcon = expandIcon;
  193. if (!expandIcon) {
  194. mergedExpandIcon = isRtl.value ? _createVNode(LeftOutlined, null, null) : _createVNode(RightOutlined, null, null);
  195. }
  196. var loadingIcon = _createVNode("span", {
  197. "class": "".concat(prefixCls.value, "-menu-item-loading-icon")
  198. }, [_createVNode(LoadingOutlined, {
  199. "spin": true
  200. }, null)]);
  201. // ===================== Icons =====================
  202. var _getIcons = getIcons(_objectSpread(_objectSpread({}, props), {}, {
  203. multiple: multiple,
  204. prefixCls: prefixCls.value,
  205. showArrow: mergedShowArrow.value
  206. }), slots),
  207. suffixIcon = _getIcons.suffixIcon,
  208. removeIcon = _getIcons.removeIcon,
  209. clearIcon = _getIcons.clearIcon;
  210. return _createVNode(VcCascader, _objectSpread(_objectSpread(_objectSpread({}, restProps), attrs), {}, {
  211. "id": id,
  212. "prefixCls": prefixCls.value,
  213. "class": [cascaderPrefixCls.value, (_ref3 = {}, _defineProperty(_ref3, "".concat(prefixCls.value, "-lg"), size.value === 'large'), _defineProperty(_ref3, "".concat(prefixCls.value, "-sm"), size.value === 'small'), _defineProperty(_ref3, "".concat(prefixCls.value, "-rtl"), isRtl.value), _defineProperty(_ref3, "".concat(prefixCls.value, "-borderless"), !bordered), _ref3), attrs.class],
  214. "direction": direction.value,
  215. "placement": placement.value,
  216. "notFoundContent": mergedNotFoundContent,
  217. "allowClear": allowClear,
  218. "showSearch": mergedShowSearch.value,
  219. "expandIcon": mergedExpandIcon,
  220. "inputIcon": suffixIcon,
  221. "removeIcon": removeIcon,
  222. "clearIcon": clearIcon,
  223. "loadingIcon": loadingIcon,
  224. "checkable": !!multiple,
  225. "dropdownClassName": mergedDropdownClassName.value,
  226. "dropdownPrefixCls": cascaderPrefixCls.value,
  227. "choiceTransitionName": getTransitionName(rootPrefixCls.value, '', choiceTransitionName),
  228. "transitionName": getTransitionName(rootPrefixCls.value, getTransitionDirection(placement.value), transitionName),
  229. "getPopupContainer": getPopupContainer.value,
  230. "customSlots": _objectSpread(_objectSpread({}, slots), {}, {
  231. checkable: function checkable() {
  232. return _createVNode("span", {
  233. "class": "".concat(cascaderPrefixCls.value, "-checkbox-inner")
  234. }, null);
  235. }
  236. }),
  237. "tagRender": props.tagRender || slots.tagRender,
  238. "displayRender": props.displayRender || slots.displayRender,
  239. "maxTagPlaceholder": props.maxTagPlaceholder || slots.maxTagPlaceholder,
  240. "showArrow": props.showArrow,
  241. "onChange": handleChange,
  242. "onBlur": handleBlur,
  243. "ref": selectRef
  244. }), slots);
  245. };
  246. }
  247. });
  248. export default withInstall(Cascader);