Files
sam-manage/database/seeders/SalesMenuFixSeeder.php
pro 15b01c7224 feat:영업관리 메뉴 정리 시더 추가
- 세일즈 사이트, 렌딩페이지 영업관리 하위로 이동
- 중복 영업관리 메뉴 제거

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2026-01-30 21:07:44 +09:00

88 lines
2.9 KiB
PHP

<?php
namespace Database\Seeders;
use App\Models\Commons\Menu;
use Illuminate\Database\Seeder;
/**
* 영업관리 메뉴 정리 시더
* - 세일즈 사이트, 렌딩페이지를 영업관리 하위로 이동
* - 중복 영업관리 메뉴 제거
*/
class SalesMenuFixSeeder extends Seeder
{
public function run(): void
{
$tenantId = 1;
// 영업관리 메뉴 찾기 (parent_id가 null인 것)
$salesMenus = Menu::where('tenant_id', $tenantId)
->where('name', '영업관리')
->whereNull('parent_id')
->orderBy('id')
->get();
if ($salesMenus->count() > 1) {
// 첫 번째를 유지하고 나머지는 삭제
$mainSalesMenu = $salesMenus->first();
$duplicates = $salesMenus->skip(1);
foreach ($duplicates as $dup) {
// 중복 메뉴의 하위 메뉴들을 메인으로 이동
Menu::where('parent_id', $dup->id)->update(['parent_id' => $mainSalesMenu->id]);
// 중복 메뉴 삭제
$dup->forceDelete();
$this->command->info("중복 영업관리 메뉴 삭제: ID {$dup->id}");
}
}
// 영업관리 메뉴 ID
$salesParentId = Menu::where('tenant_id', $tenantId)
->where('name', '영업관리')
->whereNull('parent_id')
->value('id');
if (!$salesParentId) {
$this->command->error('영업관리 메뉴를 찾을 수 없습니다.');
return;
}
// 세일즈 사이트 메뉴 찾아서 이동
$salesSite = Menu::where('tenant_id', $tenantId)
->where('name', '세일즈 사이트')
->first();
if ($salesSite) {
$salesSite->parent_id = $salesParentId;
$salesSite->sort_order = 5;
$salesSite->save();
$this->command->info('세일즈 사이트 → 영업관리 하위로 이동');
}
// 렌딩페이지 메뉴 찾아서 이동 및 URL 설정
$landingPage = Menu::where('tenant_id', $tenantId)
->where('name', '렌딩페이지')
->first();
if ($landingPage) {
$landingPage->parent_id = $salesParentId;
$landingPage->sort_order = 6;
$landingPage->url = '/sales/salesmanagement/dashboard';
$landingPage->save();
$this->command->info('렌딩페이지 → 영업관리 하위로 이동, URL 설정');
}
// 결과 출력
$this->command->info('');
$this->command->info('=== 영업관리 하위 메뉴 ===');
$children = Menu::where('parent_id', $salesParentId)
->orderBy('sort_order')
->get(['name', 'url', 'sort_order']);
foreach ($children as $child) {
$this->command->info("{$child->sort_order}. {$child->name} ({$child->url})");
}
}
}