Update use-pagination.ts

This commit is contained in:
syuilo 2025-04-28 20:20:48 +09:00
parent d3bc92daff
commit 1b77f0d2b2
1 changed files with 10 additions and 21 deletions

View File

@ -3,7 +3,7 @@
* SPDX-License-Identifier: AGPL-3.0-only * SPDX-License-Identifier: AGPL-3.0-only
*/ */
import { computed, isRef, nextTick, onActivated, onBeforeMount, onBeforeUnmount, onDeactivated, onUnmounted, ref, watch } from 'vue'; import { computed, isRef, ref, watch } from 'vue';
import * as Misskey from 'misskey-js'; import * as Misskey from 'misskey-js';
import type { ComputedRef, Ref, ShallowRef } from 'vue'; import type { ComputedRef, Ref, ShallowRef } from 'vue';
import { misskeyApi } from '@/utility/misskey-api.js'; import { misskeyApi } from '@/utility/misskey-api.js';
@ -162,35 +162,23 @@ export function usePagination<T>(props: {
}); });
}; };
/** function trim() {
* itemsの先頭に追加しMAX_ITEMSを適用する if (items.value.size >= MAX_ITEMS) canFetchMore.value = true;
* @param newItems items.value = new Map([...items.value].slice(0, MAX_ITEMS));
*/
function unshiftItems(newItems: MisskeyEntity[]) {
const length = newItems.length + items.value.size;
items.value = new Map([...arrayToEntries(newItems), ...items.value].slice(0, MAX_ITEMS));
if (length >= MAX_ITEMS) canFetchMore.value = true;
} }
/** function unshiftItems(newItems: MisskeyEntity[]) {
* itemsの末尾に追加しMAX_ITEMSを適用する items.value = new Map([...arrayToEntries(newItems), ...items.value]);
* @param oldItems }
*/
function concatItems(oldItems: MisskeyEntity[]) {
const length = oldItems.length + items.value.size;
items.value = new Map([...items.value, ...arrayToEntries(oldItems)].slice(0, MAX_ITEMS));
if (length >= MAX_ITEMS) canFetchMore.value = true; function concatItems(oldItems: MisskeyEntity[]) {
items.value = new Map([...items.value, ...arrayToEntries(oldItems)]);
} }
function prepend(item: MisskeyEntity) { function prepend(item: MisskeyEntity) {
unshiftItems([item]); unshiftItems([item]);
} }
/*
* 使
*/
const appendItem = (item: MisskeyEntity): void => { const appendItem = (item: MisskeyEntity): void => {
items.value.set(item.id, item); items.value.set(item.id, item);
}; };
@ -215,6 +203,7 @@ export function usePagination<T>(props: {
fetchMoreAhead, fetchMoreAhead,
unshiftItems, unshiftItems,
prepend, prepend,
trim,
error, error,
}; };
} }