UNPKG

tdesign-vue-next

Version:
541 lines (533 loc) 20.9 kB
/** * tdesign v1.19.2 * (c) 2026 tdesign * @license MIT */ 'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var Vue = require('vue'); var _toConsumableArray = require('@babel/runtime/helpers/toConsumableArray'); var _defineProperty = require('@babel/runtime/helpers/defineProperty'); var _slicedToArray = require('@babel/runtime/helpers/slicedToArray'); var utils = require('../_chunks/dep-b81b238d.js'); require('@babel/runtime/helpers/typeof'); require('../_chunks/dep-35e23c2b.js'); var index$2 = require('../_chunks/dep-38acad3d.js'); var index$1 = require('../_chunks/dep-0238ed9a.js'); var index = require('../_chunks/dep-362c5212.js'); require('../_chunks/dep-0989c3be.js'); var index$3 = require('../_chunks/dep-ce9c15f5.js'); var slider_constants_index = require('./constants/index.js'); var slider_hooks_useSliderInput = require('./hooks/useSliderInput.js'); var slider_hooks_useSliderMark = require('./hooks/useSliderMark.js'); var slider_props = require('./props.js'); var slider_sliderButton = require('./slider-button.js'); var isArray = require('../_chunks/dep-4cb26289.js'); var isNumber = require('../_chunks/dep-44195fb2.js'); require('../_chunks/dep-631750cd.js'); require('../_chunks/dep-22dc294c.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-2dcf9237.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('../_chunks/dep-74b143e0.js'); require('@babel/runtime/helpers/createClass'); require('@babel/runtime/helpers/classCallCheck'); require('../_chunks/dep-9f98bf9b.js'); require('../_chunks/dep-b2024592.js'); require('../_chunks/dep-2fb8d44f.js'); require('../_chunks/dep-80a41429.js'); require('../input-number/index.js'); require('../input-number/input-number.js'); require('tdesign-icons-vue-next'); require('../button/index.js'); require('../button/button.js'); require('../loading/index.js'); require('../_chunks/dep-34cd76d4.js'); require('../loading/plugin.js'); require('../_chunks/dep-d632b788.js'); require('../loading/icon/gradient.js'); require('../_chunks/dep-4ba41627.js'); require('../_chunks/dep-2aa3d3cf.js'); require('@babel/runtime/helpers/objectWithoutProperties'); require('../_chunks/dep-3d29e358.js'); require('../_chunks/dep-6212811d.js'); require('../_chunks/dep-8d990e66.js'); require('../_chunks/dep-1862d466.js'); require('../_chunks/dep-a6551cc4.js'); require('../_chunks/dep-7d9abefd.js'); require('../_chunks/dep-91305690.js'); require('../_chunks/dep-0b92e695.js'); require('../loading/props.js'); require('../_chunks/dep-43dcd2db.js'); require('../_chunks/dep-392dde71.js'); require('../_chunks/dep-02ea4f3c.js'); require('../_chunks/dep-5103206f.js'); require('../_chunks/dep-7707ffe2.js'); require('../_chunks/dep-74a5bebe.js'); require('../_chunks/dep-4eca9add.js'); require('../_chunks/dep-42740075.js'); require('../_chunks/dep-9ac5c6ca.js'); require('../_chunks/dep-e3edff33.js'); require('../button/props.js'); require('../_chunks/dep-719a33c8.js'); require('../input/index.js'); require('../input/input.js'); require('../input/props.js'); require('../_chunks/dep-c26a7d50.js'); require('../_chunks/dep-9dbade68.js'); require('../input/hooks/useInput.js'); require('../form/constants/index.js'); require('../input/hooks/useLengthLimit.js'); require('../_chunks/dep-692bdebe.js'); require('../input/hooks/useInputEventHandler.js'); require('../input/hooks/useInputWidth.js'); require('../_chunks/dep-e2122882.js'); require('../input/input-group.js'); require('../input/input-group-props.js'); require('../input-number/props.js'); require('../_chunks/dep-a13f0135.js'); require('../input-number/hooks/useInputNumber.js'); require('../_chunks/dep-6bac596c.js'); require('../_chunks/dep-73734701.js'); require('../_chunks/dep-5c79e9ef.js'); require('../_chunks/dep-9a54a293.js'); require('../_chunks/dep-7870f4cb.js'); require('./slider-mark.js'); require('../tooltip/index.js'); require('../tooltip/tooltip.js'); require('../tooltip/props.js'); require('../popup/props.js'); require('../popup/index.js'); require('../popup/popup.js'); require('@popperjs/core'); require('../popup/container.js'); require('../_chunks/dep-9bee89d3.js'); require('../_chunks/dep-027cd76f.js'); require('../_chunks/dep-ae4040c5.js'); require('../_chunks/dep-79476fcb.js'); require('../tooltip/utils/index.js'); require('./hooks/useSliderTooltip.js'); function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; } var _toConsumableArray__default = /*#__PURE__*/_interopDefaultLegacy(_toConsumableArray); var _defineProperty__default = /*#__PURE__*/_interopDefaultLegacy(_defineProperty); var _slicedToArray__default = /*#__PURE__*/_interopDefaultLegacy(_slicedToArray); var _Slider = Vue.defineComponent({ name: "TSlider", model: { prop: "value", event: "change" }, props: slider_props["default"], setup: function setup(props2) { var isDisabled = index.useDisabled(); var COMPONENT_NAME = index$1.usePrefixClass("slider"); var _useCommonClassName = index$2.useCommonClassName(), STATUS = _useCommonClassName.STATUS; var _toRefs = Vue.toRefs(props2), value = _toRefs.value, modelValue = _toRefs.modelValue; var _useVModel = index$3.useVModel(value, modelValue, props2.defaultValue, props2.onChange), _useVModel2 = _slicedToArray__default["default"](_useVModel, 2), sliderValue = _useVModel2[0], setSliderValue = _useVModel2[1]; var sliderContainerRef = Vue.ref(); var sliderRef = Vue.ref(); var firstButtonRef = Vue.ref(); var secondButtonRef = Vue.ref(); var firstValue = Vue.ref(utils.formatSliderValue(sliderValue.value, "first")); var secondValue = Vue.ref(utils.formatSliderValue(sliderValue.value, "second")); var dragging = Vue.ref(false); var sliderSize = Vue.ref(1); var vertical = Vue.computed(function () { return props2.layout === "vertical"; }); var containerClass = Vue.computed(function () { return ["".concat(COMPONENT_NAME.value, "__container"), { "is-vertical": vertical.value }]; }); var sliderClass = Vue.computed(function () { return ["".concat(COMPONENT_NAME.value), _defineProperty__default["default"](_defineProperty__default["default"](_defineProperty__default["default"]({ "is-vertical": vertical.value }, "".concat(COMPONENT_NAME.value, "--with-input"), props2.inputNumberProps), "".concat(COMPONENT_NAME.value, "--vertical"), vertical.value), STATUS.value.disabled, isDisabled.value)]; }); var sliderRailClass = Vue.computed(function () { return ["".concat(COMPONENT_NAME.value, "__rail"), { "show-input": props2.inputNumberProps, disabled: isDisabled.value }]; }); var runwayStyle = Vue.computed(function () { return vertical.value ? { height: "100%" } : {}; }); var barStyle = Vue.computed(function () { var barStart = props2.range ? "".concat(100 * (minValue.value - props2.min) / rangeDiff.value, "%") : "0%"; var currentDiff = props2.range ? maxValue.value - minValue.value : firstValue.value - props2.min; var barSize = "".concat(100 * currentDiff / rangeDiff.value, "%"); return vertical.value ? { height: barSize, bottom: barStart } : { width: barSize, left: barStart }; }); var rangeDiff = Vue.computed(function () { return props2.max - props2.min; }); var minValue = Vue.computed(function () { return Math.min(firstValue.value, secondValue.value); }); var maxValue = Vue.computed(function () { return Math.max(firstValue.value, secondValue.value); }); var steps = Vue.computed(function () { if (!props2.showStep || props2.min > props2.max) return []; if (props2.step === 0) { console.warn("[Element Warn][Slider]step should not be 0."); return []; } var stepCount = rangeDiff.value / props2.step; var stepWidth = 100 * props2.step / rangeDiff.value; var result = []; for (var i = 1; i < stepCount; i++) { result.push(i * stepWidth); } if (props2.range) { var r = result.filter(function (step2) { return step2 < 100 * (minValue.value - props2.min) / rangeDiff.value || props2.step > 100 * (maxValue.value - props2.max) / rangeDiff.value; }); return r; } return result.filter(function (step2) { return step2 > 100 * (firstValue.value - props2.min) / rangeDiff.value; }); }); var precision = Vue.computed(function () { var precisions = [props2.min, props2.max, props2.step].map(function (item) { var decimalArr = "".concat(item).split("."); return decimalArr[1] ? decimalArr[1].length : 0; }); return Math.max.apply(null, precisions); }); var setValues = function setValues(value2) { var _ref2 = [props2.min, props2.max], min2 = _ref2[0], max2 = _ref2[1]; if (min2 > max2) { console.warn("[Slider] max should be greater than min."); return; } if (props2.range && isArray.isArray(value2)) { var _ref3 = [Math.min.apply(Math, _toConsumableArray__default["default"](value2)), Math.max.apply(Math, _toConsumableArray__default["default"](value2))], maxLimit = _ref3[0], minLimit = _ref3[1]; if (maxLimit > max2) { maxLimit = firstValue.value; } if (maxLimit < min2) { maxLimit = min2; } if (minLimit < min2) { minLimit = secondValue.value; } if (minLimit > max2) { minLimit = max2; } var _ref4 = [maxLimit, minLimit]; firstValue.value = _ref4[0]; secondValue.value = _ref4[1]; return [maxLimit, minLimit]; } var preValue = value2; if (preValue < min2) { preValue = min2; } if (preValue > max2) { preValue = max2; } return preValue; }; var emitChange = function emitChange(value2) { var changeValue2 = value2; if (changeValue2 === void 0) { if (props2.range) { changeValue2 = [firstValue.value, secondValue.value]; } else { changeValue2 = firstValue.value; } } var fixValue = setValues(changeValue2); setSliderValue(fixValue); }; var resetSize = function resetSize() { if (sliderRef.value) { sliderSize.value = sliderRef.value["client".concat(vertical.value ? "Height" : "Width")]; } }; var isAlreadyMount = Vue.ref(false); var init = function init() { var valuetext; if (props2.range) { if (isArray.isArray(sliderValue.value)) { firstValue.value = utils.formatPrecision(Math.max(props2.min || 0, sliderValue.value[0]), precision.value); secondValue.value = utils.formatPrecision(Math.min(props2.max || 100, sliderValue.value[1]), precision.value); } else { firstValue.value = utils.formatPrecision(props2.min || 0, precision.value); secondValue.value = utils.formatPrecision(props2.max || 100, precision.value); } valuetext = "".concat(firstValue.value, "-").concat(secondValue.value); } else { if (!isNumber.isNumber(sliderValue.value)) { firstValue.value = props2.min; } else { var value2 = Math.min(props2.max, Math.max(props2.min, sliderValue.value)); firstValue.value = utils.formatPrecision(value2, precision.value); } valuetext = String(firstValue.value); } if (sliderContainerRef.value) { sliderContainerRef.value.setAttribute("aria-valuetext", valuetext); } resetSize(); window.addEventListener("resize", resetSize); }; var setPosition = function setPosition(percent) { var targetValue = percent * rangeDiff.value / 100; targetValue = props2.min + targetValue; if (!props2.range && firstButtonRef.value) { firstButtonRef.value.setPosition(percent); return; } var button; if (Math.abs(minValue.value - targetValue) < Math.abs(maxValue.value - targetValue)) { button = firstValue.value < secondValue.value ? "button1" : "button2"; } else { button = firstValue.value > secondValue.value ? "button1" : "button2"; } if (button === "button1" && firstButtonRef.value) { firstButtonRef.value.setPosition(percent); } if (button === "button2" && secondButtonRef.value) { secondButtonRef.value.setPosition(percent); } }; var getFixValue = function getFixValue() { var changeValue2 = props2.range ? [firstValue.value, secondValue.value] : firstValue.value; return setValues(changeValue2); }; var onSliderClick = function onSliderClick(event) { var _props2$onChangeEnd; if (isDisabled.value || dragging.value) { return; } if (!sliderRef.value) return; resetSize(); var value2 = 0; if (vertical.value) { var sliderOffsetBottom = sliderRef.value.getBoundingClientRect().bottom; value2 = (sliderOffsetBottom - event.clientY) / sliderSize.value * 100; setPosition(value2); } else { var sliderOffsetLeft = sliderRef.value.getBoundingClientRect().left; value2 = (event.clientX - sliderOffsetLeft) / sliderSize.value * 100; setPosition(value2); } var fixValue = getFixValue(); (_props2$onChangeEnd = props2.onChangeEnd) === null || _props2$onChangeEnd === void 0 || _props2$onChangeEnd.call(props2, fixValue); }; var changeValue = function changeValue(point) { var _props2$onChangeEnd2; if (isDisabled.value || dragging.value) { return; } resetSize(); var value2 = Number(point / rangeDiff.value * 100); setPosition(value2); emitChange(point); var fixValue = getFixValue(); (_props2$onChangeEnd2 = props2.onChangeEnd) === null || _props2$onChangeEnd2 === void 0 || _props2$onChangeEnd2.call(props2, fixValue); }; Vue.watch(function () { return sliderValue.value; }, function (newVal) { if (dragging.value === true) return; if (isArray.isArray(newVal) && props2.range) { var _newVal = _slicedToArray__default["default"](newVal, 2); firstValue.value = _newVal[0]; secondValue.value = _newVal[1]; } else { firstValue.value = newVal; } }, { deep: true }); Vue.watch([firstValue, secondValue, dragging], function (newStates, prevStates) { if (newStates[0] !== prevStates[0]) { if (props2.range) { emitChange([minValue.value, maxValue.value]); } else { emitChange(firstValue.value); } } if (newStates[1] !== prevStates[1]) { if (props2.range) { emitChange([minValue.value, maxValue.value]); } } if (newStates[2] !== prevStates[2] && newStates[2] === false) { init(); } }); Vue.onMounted(function () { init(); isAlreadyMount.value = true; }); Vue.onBeforeUnmount(function () { window.removeEventListener("resize", resetSize); }); var markConfig = Vue.computed(function () { return { max: props2.max, min: props2.min, marks: props2.marks, vertical: vertical.value, prefixName: COMPONENT_NAME.value }; }); var renderMask = slider_hooks_useSliderMark.useSliderMark(markConfig); var inputConfig = Vue.computed(function () { return { max: props2.max, min: props2.min, inputNumberProps: props2.inputNumberProps, step: props2.step, prefixName: COMPONENT_NAME.value, vertical: vertical.value, disabled: isDisabled.value }; }); var renderInputNumber = slider_hooks_useSliderInput.useSliderInput(inputConfig); var renderInputButton = function renderInputButton() { var firstInputVal = setValues(firstValue.value); var firstInputOnChange = function firstInputOnChange(v) { firstValue.value = setValues(v); }; var secondInputVal = setValues(secondValue.value); var secondInputOnChange = function secondInputOnChange(v) { secondValue.value = setValues(v); }; return Vue.createVNode("div", { "class": ["".concat(COMPONENT_NAME.value, "__input-container"), { "is-vertical": vertical.value }] }, [renderInputNumber(firstInputVal, firstInputOnChange), props2.range && Vue.createVNode("div", { "class": "".concat(COMPONENT_NAME.value, "__center-line") }, null), props2.range && renderInputNumber(secondInputVal, secondInputOnChange)]); }; var toggleDragging = function toggleDragging(toState) { dragging.value = toState; }; var _toRefs2 = Vue.toRefs(props2), min = _toRefs2.min, max = _toRefs2.max, step = _toRefs2.step; Vue.provide(slider_constants_index.sliderPropsInjectKey, Vue.reactive({ min: min, max: max, step: step, dragging: dragging, toggleDragging: toggleDragging, precision: precision, disabled: isDisabled, resetSize: resetSize, sliderSize: sliderSize })); return function () { return Vue.createVNode("div", { "class": containerClass.value, "ref": sliderContainerRef }, [Vue.createVNode("div", { "class": sliderClass.value, "role": "slider", "aria-valuemin": props2.min, "aria-valuemax": props2.max, "aria-orientation": props2.layout, "aria-disabled": isDisabled.value, "tooltip-props": props2.tooltipProps }, [Vue.createVNode("div", { "class": sliderRailClass.value, "style": runwayStyle.value, "onClick": onSliderClick, "ref": sliderRef }, [Vue.createVNode("div", { "class": "".concat(COMPONENT_NAME.value, "__track"), "style": barStyle.value }, null), Vue.createVNode(slider_sliderButton["default"], { "vertical": vertical.value, "value": firstValue.value, "ref": firstButtonRef, "range": props2.range, "position": "start", "tooltip-props": props2.tooltipProps, "label": props2.label, "onInput": function onInput(v) { firstValue.value = v; }, "onMouseup": function onMouseup() { var _props2$onChangeEnd3; var fixValue = getFixValue(); (_props2$onChangeEnd3 = props2.onChangeEnd) === null || _props2$onChangeEnd3 === void 0 || _props2$onChangeEnd3.call(props2, fixValue); } }, null), props2.range && Vue.createVNode(slider_sliderButton["default"], { "vertical": vertical.value, "value": secondValue.value, "ref": secondButtonRef, "label": props2.label, "range": props2.range, "position": "end", "tooltip-props": props2.tooltipProps, "onInput": function onInput(v) { secondValue.value = v; }, "onMouseup": function onMouseup() { var _props2$onChangeEnd4; var fixValue = getFixValue(); (_props2$onChangeEnd4 = props2.onChangeEnd) === null || _props2$onChangeEnd4 === void 0 || _props2$onChangeEnd4.call(props2, fixValue); } }, null), props2.showStep && Vue.createVNode("div", { "class": "".concat(COMPONENT_NAME.value, "__stops") }, [steps.value.map(function (item, key) { if (item.position === 0 || item.position === 100) return null; return Vue.createVNode("div", { "class": "".concat(COMPONENT_NAME.value, "__stop"), "key": key, "style": utils.getStopStyle(item, vertical.value) }, null); })]), renderMask(changeValue)])]), isAlreadyMount.value && props2.inputNumberProps && renderInputButton()]); }; } }); exports["default"] = _Slider; //# sourceMappingURL=slider.js.map