tdesign-vue-next
Version:
TDesign Component for vue-next
315 lines (307 loc) • 10.9 kB
JavaScript
/**
* tdesign v1.20.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-e7f02647.js');
require('@babel/runtime/helpers/toConsumableArray');
require('@babel/runtime/helpers/typeof');
require('../_chunks/dep-449273df.js');
var index = require('../_chunks/dep-95cb1381.js');
require('@babel/runtime/helpers/slicedToArray');
require('../_chunks/dep-497fc9a5.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-80827572.js');
require('../_chunks/dep-df5442c5.js');
require('../_chunks/dep-f9b59444.js');
require('../config-provider/hooks/useConfig.js');
require('../_chunks/dep-31abb282.js');
require('../_chunks/dep-c71a9cd7.js');
require('dayjs');
require('../_chunks/dep-39529ef1.js');
require('../_chunks/dep-f4c1cb5b.js');
require('../_chunks/dep-4896d30f.js');
require('../_chunks/dep-2610df9f.js');
require('../_chunks/dep-2c7a67b8.js');
require('../_chunks/dep-db6459dd.js');
require('../_chunks/dep-4d7a3a91.js');
require('../_chunks/dep-6e64ef0e.js');
require('../_chunks/dep-959f4847.js');
require('../_chunks/dep-ae380218.js');
require('../_chunks/dep-fdac7521.js');
require('../_chunks/dep-141cbae1.js');
require('../_chunks/dep-c277c7cb.js');
require('../_chunks/dep-7653f80f.js');
require('../_chunks/dep-6e7a2100.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-51846987.js');
require('../_chunks/dep-be760bc2.js');
require('../_chunks/dep-c0cb4d13.js');
require('../_chunks/dep-9dfd682d.js');
require('../_chunks/dep-2db31625.js');
require('../_chunks/dep-0a17438d.js');
require('../_chunks/dep-5090b515.js');
require('../_chunks/dep-39313d05.js');
require('../_chunks/dep-f9bc7c82.js');
require('../_chunks/dep-1c6213b5.js');
require('../_chunks/dep-cfdee5e7.js');
require('../_chunks/dep-9ada3ec1.js');
require('../_chunks/dep-e3eb5659.js');
require('../_chunks/dep-d0227fbe.js');
require('../popup/container.js');
require('../_chunks/dep-ba2511b0.js');
require('../_chunks/dep-4e2a4791.js');
require('../_chunks/dep-f3377589.js');
require('../_chunks/dep-71d9daf0.js');
require('../_chunks/dep-abc005aa.js');
require('../tooltip/utils/index.js');
require('../_chunks/dep-3a800699.js');
require('../_chunks/dep-e25ae470.js');
require('../_chunks/dep-648bfb84.js');
require('../_chunks/dep-4e2907e0.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