ClearableLabeledInput.js 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235
  1. import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
  2. import { createVNode as _createVNode } from "vue";
  3. import classNames from '../_util/classNames';
  4. import CloseCircleFilled from "@ant-design/icons-vue/es/icons/CloseCircleFilled";
  5. import PropTypes from '../_util/vue-types';
  6. import { cloneElement } from '../_util/vnode';
  7. import { ref, defineComponent } from 'vue';
  8. import { tuple } from '../_util/type';
  9. import { getInputClassName, hasAddon, hasPrefixSuffix } from './util';
  10. var ClearableInputType = ['text', 'input'];
  11. export default defineComponent({
  12. compatConfig: {
  13. MODE: 3
  14. },
  15. name: 'ClearableLabeledInput',
  16. inheritAttrs: false,
  17. props: {
  18. prefixCls: String,
  19. inputType: PropTypes.oneOf(tuple('text', 'input')),
  20. value: PropTypes.any,
  21. defaultValue: PropTypes.any,
  22. allowClear: {
  23. type: Boolean,
  24. default: undefined
  25. },
  26. element: PropTypes.any,
  27. handleReset: Function,
  28. disabled: {
  29. type: Boolean,
  30. default: undefined
  31. },
  32. direction: {
  33. type: String
  34. },
  35. size: {
  36. type: String
  37. },
  38. suffix: PropTypes.any,
  39. prefix: PropTypes.any,
  40. addonBefore: PropTypes.any,
  41. addonAfter: PropTypes.any,
  42. readonly: {
  43. type: Boolean,
  44. default: undefined
  45. },
  46. focused: {
  47. type: Boolean,
  48. default: undefined
  49. },
  50. bordered: {
  51. type: Boolean,
  52. default: true
  53. },
  54. triggerFocus: {
  55. type: Function
  56. },
  57. hidden: Boolean
  58. },
  59. setup: function setup(props, _ref) {
  60. var slots = _ref.slots,
  61. attrs = _ref.attrs;
  62. var containerRef = ref();
  63. var onInputMouseUp = function onInputMouseUp(e) {
  64. var _containerRef$value;
  65. if ((_containerRef$value = containerRef.value) !== null && _containerRef$value !== void 0 && _containerRef$value.contains(e.target)) {
  66. var triggerFocus = props.triggerFocus;
  67. triggerFocus === null || triggerFocus === void 0 ? void 0 : triggerFocus();
  68. }
  69. };
  70. var renderClearIcon = function renderClearIcon(prefixCls) {
  71. var _classNames;
  72. var allowClear = props.allowClear,
  73. value = props.value,
  74. disabled = props.disabled,
  75. readonly = props.readonly,
  76. handleReset = props.handleReset,
  77. _props$suffix = props.suffix,
  78. suffix = _props$suffix === void 0 ? slots.suffix : _props$suffix;
  79. if (!allowClear) {
  80. return null;
  81. }
  82. var needClear = !disabled && !readonly && value;
  83. var className = "".concat(prefixCls, "-clear-icon");
  84. return _createVNode(CloseCircleFilled, {
  85. "onClick": handleReset,
  86. "onMousedown": function onMousedown(e) {
  87. return e.preventDefault();
  88. },
  89. "class": classNames((_classNames = {}, _defineProperty(_classNames, "".concat(className, "-hidden"), !needClear), _defineProperty(_classNames, "".concat(className, "-has-suffix"), !!suffix), _classNames), className),
  90. "role": "button"
  91. }, null);
  92. };
  93. var renderSuffix = function renderSuffix(prefixCls) {
  94. var _slots$suffix;
  95. var _props$suffix2 = props.suffix,
  96. suffix = _props$suffix2 === void 0 ? (_slots$suffix = slots.suffix) === null || _slots$suffix === void 0 ? void 0 : _slots$suffix.call(slots) : _props$suffix2,
  97. allowClear = props.allowClear;
  98. if (suffix || allowClear) {
  99. return _createVNode("span", {
  100. "class": "".concat(prefixCls, "-suffix")
  101. }, [renderClearIcon(prefixCls), suffix]);
  102. }
  103. return null;
  104. };
  105. var renderLabeledIcon = function renderLabeledIcon(prefixCls, element) {
  106. var _slots$prefix, _slots$suffix2, _classNames2;
  107. var focused = props.focused,
  108. value = props.value,
  109. _props$prefix = props.prefix,
  110. prefix = _props$prefix === void 0 ? (_slots$prefix = slots.prefix) === null || _slots$prefix === void 0 ? void 0 : _slots$prefix.call(slots) : _props$prefix,
  111. size = props.size,
  112. _props$suffix3 = props.suffix,
  113. suffix = _props$suffix3 === void 0 ? (_slots$suffix2 = slots.suffix) === null || _slots$suffix2 === void 0 ? void 0 : _slots$suffix2.call(slots) : _props$suffix3,
  114. disabled = props.disabled,
  115. allowClear = props.allowClear,
  116. direction = props.direction,
  117. readonly = props.readonly,
  118. bordered = props.bordered,
  119. hidden = props.hidden,
  120. _props$addonAfter = props.addonAfter,
  121. addonAfter = _props$addonAfter === void 0 ? slots.addonAfter : _props$addonAfter,
  122. _props$addonBefore = props.addonBefore,
  123. addonBefore = _props$addonBefore === void 0 ? slots.addonBefore : _props$addonBefore;
  124. var suffixNode = renderSuffix(prefixCls);
  125. if (!hasPrefixSuffix({
  126. prefix: prefix,
  127. suffix: suffix,
  128. allowClear: allowClear
  129. })) {
  130. return cloneElement(element, {
  131. value: value
  132. });
  133. }
  134. var prefixNode = prefix ? _createVNode("span", {
  135. "class": "".concat(prefixCls, "-prefix")
  136. }, [prefix]) : null;
  137. var affixWrapperCls = classNames("".concat(prefixCls, "-affix-wrapper"), (_classNames2 = {}, _defineProperty(_classNames2, "".concat(prefixCls, "-affix-wrapper-focused"), focused), _defineProperty(_classNames2, "".concat(prefixCls, "-affix-wrapper-disabled"), disabled), _defineProperty(_classNames2, "".concat(prefixCls, "-affix-wrapper-sm"), size === 'small'), _defineProperty(_classNames2, "".concat(prefixCls, "-affix-wrapper-lg"), size === 'large'), _defineProperty(_classNames2, "".concat(prefixCls, "-affix-wrapper-input-with-clear-btn"), suffix && allowClear && value), _defineProperty(_classNames2, "".concat(prefixCls, "-affix-wrapper-rtl"), direction === 'rtl'), _defineProperty(_classNames2, "".concat(prefixCls, "-affix-wrapper-readonly"), readonly), _defineProperty(_classNames2, "".concat(prefixCls, "-affix-wrapper-borderless"), !bordered), _defineProperty(_classNames2, "".concat(attrs.class), !hasAddon({
  138. addonAfter: addonAfter,
  139. addonBefore: addonBefore
  140. }) && attrs.class), _classNames2));
  141. return _createVNode("span", {
  142. "ref": containerRef,
  143. "class": affixWrapperCls,
  144. "style": attrs.style,
  145. "onMouseup": onInputMouseUp,
  146. "hidden": hidden
  147. }, [prefixNode, cloneElement(element, {
  148. style: null,
  149. value: value,
  150. class: getInputClassName(prefixCls, bordered, size, disabled)
  151. }), suffixNode]);
  152. };
  153. var renderInputWithLabel = function renderInputWithLabel(prefixCls, labeledElement) {
  154. var _slots$addonBefore, _slots$addonAfter, _classNames5;
  155. var _props$addonBefore2 = props.addonBefore,
  156. addonBefore = _props$addonBefore2 === void 0 ? (_slots$addonBefore = slots.addonBefore) === null || _slots$addonBefore === void 0 ? void 0 : _slots$addonBefore.call(slots) : _props$addonBefore2,
  157. _props$addonAfter2 = props.addonAfter,
  158. addonAfter = _props$addonAfter2 === void 0 ? (_slots$addonAfter = slots.addonAfter) === null || _slots$addonAfter === void 0 ? void 0 : _slots$addonAfter.call(slots) : _props$addonAfter2,
  159. size = props.size,
  160. direction = props.direction,
  161. hidden = props.hidden,
  162. disabled = props.disabled;
  163. // Not wrap when there is not addons
  164. if (!hasAddon({
  165. addonBefore: addonBefore,
  166. addonAfter: addonAfter
  167. })) {
  168. return labeledElement;
  169. }
  170. var wrapperClassName = "".concat(prefixCls, "-group");
  171. var addonClassName = "".concat(wrapperClassName, "-addon");
  172. // fix form error style for input addonAfter slot when disabled
  173. var mergedAddonClassName = classNames(addonClassName, _defineProperty({}, "".concat(addonClassName, "-disabled"), disabled));
  174. var addonBeforeNode = addonBefore ? _createVNode("span", {
  175. "class": mergedAddonClassName
  176. }, [addonBefore]) : null;
  177. var addonAfterNode = addonAfter ? _createVNode("span", {
  178. "class": mergedAddonClassName
  179. }, [addonAfter]) : null;
  180. var mergedWrapperClassName = classNames("".concat(prefixCls, "-wrapper"), wrapperClassName, _defineProperty({}, "".concat(wrapperClassName, "-rtl"), direction === 'rtl'));
  181. var mergedGroupClassName = classNames("".concat(prefixCls, "-group-wrapper"), (_classNames5 = {}, _defineProperty(_classNames5, "".concat(prefixCls, "-group-wrapper-sm"), size === 'small'), _defineProperty(_classNames5, "".concat(prefixCls, "-group-wrapper-lg"), size === 'large'), _defineProperty(_classNames5, "".concat(prefixCls, "-group-wrapper-rtl"), direction === 'rtl'), _classNames5), attrs.class);
  182. // Need another wrapper for changing display:table to display:inline-block
  183. // and put style prop in wrapper
  184. return _createVNode("span", {
  185. "class": mergedGroupClassName,
  186. "style": attrs.style,
  187. "hidden": hidden
  188. }, [_createVNode("span", {
  189. "class": mergedWrapperClassName
  190. }, [addonBeforeNode, cloneElement(labeledElement, {
  191. style: null
  192. }), addonAfterNode])]);
  193. };
  194. var renderTextAreaWithClearIcon = function renderTextAreaWithClearIcon(prefixCls, element) {
  195. var _classNames6;
  196. var value = props.value,
  197. allowClear = props.allowClear,
  198. direction = props.direction,
  199. bordered = props.bordered,
  200. hidden = props.hidden,
  201. _props$addonAfter3 = props.addonAfter,
  202. addonAfter = _props$addonAfter3 === void 0 ? slots.addonAfter : _props$addonAfter3,
  203. _props$addonBefore3 = props.addonBefore,
  204. addonBefore = _props$addonBefore3 === void 0 ? slots.addonBefore : _props$addonBefore3;
  205. if (!allowClear) {
  206. return cloneElement(element, {
  207. value: value
  208. });
  209. }
  210. var affixWrapperCls = classNames("".concat(prefixCls, "-affix-wrapper"), "".concat(prefixCls, "-affix-wrapper-textarea-with-clear-btn"), (_classNames6 = {}, _defineProperty(_classNames6, "".concat(prefixCls, "-affix-wrapper-rtl"), direction === 'rtl'), _defineProperty(_classNames6, "".concat(prefixCls, "-affix-wrapper-borderless"), !bordered), _defineProperty(_classNames6, "".concat(attrs.class), !hasAddon({
  211. addonAfter: addonAfter,
  212. addonBefore: addonBefore
  213. }) && attrs.class), _classNames6));
  214. return _createVNode("span", {
  215. "class": affixWrapperCls,
  216. "style": attrs.style,
  217. "hidden": hidden
  218. }, [cloneElement(element, {
  219. style: null,
  220. value: value
  221. }), renderClearIcon(prefixCls)]);
  222. };
  223. return function () {
  224. var _slots$element;
  225. var prefixCls = props.prefixCls,
  226. inputType = props.inputType,
  227. _props$element = props.element,
  228. element = _props$element === void 0 ? (_slots$element = slots.element) === null || _slots$element === void 0 ? void 0 : _slots$element.call(slots) : _props$element;
  229. if (inputType === ClearableInputType[0]) {
  230. return renderTextAreaWithClearIcon(prefixCls, element);
  231. }
  232. return renderInputWithLabel(prefixCls, renderLabeledIcon(prefixCls, element));
  233. };
  234. }
  235. });