UNPKG

ant-design-vue

Version:

An enterprise-class UI design language and Vue-based implementation

137 lines (115 loc) 4.04 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _classNames = _interopRequireDefault(require("../../_util/classNames")); var _propsUtil = require("../../_util/props-util"); var _vnode = require("../../_util/vnode"); var _warning = _interopRequireDefault(require("../../_util/warning")); var _BaseMixin = _interopRequireDefault(require("../../_util/BaseMixin")); var _PropTypes = require("./PropTypes"); var _vue = require("vue"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } var _default = (0, _vue.defineComponent)({ name: 'TouchFeedback', mixins: [_BaseMixin.default], inheritAttrs: false, props: (0, _propsUtil.initDefaultProps)(_PropTypes.ITouchProps, { disabled: false }), data: function data() { this.child = null; return { active: false }; }, mounted: function mounted() { var _this = this; this.$nextTick(function () { if (_this.disabled && _this.active) { _this.setState({ active: false }); } }); }, methods: { triggerEvent: function triggerEvent(type, isActive, ev) { var eventType = "on".concat(type); var child = this.child; if (child.props[eventType]) { child.props[eventType](ev); } if (isActive !== this.active) { this.setState({ active: isActive }); } }, onTouchStart: function onTouchStart(e) { this.triggerEvent('Touchstart', true, e); }, onTouchMove: function onTouchMove(e) { this.triggerEvent('Touchmove', false, e); }, onTouchEnd: function onTouchEnd(e) { this.triggerEvent('Touchend', false, e); }, onTouchCancel: function onTouchCancel(e) { this.triggerEvent('Touchcancel', false, e); }, onMouseDown: function onMouseDown(e) { // pc simulate mobile this.triggerEvent('Mousedown', true, e); }, onMouseUp: function onMouseUp(e) { this.triggerEvent('Mouseup', false, e); }, onMouseLeave: function onMouseLeave(e) { this.triggerEvent('Mouseleave', false, e); } }, render: function render() { var _this$$props = this.$props, disabled = _this$$props.disabled, _this$$props$activeCl = _this$$props.activeClassName, activeClassName = _this$$props$activeCl === void 0 ? '' : _this$$props$activeCl, _this$$props$activeSt = _this$$props.activeStyle, activeStyle = _this$$props$activeSt === void 0 ? {} : _this$$props$activeSt; var child = (0, _propsUtil.getSlot)(this); if (child.length !== 1) { (0, _warning.default)(false, 'm-feedback组件只能包含一个子元素'); return null; } var events = disabled ? undefined : { onTouchstart: this.onTouchStart, onTouchmove: this.onTouchMove, onTouchend: this.onTouchEnd, onTouchcancel: this.onTouchCancel, onMousedown: this.onMouseDown, onMouseup: this.onMouseUp, onMouseleave: this.onMouseLeave }; child = child[0]; this.child = child; if (!disabled && this.active) { var _child$props = child.props, style = _child$props.style, className = _child$props.class; if (activeStyle !== false) { if (activeStyle) { style = _extends(_extends({}, style), activeStyle); } className = (0, _classNames.default)(className, activeClassName); } return (0, _vnode.cloneElement)(child, _extends({ class: className, style: style }, events)); } return (0, _vnode.cloneElement)(child, events); } }); exports.default = _default;