2024-07-14 20:28:44 +08:00
|
|
|
import { type mastodon } from "masto";
|
|
|
|
import { Accessor, createResource, createSignal } from "solid-js";
|
|
|
|
|
|
|
|
type TimelineFetchTips = {
|
|
|
|
direction?: "new" | "old";
|
|
|
|
};
|
|
|
|
|
|
|
|
type Timeline = {
|
|
|
|
list(params: {
|
|
|
|
maxId?: string;
|
|
|
|
minId?: string;
|
|
|
|
}): mastodon.Paginator<mastodon.v1.Status[], unknown>;
|
|
|
|
};
|
|
|
|
|
2024-08-05 15:33:00 +08:00
|
|
|
export function useTimeline(timeline: Accessor<Timeline>) {
|
2024-07-14 20:28:44 +08:00
|
|
|
let minId: string | undefined;
|
|
|
|
let maxId: string | undefined;
|
|
|
|
let otl: Timeline | undefined;
|
|
|
|
const idSet = new Set<string>();
|
|
|
|
return createResource<
|
|
|
|
mastodon.v1.Status[],
|
|
|
|
[Timeline],
|
|
|
|
TimelineFetchTips | undefined
|
|
|
|
>(
|
|
|
|
() => [timeline()] as const,
|
|
|
|
async ([tl], info) => {
|
|
|
|
if (otl !== tl) {
|
|
|
|
minId = undefined;
|
|
|
|
maxId = undefined;
|
|
|
|
idSet.clear();
|
|
|
|
info.value = [];
|
|
|
|
otl = tl;
|
|
|
|
}
|
|
|
|
const direction =
|
|
|
|
typeof info.refetching !== "boolean"
|
|
|
|
? info.refetching?.direction
|
|
|
|
: "old";
|
|
|
|
const pager = await tl.list(
|
|
|
|
direction === "old"
|
|
|
|
? {
|
|
|
|
maxId: minId,
|
|
|
|
}
|
|
|
|
: {
|
|
|
|
minId: maxId,
|
|
|
|
},
|
|
|
|
);
|
|
|
|
const old = info.value || [];
|
|
|
|
const diff = pager.filter((x) => !idSet.has(x.id));
|
|
|
|
for (const v of diff.map((x) => x.id)) {
|
|
|
|
idSet.add(v);
|
|
|
|
}
|
|
|
|
if (direction === "old") {
|
|
|
|
minId = pager[pager.length - 1]?.id;
|
|
|
|
if (!maxId && pager.length > 0) {
|
|
|
|
maxId = pager[0].id;
|
|
|
|
}
|
|
|
|
return [...old, ...diff];
|
|
|
|
} else {
|
|
|
|
maxId = pager.length > 0 ? pager[0].id : undefined;
|
|
|
|
if (!minId && pager.length > 0) {
|
|
|
|
minId = pager[pager.length - 1]?.id;
|
|
|
|
}
|
|
|
|
return [...diff, ...old];
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{
|
|
|
|
initialValue: [],
|
|
|
|
storage(init) {
|
|
|
|
return createSignal(init, { equals: false });
|
|
|
|
},
|
|
|
|
},
|
|
|
|
);
|
|
|
|
}
|