测试
This commit is contained in:
16
frontend/node_modules/element-plus/es/components/infinite-scroll/index.d.ts
generated
vendored
Normal file
16
frontend/node_modules/element-plus/es/components/infinite-scroll/index.d.ts
generated
vendored
Normal file
@@ -0,0 +1,16 @@
|
||||
import InfiniteScroll from './src';
|
||||
import type { SFCWithInstall } from 'element-plus/es/utils';
|
||||
declare const _InfiniteScroll: SFCWithInstall<typeof InfiniteScroll>;
|
||||
export default _InfiniteScroll;
|
||||
export declare const ElInfiniteScroll: SFCWithInstall<import("vue").ObjectDirective<HTMLElement & {
|
||||
ElInfiniteScroll: {
|
||||
container: HTMLElement | Window;
|
||||
containerEl: HTMLElement;
|
||||
instance: import("vue").ComponentPublicInstance;
|
||||
delay: number;
|
||||
lastScrollTop: number;
|
||||
cb: () => void;
|
||||
onScroll: () => void;
|
||||
observer?: MutationObserver;
|
||||
};
|
||||
}, () => void>>;
|
||||
10
frontend/node_modules/element-plus/es/components/infinite-scroll/index.mjs
generated
vendored
Normal file
10
frontend/node_modules/element-plus/es/components/infinite-scroll/index.mjs
generated
vendored
Normal file
@@ -0,0 +1,10 @@
|
||||
import InfiniteScroll from './src/index.mjs';
|
||||
|
||||
const _InfiniteScroll = InfiniteScroll;
|
||||
_InfiniteScroll.install = (app) => {
|
||||
app.directive("InfiniteScroll", _InfiniteScroll);
|
||||
};
|
||||
const ElInfiniteScroll = _InfiniteScroll;
|
||||
|
||||
export { ElInfiniteScroll, _InfiniteScroll as default };
|
||||
//# sourceMappingURL=index.mjs.map
|
||||
1
frontend/node_modules/element-plus/es/components/infinite-scroll/index.mjs.map
generated
vendored
Normal file
1
frontend/node_modules/element-plus/es/components/infinite-scroll/index.mjs.map
generated
vendored
Normal file
@@ -0,0 +1 @@
|
||||
{"version":3,"file":"index.mjs","sources":["../../../../../packages/components/infinite-scroll/index.ts"],"sourcesContent":["// TODO: remove the directive in 3.0\nimport InfiniteScroll from './src'\n\nimport type { App } from 'vue'\nimport type { SFCWithInstall } from '@element-plus/utils'\n\nconst _InfiniteScroll = InfiniteScroll as SFCWithInstall<typeof InfiniteScroll>\n\n_InfiniteScroll.install = (app: App) => {\n app.directive('InfiniteScroll', _InfiniteScroll)\n}\n\nexport default _InfiniteScroll\nexport const ElInfiniteScroll = _InfiniteScroll\n"],"names":[],"mappings":";;AACK,MAAC,eAAe,GAAG,eAAe;AACvC,eAAe,CAAC,OAAO,GAAG,CAAC,GAAG,KAAK;AACnC,EAAE,GAAG,CAAC,SAAS,CAAC,gBAAgB,EAAE,eAAe,CAAC,CAAC;AACnD,CAAC,CAAC;AAEU,MAAC,gBAAgB,GAAG;;;;"}
|
||||
20
frontend/node_modules/element-plus/es/components/infinite-scroll/src/index.d.ts
generated
vendored
Normal file
20
frontend/node_modules/element-plus/es/components/infinite-scroll/src/index.d.ts
generated
vendored
Normal file
@@ -0,0 +1,20 @@
|
||||
import type { ComponentPublicInstance, ObjectDirective } from 'vue';
|
||||
export declare const SCOPE = "ElInfiniteScroll";
|
||||
export declare const CHECK_INTERVAL = 50;
|
||||
export declare const DEFAULT_DELAY = 200;
|
||||
export declare const DEFAULT_DISTANCE = 0;
|
||||
type InfiniteScrollCallback = () => void;
|
||||
type InfiniteScrollEl = HTMLElement & {
|
||||
[SCOPE]: {
|
||||
container: HTMLElement | Window;
|
||||
containerEl: HTMLElement;
|
||||
instance: ComponentPublicInstance;
|
||||
delay: number;
|
||||
lastScrollTop: number;
|
||||
cb: InfiniteScrollCallback;
|
||||
onScroll: () => void;
|
||||
observer?: MutationObserver;
|
||||
};
|
||||
};
|
||||
declare const InfiniteScroll: ObjectDirective<InfiniteScrollEl, InfiniteScrollCallback>;
|
||||
export default InfiniteScroll;
|
||||
138
frontend/node_modules/element-plus/es/components/infinite-scroll/src/index.mjs
generated
vendored
Normal file
138
frontend/node_modules/element-plus/es/components/infinite-scroll/src/index.mjs
generated
vendored
Normal file
@@ -0,0 +1,138 @@
|
||||
import { nextTick } from 'vue';
|
||||
import { throttle } from 'lodash-unified';
|
||||
import { useDeprecated } from '../../../hooks/use-deprecated/index.mjs';
|
||||
import { isFunction } from '@vue/shared';
|
||||
import { throwError } from '../../../utils/error.mjs';
|
||||
import { getScrollContainer } from '../../../utils/dom/scroll.mjs';
|
||||
import { getOffsetTopDistance } from '../../../utils/dom/position.mjs';
|
||||
|
||||
const SCOPE = "ElInfiniteScroll";
|
||||
const CHECK_INTERVAL = 50;
|
||||
const DEFAULT_DELAY = 200;
|
||||
const DEFAULT_DISTANCE = 0;
|
||||
const attributes = {
|
||||
delay: {
|
||||
type: Number,
|
||||
default: DEFAULT_DELAY
|
||||
},
|
||||
distance: {
|
||||
type: Number,
|
||||
default: DEFAULT_DISTANCE
|
||||
},
|
||||
disabled: {
|
||||
type: Boolean,
|
||||
default: false
|
||||
},
|
||||
immediate: {
|
||||
type: Boolean,
|
||||
default: true
|
||||
}
|
||||
};
|
||||
const getScrollOptions = (el, instance) => {
|
||||
return Object.entries(attributes).reduce((acm, [name, option]) => {
|
||||
var _a, _b;
|
||||
const { type, default: defaultValue } = option;
|
||||
const attrVal = el.getAttribute(`infinite-scroll-${name}`);
|
||||
let value = (_b = (_a = instance[attrVal]) != null ? _a : attrVal) != null ? _b : defaultValue;
|
||||
value = value === "false" ? false : value;
|
||||
value = type(value);
|
||||
acm[name] = Number.isNaN(value) ? defaultValue : value;
|
||||
return acm;
|
||||
}, {});
|
||||
};
|
||||
const destroyObserver = (el) => {
|
||||
const { observer } = el[SCOPE];
|
||||
if (observer) {
|
||||
observer.disconnect();
|
||||
delete el[SCOPE].observer;
|
||||
}
|
||||
};
|
||||
const handleScroll = (el, cb) => {
|
||||
const { container, containerEl, instance, observer, lastScrollTop } = el[SCOPE];
|
||||
const { disabled, distance } = getScrollOptions(el, instance);
|
||||
const { clientHeight, scrollHeight, scrollTop } = containerEl;
|
||||
const delta = scrollTop - lastScrollTop;
|
||||
el[SCOPE].lastScrollTop = scrollTop;
|
||||
if (observer || disabled || delta < 0)
|
||||
return;
|
||||
let shouldTrigger = false;
|
||||
if (container === el) {
|
||||
shouldTrigger = scrollHeight - (clientHeight + scrollTop) <= distance;
|
||||
} else {
|
||||
const { clientTop, scrollHeight: height } = el;
|
||||
const offsetTop = getOffsetTopDistance(el, containerEl);
|
||||
shouldTrigger = scrollTop + clientHeight >= offsetTop + clientTop + height - distance;
|
||||
}
|
||||
if (shouldTrigger) {
|
||||
cb.call(instance);
|
||||
}
|
||||
};
|
||||
function checkFull(el, cb) {
|
||||
const { containerEl, instance } = el[SCOPE];
|
||||
const { disabled } = getScrollOptions(el, instance);
|
||||
if (disabled || containerEl.clientHeight === 0)
|
||||
return;
|
||||
if (containerEl.scrollHeight <= containerEl.clientHeight) {
|
||||
cb.call(instance);
|
||||
} else {
|
||||
destroyObserver(el);
|
||||
}
|
||||
}
|
||||
const InfiniteScroll = {
|
||||
async mounted(el, binding) {
|
||||
const { instance, value: cb } = binding;
|
||||
useDeprecated({
|
||||
scope: SCOPE,
|
||||
from: "the directive v-infinite-scroll",
|
||||
replacement: "the el-scrollbar infinite scroll",
|
||||
version: "3.0.0",
|
||||
ref: "https://element-plus.org/en-US/component/scrollbar#infinite-scroll"
|
||||
}, true);
|
||||
if (!isFunction(cb)) {
|
||||
throwError(SCOPE, "'v-infinite-scroll' binding value must be a function");
|
||||
}
|
||||
await nextTick();
|
||||
const { delay, immediate } = getScrollOptions(el, instance);
|
||||
const container = getScrollContainer(el, true);
|
||||
const containerEl = container === window ? document.documentElement : container;
|
||||
const onScroll = throttle(handleScroll.bind(null, el, cb), delay);
|
||||
if (!container)
|
||||
return;
|
||||
el[SCOPE] = {
|
||||
instance,
|
||||
container,
|
||||
containerEl,
|
||||
delay,
|
||||
cb,
|
||||
onScroll,
|
||||
lastScrollTop: containerEl.scrollTop
|
||||
};
|
||||
if (immediate) {
|
||||
const observer = new MutationObserver(throttle(checkFull.bind(null, el, cb), CHECK_INTERVAL));
|
||||
el[SCOPE].observer = observer;
|
||||
observer.observe(el, { childList: true, subtree: true });
|
||||
checkFull(el, cb);
|
||||
}
|
||||
container.addEventListener("scroll", onScroll);
|
||||
},
|
||||
unmounted(el) {
|
||||
if (!el[SCOPE])
|
||||
return;
|
||||
const { container, onScroll } = el[SCOPE];
|
||||
container == null ? void 0 : container.removeEventListener("scroll", onScroll);
|
||||
destroyObserver(el);
|
||||
},
|
||||
async updated(el) {
|
||||
if (!el[SCOPE]) {
|
||||
await nextTick();
|
||||
} else {
|
||||
const { containerEl, cb, observer } = el[SCOPE];
|
||||
if (containerEl.clientHeight && observer) {
|
||||
checkFull(el, cb);
|
||||
}
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
export { CHECK_INTERVAL, DEFAULT_DELAY, DEFAULT_DISTANCE, SCOPE, InfiniteScroll as default };
|
||||
//# sourceMappingURL=index.mjs.map
|
||||
1
frontend/node_modules/element-plus/es/components/infinite-scroll/src/index.mjs.map
generated
vendored
Normal file
1
frontend/node_modules/element-plus/es/components/infinite-scroll/src/index.mjs.map
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
2
frontend/node_modules/element-plus/es/components/infinite-scroll/style/css.d.ts
generated
vendored
Normal file
2
frontend/node_modules/element-plus/es/components/infinite-scroll/style/css.d.ts
generated
vendored
Normal file
@@ -0,0 +1,2 @@
|
||||
import 'element-plus/es/components/base/style/css';
|
||||
import 'element-plus/theme-chalk/el-infinite-scroll.css';
|
||||
3
frontend/node_modules/element-plus/es/components/infinite-scroll/style/css.mjs
generated
vendored
Normal file
3
frontend/node_modules/element-plus/es/components/infinite-scroll/style/css.mjs
generated
vendored
Normal file
@@ -0,0 +1,3 @@
|
||||
import '../../base/style/css.mjs';
|
||||
import 'element-plus/theme-chalk/el-infinite-scroll.css';
|
||||
//# sourceMappingURL=css.mjs.map
|
||||
1
frontend/node_modules/element-plus/es/components/infinite-scroll/style/css.mjs.map
generated
vendored
Normal file
1
frontend/node_modules/element-plus/es/components/infinite-scroll/style/css.mjs.map
generated
vendored
Normal file
@@ -0,0 +1 @@
|
||||
{"version":3,"file":"css.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
|
||||
2
frontend/node_modules/element-plus/es/components/infinite-scroll/style/index.d.ts
generated
vendored
Normal file
2
frontend/node_modules/element-plus/es/components/infinite-scroll/style/index.d.ts
generated
vendored
Normal file
@@ -0,0 +1,2 @@
|
||||
import 'element-plus/es/components/base/style';
|
||||
import 'element-plus/theme-chalk/src/infinite-scroll.scss';
|
||||
3
frontend/node_modules/element-plus/es/components/infinite-scroll/style/index.mjs
generated
vendored
Normal file
3
frontend/node_modules/element-plus/es/components/infinite-scroll/style/index.mjs
generated
vendored
Normal file
@@ -0,0 +1,3 @@
|
||||
import '../../base/style/index.mjs';
|
||||
import 'element-plus/theme-chalk/src/infinite-scroll.scss';
|
||||
//# sourceMappingURL=index.mjs.map
|
||||
1
frontend/node_modules/element-plus/es/components/infinite-scroll/style/index.mjs.map
generated
vendored
Normal file
1
frontend/node_modules/element-plus/es/components/infinite-scroll/style/index.mjs.map
generated
vendored
Normal file
@@ -0,0 +1 @@
|
||||
{"version":3,"file":"index.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
|
||||
Reference in New Issue
Block a user