tdesign-vue-next
Version:
TDesign Component for vue-next
217 lines (209 loc) • 8.29 kB
JavaScript
/**
* tdesign v1.19.2
* (c) 2026 tdesign
* @license MIT
*/
;
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