Claude-skill-registry flutter-skill
install
source · Clone the upstream repo
git clone https://github.com/majiayu000/claude-skill-registry
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/flutter-skill" ~/.claude/skills/majiayu000-claude-skill-registry-flutter-skill && rm -rf "$T"
manifest:
skills/data/flutter-skill/SKILL.mdsource content
Flutter Skill
본 스킬은 Flutter 프레임워크로 앱을 개발하는 데 반드시 따라야 하는 범용적인 UI/UX 디자인, 상태관리, 네트워킹, API 연동에 관한 가이드라인을 제공합니다. 즉, 본 스킬은 특정 앱에 종속되는 코딩 가이드라인을 제공하는 것이 아니라, 다양한 종류의 플러터 앱 개발에 사용 될 수 있는 범용적인 지침을 제공합니다.
Table of Contents
Workflow
개발자 요청에 따라 아래 워크플로우를 따릅니다:
-
디자인/UI/UX 요청 시: Comic Design 문서 참조
- 키워드: 디자인, UI, UX, 버튼, 카드, 레이아웃, 애니메이션, Comic, 코믹
-
레이아웃 요청 시: Flutter Layout 문서 참조
- 키워드: 레이아웃, 스크롤, CustomScrollView, ListView, 위젯 배치
-
상태관리 요청 시: Provider 문서 참조
- 키워드: 상태관리, Provider, Selector, ChangeNotifier
-
라우팅 요청 시: Go Route 문서 참조
- 키워드: 라우팅, 네비게이션, GoRouter, 페이지 이동
-
다국어 요청 시: i18n 문서 참조
- 키워드: 다국어, 번역, localization, i18n, arb
-
푸시 알림/FCM 요청 시: Firebase FCM 문서 참조
- 키워드: 푸시 알림, FCM, Firebase Messaging, 알림, notification, 토큰, 구독
-
Firebase 인증 요청 시: Firebase Auth 문서 참조
- 키워드: Firebase Auth, 로그인, 회원가입, 인증, 에러 처리, invalid-credential, user-not-found, wrong-password, Email enumeration protection
Core Principles
필수 규칙
// ❌ 절대 금지 color: Colors.blue // 하드코딩된 색상 fontSize: 16 // 하드코딩된 크기 Text('Hello') // 하드코딩된 텍스트 elevation: 4 // 0이 아닌 elevation // ✅ 반드시 사용 color: Theme.of(context).colorScheme.primary // 테마 색상 style: Theme.of(context).textTheme.bodyLarge // 테마 텍스트 스타일 Text(T.hello) // i18n 번역 elevation: 0 // 플랫 디자인
테마 기반 스타일링
모든 색상, 폰트, 스타일은 반드시
Theme.of(context)를 사용합니다:
| 용도 | 사용 방법 |
|---|---|
| Primary 색상 | |
| Surface 색상 | |
| 테두리 색상 | |
| 본문 텍스트 | |
| 제목 텍스트 | |
Comic 디자인 규칙 요약
| 속성 | 값 | 설명 |
|---|---|---|
| Border Width | (표준), (목록) | Comic 스타일 테두리 |
| Border Radius | | 둥근 모서리 |
| Elevation | | 그림자 없음 |
| 간격 | 8의 배수 | 8, 16, 24, 32... |
Reference Documents
각 문서는 해당 주제에 대한 상세한 가이드라인과 코드 예제를 제공합니다:
| 문서 | 내용 |
|---|---|
| comic-design.md | Comic UI 디자인 시스템, 버튼, 카드, 폼, SnackBar 등 |
| flutter-layout.md | 스크롤 화면, CustomScrollView, ListView 패턴 |
| provider.md | Provider 상태관리, Selector, ChangeNotifier |
| go_route.md | GoRouter 라우팅, 파라미터 전달, redirect |
| i18n.md | 다국어 지원, ARB 파일 관리 |
| firebase-fcm.md | FCM 푸시 알림, 토큰 관리, 메시지 핸들링 |
| firebase/firebase-auth.md | Firebase 인증, Email enumeration protection, 에러 코드 처리 (, , 등) |
필수 pub.dev 패키지
file_cache_flutter
Flutter 애플리케이션용 파일 캐시 라이브러리로, 메모리 + 파일 이중 캐싱과 TTL(Time-To-Live) 기반 자동 만료를 지원합니다.
- pub.dev: file_cache_flutter
주요 기능
| 기능 | 설명 |
|---|---|
| 이중 캐싱 | 메모리와 파일 캐시 동시 활용으로 빠른 접근 |
| TTL 지원 | 캐시 만료 시간 설정 가능 (기본값 30분) |
| 제네릭 타입 | 모든 데이터 타입 캐싱 가능 |
| 자동 정리 | 만료된 캐시 자동 삭제 |
설치
dependencies: file_cache_flutter: ^0.0.3
사용 예제
import 'package:file_cache_flutter/file_cache_flutter.dart'; // 캐시 인스턴스 생성 final cache = FileCache<UserData>( cacheName: 'user_data', // 캐시 이름 (파일 저장 경로에 사용) fromJson: UserData.fromJson, // JSON → 객체 변환 함수 toJson: (data) => data.toJson(), // 객체 → JSON 변환 함수 defaultTtl: Duration(minutes: 30), // 기본 TTL 설정 ); // 데이터 저장 await cache.set('user_123', UserData(name: '홍길동', age: 25)); // 데이터 조회 (만료되지 않은 경우에만 반환) final user = await cache.get('user_123'); // 캐시 존재 여부 확인 final exists = await cache.has('user_123'); // 특정 키 삭제 await cache.remove('user_123'); // 전체 캐시 삭제 await cache.clear(); // 만료된 캐시만 정리 await cache.cleanup();
주요 메서드
| 메서드 | 설명 |
|---|---|
| 캐시에서 데이터 조회 (만료 시 null 반환) |
| 캐시에 데이터 저장 (선택적 TTL 지정) |
| 캐시 존재 여부 확인 |
| 특정 키의 캐시 삭제 |
| 전체 캐시 삭제 |
| 만료된 캐시 정리 |
Quick Reference
Import 문
import 'package:flutter/material.dart'; import 'package:font_awesome_flutter/font_awesome_flutter.dart'; import 'package:flutter_animate/flutter_animate.dart'; import 'package:provider/provider.dart'; import 'package:go_router/go_router.dart';
애니메이션 (flutter_animate 패키지 사용)
Container() .animate() .fadeIn(duration: 300.ms) .slideX(begin: -0.2, end: 0)
아이콘 우선순위
Font Awesome Pro 아이콘 사용 시 우선순위: Light > Regular > Solid
FaIcon(FontAwesomeIcons.lightCamera) // Light 우선