| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239 |
- "use strict";
- var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.default = void 0;
- var _vue = require("vue");
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
- var _classNames6 = _interopRequireDefault(require("../_util/classNames"));
- var _CloseCircleFilled = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/CloseCircleFilled"));
- var _vueTypes = _interopRequireDefault(require("../_util/vue-types"));
- var _vnode = require("../_util/vnode");
- var _type = require("../_util/type");
- var _util = require("./util");
- var ClearableInputType = ['text', 'input'];
- var _default = (0, _vue.defineComponent)({
- compatConfig: {
- MODE: 3
- },
- name: 'ClearableLabeledInput',
- inheritAttrs: false,
- props: {
- prefixCls: String,
- inputType: _vueTypes.default.oneOf((0, _type.tuple)('text', 'input')),
- value: _vueTypes.default.any,
- defaultValue: _vueTypes.default.any,
- allowClear: {
- type: Boolean,
- default: undefined
- },
- element: _vueTypes.default.any,
- handleReset: Function,
- disabled: {
- type: Boolean,
- default: undefined
- },
- direction: {
- type: String
- },
- size: {
- type: String
- },
- suffix: _vueTypes.default.any,
- prefix: _vueTypes.default.any,
- addonBefore: _vueTypes.default.any,
- addonAfter: _vueTypes.default.any,
- readonly: {
- type: Boolean,
- default: undefined
- },
- focused: {
- type: Boolean,
- default: undefined
- },
- bordered: {
- type: Boolean,
- default: true
- },
- triggerFocus: {
- type: Function
- },
- hidden: Boolean
- },
- setup: function setup(props, _ref) {
- var slots = _ref.slots,
- attrs = _ref.attrs;
- var containerRef = (0, _vue.ref)();
- var onInputMouseUp = function onInputMouseUp(e) {
- var _containerRef$value;
- if ((_containerRef$value = containerRef.value) !== null && _containerRef$value !== void 0 && _containerRef$value.contains(e.target)) {
- var triggerFocus = props.triggerFocus;
- triggerFocus === null || triggerFocus === void 0 ? void 0 : triggerFocus();
- }
- };
- var renderClearIcon = function renderClearIcon(prefixCls) {
- var _classNames;
- var allowClear = props.allowClear,
- value = props.value,
- disabled = props.disabled,
- readonly = props.readonly,
- handleReset = props.handleReset,
- _props$suffix = props.suffix,
- suffix = _props$suffix === void 0 ? slots.suffix : _props$suffix;
- if (!allowClear) {
- return null;
- }
- var needClear = !disabled && !readonly && value;
- var className = "".concat(prefixCls, "-clear-icon");
- return (0, _vue.createVNode)(_CloseCircleFilled.default, {
- "onClick": handleReset,
- "onMousedown": function onMousedown(e) {
- return e.preventDefault();
- },
- "class": (0, _classNames6.default)((_classNames = {}, (0, _defineProperty2.default)(_classNames, "".concat(className, "-hidden"), !needClear), (0, _defineProperty2.default)(_classNames, "".concat(className, "-has-suffix"), !!suffix), _classNames), className),
- "role": "button"
- }, null);
- };
- var renderSuffix = function renderSuffix(prefixCls) {
- var _slots$suffix;
- var _props$suffix2 = props.suffix,
- suffix = _props$suffix2 === void 0 ? (_slots$suffix = slots.suffix) === null || _slots$suffix === void 0 ? void 0 : _slots$suffix.call(slots) : _props$suffix2,
- allowClear = props.allowClear;
- if (suffix || allowClear) {
- return (0, _vue.createVNode)("span", {
- "class": "".concat(prefixCls, "-suffix")
- }, [renderClearIcon(prefixCls), suffix]);
- }
- return null;
- };
- var renderLabeledIcon = function renderLabeledIcon(prefixCls, element) {
- var _slots$prefix, _slots$suffix2, _classNames2;
- var focused = props.focused,
- value = props.value,
- _props$prefix = props.prefix,
- prefix = _props$prefix === void 0 ? (_slots$prefix = slots.prefix) === null || _slots$prefix === void 0 ? void 0 : _slots$prefix.call(slots) : _props$prefix,
- size = props.size,
- _props$suffix3 = props.suffix,
- suffix = _props$suffix3 === void 0 ? (_slots$suffix2 = slots.suffix) === null || _slots$suffix2 === void 0 ? void 0 : _slots$suffix2.call(slots) : _props$suffix3,
- disabled = props.disabled,
- allowClear = props.allowClear,
- direction = props.direction,
- readonly = props.readonly,
- bordered = props.bordered,
- hidden = props.hidden,
- _props$addonAfter = props.addonAfter,
- addonAfter = _props$addonAfter === void 0 ? slots.addonAfter : _props$addonAfter,
- _props$addonBefore = props.addonBefore,
- addonBefore = _props$addonBefore === void 0 ? slots.addonBefore : _props$addonBefore;
- var suffixNode = renderSuffix(prefixCls);
- if (!(0, _util.hasPrefixSuffix)({
- prefix: prefix,
- suffix: suffix,
- allowClear: allowClear
- })) {
- return (0, _vnode.cloneElement)(element, {
- value: value
- });
- }
- var prefixNode = prefix ? (0, _vue.createVNode)("span", {
- "class": "".concat(prefixCls, "-prefix")
- }, [prefix]) : null;
- var affixWrapperCls = (0, _classNames6.default)("".concat(prefixCls, "-affix-wrapper"), (_classNames2 = {}, (0, _defineProperty2.default)(_classNames2, "".concat(prefixCls, "-affix-wrapper-focused"), focused), (0, _defineProperty2.default)(_classNames2, "".concat(prefixCls, "-affix-wrapper-disabled"), disabled), (0, _defineProperty2.default)(_classNames2, "".concat(prefixCls, "-affix-wrapper-sm"), size === 'small'), (0, _defineProperty2.default)(_classNames2, "".concat(prefixCls, "-affix-wrapper-lg"), size === 'large'), (0, _defineProperty2.default)(_classNames2, "".concat(prefixCls, "-affix-wrapper-input-with-clear-btn"), suffix && allowClear && value), (0, _defineProperty2.default)(_classNames2, "".concat(prefixCls, "-affix-wrapper-rtl"), direction === 'rtl'), (0, _defineProperty2.default)(_classNames2, "".concat(prefixCls, "-affix-wrapper-readonly"), readonly), (0, _defineProperty2.default)(_classNames2, "".concat(prefixCls, "-affix-wrapper-borderless"), !bordered), (0, _defineProperty2.default)(_classNames2, "".concat(attrs.class), !(0, _util.hasAddon)({
- addonAfter: addonAfter,
- addonBefore: addonBefore
- }) && attrs.class), _classNames2));
- return (0, _vue.createVNode)("span", {
- "ref": containerRef,
- "class": affixWrapperCls,
- "style": attrs.style,
- "onMouseup": onInputMouseUp,
- "hidden": hidden
- }, [prefixNode, (0, _vnode.cloneElement)(element, {
- style: null,
- value: value,
- class: (0, _util.getInputClassName)(prefixCls, bordered, size, disabled)
- }), suffixNode]);
- };
- var renderInputWithLabel = function renderInputWithLabel(prefixCls, labeledElement) {
- var _slots$addonBefore, _slots$addonAfter, _classNames4;
- var _props$addonBefore2 = props.addonBefore,
- addonBefore = _props$addonBefore2 === void 0 ? (_slots$addonBefore = slots.addonBefore) === null || _slots$addonBefore === void 0 ? void 0 : _slots$addonBefore.call(slots) : _props$addonBefore2,
- _props$addonAfter2 = props.addonAfter,
- addonAfter = _props$addonAfter2 === void 0 ? (_slots$addonAfter = slots.addonAfter) === null || _slots$addonAfter === void 0 ? void 0 : _slots$addonAfter.call(slots) : _props$addonAfter2,
- size = props.size,
- direction = props.direction,
- hidden = props.hidden;
- // Not wrap when there is not addons
- if (!(0, _util.hasAddon)({
- addonBefore: addonBefore,
- addonAfter: addonAfter
- })) {
- return labeledElement;
- }
- var wrapperClassName = "".concat(prefixCls, "-group");
- var addonClassName = "".concat(wrapperClassName, "-addon");
- var addonBeforeNode = addonBefore ? (0, _vue.createVNode)("span", {
- "class": addonClassName
- }, [addonBefore]) : null;
- var addonAfterNode = addonAfter ? (0, _vue.createVNode)("span", {
- "class": addonClassName
- }, [addonAfter]) : null;
- var mergedWrapperClassName = (0, _classNames6.default)("".concat(prefixCls, "-wrapper"), wrapperClassName, (0, _defineProperty2.default)({}, "".concat(wrapperClassName, "-rtl"), direction === 'rtl'));
- var mergedGroupClassName = (0, _classNames6.default)("".concat(prefixCls, "-group-wrapper"), (_classNames4 = {}, (0, _defineProperty2.default)(_classNames4, "".concat(prefixCls, "-group-wrapper-sm"), size === 'small'), (0, _defineProperty2.default)(_classNames4, "".concat(prefixCls, "-group-wrapper-lg"), size === 'large'), (0, _defineProperty2.default)(_classNames4, "".concat(prefixCls, "-group-wrapper-rtl"), direction === 'rtl'), _classNames4), attrs.class);
- // Need another wrapper for changing display:table to display:inline-block
- // and put style prop in wrapper
- return (0, _vue.createVNode)("span", {
- "class": mergedGroupClassName,
- "style": attrs.style,
- "hidden": hidden
- }, [(0, _vue.createVNode)("span", {
- "class": mergedWrapperClassName
- }, [addonBeforeNode, (0, _vnode.cloneElement)(labeledElement, {
- style: null
- }), addonAfterNode])]);
- };
- var renderTextAreaWithClearIcon = function renderTextAreaWithClearIcon(prefixCls, element) {
- var _classNames5;
- var value = props.value,
- allowClear = props.allowClear,
- direction = props.direction,
- bordered = props.bordered,
- hidden = props.hidden,
- _props$addonAfter3 = props.addonAfter,
- addonAfter = _props$addonAfter3 === void 0 ? slots.addonAfter : _props$addonAfter3,
- _props$addonBefore3 = props.addonBefore,
- addonBefore = _props$addonBefore3 === void 0 ? slots.addonBefore : _props$addonBefore3;
- if (!allowClear) {
- return (0, _vnode.cloneElement)(element, {
- value: value
- });
- }
- var affixWrapperCls = (0, _classNames6.default)("".concat(prefixCls, "-affix-wrapper"), "".concat(prefixCls, "-affix-wrapper-textarea-with-clear-btn"), (_classNames5 = {}, (0, _defineProperty2.default)(_classNames5, "".concat(prefixCls, "-affix-wrapper-rtl"), direction === 'rtl'), (0, _defineProperty2.default)(_classNames5, "".concat(prefixCls, "-affix-wrapper-borderless"), !bordered), (0, _defineProperty2.default)(_classNames5, "".concat(attrs.class), !(0, _util.hasAddon)({
- addonAfter: addonAfter,
- addonBefore: addonBefore
- }) && attrs.class), _classNames5));
- return (0, _vue.createVNode)("span", {
- "class": affixWrapperCls,
- "style": attrs.style,
- "hidden": hidden
- }, [(0, _vnode.cloneElement)(element, {
- style: null,
- value: value
- }), renderClearIcon(prefixCls)]);
- };
- return function () {
- var _slots$element;
- var prefixCls = props.prefixCls,
- inputType = props.inputType,
- _props$element = props.element,
- element = _props$element === void 0 ? (_slots$element = slots.element) === null || _slots$element === void 0 ? void 0 : _slots$element.call(slots) : _props$element;
- if (inputType === ClearableInputType[0]) {
- return renderTextAreaWithClearIcon(prefixCls, element);
- }
- return renderInputWithLabel(prefixCls, renderLabeledIcon(prefixCls, element));
- };
- }
- });
- exports.default = _default;
|