UNPKG

tdesign-vue-next

Version:
304 lines (296 loc) 11.3 kB
/** * tdesign v1.20.0 * (c) 2026 tdesign * @license MIT */ 'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var Vue = require('vue'); var _asyncToGenerator = require('@babel/runtime/helpers/asyncToGenerator'); var _regeneratorRuntime = require('@babel/runtime/regenerator'); var anchor_utils_index = require('./utils/index.js'); var dom = require('../_chunks/dep-aa61e27f.js'); var anchor_props = require('./props.js'); require('@babel/runtime/helpers/toConsumableArray'); require('@babel/runtime/helpers/typeof'); var index$2 = require('../_chunks/dep-aa87a8f5.js'); var index$1 = require('../_chunks/dep-6b2b1f80.js'); var index = require('../_chunks/dep-b9c82189.js'); require('@babel/runtime/helpers/slicedToArray'); require('../_chunks/dep-ce392f73.js'); require('@babel/runtime/helpers/defineProperty'); var affix_index = require('../affix/index.js'); var anchor_constants_index = require('./constants/index.js'); require('../_chunks/dep-b3ef977e.js'); require('../_chunks/dep-0e867224.js'); require('../_chunks/dep-cd6733fb.js'); require('../_chunks/dep-caa8987f.js'); require('../_chunks/dep-5c730151.js'); require('../_chunks/dep-f549ecb7.js'); require('../_chunks/dep-8e3205d4.js'); require('../_chunks/dep-1da18355.js'); require('../_chunks/dep-4f8e5834.js'); require('../_chunks/dep-b809bbd2.js'); require('../_chunks/dep-08fc313e.js'); require('../_chunks/dep-ff23118f.js'); require('../_chunks/dep-678c34e4.js'); require('../_chunks/dep-950f8e72.js'); require('../_chunks/dep-bf028c39.js'); require('../config-provider/hooks/useConfig.js'); require('../_chunks/dep-a64c9b8c.js'); require('../_chunks/dep-aafbacfe.js'); require('dayjs'); require('../_chunks/dep-c539b8cf.js'); require('../_chunks/dep-bd404105.js'); require('../_chunks/dep-5ed96ff4.js'); require('../_chunks/dep-b937ef62.js'); require('../_chunks/dep-0ad5a5a6.js'); require('../_chunks/dep-68ca5b5a.js'); require('../_chunks/dep-ce54d478.js'); require('../_chunks/dep-9b493151.js'); require('../_chunks/dep-933eb47e.js'); require('../_chunks/dep-01e6d254.js'); require('../_chunks/dep-d3fa0c96.js'); require('../_chunks/dep-5a252af6.js'); require('../_chunks/dep-f4839f43.js'); require('../_chunks/dep-330e6dfc.js'); require('../_chunks/dep-af55a921.js'); require('@babel/runtime/helpers/createClass'); require('@babel/runtime/helpers/classCallCheck'); require('../affix/affix.js'); require('../affix/props.js'); require('../_chunks/dep-ce75379a.js'); require('../_chunks/dep-654cced3.js'); function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; } var _asyncToGenerator__default = /*#__PURE__*/_interopDefaultLegacy(_asyncToGenerator); var _regeneratorRuntime__default = /*#__PURE__*/_interopDefaultLegacy(_regeneratorRuntime); function _isSlot(s) { return typeof s === 'function' || Object.prototype.toString.call(s) === '[object Object]' && !Vue.isVNode(s); } var _Anchor = Vue.defineComponent({ name: "TAnchor", inheritAttrs: false, props: anchor_props["default"], setup: function setup(props2, _ref) { var attrs = _ref.attrs; var anchorRef = Vue.ref(null); var links = Vue.ref([]); var active = Vue.ref(""); var scrollContainer = Vue.ref(); var handleScrollLock = Vue.ref(false); var activeLineStyle = Vue.reactive({}); var COMPONENT_NAME = index.usePrefixClass("anchor"); var ANCHOR_LINE_CLASSNAME = index.usePrefixClass("anchor__line"); var ANCHOR_LINE_CURSOR_CLASSNAME = index.usePrefixClass("anchor__line-cursor"); var _useCommonClassName = index$1.useCommonClassName(), STATUS = _useCommonClassName.STATUS, SIZE = _useCommonClassName.SIZE; var renderTNodeJSX = index$2.useTNodeJSX(); var getScrollContainer = function getScrollContainer() { if (dom.isServer) { return; } var container = props2.container; scrollContainer.value = dom.getScrollContainer(container); dom.on(scrollContainer.value, "scroll", handleScroll); handleScroll(); }; var handleScroll = function handleScroll() { if (handleScrollLock.value) return; var bounds = props2.bounds, targetOffset = props2.targetOffset; var filters = []; var active2 = ""; links.value.forEach(function (link) { var anchor = getAnchorTarget(link); if (!anchor) { return; } var top = anchor_utils_index.getOffsetTop(anchor, scrollContainer.value); if (top < bounds + targetOffset) { filters.push({ link: link, top: top }); } }); if (filters.length) { var latest = filters.reduce(function (prev, cur) { return prev.top > cur.top ? prev : cur; }); active2 = latest.link; } setCurrentActiveLink(active2); }; var getAnchorTarget = function getAnchorTarget(link) { var matcher = link.match(anchor_utils_index.ANCHOR_SHARP_REGEXP); if (!matcher) { return; } var anchor = document.getElementById(matcher[1]); if (!anchor) { return; } return anchor; }; var registerLink = function registerLink(link) { if (!anchor_utils_index.ANCHOR_SHARP_REGEXP.test(link) || links.value.indexOf(link) !== -1) { return; } links.value.push(link); }; var unregisterLink = function unregisterLink(link) { links.value = links.value.filter(function (each) { return each !== link; }); }; var setCurrentActiveLink = /*#__PURE__*/function () { var _ref2 = _asyncToGenerator__default["default"](/*#__PURE__*/_regeneratorRuntime__default["default"].mark(function _callee(link) { var _props2$onChange; return _regeneratorRuntime__default["default"].wrap(function (_context) { while (1) switch (_context.prev = _context.next) { case 0: if (!(active.value === link)) { _context.next = 1; break; } return _context.abrupt("return"); case 1: active.value = link; (_props2$onChange = props2.onChange) === null || _props2$onChange === void 0 || _props2$onChange.call(props2, link, active.value); _context.next = 2; return Vue.nextTick(); case 2: updateActiveLine(); case 3: case "end": return _context.stop(); } }, _callee); })); return function setCurrentActiveLink(_x) { return _ref2.apply(this, arguments); }; }(); var updateActiveLine = function updateActiveLine() { var _anchorRef$value; var ele = (_anchorRef$value = anchorRef.value) === null || _anchorRef$value === void 0 ? void 0 : _anchorRef$value.querySelector(".".concat(STATUS.value.active, ">a")); if (!ele) { Object.assign(activeLineStyle, {}); return; } var top = ele.offsetTop, height = ele.offsetHeight; Object.assign(activeLineStyle, { top: "".concat(top, "px"), height: "".concat(height, "px"), opacity: 1 }); }; var handleLinkClick = function handleLinkClick(link) { var _props2$onClick; (_props2$onClick = props2.onClick) === null || _props2$onClick === void 0 || _props2$onClick.call(props2, link); }; var handleScrollTo = /*#__PURE__*/function () { var _ref3 = _asyncToGenerator__default["default"](/*#__PURE__*/_regeneratorRuntime__default["default"].mark(function _callee2(link) { var anchor, targetOffset, scrollTop, offsetTop, top; return _regeneratorRuntime__default["default"].wrap(function (_context2) { while (1) switch (_context2.prev = _context2.next) { case 0: anchor = getAnchorTarget(link); setCurrentActiveLink(link); if (anchor) { _context2.next = 1; break; } return _context2.abrupt("return"); case 1: handleScrollLock.value = true; targetOffset = props2.targetOffset; scrollTop = dom.getScroll(scrollContainer.value); offsetTop = anchor_utils_index.getOffsetTop(anchor, scrollContainer.value); top = scrollTop + offsetTop - targetOffset; _context2.next = 2; return dom.scrollTo(top, { container: scrollContainer.value }); case 2: handleScrollLock.value = false; case 3: case "end": return _context2.stop(); } }, _callee2); })); return function handleScrollTo(_x2) { return _ref3.apply(this, arguments); }; }(); var renderCursor = function renderCursor() { var titleContent = renderTNodeJSX("cursor"); return titleContent || Vue.createVNode("div", { "class": ANCHOR_LINE_CURSOR_CLASSNAME.value }, null); }; Vue.onMounted(/*#__PURE__*/_asyncToGenerator__default["default"](/*#__PURE__*/_regeneratorRuntime__default["default"].mark(function _callee3() { return _regeneratorRuntime__default["default"].wrap(function (_context3) { while (1) switch (_context3.prev = _context3.next) { case 0: getScrollContainer(); if (!active.value) { _context3.next = 2; break; } _context3.next = 1; return Vue.nextTick(); case 1: handleScrollTo(active.value); case 2: case "end": return _context3.stop(); } }, _callee3); }))); Vue.onUnmounted(function () { if (!scrollContainer.value) return; dom.off(scrollContainer.value, "scroll", handleScroll); }); Vue.watchEffect(function () { if (scrollContainer.value) { dom.off(scrollContainer.value, "scroll", handleScroll); } getScrollContainer(); }); Vue.provide(anchor_constants_index.AnchorInjectionKey, Vue.reactive({ registerLink: registerLink, unregisterLink: unregisterLink, handleScrollTo: handleScrollTo, handleLinkClick: handleLinkClick, active: active })); return function () { var size = props2.size, affixProps = props2.affixProps; var className = [COMPONENT_NAME.value, SIZE.value[size]]; var content = Vue.createVNode("div", Vue.mergeProps({ "ref": anchorRef, "class": className }, attrs), [Vue.createVNode("div", { "class": ANCHOR_LINE_CLASSNAME.value }, [Vue.createVNode("div", { "class": "".concat(ANCHOR_LINE_CURSOR_CLASSNAME.value, "-wrapper"), "style": activeLineStyle }, [renderCursor()])]), renderTNodeJSX("default")]); if (affixProps) { return Vue.createVNode(affix_index.Affix, affixProps, _isSlot(content) ? content : { "default": function _default() { return [content]; } }); } return content; }; } }); exports["default"] = _Anchor; //# sourceMappingURL=anchor.js.map