UNPKG

primevue

Version:

PrimeVue is an open source UI library for Vue featuring a rich set of 80+ components, a theme designer, various theme alternatives such as Material, Bootstrap, Tailwind, premium templates and professional support. In addition, it integrates with PrimeBloc

69 lines (64 loc) 1.99 kB
import BaseComponent from 'primevue/basecomponent'; import DeferredContentStyle from 'primevue/deferredcontent/style'; import { openBlock, createElementBlock, mergeProps, renderSlot, createCommentVNode } from 'vue'; var script = { name: 'DeferredContent', "extends": BaseComponent, inheritAttrs: false, emits: ['load'], style: DeferredContentStyle, data: function data() { return { loaded: false }; }, mounted: function mounted() { if (!this.loaded) { if (this.shouldLoad()) this.load();else this.bindScrollListener(); } }, beforeUnmount: function beforeUnmount() { this.unbindScrollListener(); }, methods: { bindScrollListener: function bindScrollListener() { var _this = this; this.documentScrollListener = function () { if (_this.shouldLoad()) { _this.load(); _this.unbindScrollListener(); } }; window.addEventListener('scroll', this.documentScrollListener); }, unbindScrollListener: function unbindScrollListener() { if (this.documentScrollListener) { window.removeEventListener('scroll', this.documentScrollListener); this.documentScrollListener = null; } }, shouldLoad: function shouldLoad() { if (this.loaded) { return false; } else { var rect = this.$refs.container.getBoundingClientRect(); var docElement = document.documentElement; var winHeight = docElement.clientHeight; return winHeight >= rect.top; } }, load: function load(event) { this.loaded = true; this.$emit('load', event); } } }; function render(_ctx, _cache, $props, $setup, $data, $options) { return openBlock(), createElementBlock("div", mergeProps({ ref: "container" }, _ctx.ptmi('root')), [$data.loaded ? renderSlot(_ctx.$slots, "default", { key: 0 }) : createCommentVNode("", true)], 16); } script.render = render; export { script as default };