# MNG 프로젝트 문서 > 📌 **MNG 관리자 패널 문서 (Laravel + Blade + Tailwind)** --- ## 📋 프로젝트 개요 **MNG**는 Filament 의존성 없이 AI 없이도 수정 가능한 Plain Laravel 관리자 패널입니다. **핵심 철학:** - **단순함 > 복잡함** - 복잡한 추상화 제거 - **수정 용이성** - AI 없이도 Blade 템플릿 수정 가능 - **코드 재사용** - admin/ 모델/서비스 복사 후 간소화 **기술 스택:** - Laravel 12 + PHP 8.4 - Blade + Tailwind CSS 3.x + HTMX - Sanctum 인증 (세션 + 토큰) - MySQL 8.0 (admin/api와 DB 공유) **도메인:** `mng.sam.kr` --- ## 🚀 빠른 시작 ### 개발 명령어 ```bash # 서버 실행 php artisan serve # Vite (Tailwind CSS) npm run dev # 마이그레이션 php artisan migrate # 코드 스타일 ./vendor/bin/pint ``` ### 로그인 - URL: `http://mng.sam.kr/login` - 계정: admin/ 또는 api/와 동일한 users 테이블 사용 --- ## 📖 개발 가이드 ### 현재 진행 상황 **완료된 Phase:** - ✅ **Phase 1**: 인증 시스템 (AuthService, LoginController, User 모델) - ✅ **Phase 2**: 레이아웃 구조 (sidebar + header, Pure Tailwind) - ✅ **Phase 3**: 테넌트 선택 기능 (TenantController, ViewServiceProvider) - ✅ **Phase 4**: 시스템 관리 메뉴 완성 (2025-11-24) - ✅ Phase 4-1: 테넌트 관리 (CRUD, 복구/영구삭제) - ✅ Phase 4-2: 역할 관리 (CRUD, 권한 할당, Spatie Permission) - ✅ Phase 4-3: 부서 관리 (CRUD, 계층 구조) - ✅ Phase 4-4: 사용자 관리 (CRUD, 복구/영구삭제) - ✅ Phase 4-5: 메뉴 관리 (CRUD, 트리 구조, 토글) **다음 Phase:** - 🎯 **Phase 5**: 제품/자재 관리 - [ ] 제품 관리 (Products) - [ ] 자재 관리 (Materials) - [ ] 카테고리 관리 (Categories) - ⏳ **Phase 6**: BOM 관리 - [ ] BOM 구조 (Bill of Materials) - [ ] BOM 버전 관리 - ⏳ **Phase 7**: 시스템 관리 - [ ] 감사 로그 (Audit Logs) - [ ] 시스템 설정 (Settings) ### 프로젝트 문서 **MNG 프로젝트:** - **[🚨 MNG_CRITICAL_RULES.md](./MNG_CRITICAL_RULES.md)** - 절대 위반 금지 규칙 (필독!) - **[📋 TABLE_LAYOUT_STANDARD.md](./TABLE_LAYOUT_STANDARD.md)** - 테이블 페이지 레이아웃 표준 (권한 관리 페이지 기반) - **[CURRENT_WORKS.md](../CURRENT_WORKS.md)** - 현재 작업 진행 상황 - **[TROUBLESHOOTING.md](./TROUBLESHOOTING.md)** - 트러블슈팅 가이드 - **[MIGRATION_PLAN.md](./MIGRATION_PLAN.md)** - Admin → MNG 마이그레이션 계획 (Phase 4) - **[MNG_PROJECT_PLAN.md](./MNG_PROJECT_PLAN.md)** - 전체 프로젝트 계획 - **[DEV_PROCESS.md](./DEV_PROCESS.md)** - 개발 프로세스 (HTMX + API 방식) - **[SETUP_GUIDE.md](./SETUP_GUIDE.md)** - 초기 설정 가이드 - **[HTMX_API_PATTERN.md](./HTMX_API_PATTERN.md)** - HTMX + API 패턴 가이드 - **[LAYOUT_PATTERN.md](./LAYOUT_PATTERN.md)** - 레이아웃 패턴 가이드 - **[kma-weather-api.md](./kma-weather-api.md)** - 기상청 날씨 API 연동 가이드 (발표시각별 데이터 범위 주의) **SAM 공통 문서:** - **[📊 ../../docs/specs/database-schema.md](../../docs/specs/database-schema.md)** - 데이터베이스 스키마 (Phase 4: 8개 테이블 상세) - **[../../docs/INDEX.md](../../docs/INDEX.md)** - SAM 전체 문서 네비게이션 - **[../../docs/reference/architecture.md](../../docs/reference/architecture.md)** - SAM 아키텍처 --- ## 🏗️ 아키텍처 ### 디렉토리 구조 ``` mng/ ├── app/ │ ├── Http/ │ │ ├── Controllers/ │ │ │ ├── Auth/ # 인증 컨트롤러 │ │ │ └── TenantController.php │ │ ├── Requests/ # FormRequest (검증) │ │ └── Middleware/ │ ├── Services/ # 비즈니스 로직 (Service-First) │ ├── Models/ # Eloquent 모델 (독립 운영) │ │ ├── User.php │ │ └── Tenant.php │ └── Providers/ │ └── ViewServiceProvider.php ├── routes/ │ ├── web.php # Blade 라우트 │ └── api.php # Admin API (향후) ├── resources/ │ └── views/ │ ├── layouts/ │ │ └── app.blade.php # 마스터 레이아웃 │ ├── partials/ │ │ ├── sidebar.blade.php │ │ ├── header.blade.php │ │ └── tenant-selector.blade.php │ ├── auth/ # 로그인 화면 │ └── dashboard/ # 대시보드 ├── database/ │ └── migrations/ └── docs/ # 프로젝트 문서 └── INDEX.md # 이 문서 ``` ### 레이아웃 구조 ``` ┌─────────────────────────────────────┐ │ ┌──────┐ ┌─────────────────────┐ │ │ │ │ │ Header (64px) │ │ │ │ Side │ ├─────────────────────┤ │ │ │ bar │ │ │ │ │ │(256) │ │ Main Content │ │ │ │ │ │ │ │ │ └──────┘ └─────────────────────┘ │ └─────────────────────────────────────┘ ``` **특징:** - 좌측 사이드바: 256px 고정 - 상단 헤더: 64px 고정 - Pure Tailwind CSS (DaisyUI 제거됨 - oklch() 호환성 문제) - HTMX 기반 인터랙션 (Alpine.js 제거) - 반응형: 추후 모바일 대응 예정 --- ## 🔄 Admin → MNG 마이그레이션 전략 ### 모델 복사 프로세스 ```bash # 1. admin/ 모델 복사 cp -r admin/app/Models/* mng/app/Models/ # 2. Filament 코드 제거 # - form(), table(), getNavigationLabel() 등 제거 # - 순수 Eloquent 관계만 유지 # 3. Traits 복사 cp admin/app/Traits/BelongsToTenant.php mng/app/Traits/ cp admin/app/Traits/HasAuditLog.php mng/app/Traits/ ``` ### Blade + HTMX 작성 원칙 ```blade {{-- ✅ GOOD: HTMX로 API 호출 --}}
{{-- ❌ BAD: 과도한 추상화 --}}