ant-design-vue
Version:
An enterprise-class UI design language and Vue-based implementation
137 lines (115 loc) • 4.04 kB
JavaScript
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;
;