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';
|
2023-03-18 15:20:48 +03:00
|
|
|
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-18 15:20:48 +03:00
|
|
|
|
2023-03-21 19:09:36 +03:00
|
|
|
value = filteredItems(value, 'home');
|
2023-03-18 15:20:48 +03:00
|
|
|
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}
|
2023-03-18 15:20:48 +03:00
|
|
|
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;
|