infinity-forge 11.8.8 → 11.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/ui/components/index.d.ts +1 -0
- package/dist/ui/components/index.js +1 -0
- package/dist/ui/components/index.js.map +1 -1
- package/dist/ui/components/infinity-list/index.d.ts +2 -0
- package/dist/ui/components/infinity-list/index.js +60 -0
- package/dist/ui/components/infinity-list/index.js.map +1 -0
- package/dist/ui/components/infinity-list/type.d.ts +15 -0
- package/dist/ui/components/infinity-list/type.js +3 -0
- package/dist/ui/components/infinity-list/type.js.map +1 -0
- package/package.json +1 -1
|
@@ -26,6 +26,7 @@ export * from './menu-mobile/index.js';
|
|
|
26
26
|
export * from './login-modal/index.js';
|
|
27
27
|
export * from './pop-confirm/index.js';
|
|
28
28
|
export * from './loader-circle/index.js';
|
|
29
|
+
export * from './infinity-list/index.js';
|
|
29
30
|
export * from './step-navigator/index.js';
|
|
30
31
|
export * from './error-boundary/index.js';
|
|
31
32
|
export * from './loading-screen/index.js';
|
|
@@ -42,6 +42,7 @@ __exportStar(require("./menu-mobile/index.js"), exports);
|
|
|
42
42
|
__exportStar(require("./login-modal/index.js"), exports);
|
|
43
43
|
__exportStar(require("./pop-confirm/index.js"), exports);
|
|
44
44
|
__exportStar(require("./loader-circle/index.js"), exports);
|
|
45
|
+
__exportStar(require("./infinity-list/index.js"), exports);
|
|
45
46
|
__exportStar(require("./step-navigator/index.js"), exports);
|
|
46
47
|
__exportStar(require("./error-boundary/index.js"), exports);
|
|
47
48
|
__exportStar(require("./loading-screen/index.js"), exports);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/ui/components/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,wCAAqB;AACrB,yCAAsB;AACtB,yCAAsB;AACtB,0CAAuB;AACvB,0CAAuB;AACvB,2CAAwB;AACxB,4CAAyB;AACzB,2CAAwB;AACxB,8CAA2B;AAC3B,4CAAyB;AACzB,6CAA0B;AAC1B,4CAAyB;AACzB,4CAAyB;AACzB,4CAAyB;AACzB,6CAA0B;AAC1B,6CAA0B;AAC1B,8CAA2B;AAC3B,8CAA2B;AAC3B,8CAA2B;AAC3B,8CAA2B;AAC3B,+CAA4B;AAC5B,+CAA4B;AAC5B,+CAA4B;AAC5B,+CAA4B;AAC5B,gDAA6B;AAC7B,gDAA6B;AAC7B,gDAA6B;AAC7B,kDAA+B;AAC/B,mDAAgC;AAChC,mDAAgC;AAChC,mDAAgC;AAChC,0DAAuC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/ui/components/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,wCAAqB;AACrB,yCAAsB;AACtB,yCAAsB;AACtB,0CAAuB;AACvB,0CAAuB;AACvB,2CAAwB;AACxB,4CAAyB;AACzB,2CAAwB;AACxB,8CAA2B;AAC3B,4CAAyB;AACzB,6CAA0B;AAC1B,4CAAyB;AACzB,4CAAyB;AACzB,4CAAyB;AACzB,6CAA0B;AAC1B,6CAA0B;AAC1B,8CAA2B;AAC3B,8CAA2B;AAC3B,8CAA2B;AAC3B,8CAA2B;AAC3B,+CAA4B;AAC5B,+CAA4B;AAC5B,+CAA4B;AAC5B,+CAA4B;AAC5B,gDAA6B;AAC7B,gDAA6B;AAC7B,gDAA6B;AAC7B,kDAA+B;AAC/B,kDAA+B;AAC/B,mDAAgC;AAChC,mDAAgC;AAChC,mDAAgC;AAChC,0DAAuC"}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __assign = (this && this.__assign) || function () {
|
|
3
|
+
__assign = Object.assign || function(t) {
|
|
4
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
5
|
+
s = arguments[i];
|
|
6
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
|
|
7
|
+
t[p] = s[p];
|
|
8
|
+
}
|
|
9
|
+
return t;
|
|
10
|
+
};
|
|
11
|
+
return __assign.apply(this, arguments);
|
|
12
|
+
};
|
|
13
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
14
|
+
exports.InfinityList = InfinityList;
|
|
15
|
+
var jsx_runtime_1 = require("react/jsx-runtime");
|
|
16
|
+
var react_1 = require("react");
|
|
17
|
+
var react_query_1 = require("@tanstack/react-query");
|
|
18
|
+
var ui_1 = require("../../../ui/index.js");
|
|
19
|
+
function InfinityList(props) {
|
|
20
|
+
var queryKey = props.queryKey, queryFn = props.queryFn, initialPageParam = props.initialPageParam, Item = props.Item, NotFound = props.NotFound;
|
|
21
|
+
var observerRef = (0, react_1.useRef)(null);
|
|
22
|
+
var observerInstance = (0, react_1.useRef)(null);
|
|
23
|
+
var _a = (0, react_query_1.useInfiniteQuery)({
|
|
24
|
+
queryFn: queryFn,
|
|
25
|
+
queryKey: queryKey,
|
|
26
|
+
initialPageParam: initialPageParam,
|
|
27
|
+
getNextPageParam: function (lastPage, pages) { var _a; return (((_a = lastPage === null || lastPage === void 0 ? void 0 : lastPage.pagination) === null || _a === void 0 ? void 0 : _a.hasNextPage) ? pages.length + 1 : undefined); },
|
|
28
|
+
}), data = _a.data, isFetching = _a.isFetching, fetchNextPage = _a.fetchNextPage, isFetchingNextPage = _a.isFetchingNextPage, hasNextPage = _a.hasNextPage;
|
|
29
|
+
var dataAccumuled = data === null || data === void 0 ? void 0 : data.pages.flatMap(function (page) { return page === null || page === void 0 ? void 0 : page.items; });
|
|
30
|
+
var handleObserver = (0, react_1.useCallback)(function (entries) {
|
|
31
|
+
var entry = entries[0];
|
|
32
|
+
if (entry.isIntersecting && !isFetchingNextPage && hasNextPage) {
|
|
33
|
+
fetchNextPage();
|
|
34
|
+
}
|
|
35
|
+
}, [fetchNextPage, isFetchingNextPage, hasNextPage]);
|
|
36
|
+
(0, react_1.useEffect)(function () {
|
|
37
|
+
var el = observerRef.current;
|
|
38
|
+
if (!el)
|
|
39
|
+
return;
|
|
40
|
+
if (observerInstance.current) {
|
|
41
|
+
observerInstance.current.disconnect();
|
|
42
|
+
}
|
|
43
|
+
observerInstance.current = new IntersectionObserver(handleObserver, {
|
|
44
|
+
root: null,
|
|
45
|
+
threshold: 1.0,
|
|
46
|
+
rootMargin: '100px',
|
|
47
|
+
});
|
|
48
|
+
observerInstance.current.observe(el);
|
|
49
|
+
return function () {
|
|
50
|
+
if (observerInstance.current) {
|
|
51
|
+
observerInstance.current.disconnect();
|
|
52
|
+
}
|
|
53
|
+
};
|
|
54
|
+
}, [handleObserver]);
|
|
55
|
+
if (isFetching && !dataAccumuled) {
|
|
56
|
+
return (0, jsx_runtime_1.jsx)(ui_1.LoaderCircle, { size: 30, color: '#000' });
|
|
57
|
+
}
|
|
58
|
+
return ((0, jsx_runtime_1.jsx)(ui_1.Error, { name: 'InfinityList', children: (0, jsx_runtime_1.jsxs)("div", { className: 'infinity_list_infinity_forge', children: [((!isFetching && !dataAccumuled) || (dataAccumuled === null || dataAccumuled === void 0 ? void 0 : dataAccumuled.length) === 0) && NotFound && (0, jsx_runtime_1.jsx)(NotFound, {}), Array.isArray(dataAccumuled) && (dataAccumuled === null || dataAccumuled === void 0 ? void 0 : dataAccumuled.length) > 0 && !isFetching && Item && ((0, jsx_runtime_1.jsx)("div", { className: 'list_infinity-forge', style: { marginBottom: isFetchingNextPage ? '20px' : '0' }, children: Item && (dataAccumuled === null || dataAccumuled === void 0 ? void 0 : dataAccumuled.map(function (item, index) { return (0, jsx_runtime_1.jsx)(Item, __assign({}, item), (item === null || item === void 0 ? void 0 : item.id) || index); })) })), (0, jsx_runtime_1.jsx)("div", { ref: observerRef }), isFetchingNextPage && (0, jsx_runtime_1.jsx)(ui_1.LoaderCircle, { size: 30, color: '#000' })] }) }));
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/ui/components/infinity-list/index.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { JSX } from 'react';
|
|
2
|
+
import { QueryFunction } from '@tanstack/react-query';
|
|
3
|
+
export type InfinityListProps<T, R extends PaginatedResponse<T>> = {
|
|
4
|
+
queryKey: any[];
|
|
5
|
+
initialPageParam?: number;
|
|
6
|
+
NotFound?: () => JSX.Element;
|
|
7
|
+
Item: (item: T) => JSX.Element;
|
|
8
|
+
queryFn: QueryFunction<R, any>;
|
|
9
|
+
};
|
|
10
|
+
export type PaginatedResponse<T> = {
|
|
11
|
+
items: T[];
|
|
12
|
+
pagination: {
|
|
13
|
+
hasNextPage: boolean;
|
|
14
|
+
};
|
|
15
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"type.js","sourceRoot":"","sources":["../../../../src/ui/components/infinity-list/type.ts"],"names":[],"mappings":""}
|