From d0e4a8e6a28f7c6cee7da6b7464efdf19614d477 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EA=B9=80=EB=B3=B4=EA=B3=A4?= Date: Fri, 6 Feb 2026 21:09:02 +0900 Subject: [PATCH] =?UTF-8?q?fix:=EC=9D=B8=ED=84=B0=EB=B7=B0=20=EC=8B=9C?= =?UTF-8?q?=EB=82=98=EB=A6=AC=EC=98=A4=20=EB=A9=94=EB=89=B4=EB=A5=BC=20?= =?UTF-8?q?=EB=AA=A8=EB=93=A0=20=ED=85=8C=EB=84=8C=ED=8A=B8=EC=97=90=20?= =?UTF-8?q?=EC=B6=94=EA=B0=80?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - 기존: tenant_id=1에만 메뉴 생성 - 수정: 글로벌(null) + 모든 테넌트의 영업관리 하위에 생성 Co-Authored-By: Claude Opus 4.6 --- database/seeders/InterviewMenuSeeder.php | 72 ++++++++++++------------ 1 file changed, 37 insertions(+), 35 deletions(-) diff --git a/database/seeders/InterviewMenuSeeder.php b/database/seeders/InterviewMenuSeeder.php index e5bae7fd..c468144e 100644 --- a/database/seeders/InterviewMenuSeeder.php +++ b/database/seeders/InterviewMenuSeeder.php @@ -9,49 +9,51 @@ class InterviewMenuSeeder extends Seeder { public function run(): void { - $tenantId = 1; - - // 영업관리 상위 메뉴 찾기 - $salesParentId = Menu::where('tenant_id', $tenantId) + // 모든 테넌트의 영업관리 메뉴 찾기 (글로벌 포함) + $salesMenus = Menu::withoutGlobalScopes() ->where('name', '영업관리') ->whereNull('parent_id') - ->value('id'); + ->whereNull('deleted_at') + ->get(); - if (!$salesParentId) { + if ($salesMenus->isEmpty()) { $this->command->error('영업관리 메뉴를 찾을 수 없습니다.'); return; } - // 이미 존재하는지 확인 - $exists = Menu::where('tenant_id', $tenantId) - ->where('parent_id', $salesParentId) - ->where('name', '인터뷰 시나리오') - ->exists(); + foreach ($salesMenus as $salesMenu) { + $tenantId = $salesMenu->tenant_id; + $label = $tenantId ? "tenant_id={$tenantId}" : 'global(tenant_id=null)'; - if ($exists) { - $this->command->info('인터뷰 시나리오 메뉴가 이미 존재합니다.'); - return; + // 이미 존재하는지 확인 + $exists = Menu::withoutGlobalScopes() + ->where('parent_id', $salesMenu->id) + ->where('name', '인터뷰 시나리오') + ->whereNull('deleted_at') + ->exists(); + + if ($exists) { + $this->command->info("[{$label}] 인터뷰 시나리오 메뉴가 이미 존재합니다."); + continue; + } + + // 마지막 sort_order 확인 + $maxSort = Menu::withoutGlobalScopes() + ->where('parent_id', $salesMenu->id) + ->whereNull('deleted_at') + ->max('sort_order') ?? 0; + + Menu::withoutGlobalScopes()->create([ + 'tenant_id' => $tenantId, + 'parent_id' => $salesMenu->id, + 'name' => '인터뷰 시나리오', + 'url' => '/sales/interviews', + 'icon' => 'clipboard-check', + 'sort_order' => $maxSort + 1, + 'is_active' => true, + ]); + + $this->command->info("[{$label}] 인터뷰 시나리오 메뉴 생성 완료."); } - - // 영업파트너 승인 메뉴의 sort_order 확인 - $approvalMenu = Menu::where('tenant_id', $tenantId) - ->where('parent_id', $salesParentId) - ->where('name', '영업파트너 승인') - ->first(); - - $sortOrder = $approvalMenu ? $approvalMenu->sort_order + 1 : 10; - - // 인터뷰 시나리오 메뉴 생성 - Menu::create([ - 'tenant_id' => $tenantId, - 'parent_id' => $salesParentId, - 'name' => '인터뷰 시나리오', - 'url' => '/sales/interviews', - 'icon' => 'clipboard-check', - 'sort_order' => $sortOrder, - 'is_active' => true, - ]); - - $this->command->info('인터뷰 시나리오 메뉴가 생성되었습니다.'); } }