phanpy/src/pages/list.jsx

93 lines
2.2 KiB
React
Raw Normal View History

2023-02-10 19:05:18 +03:00
import { useEffect, useRef, useState } from 'preact/hooks';
import { useParams } from 'react-router-dom';
import Icon from '../components/icon';
import Link from '../components/link';
import Timeline from '../components/timeline';
import { api } from '../utils/api';
2023-03-21 19:09:36 +03:00
import { filteredItems } from '../utils/filters';
import { saveStatus } from '../utils/states';
2023-02-10 19:05:18 +03:00
import useTitle from '../utils/useTitle';
const LIMIT = 20;
2023-02-18 15:48:24 +03:00
function List(props) {
2023-02-18 19:05:46 +03:00
const { masto, instance } = api();
2023-02-18 15:48:24 +03:00
const id = props?.id || useParams()?.id;
2023-02-11 11:28:03 +03:00
const latestItem = useRef();
2023-02-10 19:05:18 +03:00
const listIterator = useRef();
async function fetchList(firstLoad) {
if (firstLoad || !listIterator.current) {
listIterator.current = masto.v1.timelines.listList(id, {
limit: LIMIT,
});
}
2023-02-11 11:28:03 +03:00
const results = await listIterator.current.next();
2023-03-21 19:09:36 +03:00
let { value } = results;
2023-02-11 11:28:03 +03:00
if (value?.length) {
if (firstLoad) {
latestItem.current = value[0].id;
}
2023-03-21 19:09:36 +03:00
value = filteredItems(value, 'home');
value.forEach((item) => {
saveStatus(item, instance);
});
2023-02-11 11:28:03 +03:00
}
return results;
}
async function checkForUpdates() {
try {
const results = await masto.v1.timelines.listList(id, {
limit: 1,
since_id: latestItem.current,
});
2023-03-21 19:09:36 +03:00
let { value } = results;
value = filteredItems(value, 'home');
2023-02-11 11:28:03 +03:00
if (value?.length) {
return true;
}
return false;
} catch (e) {
return false;
}
2023-02-10 19:05:18 +03:00
}
const [title, setTitle] = useState(`List`);
useTitle(title, `/l/:id`);
useEffect(() => {
(async () => {
try {
const list = await masto.v1.lists.fetch(id);
setTitle(list.title);
} catch (e) {
console.error(e);
}
})();
}, [id]);
return (
<Timeline
title={title}
id="list"
emptyText="Nothing yet."
errorText="Unable to load posts."
2023-02-18 19:05:46 +03:00
instance={instance}
2023-02-10 19:05:18 +03:00
fetchItems={fetchList}
2023-02-11 11:28:03 +03:00
checkForUpdates={checkForUpdates}
useItemID
2023-02-10 19:05:18 +03:00
boostsCarousel
2023-03-21 19:09:36 +03:00
allowFilters
2023-02-10 19:05:18 +03:00
headerStart={
<Link to="/l" class="button plain">
<Icon icon="list" size="l" />
</Link>
}
/>
);
}
export default List;