components/CommentModal.tsx

    import React, {useState, useEffect} from 'react';
    import {
      View,
      StyleSheet,
      Modal,
      KeyboardAvoidingView,
      Pressable,
      Platform,
      TextInput
    } from 'react-native';
    import {useSafeAreaInsets} from 'react-native-safe-area-context';
    
    export interface CommentFormProps {
      visible: boolean;
      onClose(): void;
      onSubmit(message: string): void;
      initialMessage?: string;
    }
    
    function CommentModal({
      visible,
      onClose,
      onSubmit,
      initialMessage,
    }: CommentFormProps) {
      const {bottom} = useSafeAreaInsets(); // Home 키 없는 iOS 기종 대응
      const [message, setMessage] = useState('');
    
      // initialMessage가 변경되면 message 변경
      useEffect(() => {
        setMessage(initialMessage ?? '');
      }, [initialMessage]);
    
      return (
        <Modal transparent visible={visible} animationType="fade" onRequestClose={onClose}>
          <KeyboardAvoidingView
            behavior={Platform.select({ios: 'padding'})}
            style={styles.keyboardAvoiding}
            keyboardVerticalOffset={Platform.select({ios: -bottom})}>
            <View style={styles.block}>
              <Pressable style={styles.dismissArea} onTouchStart={onClose} />
              <View style={[styles.whiteBox, {paddingBottom: 24 + bottom}]}>
                <TextInput
                  style={styles.input}
                  autoFocus
                  returnKeyType="send"
                  value={message}
                  onChangeText={setMessage}
                  onSubmitEditing={() => {
                    onSubmit(message);
                    setMessage('');
                  }}
                  placeholder="댓글을 입력하세요"
                />
              </View>
            </View>
          </KeyboardAvoidingView>
        </Modal>
      );
    }
    
    const styles = StyleSheet.create({
      block: {
        backgroundColor: 'rgba(0,0,0,0.5)',
        width: '100%',
        flex: 1,
      },
      dismissArea: {
        flex: 1,
      },
      keyboardAvoiding: {flex: 1},
      whiteBox: {
        backgroundColor: 'white',
        paddingTop: 24,
        paddingHorizontal: 16,
      },
      input: {
        paddingLeft: 16,
        paddingRight: 16,
        height: 48,
        fontSize: 12,
        borderColor: '#ababab',
        borderWidth: 1,
        borderRadius: 4,
      },
    });
    
    export default CommentModal;

    이 컴포넌트는 visible Props를 통해 보이거나 숨겨집니다. onClose는 댓글 작성 화면을 닫을 때 호출할 함수이고, onSubmit은 키보드에서 등록 버튼을 눌렀을 때 호출할 함수입니다.

    initialMessageTextInput의 기본값으로 사용할 문자열인데, 이는 추후 댓글을 수정하는 경우에만 사용합니다.

    신간 소식 구독하기
    뉴스레터에 가입하시고 이메일로 신간 소식을 받아 보세요.