plebdevs/src/hooks/useContentSearch.js

66 lines
1.9 KiB
JavaScript
Raw Normal View History

import { useState, useEffect } from 'react';
import { useContentIdsQuery } from '@/hooks/apiQueries/useContentIdsQuery';
import { useNDKContext } from '@/context/NDKContext';
import { parseEvent, parseCourseEvent } from '@/utils/nostr';
2025-04-02 17:47:30 -05:00
import appConfig from '@/config/appConfig';
export const useContentSearch = () => {
2025-04-02 17:47:30 -05:00
const [allContent, setAllContent] = useState([]);
const [searchResults, setSearchResults] = useState([]);
const { contentIds } = useContentIdsQuery();
const { ndk } = useNDKContext();
2025-04-02 17:47:30 -05:00
const fetchAllEvents = async ids => {
try {
await ndk.connect();
const filter = {
authors: appConfig.authorPubkeys,
kinds: [30004, 30023, 30402],
'#d': ids,
};
const events = await ndk.fetchEvents(filter);
2025-04-02 17:47:30 -05:00
const parsedEvents = new Set();
events.forEach(event => {
let parsed;
if (event.kind === 30004) {
parsed = parseCourseEvent(event);
} else {
parsed = parseEvent(event);
}
2025-04-02 17:47:30 -05:00
parsedEvents.add(parsed);
});
setAllContent(parsedEvents);
} catch (error) {
console.error('error', error);
}
2025-04-02 17:47:30 -05:00
};
2025-04-02 17:47:30 -05:00
useEffect(() => {
if (contentIds) {
fetchAllEvents(contentIds);
}
}, [contentIds]);
2025-04-02 17:47:30 -05:00
const searchContent = term => {
if (term.length > 2) {
const filtered = Array.from(allContent).filter(content => {
const searchableTitle = (content?.title || content?.name || '').toLowerCase();
const searchableDescription = (
content?.summary ||
content?.description ||
''
).toLowerCase();
const searchTerm = term.toLowerCase();
2025-04-02 17:47:30 -05:00
return searchableTitle.includes(searchTerm) || searchableDescription.includes(searchTerm);
});
setSearchResults(filtered);
} else {
setSearchResults([]);
}
};
2025-04-02 17:47:30 -05:00
return { searchContent, searchResults };
};