UNPKG

tdesign-vue-next

Version:
215 lines (207 loc) 8.21 kB
/** * tdesign v1.20.2 * (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 dom = require('../_chunks/dep-51846987.js'); var affix_props = require('./props.js'); require('@babel/runtime/helpers/toConsumableArray'); require('@babel/runtime/helpers/typeof'); var index$1 = require('../_chunks/dep-c0cb4d13.js'); var index = require('../_chunks/dep-95cb1381.js'); require('@babel/runtime/helpers/slicedToArray'); require('../_chunks/dep-497fc9a5.js'); require('@babel/runtime/helpers/defineProperty'); var isUndefined = require('../_chunks/dep-2cf25d25.js'); var isFunction = require('../_chunks/dep-80827572.js'); require('../_chunks/dep-449273df.js'); require('../_chunks/dep-f9b59444.js'); require('../_chunks/dep-be760bc2.js'); require('../_chunks/dep-2610df9f.js'); require('../_chunks/dep-959f4847.js'); require('../_chunks/dep-6e64ef0e.js'); require('../_chunks/dep-9dfd682d.js'); require('../_chunks/dep-2c7a67b8.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('../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-db6459dd.js'); require('../_chunks/dep-4d7a3a91.js'); require('../_chunks/dep-ae380218.js'); require('../_chunks/dep-fdac7521.js'); require('../_chunks/dep-df5442c5.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'); 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); var _Affix = Vue.defineComponent({ name: "TAffix", props: affix_props["default"], emits: ["fixedChange"], setup: function setup(props2, context) { var _document; var COMPONENT_NAME = index.usePrefixClass("affix"); var renderContent = index$1.useContent(); var affixWrapRef = Vue.ref(null); var affixRef = Vue.ref(null); var placeholderEL = Vue.ref((_document = document) === null || _document === void 0 ? void 0 : _document.createElement("div")); var ticking = Vue.ref(false); var isBind = Vue.ref(false); var scrollContainer = Vue.ref(); var affixStyle = Vue.ref(); var rAFId = 0; var handleScroll = function handleScroll() { if (!ticking.value) { rAFId = window.requestAnimationFrame(function () { var _affixWrapRef$value$g, _affixWrapRef$value; rAFId = 0; var _ref = (_affixWrapRef$value$g = (_affixWrapRef$value = affixWrapRef.value) === null || _affixWrapRef$value === void 0 ? void 0 : _affixWrapRef$value.getBoundingClientRect()) !== null && _affixWrapRef$value$g !== void 0 ? _affixWrapRef$value$g : { top: 0, width: 0, height: 0 }, wrapToTop = _ref.top, wrapWidth = _ref.width, wrapHeight = _ref.height; var containerTop = 0; if (scrollContainer.value instanceof HTMLElement) { containerTop = scrollContainer.value.getBoundingClientRect().top; } var fixedTop; var calcTop = wrapToTop - containerTop; var containerHeight = scrollContainer.value[scrollContainer.value instanceof Window ? "innerHeight" : "clientHeight"] - wrapHeight; var calcBottom = containerTop + containerHeight - props2.offsetBottom; if (!isUndefined.isUndefined(props2.offsetTop) && calcTop <= props2.offsetTop) { fixedTop = containerTop + props2.offsetTop; } else if (!isUndefined.isUndefined(props2.offsetBottom) && wrapToTop >= calcBottom) { fixedTop = calcBottom; } else { fixedTop = false; } if (affixRef.value) { var affixed = fixedTop !== false; var placeholderStatus = affixWrapRef.value.contains(placeholderEL.value); if (affixed) { affixRef.value.className = COMPONENT_NAME.value; affixStyle.value = { top: "".concat(fixedTop, "px"), width: "".concat(wrapWidth, "px"), height: "".concat(wrapHeight, "px"), zIndex: props2.zIndex }; if (!placeholderStatus) { placeholderEL.value.style.width = "".concat(wrapWidth, "px"); placeholderEL.value.style.height = "".concat(wrapHeight, "px"); affixWrapRef.value.appendChild(placeholderEL.value); } } else { affixRef.value.removeAttribute("class"); affixStyle.value = void 0; placeholderStatus && placeholderEL.value.remove(); } context.emit("fixedChange", affixed, { top: Number(fixedTop) }); if (isFunction.isFunction(props2.onFixedChange)) props2.onFixedChange(affixed, { top: Number(fixedTop) }); } ticking.value = false; }); ticking.value = true; } }; var bindScroll = /*#__PURE__*/function () { var _ref2 = _asyncToGenerator__default["default"](/*#__PURE__*/_regeneratorRuntime__default["default"].mark(function _callee() { return _regeneratorRuntime__default["default"].wrap(function (_context) { while (1) switch (_context.prev = _context.next) { case 0: _context.next = 1; return Vue.nextTick(); case 1: if (!isBind.value) { _context.next = 2; break; } return _context.abrupt("return"); case 2: scrollContainer.value = dom.getScrollContainer(props2.container); dom.on(scrollContainer.value, "scroll", handleScroll); dom.on(window, "resize", handleScroll); isBind.value = true; case 3: case "end": return _context.stop(); } }, _callee); })); return function bindScroll() { return _ref2.apply(this, arguments); }; }(); var unbindScroll = function unbindScroll() { if (!scrollContainer.value || !isBind.value) return; dom.off(scrollContainer.value, "scroll", handleScroll); dom.off(window, "resize", handleScroll); if (rAFId) { window.cancelAnimationFrame(rAFId); } isBind.value = false; }; Vue.watch(function () { return props2.offsetTop; }, function () { handleScroll(); }); Vue.watch(function () { return props2.offsetBottom; }, function () { handleScroll(); }); Vue.watch(function () { return props2.zIndex; }, function () { handleScroll(); }); Vue.onMounted(bindScroll); Vue.onActivated(bindScroll); Vue.onDeactivated(unbindScroll); Vue.onBeforeUnmount(unbindScroll); context.expose({ scrollContainer: scrollContainer, affixWrapRef: affixWrapRef, handleScroll: handleScroll }); return function () { return Vue.createVNode("div", { "ref": affixWrapRef }, [Vue.createVNode("div", { "ref": affixRef, "style": affixStyle.value }, [renderContent("default", "content")])]); }; } }); exports["default"] = _Affix; //# sourceMappingURL=affix.js.map