bluejoyq

Merge branch 'design3' into 'master'

Design3

rate 디자인 거의 완성!!

See merge request !12
......@@ -3,7 +3,7 @@ import { Text } from 'react-native-paper';
import { StyleSheet,View } from 'react-native';
export default PromptSearchRate = () => (
<View style={{alignItems:'center'}}>
<View style={{alignItems: 'center',justifyContent: 'center'}}>
<Text style={styles.Text}>아직까지 검색</Text>
<Text style={styles.Text}>결과가 없습니다!</Text>
</View>
......
import React,{ useState } from 'react';
import { Surface, Text ,HelperText} from 'react-native-paper';
import { StyleSheet,View } from 'react-native';
import { StackedBarChart } from 'react-native-svg-charts';
import { PieChart } from 'react-native-svg-charts';
import PromptSearchRate from '../PromptSearch/PromptSearchRate';
export default RateBar = (props) => {
......@@ -14,48 +14,54 @@ export default RateBar = (props) => {
<>
<View style={styles.container}>
<Text style={styles.Text}> 점수 : {props.score.full}</Text>
<View style={styles.colorContainer}>
<View style={styles.textContainer}>
<View style={styles.colorA}></View><Text>키워드 점수</Text>
</View>
<View style={styles.textContainer}>
<View style={styles.colorB}></View><Text>맞춤법 점수</Text>
</View>
</View>
</View>
<StackedBarChart
data={ [{
keyword: {
value: props.score.key,
svg: {
onPressIn: () => {setClick(1)},
onPressOut: ()=>{setClick(0)}
},
},
korean: {
value: props.score.fix,
svg: {
onPressIn: () => {setClick(2)},
onPressOut: ()=>{setClick(0)}
},
},
rest: {
value: (100-(props.score.key+props.score.fix)),
}
}]}
style={{height:50, width:'90%'}}
keys={['keyword','korean','rest']}
colors={['#f98a1a','#14a986','#ffffff']}
showGrid={ false }
horizontal={ true }
contentInset={ { top: 10 } }
valueAccessor={({ item, key }) => item[key].value}
/>
<View style={styles.container}>
<Text style={styles.message}>눌러서 각각의 점수를 알아보세요!</Text>
</View>
<View style={styles.infoContainer}>
<HelperText type={'info'} visible={click==1} style={styles.helper}>키워드 : {props.score.key}</HelperText>
<HelperText type={'info'} visible={click==2} style={styles.helper}>맞춤법 : {props.score.fix}</HelperText>
<HelperText type={'info'} visible={click==1} style={styles.helper}>키워드 : {props.score.key}</HelperText>
</View>
<View style={styles.chartContatiner}>
<View>
<PieChart
style={ styles.chart }
data={[{
value: props.score.key,
svg:{
fill : '#e85a71',
onPressIn: () => {setClick(1)},
onPressOut: ()=>{setClick(0)}
},
key: "키워드"
},
{
value: props.score.fix,
svg: {
fill : '#d8e9ef',
onPressIn: () => {setClick(2)},
onPressOut: ()=>{setClick(0)}
},
key: "맞춤법"
},
{
value: (100-(props.score.key+props.score.fix)),
key : ""
}
]}
innerRadius={"50%"}
/>
</View>
<View style={styles.colorContainer}>
<View style={styles.textContainer}>
<View style={styles.colorA}></View><Text>키워드 점수</Text>
</View>
<View style={styles.textContainer}>
<View style={styles.colorB}></View><Text>맞춤법 점수</Text>
</View>
</View>
</View>
<Text style={styles.message}>눌러서 각각의 점수를 알아보세요!</Text>
</>
: <PromptSearchRate />}
</Surface>
......@@ -70,13 +76,14 @@ const styles = StyleSheet.create({
width: '100%',
flexDirection:'row',
justifyContent:'center',
marginTop : 8,
},
colorContainer:{
position:"absolute",
right:0,
right:20,
},
colorA:{
backgroundColor:'#f98a1a',
backgroundColor:'#e85a71',
height: 7,
width: 7,
marginRight: 5,
......@@ -84,13 +91,23 @@ const styles = StyleSheet.create({
fontSize: 13,
},
colorB:{
backgroundColor:'#2cc3c2',
backgroundColor:'#d8e9ef',
height: 7,
width: 7,
marginRight: 5,
fontFamily:"Regular",
fontSize: 13,
},
chartContatiner:{
flexDirection:'row',
justifyContent:"flex-start",
alignItems:'flex-start',
},
chart:{
height: 125,
width:"100%",
position:"absolute",
},
textContainer:{
flexDirection:'row',
justifyContent:'center',
......@@ -104,11 +121,13 @@ const styles = StyleSheet.create({
width: '100%'
},
surface: {
padding: 8,
flex: 0.3,
paddingTop: 10,
paddingBottom:0,
flex: 0.55,
width: '95%',
alignItems: 'center',
justifyContent: 'center',
flexDirection:'column',
alignItems: "center",
justifyContent: 'flex-start',
elevation: 2,
marginTop: 10,
borderRadius: 5
......@@ -121,9 +140,10 @@ const styles = StyleSheet.create({
message:{
fontFamily:"Son",
fontSize: 20,
marginBottom: 10,
},
helper:{
fontFamily:"Regular",
fontFamily:"Bold",
fontSize:15
}
});
......
......@@ -15,16 +15,22 @@ const RateLine = ({load,pastRecords }) => {
<Surface style={styles.surface}>
{pastRecords.length ?
<>
<Text style={styles.info}>점수 변화</Text>
<Text style={styles.message}>당신의 점수 변화를 확인하세요!</Text>
<View style={styles.scoreContainer}>
{pastRecords.map((past,index)=> (
pastRecords.length - 1 > index ?
<View key={index} style={styles.past}>
<Text style={styles.score}>{past.score}</Text>
<Text style={styles.date}>{past.date.substring(5,7)+'/'+past.date.substring(8,10)}</Text>
<Text style={styles.date, {fontSize:11}}>{past.date.substring(5,7)+'/'+past.date.substring(8,10)}</Text>
<Text style={styles.score}>{past.score}</Text>
</View>
))}
:
<View key={index} style={styles.past}>
<Text style={styles.date, {fontSize:15}}>{past.date.substring(5,7)+'/'+past.date.substring(8,10)}</Text>
<Text style={styles.score, {fontFamily:"ExtraBold", fontSize:25, color: "#4ea1d3"}}>{past.score}</Text>
</View>
<Text style={styles.message}>당신의 점수 변화를 확인하세요!</Text>
))}
</View>
</>
: <PromptSearchRate />
}
......@@ -32,10 +38,11 @@ const RateLine = ({load,pastRecords }) => {
);
}
const styles = StyleSheet.create({
surface: {
padding: 8,
surface: {
padding :5,
flex: 0.3,
width: '95%',
flexDirection:'column',
alignItems: 'center',
justifyContent: 'center',
elevation: 2,
......@@ -44,23 +51,29 @@ const styles = StyleSheet.create({
borderRadius: 5,
},
info:{
fontSize:22,
marginBottom: 5,
fontFamily:"Bold",
},
score:{
fontSize:20,
fontSize:21,
marginBottom: 10,
fontFamily:"Bold",
},
scoreContainer:{
flexDirection:'row',
alignItems : 'center',
justifyContent: 'space-around',
width:'100%'
width:'100%',
backgroundColor :'#ececf8',
padding : 5,
marginTop : 10,
marginBottom : 10,
borderRadius:5,
},
data:{
fontSize:10,
textAlign:'center',
fontFamily:"Regular",
fontFamily:"Son",
textAlign:'center',
marginBottom:10,
},
score:{
fontSize:20,
fontFamily:"Bold"
},
past:{
alignItems:'center',
......@@ -68,8 +81,9 @@ const styles = StyleSheet.create({
},
message:{
fontFamily:"Son",
marginTop : 10,
fontSize: 20,
margin : 5,
fontSize: 25,
justifyContent: 'flex-start',
}
});
const RateLineContainer = ( {load,pastRecords } ) => (
......
......@@ -35,7 +35,7 @@ const RateMessage = ({keywordText, score }) => {
const styles = StyleSheet.create({
surface: {
padding: 8,
flex: 0.2,
flex: 0.225,
width: '95%',
alignItems: 'center',
justifyContent: 'center',
......
......@@ -43,7 +43,7 @@ const RateSentence = ({originalText, fixedText, keywordText }) => {
const styles = StyleSheet.create({
surface: {
padding: 8,
flex: 0.2,
flex: 0.225,
width: '95%',
alignItems: 'center',
justifyContent: 'center',
......