From 9bc23e7f9c35f54f00506783a92d687adc5a52a4 Mon Sep 17 00:00:00 2001 From: Aditya Pawar Date: Mon, 15 Apr 2024 17:37:33 -0700 Subject: [PATCH] Add save story to preview card, one home screen viewing bug --- src/app/(tabs)/author/index.tsx | 1 + src/app/(tabs)/genre/index.tsx | 1 + src/app/(tabs)/home/index.tsx | 1 + src/app/(tabs)/search/index.tsx | 4 +- src/components/ContentCard/ContentCard.tsx | 22 ++++++++-- src/components/PreviewCard/PreviewCard.tsx | 26 +++++++++++- src/queries/reactions.tsx | 2 +- src/queries/savedStories.tsx | 48 ++++++++++++++++++---- 8 files changed, 91 insertions(+), 14 deletions(-) diff --git a/src/app/(tabs)/author/index.tsx b/src/app/(tabs)/author/index.tsx index 38b8b88e..7767637c 100644 --- a/src/app/(tabs)/author/index.tsx +++ b/src/app/(tabs)/author/index.tsx @@ -122,6 +122,7 @@ function AuthorScreen() { {authorStoryPreview?.map(story => ( ( ( ( ( void; }; +const saveStoryImage = require('../../../assets/save_story.png'); +const savedStoryImage = require('../../../assets/saved_story.png'); + function ContentCard({ title, author, @@ -31,9 +36,20 @@ function ContentCard({ pressFunction, }: ContentCardProps) { const { user } = useSession(); + const [storyIsSaved, setStoryIsSaved] = useState(false); + + useEffect(() => { + isStoryInReadingList(storyId, user?.id).then(storyInReadingList => setStoryIsSaved(storyInReadingList)) + }, [storyId]) + const saveStory = () => { - addUserStoryToReadingList(user?.id, storyId); + if (storyIsSaved) { + deleteUserStoryToReadingList(user?.id, storyId); + } else { + addUserStoryToReadingList(user?.id, storyId); + } + setStoryIsSaved(!storyIsSaved); }; return ( @@ -85,7 +101,7 @@ function ContentCard({ saveStory()}> diff --git a/src/components/PreviewCard/PreviewCard.tsx b/src/components/PreviewCard/PreviewCard.tsx index 45a31a73..db5b283f 100644 --- a/src/components/PreviewCard/PreviewCard.tsx +++ b/src/components/PreviewCard/PreviewCard.tsx @@ -11,13 +11,20 @@ import Emoji from 'react-native-emoji'; import styles from './styles'; import globalStyles from '../../styles/globalStyles'; +import { useEffect, useState } from 'react'; +import { addUserStoryToReadingList, deleteUserStoryToReadingList, isStoryInReadingList } from '../../queries/savedStories'; +import { useSession } from '../../utils/AuthContext'; +import { useIsFocused } from '@react-navigation/native'; const placeholderImage = 'https://gwn-uploads.s3.amazonaws.com/wp-content/uploads/2021/10/10120952/Girls-Write-Now-logo-avatar.png'; +const saveStoryImage = require('../../../assets/save_story.png'); +const savedStoryImage = require('../../../assets/saved_story.png'); type PreviewCardProps = { title: string; image: string; + storyId: number; author: string; authorImage: string; excerpt: { html: string }; @@ -28,14 +35,29 @@ type PreviewCardProps = { function PreviewCard({ title, image, + storyId, author, authorImage, excerpt, tags, pressFunction, }: PreviewCardProps) { + const { user } = useSession(); + const isFocused = useIsFocused(); + const [storyIsSaved, setStoryIsSaved] = useState(false); + + useEffect(() => { + isStoryInReadingList(storyId, user?.id).then(storyInReadingList => setStoryIsSaved(storyInReadingList)) + }, [storyId, isFocused]) + + const saveStory = () => { - console.log("testing '+' icon does something for story " + title); + if (storyIsSaved) { + deleteUserStoryToReadingList(user?.id, storyId); + } else { + addUserStoryToReadingList(user?.id, storyId); + } + setStoryIsSaved(!storyIsSaved); }; return ( @@ -48,7 +70,7 @@ function PreviewCard({ saveStory()}> diff --git a/src/queries/reactions.tsx b/src/queries/reactions.tsx index 8a9da888..ffe68c40 100644 --- a/src/queries/reactions.tsx +++ b/src/queries/reactions.tsx @@ -53,7 +53,7 @@ export async function fetchAllReactionsToStory( `An error occured when trying to fetch reactions to a story', ${error}`, ); } else { - return data; + return data as Reactions[]; } } diff --git a/src/queries/savedStories.tsx b/src/queries/savedStories.tsx index 59f6ecaa..8b884607 100644 --- a/src/queries/savedStories.tsx +++ b/src/queries/savedStories.tsx @@ -1,7 +1,10 @@ import supabase from '../utils/supabase'; -const favorites = 'favorites'; -const readingList = 'reading list'; +enum SavedList { + FAVORITES = 'favorites', + READING_LIST = 'reading list' +} + async function fetchUserStories( user_id: string | undefined, @@ -48,11 +51,11 @@ async function fetchUserStories( } export async function fetchUserStoriesFavorites(user_id: string | undefined) { - return await fetchUserStories(user_id, favorites); + return await fetchUserStories(user_id, SavedList.FAVORITES); } export async function fetchUserStoriesReadingList(user_id: string | undefined) { - return await fetchUserStories(user_id, readingList); + return await fetchUserStories(user_id, SavedList.READING_LIST); } async function addUserStory( @@ -78,17 +81,32 @@ export async function addUserStoryToFavorites( user_id: string | undefined, story_id: number, ) { - addUserStory(user_id, story_id, favorites); + addUserStory(user_id, story_id, SavedList.FAVORITES); } export async function addUserStoryToReadingList( user_id: string | undefined, story_id: number, ) { - addUserStory(user_id, story_id, readingList); + addUserStory(user_id, story_id, SavedList.READING_LIST); +} + +export async function deleteUserStoryToFavorites( + user_id: string | undefined, + story_id: number, +) { + deleteUserStory(user_id, story_id, SavedList.FAVORITES); } -export async function deleteUserStories( +export async function deleteUserStoryToReadingList( + user_id: string | undefined, + story_id: number, +) { + deleteUserStory(user_id, story_id, SavedList.READING_LIST); +} + + +export async function deleteUserStory( user_id: string | undefined, story_id: number, name: string, @@ -108,3 +126,19 @@ export async function deleteUserStories( } } } + +export async function isStoryInReadingList(storyId: number, userId: string | undefined): Promise { + let { data, error } = await supabase + .rpc('is_story_saved_for_user', { + list_name: "reading list", + story_db_id: storyId, + user_uuid: userId, + }) + + if (error) { + console.error(error) + return false; + } + + return data; +}