Skip to content

Commit

Permalink
feature: 리뷰 작성 페이지 UI 작업 (#13)
Browse files Browse the repository at this point in the history
Co-authored-by: MinseoKim <[email protected]>
  • Loading branch information
m1nse0kim and MinseoKim authored May 24, 2024
1 parent fa06a58 commit 84643f2
Show file tree
Hide file tree
Showing 3 changed files with 130 additions and 2 deletions.
1 change: 1 addition & 0 deletions src/assets/color.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,3 +8,4 @@ export const COLOR_WHITE = '#FFFFFF';
export const COLOR_TEXT70GRAY = '#4D4D4D';
export const COLOR_TEXT60GRAY = '#666666';
export const COLOR_NAVY = '#003C71';
export const COLOR_LIGHTGRAY = '#dddddd';
10 changes: 10 additions & 0 deletions src/assets/svg.js

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

121 changes: 119 additions & 2 deletions src/screens/detail/ReviewWriteScreen.js
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ import {
StyleSheet,
Image,
TouchableOpacity,
TextInput,
FlatList,
Pressable,
} from 'react-native';
Expand All @@ -22,8 +23,10 @@ import {
COLOR_BACKGROUND,
COLOR_GRAY,
COLOR_PRIMARY,
COLOR_SECONDARY,
COLOR_TEXT70GRAY,
COLOR_TEXT_BLACK,
COLOR_LIGHTGRAY,
} from '../../assets/color';
import AnimatedButton from '../../components/AnimationButton';
import {useNavigation} from '@react-navigation/native';
Expand All @@ -44,23 +47,137 @@ export default function ReviewWriteScreen(props) {
const navigation = useNavigation();
const {route} = props;
const storeData = route.params?.data;
const [rating, setRating] = useState(0);

console.log('storeData:', storeData);

const DottedLine = () => {
return (
<View style={styles.dottedContainer}>
{[...Array(20)].map((_, index) => (
<View key={index} style={styles.dot} />
))}
</View>
);
};

return (
<>
<Header title={'리뷰 쓰기'} isBackButton={true} />
<ScrollView contentContainerStyle={styles.entire}>
<Text>{storeData.name}</Text>
< View style={styles.headerContainer}>
<Text style={styles.storeName}>{storeData.name}</Text>
<View style={styles.starContainer}>
{[...Array(5)].map((_, index) => (
<TouchableOpacity key={index} onPress={() => setRating(index + 1)}>
<SvgXml
xml={index < rating ? svgXml.icon.starFill : svgXml.icon.starEmpty}
width="24"
height="24"
style={{ marginLeft: 7 }}
/>
</TouchableOpacity>
))}
</View>
</View>
<TouchableOpacity style={styles.photoButton}>
<Text style={styles.photoButtonText}>사진 첨부하기</Text>
</TouchableOpacity>
<TextInput
style={styles.reviewInput}
multiline
placeholder="음식의 맛, 양, 위생 상태 등 음식에 대한 솔직한 리뷰를 남겨주세요. (선택)"
/>
<DottedLine />
<TouchableOpacity style={styles.submitButton}>
<Text style={styles.submitButtonText}>완료</Text>
</TouchableOpacity>
</ScrollView>
</>
);
}

const styles = StyleSheet.create({
entire: {
backgroundColor: COLOR_BACKGROUND,
backgroundColor: COLOR_WHITE,
// justifyContent: 'center',
alignItems: 'center',
height: '100%',
},
headerContainer: {
flexDirection: 'row',
alignItems: 'center',
justifyContent: 'space-between',
width: '100%',
paddingHorizontal: 16,
marginVertical: 24,
},
storeName: {
fontSize: 22,
fontWeight: 'bold',
color: COLOR_TEXT_BLACK,
},
starContainer: {
flexDirection: 'row',
},
photoButton: {
backgroundColor: COLOR_WHITE,
borderColor: COLOR_PRIMARY,
borderWidth: 1,
padding: 12,
borderRadius: 8,
alignItems: 'center',
marginTop: 8,
marginBottom: 16,
width: '92%',
height: '',
},
photoButtonText: {
color: COLOR_PRIMARY,
fontSize: 16,
},
reviewInput: {
backgroundColor: COLOR_WHITE,
borderColor: COLOR_PRIMARY,
borderWidth: 1,
borderRadius: 8,
padding: 12,
width: '92%',
height: 150,
textAlignVertical: 'top',
marginVertical: 16,
fontSize: 16,
},
dottedContainer: {
flexDirection: 'row',
width: '92%',
justifyContent: 'space-between',
marginVertical: 16,
},
dot: {
width: 9,
height: 2,
backgroundColor: COLOR_LIGHTGRAY,
marginHorizontal: 1,
},
submitButton: {
position: 'absolute',
bottom: 0,
backgroundColor: COLOR_PRIMARY,
padding: 16,
borderRadius: 32,
alignItems: 'center',
width: '90%',
marginBottom: 16,
shadowColor: COLOR_TEXT_BLACK,
shadowOffset: { width: 0, height: 3 },
shadowOpacity: 1,
shadowRadius: 5,
elevation: 8,
},
submitButtonText: {
color: COLOR_WHITE,
fontSize: 18,
fontWeight: '600',
},
});

0 comments on commit 84643f2

Please sign in to comment.