MemoForm.js 2.14 KB
Newer Older
YoonDongMin's avatar
YDm    
YoonDongMin committed
1
2
import React, { useState } from 'react';
import { StyleSheet, Button, View, Text, TouchableWithoutFeedback, Keyboard } from 'react-native';
YoonDongMin's avatar
YdM    
YoonDongMin committed
3
4
5
import { globalStyles } from '../styles/global.js'
import { Formik } from 'formik';
import * as yup from 'yup';
YoonDongMin's avatar
YDm    
YoonDongMin committed
6
7
import DatePicker from '../components/DatePicker.js';
import InputBox from '../components/InputBox.js';
YoonDongMin's avatar
0808DM    
YoonDongMin committed
8
9
import { getDateStr } from '../utils/dateFunction';

YoonDongMin's avatar
YdM    
YoonDongMin committed
10
11

const ReviewSchema = yup.object({
YoonDongMin's avatar
0808DM    
YoonDongMin committed
12
13
    date: yup.string() //string만 받는다
        .required(),
YoonDongMin's avatar
YDm    
YoonDongMin committed
14
    message: yup.string()
YoonDongMin's avatar
YdM    
YoonDongMin committed
15
16
17
18
19
        .required()
        .min(2),

})

YoonDongMin's avatar
0808DM    
YoonDongMin committed
20
21
22
const getDates = () => {
    const date = new Date();
    return (getDateStr(date))
YoonDongMin's avatar
YDm    
YoonDongMin committed
23
}
YoonDongMin's avatar
YdM    
YoonDongMin committed
24
25
26
27
28
29
30
31
32


function MemoForm({ addInfo }) {
    return (
        <TouchableWithoutFeedback onPress={() => {
            Keyboard.dismiss();
        }}>
            <View style={globalStyles.container} >
                <Formik
YoonDongMin's avatar
YDm    
YoonDongMin committed
33
                    initialValues={{ date: '', message: '' }}
YoonDongMin's avatar
YdM    
YoonDongMin committed
34
35
36
37
38
39
40
41
42
                    validationSchema={ReviewSchema}
                    onSubmit={(values) => {//위의 4개의 val들을 전달

                        addInfo(values);
                    }}

                >
                    {({ handleChange, handleSubmit, values }) => (
                        <View>
YoonDongMin's avatar
YDm    
YoonDongMin committed
43
44
                            <DatePicker
                                inputTitle='날짜'
YoonDongMin's avatar
0808DM    
YoonDongMin committed
45
                                date={values.date || getDates()}//오늘날짜 아니면 바뀐날짜
YoonDongMin's avatar
YDm    
YoonDongMin committed
46
                                setDate={handleChange('date')}
YoonDongMin's avatar
YdM    
YoonDongMin committed
47
                            />
YoonDongMin's avatar
YDm    
YoonDongMin committed
48
49
50
51
                            <InputBox
                                inputTitle="내용"
                                onChangeText={handleChange('message')}
                                value={values.message}
YoonDongMin's avatar
YdM    
YoonDongMin committed
52
53
54

                            />

YoonDongMin's avatar
YDm    
YoonDongMin committed
55
56
57
                            <View style={{ marginVertical: '10%', marginHorizontal: 10 }}>
                                <Button title='입력' color='dodgerblue' onPress={handleSubmit} />
                            </View>
YoonDongMin's avatar
YdM    
YoonDongMin committed
58
59
60
61
62
63
64
65
66
67
68
                        </View>
                    )}

                </Formik>

            </View >
        </TouchableWithoutFeedback>
    )
}

export default MemoForm;