From fa06a58b3c1e4855c80644e14a198af45cfa7e4b Mon Sep 17 00:00:00 2001
From: Eum SeungJu <109807198+sjsjmine129@users.noreply.github.com>
Date: Tue, 21 May 2024 16:33:06 +0900
Subject: [PATCH] [5/20] (#12)
* Add/home logic
* Add/logic
---
package.json | 1 +
src/components/FoodCategory.js | 71 +++++++++++++++----------
src/components/KingoPass.js | 5 +-
src/components/StoreCompo.js | 1 -
src/navigation/BottomTabNavigator.js | 4 +-
src/screens/home/HomeScreen.js | 79 ++++++++++++++--------------
src/screens/list/ListMainScreen.js | 18 ++++++-
yarn.lock | 5 ++
8 files changed, 111 insertions(+), 73 deletions(-)
diff --git a/package.json b/package.json
index 20ef6ab..a22f0fd 100644
--- a/package.json
+++ b/package.json
@@ -28,6 +28,7 @@
"react-native-image-modal": "^2.0.4",
"react-native-maps": "^1.14.0",
"react-native-modal": "^13.0.1",
+ "react-native-navigation-bar-color": "^2.0.2",
"react-native-reanimated": "^3.8.1",
"react-native-safe-area-context": "^4.9.0",
"react-native-screens": "^3.30.1",
diff --git a/src/components/FoodCategory.js b/src/components/FoodCategory.js
index 3aa803b..1a29c3b 100644
--- a/src/components/FoodCategory.js
+++ b/src/components/FoodCategory.js
@@ -26,6 +26,7 @@ import {
COLOR_TEXT_BLACK,
COLOR_TEXT60GRAY,
} from '../assets/color';
+import AsyncStorage from '@react-native-async-storage/async-storage';
import {useNavigation} from '@react-navigation/native';
import {SvgXml} from 'react-native-svg';
import {svgXml} from '../assets/svg';
@@ -35,6 +36,7 @@ import axios from 'axios';
import {API_URL} from '@env';
import {Dimensions} from 'react-native';
import AnimatedButton from './AnimationButton';
+import {astToReact} from 'react-native-svg/lib/typescript/xml';
const windowWidth = Dimensions.get('window').width;
@@ -54,10 +56,13 @@ export default function FoodCategory(props) {
marginBottom: 14,
}}>
카테고리
- {/* TODO: 기능 구현 */}
{
+ onPress={async () => {
console.log('카테고리로 넘어가기');
+ await AsyncStorage.setItem('category', '');
+ navigation.navigate('ListNavigator', {
+ screen: 'ListMainScreen',
+ });
}}>
@@ -66,39 +71,46 @@ export default function FoodCategory(props) {
{categroyList1.map((categroy, index) => {
return (
{
+ style={styles.buttonSet}
+ onPress={async () => {
console.log(categroy, '누름');
- }}
- style={styles.categroyButton}>
+ await AsyncStorage.setItem('category', categroy);
+ navigation.reset({
+ index: 0,
+ routes: [
+ {
+ name: 'ListNavigator',
+ },
+ ],
+ });
+ }}>
+
{categroy}
);
})}
+
+
{categroyList2.map((categroy, index) => {
return (
{
+ style={styles.buttonSet}
+ onPress={async () => {
console.log(categroy, '누름');
- }}
- style={styles.categroyButton}>
- {categroy.length > 2 ? (
-
- {categroy}
-
- ) : (
- {categroy}
- )}
+ await AsyncStorage.setItem('category', categroy);
+ navigation.reset({
+ index: 0,
+ routes: [
+ {
+ name: 'ListNavigator',
+ },
+ ],
+ });
+ }}>
+
+ {categroy}
);
})}
@@ -142,15 +154,20 @@ const styles = StyleSheet.create({
categroyButton: {
justifyContent: 'center',
alignItems: 'center',
- marginBottom: 34,
+ marginBottom: 3,
width: 50,
height: 50,
backgroundColor: COLOR_PRIMARY,
borderRadius: 20,
},
categroyText2: {
- fontSize: 20,
- color: COLOR_WHITE,
+ fontSize: 15,
+ color: COLOR_TEXT_BLACK,
fontWeight: 'bold',
},
+ buttonSet: {
+ justifyContent: 'center',
+ alignItems: 'center',
+ marginBottom: 0,
+ },
});
diff --git a/src/components/KingoPass.js b/src/components/KingoPass.js
index 01a07f8..589c7a3 100644
--- a/src/components/KingoPass.js
+++ b/src/components/KingoPass.js
@@ -67,10 +67,11 @@ export default function KingoPass(props) {
// TODO: 킹고패스 페이지로 이동
onPress={() => {
console.log('킹고패스 페이지로 이동');
+ navigation.navigate('StoreDetail', {data: data});
}}>
- {data.body}
+ {data.discountContent}
diff --git a/src/components/StoreCompo.js b/src/components/StoreCompo.js
index 5e0eee0..3d17a32 100644
--- a/src/components/StoreCompo.js
+++ b/src/components/StoreCompo.js
@@ -60,7 +60,6 @@ export default function StoreCompo(props) {
console.log('가게 상세 페이지로 이동');
navigation.navigate('StoreDetail', {data: storeData});
}}>
- {console.log('addPadding: ', addPadding)}
@@ -146,7 +148,7 @@ export default function BottomTabNavigator() {
headerShown: false,
tabBarStyle: {
height: 56,
- backgroundColor: COLOR_BACKGROUND,
+ backgroundColor: COLOR_WHITE,
// backgroundColor: 'red',
},
tabBarShowLabel: false,
diff --git a/src/screens/home/HomeScreen.js b/src/screens/home/HomeScreen.js
index 3288320..39e4b2c 100644
--- a/src/screens/home/HomeScreen.js
+++ b/src/screens/home/HomeScreen.js
@@ -31,7 +31,7 @@ import {SvgXml} from 'react-native-svg';
import {svgXml} from '../../assets/svg';
import Header from '../../components/Header';
import AppContext from '../../components/AppContext';
-import axios from 'axios';
+import axios, {AxiosError} from 'axios';
import {API_URL} from '@env';
import {Dimensions} from 'react-native';
import TodayPick from '../../components/TodayPick';
@@ -86,51 +86,50 @@ export default function HomeScreen() {
},
]);
- const [kingoPassData, setkingoPassData] = useState([
- {
- name: '율천회관',
- image: 'https://d2da4yi19up8sp.cloudfront.net/product/pro.jpeg',
- body: '가게 내부 깨끗하고, 서비스 친절해서 개좋음. 기대안하고 첨 갔는데 걍 인생 oo 맛봄. 지림.',
- },
- {
- name: '무대뽀 핫도그',
- image: 'https://d2da4yi19up8sp.cloudfront.net/product/max.jpeg',
- body: '가게 내부 깨끗하고, 서비스 친절해서 개좋음. 기대안하고 첨 갔는데 걍 인생 oo 맛봄. 지림.',
- },
- {
- name: '무대뽀 핫도그',
- image: 'https://d2da4yi19up8sp.cloudfront.net/product/max.jpeg',
- body: '가게 내부 깨끗하고, 서비스 친절해서 개좋음. 기대안하고 첨 갔는데 걍 인생 oo 맛봄. 지림.',
- },
- ]);
+ const [kingoPassData, setkingoPassData] = useState([]);
+
+ const initKingoPassData = async () => {
+ try {
+ console.log('context.accessToken:', context.accessToken);
+
+ const params = {
+ discountForSkku: true,
+ };
+
+ const queryString = new URLSearchParams(params).toString();
+
+ const response = await axios.get(
+ `${API_URL}/v1/restaurants?${queryString}`,
+ {
+ headers: {Authorization: `Bearer ${context.accessToken}`},
+ },
+ );
+
+ console.log('response:', response.data.data.restaurants[0]);
+
+ setkingoPassData(response.data.data.restaurants);
+ } catch (e) {
+ console.log('error', e);
+ }
+ };
+
+ const initTodayPickData = async () => {
+ try {
+ //TODO: 백엔드 연결
+ } catch (e) {
+ console.log('error', e);
+ }
+ };
+
+ useEffect(() => {
+ initKingoPassData();
+ }, []);
return (
<>
{/* 먹구스꾸 오늘의 픽 */}
- {/* {
- try {
- const response = await axios.get(
- `${API_URL}/hello/security-test`,
- {
- headers: {Authorization: `Bearer ${context.accessToken}`},
- },
- );
-
- console.log('response:', response.data.data);
-
- if (!response.data.data) {
- console.log('Error: No return data');
- return;
- }
- } catch (e) {
- console.log('error', e);
- }
- }}
- /> */}
diff --git a/src/screens/list/ListMainScreen.js b/src/screens/list/ListMainScreen.js
index 47ceadf..db709b0 100644
--- a/src/screens/list/ListMainScreen.js
+++ b/src/screens/list/ListMainScreen.js
@@ -22,7 +22,7 @@ import StoreCompo from '../../components/StoreCompo';
import {SvgXml} from 'react-native-svg';
import {svgXml} from '../../assets/svg';
import {Dimensions} from 'react-native';
-
+import AsyncStorage from '@react-native-async-storage/async-storage';
const windowWidth = Dimensions.get('window').width;
export default function ListMainScreen() {
@@ -274,6 +274,20 @@ export default function ListMainScreen() {
},
]);
+ const checkCategory = async () => {
+ const srcCategory = await AsyncStorage.getItem('category');
+ if (srcCategory) {
+ setSelectedCategory(srcCategory);
+ await AsyncStorage.setItem('category', '');
+ } else {
+ setSelectedCategory('전체');
+ }
+ };
+
+ useEffect(() => {
+ checkCategory();
+ }, []);
+
//TODO: 필터링 하는 함수
//리스트 위에 필터 버튼들
@@ -289,7 +303,7 @@ export default function ListMainScreen() {
{
- console.log('정렬 버튼 누름');
+ console.log('정렬 버튼 누름', selectedCategory);
}}>
diff --git a/yarn.lock b/yarn.lock
index 7352fa3..c138a8e 100644
--- a/yarn.lock
+++ b/yarn.lock
@@ -5911,6 +5911,11 @@ react-native-modal@^13.0.1:
prop-types "^15.6.2"
react-native-animatable "1.3.3"
+react-native-navigation-bar-color@^2.0.2:
+ version "2.0.2"
+ resolved "https://registry.yarnpkg.com/react-native-navigation-bar-color/-/react-native-navigation-bar-color-2.0.2.tgz#2e14ca79a656d81d5b4b7433ae43966ef5206444"
+ integrity sha512-ZmpLWRocyme1au11e5ZuecMS/UCi57nlzgnioi03Q6ERMbeUOqqbWgNBaNB7SsCeqBV6fZPjo3+A64zEIpzw4w==
+
react-native-reanimated@^3.8.1:
version "3.8.1"
resolved "https://registry.yarnpkg.com/react-native-reanimated/-/react-native-reanimated-3.8.1.tgz#45c13d4bedebef8df3d5a8756f25072de65960d7"