No description
- schedule_members 테이블 분리 (members 컬럼 → 별도 테이블) - schedules 테이블 컬럼 comment 추가 및 순서 정리 - 상세주소(location_detail) 필드 추가 - 장소 검색 UI 개선 (탭 제거 → 입력 필드+검색 버튼 병합) - 카카오 장소 검색 API 프록시 추가 (/api/admin/kakao/places) - 백엔드 CRUD API 구현 (GET/PUT/DELETE /schedules/:id) - 프론트엔드 삭제 기능 및 확인 다이얼로그 추가 - 프론트엔드 수정 모드 지원 (기존 데이터 로드) |
||
|---|---|---|
| backend | ||
| frontend | ||
| .env | ||
| .gitignore | ||
| docker-compose.dev.yml | ||
| docker-compose.yml | ||
| Dockerfile | ||
| download_photos.sh | ||
| README.md | ||
| update_descriptions.sql | ||
🌸 fromis_9 Fan Site
프로미스나인 팬사이트입니다.
✨ 주요 기능
- 👥 멤버 소개 - 프로미스나인 멤버 프로필 및 상세 정보
- 💿 디스코그래피 - 앨범 목록 및 타이틀곡 정보
- 📅 스케줄 - 예정된 활동 일정 (자동 업데이트)
- 🔗 SNS 링크 - 공식 소셜 미디어 바로가기
📁 프로젝트 구조
fromis_9/
├── frontend/ # React + Vite 프론트엔드
├── backend/ # Node.js + Express 백엔드
├── Dockerfile # 멀티스테이지 Docker 빌드
└── docker-compose.yml # Docker Compose 설정
🛠️ 기술 스택
Frontend
| 기술 | 설명 |
|---|---|
| React 18 | UI 라이브러리 |
| Vite | 빌드 도구 |
| TailwindCSS | CSS 프레임워크 |
| react-device-detect | PC/모바일 분기 |
| framer-motion | 애니메이션 |
Backend
| 기술 | 설명 |
|---|---|
| Node.js | 런타임 환경 |
| Express | 웹 프레임워크 |
| MySQL2 | 데이터베이스 연동 |
🚀 실행 방법
Docker (권장)
docker compose up -d --build
개발 모드
# 프론트엔드
cd frontend && npm install && npm run dev
# 백엔드
cd backend && npm install && npm start
⚙️ 환경 변수
.env 파일에 다음 변수들을 설정하세요:
DB_HOST=mariadb
DB_USER=fromis9
DB_PASSWORD=your_password
DB_NAME=fromis9
🌐 접속
📄 라이선스
MIT License