백엔드: - Menu 모델 + admin/menus CRUD API + 공개 /api/menus 엔드포인트 - 정렬 변경(reorder) API 추가 (드래그앤드롭 대비) 프론트엔드: - 메뉴 삭제 기능 (편집 모드 폼 좌측 빨간 버튼) - ConfirmDialog를 공용 컴포넌트로 추출 - URL 입력을 prefix(/) 형태로 분리, 실제 URL 미리보기 표시 - 캐시 hit 시 폼 동기화 안되던 버그 수정 (useEffect로 데이터 sync) - 전역 button/a 태그에 cursor-pointer 적용 Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
42 lines
991 B
JavaScript
42 lines
991 B
JavaScript
import express from 'express';
|
|
import cors from 'cors';
|
|
import adminRoutes from './routes/admin.js';
|
|
import menuRoutes from './routes/menus.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/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();
|