DeptDetails.js 3.12 KB
Newer Older
YoonDongMin's avatar
YdM    
YoonDongMin committed
1
2
import React, { useEffect, useState } from 'react';
import { StyleSheet, View, Text, Button, Pressable, TouchableWithoutFeedback, Keyboard } from 'react-native';
YoonDongMin's avatar
DongM    
YoonDongMin committed
3
import { globalStyles } from '../styles/global';
YoonDongMin's avatar
YdM    
YoonDongMin committed
4
5
import InputBox from '../components/InputBox';
import StyledButton from '../components/StyledButton';
YoonDongMin's avatar
YDm    
YoonDongMin committed
6
7
import DatePicker from '../components/DatePicker.js';
import deptApi from '../db/deptPage.api';
YoonDongMin's avatar
DongM    
YoonDongMin committed
8

YoonDongMin's avatar
YDm    
YoonDongMin committed
9
10
11
12
13
14
15
16
function DeptDetails({ route, navigation }) {
    const { item, loadLoan } = route.params
    const getDate = () => {
        var date = new Date();
        return (String(date.toJSON()).split(/T/)[0])
    }
    const [date, setDate] = useState(getDate())
    const [message, setMessage] = useState('')
YoonDongMin's avatar
YdM    
YoonDongMin committed
17
18
    const [money, setMoney] = useState('')
    const [remained_money, setRemained_money] = useState('')
YoonDongMin's avatar
YDm    
YoonDongMin committed
19

YoonDongMin's avatar
YdM    
YoonDongMin committed
20
    useEffect(() => {
YoonDongMin's avatar
YDm    
YoonDongMin committed
21
22
23
24
        setDate(String(item.date))
        setMessage(item.message)
        setMoney(String(item.money))
        setRemained_money(String(item.remained_money))
YoonDongMin's avatar
YdM    
YoonDongMin committed
25
    }, [])
YoonDongMin's avatar
DongM    
YoonDongMin committed
26

YoonDongMin's avatar
YDm    
YoonDongMin committed
27
28
29
30
31
32
33
    const onUpdateHandle = async () => {
        await deptApi.updateDept({ date, message, money, remained_money }, item.id)
        loadLoan()
        navigation.navigate('DeptPage')

    }

YoonDongMin's avatar
DongM    
YoonDongMin committed
34
    return (
YoonDongMin's avatar
YdM    
YoonDongMin committed
35
36
37
38
        <TouchableWithoutFeedback onPress={() => {
            Keyboard.dismiss();
        }}>
            <View style={{ flex: 1 }}>
YoonDongMin's avatar
YDm    
YoonDongMin committed
39
40
                <View style={style.Font}>
                    <DatePicker
YoonDongMin's avatar
YdM    
YoonDongMin committed
41
                        inputTitle="날짜"
YoonDongMin's avatar
YDm    
YoonDongMin committed
42
43
                        date={date}
                        setDate={setDate}
YoonDongMin's avatar
YdM    
YoonDongMin committed
44
45
                    />
                    <InputBox
YoonDongMin's avatar
YDm    
YoonDongMin committed
46
47
                        inputTitle="내용"
                        value={message}
YoonDongMin's avatar
YdM    
YoonDongMin committed
48
                        onChangeText={
YoonDongMin's avatar
YDm    
YoonDongMin committed
49
                            (message) => setMessage(message)
YoonDongMin's avatar
YdM    
YoonDongMin committed
50
51
52
53
54
55
56
57
58
59
60
61
62
                        }
                    />
                    <InputBox
                        inputTitle="금액"
                        value={money}
                        onChangeText={
                            (money) => setMoney(money)
                        }
                    />
                    <InputBox
                        inputTitle="남은 금액"
                        value={remained_money}
                        onChangeText={
YoonDongMin's avatar
YDm    
YoonDongMin committed
63
                            (remained_money) => setRemained_money(remained_money)
YoonDongMin's avatar
YdM    
YoonDongMin committed
64
65
66
67
68
69
                        }
                    />
                </View>
                <View style={style.buttonRow}>
                    <StyledButton
                        name="수정"
YoonDongMin's avatar
YDm    
YoonDongMin committed
70
                        onPress={() => { onUpdateHandle() }}
YoonDongMin's avatar
YdM    
YoonDongMin committed
71
72
73
74
75
                        style={style.submitButton}
                    />
                </View>
            </View>
        </TouchableWithoutFeedback>
YoonDongMin's avatar
DongM    
YoonDongMin committed
76
77
78
79
    )
}


YoonDongMin's avatar
YdM    
YoonDongMin committed
80
81
82

const style = StyleSheet.create({

YoonDongMin's avatar
YDm    
YoonDongMin committed
83
84
85
86
    Font: {
        fontFamily: 'GowunDodum-Regular'
    },

YoonDongMin's avatar
YdM    
YoonDongMin committed
87
    buttonRow: {
YoonDongMin's avatar
YDm    
YoonDongMin committed
88
        fontFamily: 'GowunDodum-Regular',
YoonDongMin's avatar
YdM    
YoonDongMin committed
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
        flexDirection: 'row',
        alignItems: "center",
        marginHorizontal: 10,
        marginVertical: 3,
    },
    submitButton: {
        flex: 1,
        height: 50,
    },
    cancelButton: {
        flex: 1,
        height: 50,
    }
});




YoonDongMin's avatar
YDm    
YoonDongMin committed
107
export default DeptDetails;