diff --git a/frontend/lib/package.json b/frontend/lib/package.json index 10761b93..c08e89d8 100644 --- a/frontend/lib/package.json +++ b/frontend/lib/package.json @@ -1,6 +1,6 @@ { "name": "@generatesac/lib", - "version": "0.0.169", + "version": "0.0.170", "type": "module", "main": "dist/index.js", "types": "dist/index.d.ts", diff --git a/frontend/lib/src/types/category.ts b/frontend/lib/src/types/category.ts index 6577d569..939d0ae2 100644 --- a/frontend/lib/src/types/category.ts +++ b/frontend/lib/src/types/category.ts @@ -1,7 +1,6 @@ import { z } from "zod"; import { rootModelSchema } from "./root"; -import { tagSchema } from "./tag"; // Schemas: export const createCategoryRequestBodySchema = z.object({ @@ -10,7 +9,6 @@ export const createCategoryRequestBodySchema = z.object({ export const categorySchemaIntermediate = z.object({ name: z.string(), - tags: z.array(tagSchema), }); export const categorySchema = categorySchemaIntermediate.merge(rootModelSchema); diff --git a/frontend/mobile/package.json b/frontend/mobile/package.json index cecda616..743b29a9 100644 --- a/frontend/mobile/package.json +++ b/frontend/mobile/package.json @@ -25,7 +25,7 @@ "@fortawesome/free-solid-svg-icons": "^6.5.2", "@fortawesome/react-fontawesome": "^0.2.2", "@fortawesome/react-native-fontawesome": "^0.3.2", - "@generatesac/lib": "0.0.169", + "@generatesac/lib": "0.0.170", "@gorhom/bottom-sheet": "^4.6.3", "@hookform/resolvers": "^3.4.2", "@react-native-async-storage/async-storage": "^1.23.1", diff --git a/frontend/mobile/src/app/(app)/(tabs)/profile.tsx b/frontend/mobile/src/app/(app)/(tabs)/profile.tsx index 1f80b3c4..08f508eb 100644 --- a/frontend/mobile/src/app/(app)/(tabs)/profile.tsx +++ b/frontend/mobile/src/app/(app)/(tabs)/profile.tsx @@ -28,7 +28,7 @@ const ProfileItem = ({ icon, text, textColor, onPress }: ProfileItemProps) => ( @@ -98,9 +98,8 @@ const styles = StyleSheet.create({ flexDirection: 'column', alignItems: 'flex-start', justifyContent: 'flex-start', - marginHorizontal: Spacing.xl, - gap: Spacing.xxl, - marginTop: Spacing.xxl + marginVertical: Spacing.m, + gap: Spacing.l, }, title: { fontSize: 20, diff --git a/frontend/mobile/src/app/(app)/event/[id].tsx b/frontend/mobile/src/app/(app)/event/[id].tsx index be85507b..64cc02bf 100644 --- a/frontend/mobile/src/app/(app)/event/[id].tsx +++ b/frontend/mobile/src/app/(app)/event/[id].tsx @@ -181,10 +181,8 @@ const EventPage = () => { eventName={event.name} color={MockEvent.color} club={club?.name} - startTime={ - new Date(event.start_time) - } - endTime={new Date(event.end_time)} + startTime={event.start_time} + endTime={event.end_time} location={ event.location || 'ISEC, Room 204' @@ -224,8 +222,8 @@ const EventPage = () => { { const { handleSubmit } = useForm(); const [_, setButtonClicked] = useState(false); - const { - data: categoryData, - isLoading: loadingCategories, - error: errorCategory - } = useCategories(); - const { - data: tagsData, - isLoading: loadingTags, - error: errorTag - } = useTags(); + const { data: tagData, error: tagError, isLoading: tagLoading} = tagApi.useTagsQuery({}); + const { data: categoryData, error: categoryError, isLoading: categoryLoading} = categoryApi.useCategoriesQuery({}); const [selectedCategory, setSelectedCategory] = useState(); const [selectedTags, setSelectedTags] = useState(mockTags); @@ -78,16 +68,16 @@ const UserInterest = () => { } }, [categoryData]); - if (loadingTags || loadingCategories) { + if (tagLoading || categoryLoading) { return Loading...; } - if (errorTag || errorCategory) { + if (tagError || categoryError) { return Error; } - const tags = tagsData ? tagsData : []; - const categories = categoryData ? categoryData : []; + const tags = tagData ?? []; + const categories = categoryData ?? []; const isSelected = (item: Tag) => { return selectedTags.map((tag) => tag.id).includes(item.id); diff --git a/frontend/mobile/src/app/(design-system)/components/Calendar/DayTimeSection.tsx b/frontend/mobile/src/app/(design-system)/components/Calendar/DayTimeSection.tsx index d4d965d5..861e7e10 100644 --- a/frontend/mobile/src/app/(design-system)/components/Calendar/DayTimeSection.tsx +++ b/frontend/mobile/src/app/(design-system)/components/Calendar/DayTimeSection.tsx @@ -95,8 +95,8 @@ export default function DayTimeSection({ time, data }: DayTimeSectionProps) { club={event.host_name} logo={event.host_logo} eventId={event.id} - startTime={new Date(event.startTime)} - endTime={new Date(event.endTime)} + startTime={event.startTime} + endTime={event.endTime} image={event.image} /> diff --git a/frontend/mobile/src/app/(design-system)/components/GlobalLayout/GlobalLayout.tsx b/frontend/mobile/src/app/(design-system)/components/GlobalLayout/GlobalLayout.tsx index 62af6fe1..a08310b4 100644 --- a/frontend/mobile/src/app/(design-system)/components/GlobalLayout/GlobalLayout.tsx +++ b/frontend/mobile/src/app/(design-system)/components/GlobalLayout/GlobalLayout.tsx @@ -10,7 +10,7 @@ const ViewBase = createBox(View); export const GlobalLayout = ({ children }: GlobalLayoutProps) => { return ( - + {children} ); diff --git a/frontend/mobile/src/app/_layout.tsx b/frontend/mobile/src/app/_layout.tsx index 4e3130ea..267dfa85 100644 --- a/frontend/mobile/src/app/_layout.tsx +++ b/frontend/mobile/src/app/_layout.tsx @@ -9,7 +9,6 @@ import { StatusBar } from 'expo-status-bar'; import FontAwesome from '@expo/vector-icons/FontAwesome'; import { ThemeProvider } from '@shopify/restyle'; -import { QueryClient, QueryClientProvider } from '@tanstack/react-query'; import StoreProvider from '../store/StoreProvider'; import { useAppSelector } from '../store/store'; @@ -57,17 +56,13 @@ const RootLayout = () => { if (!loaded) return null; - const queryClient = new QueryClient(); - return ( - - ); diff --git a/frontend/mobile/src/hooks/use-categories.ts b/frontend/mobile/src/hooks/use-categories.ts deleted file mode 100644 index 61b3d314..00000000 --- a/frontend/mobile/src/hooks/use-categories.ts +++ /dev/null @@ -1,11 +0,0 @@ -import { Category } from '@generatesac/lib'; -import { UseQueryResult, useQuery } from '@tanstack/react-query'; - -import { getCategories } from '@/src/services/categories'; - -export const useCategories = (): UseQueryResult => { - return useQuery({ - queryKey: ['categories'], - queryFn: getCategories - }); -}; diff --git a/frontend/mobile/src/hooks/use-tags.ts b/frontend/mobile/src/hooks/use-tags.ts deleted file mode 100644 index 0dfdcb57..00000000 --- a/frontend/mobile/src/hooks/use-tags.ts +++ /dev/null @@ -1,11 +0,0 @@ -import { Tag } from '@generatesac/lib'; -import { UseQueryResult, useQuery } from '@tanstack/react-query'; - -import { getTags } from '@/src/services/tags'; - -export const useTags = (): UseQueryResult => { - return useQuery({ - queryKey: ['tags'], - queryFn: getTags - }); -}; diff --git a/frontend/mobile/src/services/categories.ts b/frontend/mobile/src/services/categories.ts deleted file mode 100644 index d24d8a06..00000000 --- a/frontend/mobile/src/services/categories.ts +++ /dev/null @@ -1,14 +0,0 @@ -import { Category } from '@generatesac/lib'; -import axios from 'axios'; - -import { URL } from './tags'; - -export const getCategories = async (): Promise => { - try { - const categories = await axios.get(`${URL}/categories`); - return categories.data; - } catch (error) { - console.error('Failed to get categories', error); - throw error; - } -}; diff --git a/frontend/mobile/src/services/tags.ts b/frontend/mobile/src/services/tags.ts deleted file mode 100644 index 7fd412a3..00000000 --- a/frontend/mobile/src/services/tags.ts +++ /dev/null @@ -1,14 +0,0 @@ -import { Tag } from '@generatesac/lib'; -import axios from 'axios'; - -export const URL = 'http://127.0.0.1:8080/api/v1'; - -export const getTags = async (): Promise => { - try { - const tags = await axios.get(`${URL}/tags`); - return tags.data; - } catch (error) { - console.error('Failed to get tags', error); - throw error; - } -}; diff --git a/frontend/mobile/yarn.lock b/frontend/mobile/yarn.lock index 079b3430..26a57810 100644 --- a/frontend/mobile/yarn.lock +++ b/frontend/mobile/yarn.lock @@ -1402,10 +1402,10 @@ humps "^2.0.1" prop-types "^15.7.2" -"@generatesac/lib@0.0.169": - version "0.0.169" - resolved "https://registry.yarnpkg.com/@generatesac/lib/-/lib-0.0.169.tgz#6a5799bad43b7c08553a04e5e6ed401ed0b7e7ab" - integrity sha512-IeWdlMKTi9zdqeaSMWWB+fjma6zf3Z1lO7mPmQ8Q+PJ49CkjJVbF5G9tdYgnJrNSz9+fazr5kFXZZl26eJaN0w== +"@generatesac/lib@0.0.170": + version "0.0.170" + resolved "https://registry.yarnpkg.com/@generatesac/lib/-/lib-0.0.170.tgz#2401ac4216d43dc555f142633aba16d1141ca356" + integrity sha512-oPkqZTudQd7tGEQUpAXQrhD/cngIUV595q069d7SMQZ3zZleQqGXirvk1TOjdoEzNug1gN21yS238stq6CL4Nw== dependencies: "@reduxjs/toolkit" "^2.2.3" react "^18.2.0"