guardia-messenger/.claude/skills/rn-screen-dev/SKILL.md
DESKTOP-TKLFCPRython f29f525c77 refactor: 101.79.17.164 → zioinfo.co.kr 전체 도메인 변환 + Manager UI 배포
- 37개 파일 IP → zioinfo.co.kr 치환 (소스/매뉴얼/설정/하네스)
- Manager DrConsole/NetworkConsole/CsapConsole 빌드 + /var/www/manager/ 배포
- 테스트: Manager HTTP 200, ITSM 신규 API 7개 전체 200

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-05-31 10:09:17 +09:00

2.6 KiB

name description
rn-screen-dev GUARDiA Messenger React Native 화면 구현 스킬. Expo SDK 51 + expo-router + TypeScript. 새 화면 추가, 기존 화면 수정, 컴포넌트 생성, API 연동 모두 담당. 트리거: 화면 구현, 컴포넌트 작성, 탭 추가, UI 수정, API 연동 요청 시 반드시 사용.

GUARDiA Messenger 화면 개발 가이드

프로젝트 구조

C:\GUARDiA\app\
├── app/
│   ├── _layout.tsx          ← 루트 레이아웃 (AuthContext 제공)
│   ├── (auth)/login.tsx     ← 로그인
│   └── (tabs)/
│       ├── _layout.tsx      ← 탭 네비게이터 (5개 탭)
│       ├── index.tsx        ← 대시보드
│       ├── sr.tsx           ← SR 목록·등록
│       ├── chat.tsx         ← AI 챗봇
│       ├── notifications.tsx← 알림
│       └── settings.tsx     ← 설정
├── components/
│   ├── common/              ← 공통 컴포넌트
│   └── layout/              ← 레이아웃 컴포넌트 (없으면 생성)
├── constants/Config.ts      ← COLORS, API_BASE
├── hooks/useAuth.ts         ← JWT 인증 (expo-secure-store)
└── services/api.ts          ← axios 클라이언트

새 탭 화면 추가 패턴

// app/(tabs)/새화면.tsx
import { View, Text, StyleSheet, ScrollView } from 'react-native'
import { COLORS } from '../../constants/Config'

export default function 새화면() {
  return (
    <ScrollView style={s.container}>
      <Text>내용</Text>
    </ScrollView>
  )
}

const s = StyleSheet.create({
  container: { flex: 1, backgroundColor: COLORS.bg },
})

탭에 추가하려면 app/(tabs)/_layout.tsx<Tabs.Screen> 추가.

API 연동 패턴

import { useState, useEffect } from 'react'
import { guardiaApi } from '../../services/api'

const [data, setData] = useState<타입 | null>(null)
const [loading, setLoading] = useState(true)

useEffect(() => {
  guardiaApi.get('/api/엔드포인트')
    .then(r => setData(r.data))
    .catch(() => {})
    .finally(() => setLoading(false))
}, [])

컴포넌트 재사용 원칙

이미 구현된 컴포넌트를 먼저 확인하고 재사용한다:

  • 버튼: 인라인 TouchableOpacity 스타일 사용
  • 리스트 아이템: ScrollView + View 조합
  • 입력: TextInput with border

금기사항 (빌드 실패 원인)

  • expo-notifications import 시 app.json plugin 없으면 빌드 실패
  • android/ 폴더 존재 시 Bare Workflow로 오인됨
  • babel.config.jsexpo-router/babel 추가 금지

자세한 빌드 이슈: references/build-issues.md 참조