Add more tooltips to the Spotify activity card

This commit is contained in:
Braydon 2024-09-04 15:50:20 -04:00
parent db2891cfcd
commit 1914751649

View File

@ -88,7 +88,7 @@ const DiscordStatus = (): ReactElement | undefined => {
<div className="px-3 pt-1.5 py-2.5 flex flex-col"> <div className="px-3 pt-1.5 py-2.5 flex flex-col">
<div className="ml-[5.65rem] flex items-start"> <div className="ml-[5.65rem] flex items-start">
{dcdnUser.bio && <Bio dcdnUser={dcdnUser} />} {dcdnUser.bio && <Bio bio={dcdnUser.bio} />}
<Badges dcdnUser={dcdnUser} /> <Badges dcdnUser={dcdnUser} />
</div> </div>
<div className="mt-3"> <div className="mt-3">
@ -153,10 +153,12 @@ const BannerAvatar = ({
</div> </div>
); );
const Bio = ({ dcdnUser }: { dcdnUser: DCDNUser }): ReactElement => ( const Bio = ({ bio }: { bio: string }): ReactElement => (
<div className="p-2 bg-zinc-950/65 text-sm rounded-xl"> <SimpleTooltip content={bio}>
{truncateText(dcdnUser.bio, 15)} <div className="p-2 bg-zinc-950/65 text-sm rounded-xl">
</div> {truncateText(bio, 15)}
</div>
</SimpleTooltip>
); );
const Badges = ({ dcdnUser }: { dcdnUser: DCDNUser }): ReactElement => ( const Badges = ({ dcdnUser }: { dcdnUser: DCDNUser }): ReactElement => (
@ -192,19 +194,20 @@ const Username = ({
const SpotifyActivity = ({ spotify }: { spotify: Spotify }): ReactElement => { const SpotifyActivity = ({ spotify }: { spotify: Spotify }): ReactElement => {
const trackUrl: string = `https://open.spotify.com/track/${spotify.track_id}`; const trackUrl: string = `https://open.spotify.com/track/${spotify.track_id}`;
const trackArtist: string = spotify.artist.replace(";", ",");
const startTimestamp: number = spotify.timestamps.start; const startTimestamp: number = spotify.timestamps.start;
const endTimestamp: number = spotify.timestamps.end; const endTimestamp: number = spotify.timestamps.end;
const [songProgress, setSongProgress] = useState<string | undefined>(); const [trackProgress, setTrackProgress] = useState<string | undefined>();
const songDuration: number = endTimestamp - startTimestamp; const trackDuration: number = endTimestamp - startTimestamp;
// Update the song progress every second // Update the track progress every second
useEffect(() => { useEffect(() => {
const interval = setInterval(() => { const interval = setInterval(() => {
const songProgress = Date.now() - startTimestamp; const trackProgress = Date.now() - startTimestamp;
if (songProgress > songDuration) { if (trackProgress > trackDuration) {
return; return;
} }
setSongProgress(moment(songProgress).format("m:ss")); setTrackProgress(moment(trackProgress).format("m:ss"));
}, 1000); }, 1000);
return () => clearInterval(interval); return () => clearInterval(interval);
}, [startTimestamp]); }, [startTimestamp]);
@ -226,15 +229,19 @@ const SpotifyActivity = ({ spotify }: { spotify: Spotify }): ReactElement => {
{/* Track Info */} {/* Track Info */}
<div className="flex flex-col text-sm"> <div className="flex flex-col text-sm">
<Link href={trackUrl} target="_blank"> <Link href={trackUrl} target="_blank">
<h1 className="font-bold leading-none"> <SimpleTooltip content={spotify.song}>
{truncateText(spotify.song, 22)} <h1 className="font-bold leading-none">
</h1> {truncateText(spotify.song, 22)}
<h2 className="font-light opacity-70"> </h1>
{truncateText(spotify.artist.replace(";", ","), 26)} </SimpleTooltip>
</h2> <SimpleTooltip content={trackArtist}>
<h2 className="font-light opacity-70">
{truncateText(trackArtist, 26)}
</h2>
</SimpleTooltip>
</Link> </Link>
<p className="text-xs font-light opacity-70"> <p className="text-xs font-light opacity-70">
{songProgress} / {moment(songDuration).format("m:ss")} {trackProgress} / {moment(trackDuration).format("m:ss")}
</p> </p>
</div> </div>
</div> </div>