feat: local releay search

This commit is contained in:
2024-01-19 19:55:48 +00:00
parent 9654f70c22
commit 53c8ccbd0f
6 changed files with 137 additions and 69 deletions

View File

@ -0,0 +1,46 @@
import { EventKind, RequestBuilder, TaggedNostrEvent } from "@snort/system";
import { useRequestBuilder } from "@snort/system-react";
import { useEffect, useMemo, useState } from "react";
import { Relay } from "@/Cache";
import { SearchRelays } from "@/Utils/Const";
import PageSpinner from "../PageSpinner";
import { TimelineFragment } from "./TimelineFragment";
export function LocalSearch({ term, kind }: { term: string; kind: EventKind }) {
const [frag, setFrag] = useState<TimelineFragment>();
const r = useMemo(() => {
const rb = new RequestBuilder("search");
rb.withFilter().search(term).kinds([kind]).relay(SearchRelays).limit(100);
return rb;
}, [term]);
useRequestBuilder(r);
useEffect(() => {
setFrag(undefined);
if (term) {
Relay.req({
id: "local-search",
filters: [
{
kinds: [kind],
limit: 100,
search: term,
},
],
}).then(res => {
setFrag({
refTime: 0,
events: res.result as Array<TaggedNostrEvent>,
});
});
}
}, [term, kind]);
if (frag) {
return <TimelineFragment frag={frag} />;
}
return <PageSpinner />;
}