tdesign-vue-next
Version:
TDesign Component for vue-next
318 lines (310 loc) • 11 kB
JavaScript
/**
* tdesign v1.19.2
* (c) 2026 tdesign
* @license MIT
*/
;
Object.defineProperty(exports, '__esModule', { value: true });
var Vue = require('vue');
var _defineProperty = require('@babel/runtime/helpers/defineProperty');
var utils = require('../_chunks/dep-b81b238d.js');
require('@babel/runtime/helpers/toConsumableArray');
require('@babel/runtime/helpers/typeof');
require('../_chunks/dep-35e23c2b.js');
var index = require('../_chunks/dep-0238ed9a.js');
require('@babel/runtime/helpers/slicedToArray');
require('../_chunks/dep-0989c3be.js');
var tooltip_index = require('../tooltip/index.js');
var slider_constants_index = require('./constants/index.js');
var slider_hooks_useSliderTooltip = require('./hooks/useSliderTooltip.js');
var isFunction = require('../_chunks/dep-2dcf9237.js');
require('../_chunks/dep-631750cd.js');
require('../_chunks/dep-22dc294c.js');
require('../_chunks/dep-4cb26289.js');
require('../_chunks/dep-4a7162e7.js');
require('../config-provider/hooks/useConfig.js');
require('../_chunks/dep-be1af85d.js');
require('../_chunks/dep-db9c85b1.js');
require('dayjs');
require('../_chunks/dep-82fe2026.js');
require('../_chunks/dep-33b46a52.js');
require('../_chunks/dep-930a2de5.js');
require('../_chunks/dep-bf76dead.js');
require('../_chunks/dep-c3bbd06c.js');
require('../_chunks/dep-6d87f74d.js');
require('../_chunks/dep-281f7eb2.js');
require('../_chunks/dep-f8f7b1af.js');
require('../_chunks/dep-66d3f30f.js');
require('../_chunks/dep-e1d22111.js');
require('../_chunks/dep-754c0523.js');
require('../_chunks/dep-7076a08a.js');
require('../_chunks/dep-2fc884aa.js');
require('../_chunks/dep-75d6da05.js');
require('../_chunks/dep-274369eb.js');
require('../_chunks/dep-df6e14a0.js');
require('@babel/runtime/helpers/createClass');
require('@babel/runtime/helpers/classCallCheck');
require('../tooltip/tooltip.js');
require('../tooltip/props.js');
require('../popup/props.js');
require('../popup/index.js');
require('../popup/popup.js');
require('@popperjs/core');
require('../_chunks/dep-8d990e66.js');
require('../_chunks/dep-1862d466.js');
require('../_chunks/dep-a6551cc4.js');
require('../_chunks/dep-7d9abefd.js');
require('../_chunks/dep-2fb8d44f.js');
require('../_chunks/dep-80a41429.js');
require('../_chunks/dep-91305690.js');
require('../_chunks/dep-0b92e695.js');
require('../_chunks/dep-b2024592.js');
require('../_chunks/dep-9f98bf9b.js');
require('../_chunks/dep-38acad3d.js');
require('../_chunks/dep-4ba41627.js');
require('../_chunks/dep-ce9c15f5.js');
require('../popup/container.js');
require('../_chunks/dep-e2122882.js');
require('../_chunks/dep-9bee89d3.js');
require('../_chunks/dep-027cd76f.js');
require('../_chunks/dep-ae4040c5.js');
require('../_chunks/dep-79476fcb.js');
require('../_chunks/dep-e3edff33.js');
require('../tooltip/utils/index.js');
require('../_chunks/dep-5c79e9ef.js');
require('../_chunks/dep-4eca9add.js');
require('../_chunks/dep-9a54a293.js');
require('../_chunks/dep-7870f4cb.js');
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
var _defineProperty__default = /*#__PURE__*/_interopDefaultLegacy(_defineProperty);
var _SliderButton = Vue.defineComponent({
name: "TSliderButton",
props: {
value: {
type: [Number],
"default": 0
},
vertical: {
type: Boolean,
"default": false
},
tooltipProps: {
type: [Boolean, Object],
"default": true
},
label: {
type: [String, Boolean, Function]
},
range: {
type: Boolean,
"default": false
},
position: {
type: String
}
},
emits: ["input", "mouseup"],
setup: function setup(props, ctx) {
var COMPONENT_NAME = index.usePrefixClass("slider__button");
var tooltipConfig = Vue.computed(function () {
return props;
});
var _useSliderTooltip = slider_hooks_useSliderTooltip.useSliderTooltip(tooltipConfig),
tooltipRef = _useSliderTooltip.tooltipRef,
tooltipProps = _useSliderTooltip.tooltipProps,
toggleTooltip = _useSliderTooltip.toggleTooltip,
showTooltip = _useSliderTooltip.showTooltip;
var parentProps = Vue.inject(slider_constants_index.sliderPropsInjectKey);
var buttonRef = Vue.ref();
var dragged = Vue.ref(false);
var slideButtonProps = Vue.reactive({
dragging: false,
isClick: false,
startX: 0,
startY: 0,
startPos: 0,
newPos: null
});
var rangeDiff = Vue.computed(function () {
return Number(parentProps.max) - Number(parentProps.min);
});
var currentPos = Vue.computed(function () {
return "".concat((props.value - parentProps.min) / rangeDiff.value * 100, "%");
});
var step = Vue.computed(function () {
return parentProps.step;
});
var wrapperStyle = Vue.computed(function () {
return props.vertical ? {
bottom: currentPos.value
} : {
left: currentPos.value
};
});
Vue.watchEffect(function () {
parentProps.toggleDragging(slideButtonProps.dragging);
});
var setPosition = function setPosition(pos) {
var newPos = pos;
if (newPos === null || Number.isNaN(newPos)) {
return;
}
if (newPos > 100) {
newPos = 100;
} else if (newPos < 0) {
newPos = 0;
}
var perStepLen = 100 * step.value / rangeDiff.value;
var steps = Math.round(newPos / perStepLen);
var value = steps * perStepLen * rangeDiff.value * 0.01;
value += parentProps.min;
value = utils.formatPrecision(value, parentProps.precision);
ctx.emit("input", value);
Vue.nextTick(function () {
var _tooltipRef$value$upd, _tooltipRef$value;
tooltipRef.value && ((_tooltipRef$value$upd = (_tooltipRef$value = tooltipRef.value).updatePopper) === null || _tooltipRef$value$upd === void 0 ? void 0 : _tooltipRef$value$upd.call(_tooltipRef$value));
});
};
var handleMouseEnter = function handleMouseEnter() {
buttonRef.value.focus();
toggleTooltip(true);
};
var handleMouseLeave = function handleMouseLeave() {
if (!slideButtonProps.dragging) {
toggleTooltip(false);
}
};
var onDragStart = function onDragStart(event) {
slideButtonProps.dragging = true;
slideButtonProps.isClick = true;
var type = event.type;
var clientY = event.clientY,
clientX = event.clientX;
if (type === "touchstart") {
var touch = event.touches;
var _ref = [touch[0].clientY, touch[0].clientX];
clientY = _ref[0];
clientX = _ref[1];
}
if (props.vertical) {
slideButtonProps.startY = clientY;
} else {
slideButtonProps.startX = clientX;
}
slideButtonProps.startPos = parseFloat(currentPos.value);
slideButtonProps.newPos = slideButtonProps.startPos;
};
var onDragging = function onDragging(e) {
var event = e;
if (!slideButtonProps.dragging) {
return;
}
dragged.value = true;
slideButtonProps.isClick = false;
if (parentProps !== null && parentProps !== void 0 && parentProps.resetSize && isFunction.isFunction(parentProps === null || parentProps === void 0 ? void 0 : parentProps.resetSize)) {
parentProps.resetSize();
}
var diff = 0;
var parentSliderSize = parentProps.sliderSize;
var type = event.type;
var clientY = event.clientY,
clientX = event.clientX;
if (type === "touchmove") {
var touch = event.touches;
var _ref2 = [touch[0].clientY, touch[0].clientX];
clientY = _ref2[0];
clientX = _ref2[1];
}
if (props.vertical) {
diff = slideButtonProps.startY - clientY;
} else {
diff = clientX - slideButtonProps.startX;
}
diff = diff / parentSliderSize * 100;
slideButtonProps.newPos = slideButtonProps.startPos + diff;
setPosition(slideButtonProps.newPos);
};
var _onDragEnd = function onDragEnd() {
if (slideButtonProps.dragging) {
setTimeout(function () {
slideButtonProps.dragging = false;
toggleTooltip(false);
if (!slideButtonProps.isClick) {
setPosition(slideButtonProps.newPos);
}
dragged.value && ctx.emit("mouseup");
dragged.value = false;
}, 0);
window.removeEventListener("mousemove", onDragging);
window.removeEventListener("touchmove", onDragging);
window.removeEventListener("mouseup", _onDragEnd);
window.removeEventListener("touchend", _onDragEnd);
window.removeEventListener("contextmenu", _onDragEnd);
}
};
function onButtonDown(event) {
if (parentProps.disabled) {
return;
}
event.preventDefault();
onDragStart(event);
window.addEventListener("mousemove", onDragging);
window.addEventListener("mouseup", _onDragEnd);
window.addEventListener("touchmove", onDragging);
window.addEventListener("touchend", _onDragEnd);
window.addEventListener("contextmenu", _onDragEnd);
}
var onKeyDown = function onKeyDown(state) {
if (parentProps.disabled) {
return;
}
var stepLength = step.value / rangeDiff.value * 100;
if (state === "sub") {
stepLength = -stepLength;
}
slideButtonProps.newPos = parseFloat(currentPos.value) + stepLength;
setPosition(slideButtonProps.newPos);
};
var onNativeKeyDown = function onNativeKeyDown(e) {
var code = e.code;
e.preventDefault();
if (code === "ArrowDown" || code === "ArrowLeft") {
onKeyDown("sub");
}
if (code === "ArrowUp" || code === "ArrowRight") {
onKeyDown("add");
}
};
ctx.expose({
setPosition: setPosition
});
return function () {
return Vue.createVNode("div", {
"ref": buttonRef,
"class": "".concat(COMPONENT_NAME.value, "-wrapper"),
"style": wrapperStyle.value,
"tabindex": "0",
"show-tooltip": showTooltip.value,
"onMouseenter": handleMouseEnter,
"onMouseleave": handleMouseLeave,
"onMousedown": onButtonDown,
"onTouchstart": onButtonDown,
"onFocus": handleMouseEnter,
"onBlur": handleMouseLeave,
"onKeydown": onNativeKeyDown
}, [Vue.createVNode(tooltip_index.Tooltip, Vue.mergeProps({
"ref": tooltipRef,
"hideEmptyPopup": true,
"disabled": !showTooltip.value
}, tooltipProps.value), {
"default": function _default() {
return [Vue.createVNode("div", {
"class": [COMPONENT_NAME.value, _defineProperty__default["default"]({}, "".concat(COMPONENT_NAME.value, "--dragging"), slideButtonProps.dragging)]
}, null)];
}
})]);
};
}
});
exports["default"] = _SliderButton;
//# sourceMappingURL=slider-button.js.map