No description
트윗의 외부 링크에 대해 미리보기 카드 표시. - Nitter가 렌더링한 카드 우선 사용 (extractCard) - Nitter 카드가 비어있으면 본문 URL로 OG 직접 추출 (og.js) - YouTube/Instagram 등 복구, HTML 엔티티 디코딩 포함 - TikTok 등 봇 차단 사이트는 Nitter 카드로 커버 - schedule_x.card_data 컬럼 + getScheduleDetail 응답에 card 포함 - 가로 레이아웃 카드 (왼쪽 이미지 + 오른쪽 텍스트) - CardImage: 이미지 로드 실패 시 fallback 아이콘 (인스타 CDN 만료 대비) - 자체 영상/이미지가 있으면 OG 카드 숨김 (중복 방지) Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com> |
||
|---|---|---|
| app | ||
| backend | ||
| docs | ||
| frontend | ||
| .env | ||
| .gitignore | ||
| CLAUDE.md | ||
| docker-compose.yml | ||
| README.md | ||
🌸 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