UNPKG

tdesign-vue-next

Version:
101 lines (97 loc) 3.6 kB
/** * tdesign v1.20.3 * (c) 2026 tdesign * @license MIT */ import { computed, createVNode } from 'vue'; import { _ as _toConsumableArray } from '../../_chunks/dep-adf8ce39.mjs'; import { isArray, cloneDeep } from 'lodash-es'; import { l as log } from '../../_chunks/dep-4c65e11b.mjs'; import { g as getStopStyle } from '../../_chunks/dep-62329e33.mjs'; import TSliderMark from '../slider-mark.mjs'; import '../../_chunks/dep-390963eb.mjs'; import '../../_chunks/dep-5975d369.mjs'; import '../../_chunks/dep-d84a2ec7.mjs'; import '../../_chunks/dep-12b4e978.mjs'; import '../../_chunks/dep-0841ee8f.mjs'; import '../../config-provider/hooks/useConfig.mjs'; import '../../config-provider/utils/context.mjs'; import '../../_chunks/dep-cf105282.mjs'; import '../../_chunks/dep-dcbc09c5.mjs'; import '../../_chunks/dep-9fc6972b.mjs'; import '../../_chunks/dep-ff183185.mjs'; import '../../_chunks/dep-a1cbfaae.mjs'; import '../../_chunks/dep-3f53eff0.mjs'; import '../../_chunks/dep-46776e3b.mjs'; import '../../_chunks/dep-07d8f2aa.mjs'; import '../../_chunks/dep-8aebe545.mjs'; var useSliderMark = function useSliderMark(config) { var name = config.value.prefixName; var markList = computed(function () { var markProps = config.value; if (!markProps.marks) { return []; } var legalMarks = []; if (isArray(markProps.marks)) { var marksList = cloneDeep(markProps.marks).sort(function (a, b) { return a - b; }); var maxLimit = Math.max.apply(Math, _toConsumableArray(marksList).concat([markProps.max])); var minLimit = Math.min.apply(Math, _toConsumableArray(marksList).concat([markProps.min])); if (minLimit < markProps.min) { log.errorOnce("TSlider", "marks min value should >= props min"); } if (maxLimit > markProps.max) { log.errorOnce("TSlider", "marks max value should <= props max"); } marksList.forEach(function (item) { legalMarks.push({ point: item, position: (item - minLimit) / (maxLimit - minLimit) * 100, mark: item }); }); } else { Object.keys(markProps.marks).map(parseFloat).sort(function (a, b) { return a - b; }).filter(function (point) { return point <= markProps.max && point >= markProps.min; }).forEach(function (point) { var item = { point: point, position: (point - markProps.min) * 100 / (markProps.max - markProps.min), mark: markProps.marks[point] }; legalMarks.push(item); }); } return legalMarks; }); var renderMask = function renderMask(onChangeFn) { if (!markList.value.length) return null; return createVNode("div", null, [createVNode("div", { "class": "".concat(name, "__stops") }, [markList.value.map(function (item, index) { if (item.position === 0 || item.position === 100) return null; return createVNode("div", { "class": "".concat(name, "__stop ").concat(name, "__mark-stop"), "style": getStopStyle(item.position, config.value.vertical), "key": index }, null); })]), createVNode("div", { "class": "".concat(name, "__mark") }, [markList.value.map(function (item, key) { return createVNode(TSliderMark, { "mark": item.mark, "point": item.point, "key": key, "style": getStopStyle(item.position, config.value.vertical), "onClickMarkPoint": onChangeFn }, null); })])]); }; return renderMask; }; export { useSliderMark }; //# sourceMappingURL=useSliderMark.mjs.map