UNPKG

tdesign-vue-next

Version:
217 lines (209 loc) 8.29 kB
/** * tdesign v1.19.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-8d990e66.js'); var affix_props = require('./props.js'); require('@babel/runtime/helpers/toConsumableArray'); require('@babel/runtime/helpers/typeof'); var index$1 = require('../_chunks/dep-1862d466.js'); var index = require('../_chunks/dep-0238ed9a.js'); require('@babel/runtime/helpers/slicedToArray'); require('../_chunks/dep-0989c3be.js'); require('@babel/runtime/helpers/defineProperty'); var isUndefined = require('../_chunks/dep-3d29e358.js'); var isFunction = require('../_chunks/dep-2dcf9237.js'); require('../_chunks/dep-35e23c2b.js'); require('../_chunks/dep-4a7162e7.js'); require('../_chunks/dep-631750cd.js'); require('../_chunks/dep-22dc294c.js'); require('../_chunks/dep-4cb26289.js'); require('../_chunks/dep-a6551cc4.js'); require('../_chunks/dep-bf76dead.js'); require('../_chunks/dep-7d9abefd.js'); require('../_chunks/dep-2fb8d44f.js'); require('../_chunks/dep-80a41429.js'); require('../_chunks/dep-91305690.js'); require('../_chunks/dep-0b92e695.js'); require('../_chunks/dep-b2024592.js'); require('../_chunks/dep-9f98bf9b.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-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('@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