2025-11-21 15:00:30 +09:00
|
|
|
<?php
|
|
|
|
|
|
2025-12-14 02:13:20 +09:00
|
|
|
use App\Http\Controllers\Api\GeminiController;
|
feat: [pm] 프로젝트 진행 관리 시스템 구현
- Models: AdminPmProject, AdminPmTask, AdminPmIssue
- Services: ProjectService, TaskService, IssueService, ImportService
- API Controllers: ProjectController, TaskController, IssueController, ImportController
- FormRequests: Store/Update/BulkAction 요청 검증
- Views: 대시보드, 프로젝트 CRUD, JSON Import 화면
- Routes: API 42개 + Web 6개 엔드포인트
주요 기능:
- 프로젝트/작업/이슈 계층 구조 관리
- 상태 변경, 우선순위, 마감일 추적
- 작업 순서 드래그앤드롭 (reorder API)
- JSON Import로 일괄 등록
- Soft Delete 및 복원
2025-11-28 08:49:30 +09:00
|
|
|
use App\Http\Controllers\Api\Admin\BoardController;
|
2025-12-01 15:24:49 +09:00
|
|
|
use App\Http\Controllers\Api\Admin\DailyLogController;
|
2025-11-24 16:52:23 +09:00
|
|
|
use App\Http\Controllers\Api\Admin\DepartmentController;
|
2025-12-02 21:41:15 +09:00
|
|
|
use App\Http\Controllers\Api\Admin\GlobalMenuController;
|
2025-11-24 22:02:09 +09:00
|
|
|
use App\Http\Controllers\Api\Admin\MenuController;
|
2025-11-25 11:05:57 +09:00
|
|
|
use App\Http\Controllers\Api\Admin\PermissionController;
|
feat: [pm] 프로젝트 진행 관리 시스템 구현
- Models: AdminPmProject, AdminPmTask, AdminPmIssue
- Services: ProjectService, TaskService, IssueService, ImportService
- API Controllers: ProjectController, TaskController, IssueController, ImportController
- FormRequests: Store/Update/BulkAction 요청 검증
- Views: 대시보드, 프로젝트 CRUD, JSON Import 화면
- Routes: API 42개 + Web 6개 엔드포인트
주요 기능:
- 프로젝트/작업/이슈 계층 구조 관리
- 상태 변경, 우선순위, 마감일 추적
- 작업 순서 드래그앤드롭 (reorder API)
- JSON Import로 일괄 등록
- Soft Delete 및 복원
2025-11-28 08:49:30 +09:00
|
|
|
use App\Http\Controllers\Api\Admin\ProjectManagement\ImportController as PmImportController;
|
|
|
|
|
use App\Http\Controllers\Api\Admin\ProjectManagement\IssueController as PmIssueController;
|
|
|
|
|
use App\Http\Controllers\Api\Admin\ProjectManagement\ProjectController as PmProjectController;
|
|
|
|
|
use App\Http\Controllers\Api\Admin\ProjectManagement\TaskController as PmTaskController;
|
feat(quote-formulas): 견적수식 관리 기능 구현
## 구현 내용
### 모델 (5개)
- QuoteFormulaCategory: 수식 카테고리
- QuoteFormula: 수식 정의 (input/calculation/range/mapping)
- QuoteFormulaRange: 범위별 값 정의
- QuoteFormulaMapping: 매핑 테이블
- QuoteFormulaItem: 수식-품목 연결
### 서비스 (3개)
- QuoteFormulaCategoryService: 카테고리 CRUD
- QuoteFormulaService: 수식 CRUD, 복제, 재정렬
- FormulaEvaluatorService: 수식 계산 엔진
- 지원 함수: SUM, ROUND, CEIL, FLOOR, ABS, MIN, MAX, IF, AND, OR, NOT
### API Controller (2개)
- QuoteFormulaCategoryController: 카테고리 API (11개 엔드포인트)
- QuoteFormulaController: 수식 API (16개 엔드포인트)
### FormRequest (4개)
- Store/Update QuoteFormulaCategoryRequest
- Store/Update QuoteFormulaRequest
### Blade Views (8개)
- 수식 목록/추가/수정/시뮬레이터
- 카테고리 목록/추가/수정
- HTMX 테이블 partial
### 라우트
- API: 27개 엔드포인트
- Web: 7개 라우트
2025-12-04 14:00:24 +09:00
|
|
|
use App\Http\Controllers\Api\Admin\Quote\QuoteFormulaCategoryController;
|
|
|
|
|
use App\Http\Controllers\Api\Admin\Quote\QuoteFormulaController;
|
2025-11-24 16:36:02 +09:00
|
|
|
use App\Http\Controllers\Api\Admin\RoleController;
|
2025-11-25 15:21:48 +09:00
|
|
|
use App\Http\Controllers\Api\Admin\RolePermissionController;
|
2025-11-21 15:00:30 +09:00
|
|
|
use App\Http\Controllers\Api\Admin\TenantController;
|
2025-12-09 23:13:27 +09:00
|
|
|
use App\Http\Controllers\Api\Admin\ItemFieldController;
|
2025-11-24 18:49:02 +09:00
|
|
|
use App\Http\Controllers\Api\Admin\UserController;
|
2025-11-21 15:00:30 +09:00
|
|
|
use Illuminate\Support\Facades\Route;
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
| API Routes
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
|
| HTMX 요청 시 HTML 반환, 일반 요청 시 JSON 반환
|
2025-11-28 18:08:32 +09:00
|
|
|
| - auth: 기본 인증 확인
|
|
|
|
|
| - hq.member: 본사(HQ) 테넌트 소속 확인
|
|
|
|
|
| - super.admin: 슈퍼관리자 전용 (복구, 영구삭제)
|
2025-11-21 15:00:30 +09:00
|
|
|
*/
|
|
|
|
|
|
2025-11-28 18:08:32 +09:00
|
|
|
Route::middleware(['web', 'auth', 'hq.member'])->prefix('admin')->name('api.admin.')->group(function () {
|
2025-11-21 15:00:30 +09:00
|
|
|
|
|
|
|
|
// 테넌트 관리 API
|
|
|
|
|
Route::prefix('tenants')->name('tenants.')->group(function () {
|
2025-11-24 11:17:31 +09:00
|
|
|
// 고정 경로는 먼저 정의
|
|
|
|
|
Route::get('/stats', [TenantController::class, 'stats'])->name('stats');
|
|
|
|
|
|
|
|
|
|
// 동적 경로는 나중에 정의
|
2025-11-21 15:00:30 +09:00
|
|
|
Route::get('/', [TenantController::class, 'index'])->name('index');
|
|
|
|
|
Route::post('/', [TenantController::class, 'store'])->name('store');
|
|
|
|
|
Route::get('/{id}', [TenantController::class, 'show'])->name('show');
|
|
|
|
|
Route::put('/{id}', [TenantController::class, 'update'])->name('update');
|
|
|
|
|
Route::delete('/{id}', [TenantController::class, 'destroy'])->name('destroy');
|
|
|
|
|
|
2025-12-01 00:13:12 +09:00
|
|
|
// 복원 (일반관리자 가능)
|
|
|
|
|
Route::post('/{id}/restore', [TenantController::class, 'restore'])->name('restore');
|
|
|
|
|
|
|
|
|
|
// 슈퍼관리자 전용 액션 (영구삭제)
|
2025-11-28 18:08:32 +09:00
|
|
|
Route::middleware('super.admin')->group(function () {
|
|
|
|
|
Route::delete('/{id}/force', [TenantController::class, 'forceDestroy'])->name('forceDestroy');
|
|
|
|
|
});
|
2025-11-27 19:11:32 +09:00
|
|
|
|
|
|
|
|
// 모달 관련 API
|
|
|
|
|
Route::get('/{id}/modal', [TenantController::class, 'modal'])->name('modal');
|
|
|
|
|
Route::get('/{id}/users', [TenantController::class, 'users'])->name('users');
|
|
|
|
|
Route::get('/{id}/departments', [TenantController::class, 'departments'])->name('departments');
|
|
|
|
|
Route::get('/{id}/roles', [TenantController::class, 'roles'])->name('roles');
|
|
|
|
|
Route::get('/{id}/menus', [TenantController::class, 'menus'])->name('menus');
|
|
|
|
|
Route::get('/{id}/subscription', [TenantController::class, 'subscription'])->name('subscription');
|
2025-11-21 15:00:30 +09:00
|
|
|
});
|
2025-11-24 16:36:02 +09:00
|
|
|
|
|
|
|
|
// 역할 관리 API
|
|
|
|
|
Route::prefix('roles')->name('roles.')->group(function () {
|
|
|
|
|
Route::get('/', [RoleController::class, 'index'])->name('index');
|
|
|
|
|
Route::post('/', [RoleController::class, 'store'])->name('store');
|
|
|
|
|
Route::get('/{id}', [RoleController::class, 'show'])->name('show');
|
|
|
|
|
Route::put('/{id}', [RoleController::class, 'update'])->name('update');
|
|
|
|
|
Route::delete('/{id}', [RoleController::class, 'destroy'])->name('destroy');
|
|
|
|
|
});
|
2025-11-24 16:52:23 +09:00
|
|
|
|
|
|
|
|
// 부서 관리 API
|
|
|
|
|
Route::prefix('departments')->name('departments.')->group(function () {
|
|
|
|
|
Route::get('/', [DepartmentController::class, 'index'])->name('index');
|
|
|
|
|
Route::post('/', [DepartmentController::class, 'store'])->name('store');
|
|
|
|
|
Route::get('/{id}', [DepartmentController::class, 'show'])->name('show');
|
|
|
|
|
Route::put('/{id}', [DepartmentController::class, 'update'])->name('update');
|
|
|
|
|
Route::delete('/{id}', [DepartmentController::class, 'destroy'])->name('destroy');
|
2025-11-28 18:08:32 +09:00
|
|
|
|
2025-12-01 00:13:12 +09:00
|
|
|
// 복원 (일반관리자 가능)
|
|
|
|
|
Route::post('/{id}/restore', [DepartmentController::class, 'restore'])->name('restore');
|
|
|
|
|
|
|
|
|
|
// 슈퍼관리자 전용 액션 (영구삭제)
|
2025-11-28 18:08:32 +09:00
|
|
|
Route::middleware('super.admin')->group(function () {
|
|
|
|
|
Route::delete('/{id}/force', [DepartmentController::class, 'forceDelete'])->name('forceDelete');
|
|
|
|
|
});
|
2025-11-24 16:52:23 +09:00
|
|
|
});
|
2025-11-24 18:49:02 +09:00
|
|
|
|
|
|
|
|
// 사용자 관리 API
|
|
|
|
|
Route::prefix('users')->name('users.')->group(function () {
|
|
|
|
|
Route::get('/', [UserController::class, 'index'])->name('index');
|
|
|
|
|
Route::post('/', [UserController::class, 'store'])->name('store');
|
|
|
|
|
Route::get('/{id}', [UserController::class, 'show'])->name('show');
|
|
|
|
|
Route::put('/{id}', [UserController::class, 'update'])->name('update');
|
|
|
|
|
Route::delete('/{id}', [UserController::class, 'destroy'])->name('destroy');
|
2025-11-24 19:30:36 +09:00
|
|
|
|
2025-12-01 00:13:12 +09:00
|
|
|
// 복원 (일반관리자 가능 - 슈퍼관리자 복원은 컨트롤러에서 차단)
|
|
|
|
|
Route::post('/{id}/restore', [UserController::class, 'restore'])->name('restore');
|
|
|
|
|
|
2025-12-01 10:50:16 +09:00
|
|
|
// 비밀번호 초기화 (임의 비밀번호 생성 + 메일 발송)
|
|
|
|
|
Route::post('/{id}/reset-password', [UserController::class, 'resetPassword'])->name('resetPassword');
|
|
|
|
|
|
2025-12-01 00:13:12 +09:00
|
|
|
// 슈퍼관리자 전용 액션 (영구삭제)
|
2025-11-28 18:08:32 +09:00
|
|
|
Route::middleware('super.admin')->group(function () {
|
|
|
|
|
Route::delete('/{id}/force', [UserController::class, 'forceDestroy'])->name('forceDestroy');
|
|
|
|
|
});
|
2025-11-27 20:05:27 +09:00
|
|
|
|
|
|
|
|
// 모달 관련 API
|
|
|
|
|
Route::get('/{id}/modal', [UserController::class, 'modal'])->name('modal');
|
2025-11-24 18:49:02 +09:00
|
|
|
});
|
2025-11-24 22:02:09 +09:00
|
|
|
|
|
|
|
|
// 메뉴 관리 API
|
|
|
|
|
Route::prefix('menus')->name('menus.')->group(function () {
|
|
|
|
|
// 고정 경로는 먼저 정의
|
|
|
|
|
Route::get('/tree', [MenuController::class, 'tree'])->name('tree');
|
2025-12-01 15:24:49 +09:00
|
|
|
Route::post('/reorder', [MenuController::class, 'reorder'])->name('reorder');
|
2025-12-01 15:35:49 +09:00
|
|
|
Route::post('/move', [MenuController::class, 'move'])->name('move');
|
2025-12-02 19:16:23 +09:00
|
|
|
Route::get('/available-global', [MenuController::class, 'availableGlobal'])->name('availableGlobal');
|
|
|
|
|
Route::post('/copy-from-global', [MenuController::class, 'copyFromGlobal'])->name('copyFromGlobal');
|
2025-11-24 22:02:09 +09:00
|
|
|
|
|
|
|
|
// 동적 경로는 나중에 정의
|
|
|
|
|
Route::get('/', [MenuController::class, 'index'])->name('index');
|
|
|
|
|
Route::post('/', [MenuController::class, 'store'])->name('store');
|
|
|
|
|
Route::get('/{id}', [MenuController::class, 'show'])->name('show');
|
|
|
|
|
Route::put('/{id}', [MenuController::class, 'update'])->name('update');
|
|
|
|
|
Route::delete('/{id}', [MenuController::class, 'destroy'])->name('destroy');
|
|
|
|
|
|
2025-12-01 00:13:12 +09:00
|
|
|
// 복원 (일반관리자 가능)
|
|
|
|
|
Route::post('/{id}/restore', [MenuController::class, 'restore'])->name('restore');
|
|
|
|
|
|
|
|
|
|
// 슈퍼관리자 전용 액션 (영구삭제)
|
2025-11-28 18:08:32 +09:00
|
|
|
Route::middleware('super.admin')->group(function () {
|
|
|
|
|
Route::delete('/{id}/force', [MenuController::class, 'forceDestroy'])->name('forceDestroy');
|
|
|
|
|
});
|
|
|
|
|
|
2025-11-24 22:02:09 +09:00
|
|
|
// 추가 액션
|
|
|
|
|
Route::post('/{id}/toggle-active', [MenuController::class, 'toggleActive'])->name('toggleActive');
|
|
|
|
|
Route::post('/{id}/toggle-hidden', [MenuController::class, 'toggleHidden'])->name('toggleHidden');
|
|
|
|
|
});
|
2025-11-25 11:05:57 +09:00
|
|
|
|
2025-12-02 21:41:15 +09:00
|
|
|
// 글로벌 메뉴 관리 API (슈퍼관리자 전용)
|
|
|
|
|
Route::middleware('super.admin')->prefix('global-menus')->name('global-menus.')->group(function () {
|
|
|
|
|
// 고정 경로
|
|
|
|
|
Route::post('/reorder', [GlobalMenuController::class, 'reorder'])->name('reorder');
|
|
|
|
|
|
|
|
|
|
// 기본 CRUD
|
|
|
|
|
Route::get('/', [GlobalMenuController::class, 'index'])->name('index');
|
|
|
|
|
Route::post('/', [GlobalMenuController::class, 'store'])->name('store');
|
|
|
|
|
Route::get('/{id}', [GlobalMenuController::class, 'show'])->name('show');
|
|
|
|
|
Route::put('/{id}', [GlobalMenuController::class, 'update'])->name('update');
|
|
|
|
|
Route::delete('/{id}', [GlobalMenuController::class, 'destroy'])->name('destroy');
|
|
|
|
|
|
|
|
|
|
// 복원
|
|
|
|
|
Route::post('/{id}/restore', [GlobalMenuController::class, 'restore'])->name('restore');
|
|
|
|
|
|
|
|
|
|
// 영구삭제
|
|
|
|
|
Route::delete('/{id}/force', [GlobalMenuController::class, 'forceDestroy'])->name('forceDestroy');
|
|
|
|
|
|
|
|
|
|
// 추가 액션
|
|
|
|
|
Route::post('/{id}/toggle-active', [GlobalMenuController::class, 'toggleActive'])->name('toggleActive');
|
|
|
|
|
Route::post('/{id}/toggle-hidden', [GlobalMenuController::class, 'toggleHidden'])->name('toggleHidden');
|
|
|
|
|
});
|
|
|
|
|
|
2025-11-25 11:05:57 +09:00
|
|
|
// 권한 관리 API
|
|
|
|
|
Route::prefix('permissions')->name('permissions.')->group(function () {
|
|
|
|
|
Route::get('/', [PermissionController::class, 'index'])->name('index');
|
|
|
|
|
Route::post('/', [PermissionController::class, 'store'])->name('store');
|
|
|
|
|
Route::get('/{id}', [PermissionController::class, 'show'])->name('show');
|
|
|
|
|
Route::put('/{id}', [PermissionController::class, 'update'])->name('update');
|
|
|
|
|
Route::delete('/{id}', [PermissionController::class, 'destroy'])->name('destroy');
|
|
|
|
|
});
|
2025-11-25 15:21:48 +09:00
|
|
|
|
feat: [pm] 프로젝트 진행 관리 시스템 구현
- Models: AdminPmProject, AdminPmTask, AdminPmIssue
- Services: ProjectService, TaskService, IssueService, ImportService
- API Controllers: ProjectController, TaskController, IssueController, ImportController
- FormRequests: Store/Update/BulkAction 요청 검증
- Views: 대시보드, 프로젝트 CRUD, JSON Import 화면
- Routes: API 42개 + Web 6개 엔드포인트
주요 기능:
- 프로젝트/작업/이슈 계층 구조 관리
- 상태 변경, 우선순위, 마감일 추적
- 작업 순서 드래그앤드롭 (reorder API)
- JSON Import로 일괄 등록
- Soft Delete 및 복원
2025-11-28 08:49:30 +09:00
|
|
|
// 시스템 게시판 관리 API
|
|
|
|
|
Route::prefix('boards')->name('boards.')->group(function () {
|
|
|
|
|
// 고정 경로는 먼저 정의
|
|
|
|
|
Route::get('/stats', [BoardController::class, 'stats'])->name('stats');
|
2025-12-01 23:27:37 +09:00
|
|
|
Route::get('/templates', [BoardController::class, 'templates'])->name('templates');
|
|
|
|
|
Route::get('/templates/{type}/{key}', [BoardController::class, 'templateDetail'])->name('templateDetail');
|
|
|
|
|
Route::get('/tenants', [BoardController::class, 'tenants'])->name('tenants');
|
|
|
|
|
Route::post('/check-tenant-code', [BoardController::class, 'checkTenantCode'])->name('checkTenantCode');
|
|
|
|
|
Route::post('/create-from-template', [BoardController::class, 'storeFromTemplate'])->name('storeFromTemplate');
|
feat: [pm] 프로젝트 진행 관리 시스템 구현
- Models: AdminPmProject, AdminPmTask, AdminPmIssue
- Services: ProjectService, TaskService, IssueService, ImportService
- API Controllers: ProjectController, TaskController, IssueController, ImportController
- FormRequests: Store/Update/BulkAction 요청 검증
- Views: 대시보드, 프로젝트 CRUD, JSON Import 화면
- Routes: API 42개 + Web 6개 엔드포인트
주요 기능:
- 프로젝트/작업/이슈 계층 구조 관리
- 상태 변경, 우선순위, 마감일 추적
- 작업 순서 드래그앤드롭 (reorder API)
- JSON Import로 일괄 등록
- Soft Delete 및 복원
2025-11-28 08:49:30 +09:00
|
|
|
|
|
|
|
|
// 기본 CRUD
|
|
|
|
|
Route::get('/', [BoardController::class, 'index'])->name('index');
|
|
|
|
|
Route::post('/', [BoardController::class, 'store'])->name('store');
|
|
|
|
|
Route::get('/{id}', [BoardController::class, 'show'])->name('show');
|
|
|
|
|
Route::put('/{id}', [BoardController::class, 'update'])->name('update');
|
|
|
|
|
Route::delete('/{id}', [BoardController::class, 'destroy'])->name('destroy');
|
|
|
|
|
|
2025-12-01 00:13:12 +09:00
|
|
|
// 복원 (일반관리자 가능)
|
|
|
|
|
Route::post('/{id}/restore', [BoardController::class, 'restore'])->name('restore');
|
|
|
|
|
|
|
|
|
|
// 슈퍼관리자 전용 액션 (영구삭제)
|
2025-11-28 18:08:32 +09:00
|
|
|
Route::middleware('super.admin')->group(function () {
|
|
|
|
|
Route::delete('/{id}/force', [BoardController::class, 'forceDestroy'])->name('forceDestroy');
|
|
|
|
|
});
|
|
|
|
|
|
feat: [pm] 프로젝트 진행 관리 시스템 구현
- Models: AdminPmProject, AdminPmTask, AdminPmIssue
- Services: ProjectService, TaskService, IssueService, ImportService
- API Controllers: ProjectController, TaskController, IssueController, ImportController
- FormRequests: Store/Update/BulkAction 요청 검증
- Views: 대시보드, 프로젝트 CRUD, JSON Import 화면
- Routes: API 42개 + Web 6개 엔드포인트
주요 기능:
- 프로젝트/작업/이슈 계층 구조 관리
- 상태 변경, 우선순위, 마감일 추적
- 작업 순서 드래그앤드롭 (reorder API)
- JSON Import로 일괄 등록
- Soft Delete 및 복원
2025-11-28 08:49:30 +09:00
|
|
|
// 추가 액션
|
|
|
|
|
Route::post('/{id}/toggle-active', [BoardController::class, 'toggleActive'])->name('toggleActive');
|
|
|
|
|
|
|
|
|
|
// 필드 관리 API
|
|
|
|
|
Route::get('/{id}/fields', [BoardController::class, 'fields'])->name('fields');
|
|
|
|
|
Route::post('/{id}/fields', [BoardController::class, 'storeField'])->name('storeField');
|
|
|
|
|
Route::put('/{id}/fields/{fieldId}', [BoardController::class, 'updateField'])->name('updateField');
|
|
|
|
|
Route::delete('/{id}/fields/{fieldId}', [BoardController::class, 'destroyField'])->name('destroyField');
|
|
|
|
|
Route::post('/{id}/fields/reorder', [BoardController::class, 'reorderFields'])->name('reorderFields');
|
|
|
|
|
});
|
|
|
|
|
|
2025-11-25 15:21:48 +09:00
|
|
|
// 역할 권한 관리 API
|
|
|
|
|
Route::prefix('role-permissions')->name('role-permissions.')->group(function () {
|
|
|
|
|
Route::get('/matrix', [RolePermissionController::class, 'getMatrix'])->name('matrix');
|
|
|
|
|
Route::post('/toggle', [RolePermissionController::class, 'toggle'])->name('toggle');
|
|
|
|
|
Route::post('/allow-all', [RolePermissionController::class, 'allowAll'])->name('allowAll');
|
|
|
|
|
Route::post('/deny-all', [RolePermissionController::class, 'denyAll'])->name('denyAll');
|
2025-11-25 20:53:53 +09:00
|
|
|
Route::post('/reset', [RolePermissionController::class, 'reset'])->name('reset');
|
2025-11-25 15:21:48 +09:00
|
|
|
});
|
2025-11-25 15:32:58 +09:00
|
|
|
|
|
|
|
|
// 부서 권한 관리 API
|
|
|
|
|
Route::prefix('department-permissions')->name('department-permissions.')->group(function () {
|
|
|
|
|
Route::get('/matrix', [\App\Http\Controllers\Api\Admin\DepartmentPermissionController::class, 'getMatrix'])->name('matrix');
|
|
|
|
|
Route::post('/toggle', [\App\Http\Controllers\Api\Admin\DepartmentPermissionController::class, 'toggle'])->name('toggle');
|
|
|
|
|
Route::post('/allow-all', [\App\Http\Controllers\Api\Admin\DepartmentPermissionController::class, 'allowAll'])->name('allowAll');
|
|
|
|
|
Route::post('/deny-all', [\App\Http\Controllers\Api\Admin\DepartmentPermissionController::class, 'denyAll'])->name('denyAll');
|
2025-11-25 20:53:53 +09:00
|
|
|
Route::post('/reset', [\App\Http\Controllers\Api\Admin\DepartmentPermissionController::class, 'reset'])->name('reset');
|
2025-11-25 15:32:58 +09:00
|
|
|
});
|
2025-11-26 20:28:07 +09:00
|
|
|
|
|
|
|
|
// 개인 권한 관리 API
|
|
|
|
|
Route::prefix('user-permissions')->name('user-permissions.')->group(function () {
|
|
|
|
|
Route::get('/matrix', [\App\Http\Controllers\Api\Admin\UserPermissionController::class, 'getMatrix'])->name('matrix');
|
|
|
|
|
Route::post('/toggle', [\App\Http\Controllers\Api\Admin\UserPermissionController::class, 'toggle'])->name('toggle');
|
|
|
|
|
Route::post('/allow-all', [\App\Http\Controllers\Api\Admin\UserPermissionController::class, 'allowAll'])->name('allowAll');
|
|
|
|
|
Route::post('/deny-all', [\App\Http\Controllers\Api\Admin\UserPermissionController::class, 'denyAll'])->name('denyAll');
|
|
|
|
|
Route::post('/reset', [\App\Http\Controllers\Api\Admin\UserPermissionController::class, 'reset'])->name('reset');
|
|
|
|
|
});
|
2025-11-26 21:42:51 +09:00
|
|
|
|
|
|
|
|
// 권한 분석 API
|
|
|
|
|
Route::prefix('permission-analyze')->name('permission-analyze.')->group(function () {
|
|
|
|
|
Route::get('/menu-tree', [\App\Http\Controllers\Api\Admin\PermissionAnalyzeController::class, 'menuTree'])->name('menuTree');
|
|
|
|
|
Route::get('/analyze', [\App\Http\Controllers\Api\Admin\PermissionAnalyzeController::class, 'analyzeMenu'])->name('analyze');
|
|
|
|
|
Route::get('/trace', [\App\Http\Controllers\Api\Admin\PermissionAnalyzeController::class, 'traceUsers'])->name('trace');
|
|
|
|
|
Route::get('/export-csv', [\App\Http\Controllers\Api\Admin\PermissionAnalyzeController::class, 'exportCsv'])->name('exportCsv');
|
|
|
|
|
Route::post('/recalculate', [\App\Http\Controllers\Api\Admin\PermissionAnalyzeController::class, 'recalculate'])->name('recalculate');
|
|
|
|
|
});
|
2025-11-26 22:23:37 +09:00
|
|
|
|
|
|
|
|
// 삭제된 데이터 백업 API
|
|
|
|
|
Route::prefix('archived-records')->name('archived-records.')->group(function () {
|
|
|
|
|
Route::get('/stats', [\App\Http\Controllers\Api\Admin\ArchivedRecordController::class, 'stats'])->name('stats');
|
|
|
|
|
Route::get('/', [\App\Http\Controllers\Api\Admin\ArchivedRecordController::class, 'index'])->name('index');
|
|
|
|
|
Route::get('/{id}', [\App\Http\Controllers\Api\Admin\ArchivedRecordController::class, 'show'])->name('show');
|
|
|
|
|
});
|
feat: [pm] 프로젝트 진행 관리 시스템 구현
- Models: AdminPmProject, AdminPmTask, AdminPmIssue
- Services: ProjectService, TaskService, IssueService, ImportService
- API Controllers: ProjectController, TaskController, IssueController, ImportController
- FormRequests: Store/Update/BulkAction 요청 검증
- Views: 대시보드, 프로젝트 CRUD, JSON Import 화면
- Routes: API 42개 + Web 6개 엔드포인트
주요 기능:
- 프로젝트/작업/이슈 계층 구조 관리
- 상태 변경, 우선순위, 마감일 추적
- 작업 순서 드래그앤드롭 (reorder API)
- JSON Import로 일괄 등록
- Soft Delete 및 복원
2025-11-28 08:49:30 +09:00
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
| 프로젝트 관리 API
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
*/
|
|
|
|
|
Route::prefix('pm')->name('pm.')->group(function () {
|
|
|
|
|
|
|
|
|
|
// 프로젝트 관리 API
|
|
|
|
|
Route::prefix('projects')->name('projects.')->group(function () {
|
|
|
|
|
// 고정 경로
|
|
|
|
|
Route::get('/stats', [PmProjectController::class, 'stats'])->name('stats');
|
|
|
|
|
Route::get('/dashboard', [PmProjectController::class, 'dashboard'])->name('dashboard');
|
|
|
|
|
Route::get('/dropdown', [PmProjectController::class, 'dropdown'])->name('dropdown');
|
|
|
|
|
|
|
|
|
|
// 기본 CRUD
|
|
|
|
|
Route::get('/', [PmProjectController::class, 'index'])->name('index');
|
|
|
|
|
Route::post('/', [PmProjectController::class, 'store'])->name('store');
|
|
|
|
|
Route::get('/{id}', [PmProjectController::class, 'show'])->name('show');
|
|
|
|
|
Route::put('/{id}', [PmProjectController::class, 'update'])->name('update');
|
|
|
|
|
Route::delete('/{id}', [PmProjectController::class, 'destroy'])->name('destroy');
|
|
|
|
|
|
2025-12-01 00:13:12 +09:00
|
|
|
// 복원 (일반관리자 가능)
|
|
|
|
|
Route::post('/{id}/restore', [PmProjectController::class, 'restore'])->name('restore');
|
|
|
|
|
|
|
|
|
|
// 슈퍼관리자 전용 액션 (영구삭제)
|
2025-11-28 18:08:32 +09:00
|
|
|
Route::middleware('super.admin')->group(function () {
|
|
|
|
|
Route::delete('/{id}/force', [PmProjectController::class, 'forceDestroy'])->name('forceDestroy');
|
|
|
|
|
});
|
|
|
|
|
|
feat: [pm] 프로젝트 진행 관리 시스템 구현
- Models: AdminPmProject, AdminPmTask, AdminPmIssue
- Services: ProjectService, TaskService, IssueService, ImportService
- API Controllers: ProjectController, TaskController, IssueController, ImportController
- FormRequests: Store/Update/BulkAction 요청 검증
- Views: 대시보드, 프로젝트 CRUD, JSON Import 화면
- Routes: API 42개 + Web 6개 엔드포인트
주요 기능:
- 프로젝트/작업/이슈 계층 구조 관리
- 상태 변경, 우선순위, 마감일 추적
- 작업 순서 드래그앤드롭 (reorder API)
- JSON Import로 일괄 등록
- Soft Delete 및 복원
2025-11-28 08:49:30 +09:00
|
|
|
// 추가 액션
|
|
|
|
|
Route::post('/{id}/status', [PmProjectController::class, 'changeStatus'])->name('changeStatus');
|
|
|
|
|
Route::post('/{id}/duplicate', [PmProjectController::class, 'duplicate'])->name('duplicate');
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// 작업 관리 API
|
|
|
|
|
Route::prefix('tasks')->name('tasks.')->group(function () {
|
|
|
|
|
// 고정 경로
|
|
|
|
|
Route::get('/urgent', [PmTaskController::class, 'urgent'])->name('urgent');
|
|
|
|
|
Route::post('/bulk', [PmTaskController::class, 'bulk'])->name('bulk');
|
|
|
|
|
|
|
|
|
|
// 기본 CRUD
|
|
|
|
|
Route::get('/', [PmTaskController::class, 'index'])->name('index');
|
|
|
|
|
Route::post('/', [PmTaskController::class, 'store'])->name('store');
|
|
|
|
|
Route::get('/{id}', [PmTaskController::class, 'show'])->name('show');
|
|
|
|
|
Route::put('/{id}', [PmTaskController::class, 'update'])->name('update');
|
|
|
|
|
Route::delete('/{id}', [PmTaskController::class, 'destroy'])->name('destroy');
|
|
|
|
|
|
2025-12-01 00:13:12 +09:00
|
|
|
// 복원 (일반관리자 가능)
|
|
|
|
|
Route::post('/{id}/restore', [PmTaskController::class, 'restore'])->name('restore');
|
|
|
|
|
|
|
|
|
|
// 슈퍼관리자 전용 액션 (영구삭제)
|
2025-11-28 18:08:32 +09:00
|
|
|
Route::middleware('super.admin')->group(function () {
|
|
|
|
|
Route::delete('/{id}/force', [PmTaskController::class, 'forceDestroy'])->name('forceDestroy');
|
|
|
|
|
});
|
|
|
|
|
|
feat: [pm] 프로젝트 진행 관리 시스템 구현
- Models: AdminPmProject, AdminPmTask, AdminPmIssue
- Services: ProjectService, TaskService, IssueService, ImportService
- API Controllers: ProjectController, TaskController, IssueController, ImportController
- FormRequests: Store/Update/BulkAction 요청 검증
- Views: 대시보드, 프로젝트 CRUD, JSON Import 화면
- Routes: API 42개 + Web 6개 엔드포인트
주요 기능:
- 프로젝트/작업/이슈 계층 구조 관리
- 상태 변경, 우선순위, 마감일 추적
- 작업 순서 드래그앤드롭 (reorder API)
- JSON Import로 일괄 등록
- Soft Delete 및 복원
2025-11-28 08:49:30 +09:00
|
|
|
// 추가 액션
|
|
|
|
|
Route::post('/{id}/status', [PmTaskController::class, 'changeStatus'])->name('changeStatus');
|
2025-11-28 18:08:32 +09:00
|
|
|
Route::post('/{id}/toggle-urgent', [PmTaskController::class, 'toggleUrgent'])->name('toggleUrgent');
|
feat: [pm] 프로젝트 진행 관리 시스템 구현
- Models: AdminPmProject, AdminPmTask, AdminPmIssue
- Services: ProjectService, TaskService, IssueService, ImportService
- API Controllers: ProjectController, TaskController, IssueController, ImportController
- FormRequests: Store/Update/BulkAction 요청 검증
- Views: 대시보드, 프로젝트 CRUD, JSON Import 화면
- Routes: API 42개 + Web 6개 엔드포인트
주요 기능:
- 프로젝트/작업/이슈 계층 구조 관리
- 상태 변경, 우선순위, 마감일 추적
- 작업 순서 드래그앤드롭 (reorder API)
- JSON Import로 일괄 등록
- Soft Delete 및 복원
2025-11-28 08:49:30 +09:00
|
|
|
|
|
|
|
|
// 프로젝트별
|
|
|
|
|
Route::get('/project/{projectId}', [PmTaskController::class, 'byProject'])->name('byProject');
|
|
|
|
|
Route::post('/project/{projectId}/reorder', [PmTaskController::class, 'reorder'])->name('reorder');
|
|
|
|
|
Route::get('/project/{projectId}/stats', [PmTaskController::class, 'stats'])->name('stats');
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// 이슈 관리 API
|
|
|
|
|
Route::prefix('issues')->name('issues.')->group(function () {
|
|
|
|
|
// 고정 경로
|
|
|
|
|
Route::get('/stats', [PmIssueController::class, 'stats'])->name('stats');
|
|
|
|
|
Route::get('/open', [PmIssueController::class, 'open'])->name('open');
|
|
|
|
|
Route::post('/bulk', [PmIssueController::class, 'bulk'])->name('bulk');
|
|
|
|
|
|
|
|
|
|
// 기본 CRUD
|
|
|
|
|
Route::get('/', [PmIssueController::class, 'index'])->name('index');
|
|
|
|
|
Route::post('/', [PmIssueController::class, 'store'])->name('store');
|
|
|
|
|
Route::get('/{id}', [PmIssueController::class, 'show'])->name('show');
|
|
|
|
|
Route::put('/{id}', [PmIssueController::class, 'update'])->name('update');
|
|
|
|
|
Route::delete('/{id}', [PmIssueController::class, 'destroy'])->name('destroy');
|
|
|
|
|
|
2025-12-01 00:13:12 +09:00
|
|
|
// 복원 (일반관리자 가능)
|
|
|
|
|
Route::post('/{id}/restore', [PmIssueController::class, 'restore'])->name('restore');
|
|
|
|
|
|
|
|
|
|
// 슈퍼관리자 전용 액션 (영구삭제)
|
2025-11-28 18:08:32 +09:00
|
|
|
Route::middleware('super.admin')->group(function () {
|
|
|
|
|
Route::delete('/{id}/force', [PmIssueController::class, 'forceDestroy'])->name('forceDestroy');
|
|
|
|
|
});
|
|
|
|
|
|
feat: [pm] 프로젝트 진행 관리 시스템 구현
- Models: AdminPmProject, AdminPmTask, AdminPmIssue
- Services: ProjectService, TaskService, IssueService, ImportService
- API Controllers: ProjectController, TaskController, IssueController, ImportController
- FormRequests: Store/Update/BulkAction 요청 검증
- Views: 대시보드, 프로젝트 CRUD, JSON Import 화면
- Routes: API 42개 + Web 6개 엔드포인트
주요 기능:
- 프로젝트/작업/이슈 계층 구조 관리
- 상태 변경, 우선순위, 마감일 추적
- 작업 순서 드래그앤드롭 (reorder API)
- JSON Import로 일괄 등록
- Soft Delete 및 복원
2025-11-28 08:49:30 +09:00
|
|
|
// 추가 액션
|
|
|
|
|
Route::post('/{id}/status', [PmIssueController::class, 'changeStatus'])->name('changeStatus');
|
2025-11-28 18:08:32 +09:00
|
|
|
Route::post('/{id}/toggle-urgent', [PmIssueController::class, 'toggleUrgent'])->name('toggleUrgent');
|
feat: [pm] 프로젝트 진행 관리 시스템 구현
- Models: AdminPmProject, AdminPmTask, AdminPmIssue
- Services: ProjectService, TaskService, IssueService, ImportService
- API Controllers: ProjectController, TaskController, IssueController, ImportController
- FormRequests: Store/Update/BulkAction 요청 검증
- Views: 대시보드, 프로젝트 CRUD, JSON Import 화면
- Routes: API 42개 + Web 6개 엔드포인트
주요 기능:
- 프로젝트/작업/이슈 계층 구조 관리
- 상태 변경, 우선순위, 마감일 추적
- 작업 순서 드래그앤드롭 (reorder API)
- JSON Import로 일괄 등록
- Soft Delete 및 복원
2025-11-28 08:49:30 +09:00
|
|
|
|
|
|
|
|
// 연관별
|
|
|
|
|
Route::get('/project/{projectId}', [PmIssueController::class, 'byProject'])->name('byProject');
|
|
|
|
|
Route::get('/task/{taskId}', [PmIssueController::class, 'byTask'])->name('byTask');
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// JSON Import API
|
|
|
|
|
Route::prefix('import')->name('import.')->group(function () {
|
|
|
|
|
Route::get('/template', [PmImportController::class, 'template'])->name('template');
|
|
|
|
|
Route::post('/validate', [PmImportController::class, 'validate'])->name('validate');
|
|
|
|
|
Route::post('/', [PmImportController::class, 'import'])->name('import');
|
|
|
|
|
Route::post('/project/{projectId}/tasks', [PmImportController::class, 'importTasks'])->name('importTasks');
|
2025-12-09 16:39:52 +09:00
|
|
|
Route::post('/task/{taskId}/issues', [PmImportController::class, 'importIssues'])->name('importIssues');
|
feat: [pm] 프로젝트 진행 관리 시스템 구현
- Models: AdminPmProject, AdminPmTask, AdminPmIssue
- Services: ProjectService, TaskService, IssueService, ImportService
- API Controllers: ProjectController, TaskController, IssueController, ImportController
- FormRequests: Store/Update/BulkAction 요청 검증
- Views: 대시보드, 프로젝트 CRUD, JSON Import 화면
- Routes: API 42개 + Web 6개 엔드포인트
주요 기능:
- 프로젝트/작업/이슈 계층 구조 관리
- 상태 변경, 우선순위, 마감일 추적
- 작업 순서 드래그앤드롭 (reorder API)
- JSON Import로 일괄 등록
- Soft Delete 및 복원
2025-11-28 08:49:30 +09:00
|
|
|
});
|
|
|
|
|
});
|
feat: [daily-logs] 일일 스크럼 기능 구현
주요 기능:
- 일일 로그 CRUD (생성, 조회, 수정, 삭제, 복원, 영구삭제)
- 로그 항목(Entry) 관리 (추가, 상태변경, 삭제, 순서변경)
- 주간 타임라인 (최근 7일 진행률 표시)
- 테이블 리스트 아코디언 상세보기
- 담당자 자동완성 (일반 사용자는 슈퍼관리자 목록 제외)
- HTMX 기반 동적 테이블 로딩 및 필터링
- Soft Delete 지원
파일 추가:
- Models: AdminPmDailyLog, AdminPmDailyLogEntry
- Controllers: DailyLogController (Web, API)
- Service: DailyLogService
- Requests: StoreDailyLogRequest, UpdateDailyLogRequest
- Views: index, show, table partial, modal-form partial
라우트 추가:
- Web: /daily-logs, /daily-logs/today, /daily-logs/{id}
- API: /api/admin/daily-logs/* (CRUD + 항목관리)
2025-12-01 14:07:55 +09:00
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
| 일일 스크럼 API
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
*/
|
|
|
|
|
Route::prefix('daily-logs')->name('daily-logs.')->group(function () {
|
|
|
|
|
// 고정 경로
|
|
|
|
|
Route::get('/stats', [DailyLogController::class, 'stats'])->name('stats');
|
|
|
|
|
Route::get('/today', [DailyLogController::class, 'today'])->name('today');
|
|
|
|
|
Route::get('/assignees', [DailyLogController::class, 'assignees'])->name('assignees');
|
|
|
|
|
|
|
|
|
|
// 기본 CRUD
|
|
|
|
|
Route::get('/', [DailyLogController::class, 'index'])->name('index');
|
|
|
|
|
Route::post('/', [DailyLogController::class, 'store'])->name('store');
|
|
|
|
|
Route::get('/{id}', [DailyLogController::class, 'show'])->name('show');
|
|
|
|
|
Route::put('/{id}', [DailyLogController::class, 'update'])->name('update');
|
|
|
|
|
Route::delete('/{id}', [DailyLogController::class, 'destroy'])->name('destroy');
|
|
|
|
|
|
|
|
|
|
// 복원 (일반관리자 가능)
|
|
|
|
|
Route::post('/{id}/restore', [DailyLogController::class, 'restore'])->name('restore');
|
|
|
|
|
|
|
|
|
|
// 슈퍼관리자 전용 액션 (영구삭제)
|
|
|
|
|
Route::middleware('super.admin')->group(function () {
|
|
|
|
|
Route::delete('/{id}/force', [DailyLogController::class, 'forceDestroy'])->name('forceDestroy');
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// 항목(Entry) 관리
|
|
|
|
|
Route::post('/{logId}/entries', [DailyLogController::class, 'addEntry'])->name('addEntry');
|
|
|
|
|
Route::post('/{logId}/entries/reorder', [DailyLogController::class, 'reorderEntries'])->name('reorderEntries');
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// 항목 개별 API (로그 ID 없이 직접 접근)
|
|
|
|
|
Route::prefix('daily-logs/entries')->name('daily-logs.entries.')->group(function () {
|
2025-12-02 14:07:50 +09:00
|
|
|
Route::put('/{entryId}', [DailyLogController::class, 'updateEntry'])->name('update');
|
feat: [daily-logs] 일일 스크럼 기능 구현
주요 기능:
- 일일 로그 CRUD (생성, 조회, 수정, 삭제, 복원, 영구삭제)
- 로그 항목(Entry) 관리 (추가, 상태변경, 삭제, 순서변경)
- 주간 타임라인 (최근 7일 진행률 표시)
- 테이블 리스트 아코디언 상세보기
- 담당자 자동완성 (일반 사용자는 슈퍼관리자 목록 제외)
- HTMX 기반 동적 테이블 로딩 및 필터링
- Soft Delete 지원
파일 추가:
- Models: AdminPmDailyLog, AdminPmDailyLogEntry
- Controllers: DailyLogController (Web, API)
- Service: DailyLogService
- Requests: StoreDailyLogRequest, UpdateDailyLogRequest
- Views: index, show, table partial, modal-form partial
라우트 추가:
- Web: /daily-logs, /daily-logs/today, /daily-logs/{id}
- API: /api/admin/daily-logs/* (CRUD + 항목관리)
2025-12-01 14:07:55 +09:00
|
|
|
Route::put('/{entryId}/status', [DailyLogController::class, 'updateEntryStatus'])->name('updateStatus');
|
|
|
|
|
Route::delete('/{entryId}', [DailyLogController::class, 'deleteEntry'])->name('delete');
|
|
|
|
|
});
|
feat(quote-formulas): 견적수식 관리 기능 구현
## 구현 내용
### 모델 (5개)
- QuoteFormulaCategory: 수식 카테고리
- QuoteFormula: 수식 정의 (input/calculation/range/mapping)
- QuoteFormulaRange: 범위별 값 정의
- QuoteFormulaMapping: 매핑 테이블
- QuoteFormulaItem: 수식-품목 연결
### 서비스 (3개)
- QuoteFormulaCategoryService: 카테고리 CRUD
- QuoteFormulaService: 수식 CRUD, 복제, 재정렬
- FormulaEvaluatorService: 수식 계산 엔진
- 지원 함수: SUM, ROUND, CEIL, FLOOR, ABS, MIN, MAX, IF, AND, OR, NOT
### API Controller (2개)
- QuoteFormulaCategoryController: 카테고리 API (11개 엔드포인트)
- QuoteFormulaController: 수식 API (16개 엔드포인트)
### FormRequest (4개)
- Store/Update QuoteFormulaCategoryRequest
- Store/Update QuoteFormulaRequest
### Blade Views (8개)
- 수식 목록/추가/수정/시뮬레이터
- 카테고리 목록/추가/수정
- HTMX 테이블 partial
### 라우트
- API: 27개 엔드포인트
- Web: 7개 라우트
2025-12-04 14:00:24 +09:00
|
|
|
|
2025-12-09 23:13:27 +09:00
|
|
|
/*
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
| 품목기준 필드 관리 API
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
*/
|
|
|
|
|
Route::prefix('item-fields')->name('item-fields.')->group(function () {
|
|
|
|
|
// 시딩 상태 (HTMX partial)
|
|
|
|
|
Route::get('/seeding-status', [ItemFieldController::class, 'seedingStatus'])->name('seedingStatus');
|
|
|
|
|
|
|
|
|
|
// 소스 테이블 목록
|
|
|
|
|
Route::get('/source-tables', [ItemFieldController::class, 'sourceTables'])->name('sourceTables');
|
|
|
|
|
|
|
|
|
|
// 단일 테이블 시딩
|
|
|
|
|
Route::post('/seed', [ItemFieldController::class, 'seed'])->name('seed');
|
|
|
|
|
|
|
|
|
|
// 전체 테이블 시딩
|
|
|
|
|
Route::post('/seed-all', [ItemFieldController::class, 'seedAll'])->name('seedAll');
|
|
|
|
|
|
|
|
|
|
// 단일 테이블 초기화
|
|
|
|
|
Route::post('/reset', [ItemFieldController::class, 'reset'])->name('reset');
|
|
|
|
|
|
|
|
|
|
// 전체 테이블 초기화
|
|
|
|
|
Route::post('/reset-all', [ItemFieldController::class, 'resetAll'])->name('resetAll');
|
|
|
|
|
|
|
|
|
|
// 커스텀 필드 목록 (HTMX partial)
|
|
|
|
|
Route::get('/custom-fields', [ItemFieldController::class, 'customFields'])->name('customFields');
|
|
|
|
|
|
|
|
|
|
// 커스텀 필드 추가
|
|
|
|
|
Route::post('/custom-fields', [ItemFieldController::class, 'storeCustomField'])->name('storeCustomField');
|
|
|
|
|
|
|
|
|
|
// 커스텀 필드 수정
|
|
|
|
|
Route::put('/custom-fields/{id}', [ItemFieldController::class, 'updateCustomField'])->name('updateCustomField');
|
|
|
|
|
|
|
|
|
|
// 커스텀 필드 삭제
|
|
|
|
|
Route::delete('/custom-fields/{id}', [ItemFieldController::class, 'destroyCustomField'])->name('destroyCustomField');
|
|
|
|
|
|
|
|
|
|
// 커스텀 필드 일괄 삭제
|
|
|
|
|
Route::delete('/custom-fields', [ItemFieldController::class, 'destroyCustomFields'])->name('destroyCustomFields');
|
|
|
|
|
|
|
|
|
|
// 오류 로그 조회 (HTMX partial)
|
|
|
|
|
Route::get('/error-logs', [ItemFieldController::class, 'errorLogs'])->name('errorLogs');
|
|
|
|
|
|
|
|
|
|
// 오류 로그 초기화
|
|
|
|
|
Route::delete('/error-logs', [ItemFieldController::class, 'clearErrorLogs'])->name('clearErrorLogs');
|
|
|
|
|
|
|
|
|
|
// AI 문의용 오류 보고서 생성
|
|
|
|
|
Route::get('/error-report', [ItemFieldController::class, 'generateErrorReport'])->name('errorReport');
|
|
|
|
|
});
|
|
|
|
|
|
feat(quote-formulas): 견적수식 관리 기능 구현
## 구현 내용
### 모델 (5개)
- QuoteFormulaCategory: 수식 카테고리
- QuoteFormula: 수식 정의 (input/calculation/range/mapping)
- QuoteFormulaRange: 범위별 값 정의
- QuoteFormulaMapping: 매핑 테이블
- QuoteFormulaItem: 수식-품목 연결
### 서비스 (3개)
- QuoteFormulaCategoryService: 카테고리 CRUD
- QuoteFormulaService: 수식 CRUD, 복제, 재정렬
- FormulaEvaluatorService: 수식 계산 엔진
- 지원 함수: SUM, ROUND, CEIL, FLOOR, ABS, MIN, MAX, IF, AND, OR, NOT
### API Controller (2개)
- QuoteFormulaCategoryController: 카테고리 API (11개 엔드포인트)
- QuoteFormulaController: 수식 API (16개 엔드포인트)
### FormRequest (4개)
- Store/Update QuoteFormulaCategoryRequest
- Store/Update QuoteFormulaRequest
### Blade Views (8개)
- 수식 목록/추가/수정/시뮬레이터
- 카테고리 목록/추가/수정
- HTMX 테이블 partial
### 라우트
- API: 27개 엔드포인트
- Web: 7개 라우트
2025-12-04 14:00:24 +09:00
|
|
|
/*
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
| 견적수식 관리 API
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
*/
|
|
|
|
|
Route::prefix('quote-formulas')->name('quote-formulas.')->group(function () {
|
|
|
|
|
|
|
|
|
|
// 카테고리 관리 API
|
|
|
|
|
Route::prefix('categories')->name('categories.')->group(function () {
|
|
|
|
|
// 고정 경로
|
|
|
|
|
Route::get('/stats', [QuoteFormulaCategoryController::class, 'stats'])->name('stats');
|
|
|
|
|
Route::get('/dropdown', [QuoteFormulaCategoryController::class, 'dropdown'])->name('dropdown');
|
|
|
|
|
Route::post('/reorder', [QuoteFormulaCategoryController::class, 'reorder'])->name('reorder');
|
|
|
|
|
|
|
|
|
|
// 기본 CRUD
|
|
|
|
|
Route::get('/', [QuoteFormulaCategoryController::class, 'index'])->name('index');
|
|
|
|
|
Route::post('/', [QuoteFormulaCategoryController::class, 'store'])->name('store');
|
|
|
|
|
Route::get('/{id}', [QuoteFormulaCategoryController::class, 'show'])->name('show');
|
|
|
|
|
Route::put('/{id}', [QuoteFormulaCategoryController::class, 'update'])->name('update');
|
|
|
|
|
Route::delete('/{id}', [QuoteFormulaCategoryController::class, 'destroy'])->name('destroy');
|
|
|
|
|
|
|
|
|
|
// 복원 (일반관리자 가능)
|
|
|
|
|
Route::post('/{id}/restore', [QuoteFormulaCategoryController::class, 'restore'])->name('restore');
|
|
|
|
|
|
|
|
|
|
// 슈퍼관리자 전용 액션 (영구삭제)
|
|
|
|
|
Route::middleware('super.admin')->group(function () {
|
|
|
|
|
Route::delete('/{id}/force', [QuoteFormulaCategoryController::class, 'forceDestroy'])->name('forceDestroy');
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// 추가 액션
|
|
|
|
|
Route::post('/{id}/toggle-active', [QuoteFormulaCategoryController::class, 'toggleActive'])->name('toggleActive');
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// 수식 관리 API
|
|
|
|
|
Route::prefix('formulas')->name('formulas.')->group(function () {
|
|
|
|
|
// 고정 경로
|
|
|
|
|
Route::get('/stats', [QuoteFormulaController::class, 'stats'])->name('stats');
|
|
|
|
|
Route::get('/variables', [QuoteFormulaController::class, 'variables'])->name('variables');
|
|
|
|
|
Route::post('/reorder', [QuoteFormulaController::class, 'reorder'])->name('reorder');
|
|
|
|
|
Route::post('/validate', [QuoteFormulaController::class, 'validate'])->name('validate');
|
|
|
|
|
Route::post('/test', [QuoteFormulaController::class, 'test'])->name('test');
|
|
|
|
|
Route::post('/simulate', [QuoteFormulaController::class, 'simulate'])->name('simulate');
|
|
|
|
|
|
|
|
|
|
// 기본 CRUD
|
|
|
|
|
Route::get('/', [QuoteFormulaController::class, 'index'])->name('index');
|
|
|
|
|
Route::post('/', [QuoteFormulaController::class, 'store'])->name('store');
|
|
|
|
|
Route::get('/{id}', [QuoteFormulaController::class, 'show'])->name('show');
|
|
|
|
|
Route::put('/{id}', [QuoteFormulaController::class, 'update'])->name('update');
|
|
|
|
|
Route::delete('/{id}', [QuoteFormulaController::class, 'destroy'])->name('destroy');
|
|
|
|
|
|
|
|
|
|
// 복원 (일반관리자 가능)
|
|
|
|
|
Route::post('/{id}/restore', [QuoteFormulaController::class, 'restore'])->name('restore');
|
|
|
|
|
|
|
|
|
|
// 슈퍼관리자 전용 액션 (영구삭제)
|
|
|
|
|
Route::middleware('super.admin')->group(function () {
|
|
|
|
|
Route::delete('/{id}/force', [QuoteFormulaController::class, 'forceDestroy'])->name('forceDestroy');
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
// 추가 액션
|
|
|
|
|
Route::post('/{id}/toggle-active', [QuoteFormulaController::class, 'toggleActive'])->name('toggleActive');
|
|
|
|
|
Route::post('/{id}/duplicate', [QuoteFormulaController::class, 'duplicate'])->name('duplicate');
|
|
|
|
|
|
|
|
|
|
// 카테고리별
|
|
|
|
|
Route::get('/category/{categoryId}', [QuoteFormulaController::class, 'byCategory'])->name('byCategory');
|
|
|
|
|
});
|
|
|
|
|
});
|
2025-11-25 11:05:57 +09:00
|
|
|
});
|
2025-12-14 02:13:20 +09:00
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
| Gemini AI API
|
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
|
|
| SAM AI 음성 어시스턴트용 Gemini API 키 제공
|
|
|
|
|
| 인증된 사용자만 접근 가능
|
|
|
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
Route::middleware(['web', 'auth'])->prefix('gemini')->name('api.gemini.')->group(function () {
|
|
|
|
|
Route::get('/api-key', [GeminiController::class, 'getApiKey'])->name('api-key');
|
|
|
|
|
});
|