UNPKG

tdesign-vue-next

Version:
217 lines (209 loc) 8.29 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 dom = require('../_chunks/dep-aa61e27f.js'); var affix_props = require('./props.js'); require('@babel/runtime/helpers/toConsumableArray'); require('@babel/runtime/helpers/typeof'); var index$1 = require('../_chunks/dep-aa87a8f5.js'); var index = require('../_chunks/dep-b9c82189.js'); require('@babel/runtime/helpers/slicedToArray'); require('../_chunks/dep-ce392f73.js'); require('@babel/runtime/helpers/defineProperty'); var isUndefined = require('../_chunks/dep-ce75379a.js'); var isFunction = require('../_chunks/dep-cd6733fb.js'); require('../_chunks/dep-0e867224.js'); require('../_chunks/dep-b3ef977e.js'); require('../_chunks/dep-f549ecb7.js'); require('../_chunks/dep-caa8987f.js'); require('../_chunks/dep-8e3205d4.js'); require('../_chunks/dep-1da18355.js'); require('../_chunks/dep-5c730151.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'); 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