레이아웃: - 풀스크린 모드 컨텍스트 (BossCrystal 페이지에서 푸터 숨김 + viewport 고정) - 캐릭터 패널: 자연 높이 + viewport 한도 + 내부 목록 스크롤 - 보스 패널: 헤더 고정 + 목록 내부 스크롤 - 커스텀 스크롤바 (전역) 캐릭터 패널: - framer-motion Reorder로 드래그앤드롭 정렬 - 가로 캐릭터 행 + 6x2 보스 그리드 + 난이도 영문 첫글자 뱃지 - 총 수익에 ResizeObserver 기반 자동 폰트 fit - 캐릭터 삭제 시 첫번째 자동 선택, 입력 재개 시 에러 메시지 자동 제거 기능: - 공개 보스/캐릭터 API 추가 - API 키 라이브 키로 변경 Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
48 lines
1.3 KiB
JavaScript
48 lines
1.3 KiB
JavaScript
import express from 'express';
|
|
import cors from 'cors';
|
|
import adminRoutes from './routes/admin.js';
|
|
import menuRoutes from './routes/menus.js';
|
|
import noticeRoutes from './routes/notices.js';
|
|
import bossCrystalRoutes from './routes/boss-crystal.js';
|
|
import characterRoutes from './routes/character.js';
|
|
import { sequelize } from './lib/db.js';
|
|
import './models/index.js';
|
|
|
|
const app = express();
|
|
const PORT = process.env.PORT || 3000;
|
|
|
|
app.use(cors({
|
|
origin: process.env.NODE_ENV === 'production'
|
|
? 'https://maple.caadiq.co.kr'
|
|
: 'http://localhost:5173',
|
|
credentials: true,
|
|
}));
|
|
app.use(express.json());
|
|
|
|
app.use('/api/menus', menuRoutes);
|
|
app.use('/api/notices', noticeRoutes);
|
|
app.use('/api/boss-crystal', bossCrystalRoutes);
|
|
app.use('/api/character', characterRoutes);
|
|
app.use('/api/admin', adminRoutes);
|
|
|
|
app.get('/api/health', (_req, res) => {
|
|
res.json({ status: 'ok' });
|
|
});
|
|
|
|
async function start() {
|
|
try {
|
|
await sequelize.authenticate();
|
|
console.log('DB 연결 성공');
|
|
await sequelize.sync();
|
|
console.log('테이블 동기화 완료');
|
|
|
|
app.listen(PORT, () => {
|
|
console.log(`서버 시작: http://localhost:${PORT}`);
|
|
});
|
|
} catch (err) {
|
|
console.error('서버 시작 실패:', err);
|
|
process.exit(1);
|
|
}
|
|
}
|
|
|
|
start();
|