fp/services/next/app/components/timestamps-list.tsx

69 lines
2.5 KiB
TypeScript

import React, { useContext, useState, useEffect } from "react";
import { IVod } from "@/app/lib/vods";
import {
ITimestamp,
deleteTimestamp
} from "@/app/lib/timestamps";
import {
formatTimestamp,
formatUrlTimestamp,
} from "@/app/lib/dates";
import Link from 'next/link';
import { faClock, faLink, faTrash } from "@fortawesome/free-solid-svg-icons";
import { FontAwesomeIcon } from "@fortawesome/react-fontawesome";
import { isWithinInterval, subHours, Interval } from 'date-fns';
import { useRouter } from 'next/navigation';
export interface ITimestampsProps {
vod: IVod;
timestamps: ITimestamp[];
setTimestamps: Function;
}
function isCreatedByMeRecently(authData: any, ts: ITimestamp) {
if (!authData?.user) return false;
if (authData.user.id !== ts.creator_id) return false;
const last24H: Interval = { start: subHours(new Date(), 24), end: new Date() };
return isWithinInterval(new Date(ts.created_at), last24H);
}
export function TimestampsList({ vod, timestamps, setTimestamps }: ITimestampsProps): React.JSX.Element {
// const throttledTimestampFetch = throttle(getRawTimestampsForVod);
const hasTimestamps = timestamps.length > 0;
return (
<div className="timestamps mb-5">
{hasTimestamps && (
timestamps.map((ts: ITimestamp) => (
<p key={ts.id}>
{JSON.stringify(ts, null, 2)}<br/><br/><br/>
<Link
href={`?t=${formatUrlTimestamp(ts.time)}`}
>
{formatTimestamp(ts.time)}
</Link>{' '}
{/* <span className="mr-2">{ts.tag.name}</span> */}
{isCreatedByMeRecently({}, ts) && (
<button
onClick={() => {
deleteTimestamp({}, ts.id); // @todo restore auth
setTimestamps((prevTimestamps: ITimestamp[]) => prevTimestamps.filter((timestamp) => timestamp.id !== ts.id));
}}
className={`button icon`}
>
<FontAwesomeIcon icon={faTrash}></FontAwesomeIcon>
</button>
)}
</p>
))
)}
{!hasTimestamps && <div className="ml-5"><p><i>This VOD has no timestamps</i></p></div>}
</div>
);
}