사용자 보고: "초기화, 검색 버튼은 상단의 메뉴이름 쪽에 다른 버튼들이랑 같이 있으면 될거같아"
CompactFilterBar 안에 있던 [초기화][검색] 버튼이 자리 차지 + 시선 분산.
PageHeader 의 actions 슬롯 옆으로 통합하면서 11개 페이지 일괄 적용.
PageHeader 확장:
- onSearch / onReset / loading / searchLabel / resetLabel prop 추가
- actions 뒤에 [초기화][검색] 버튼 자동 렌더 (h-8 / text-xs)
CompactFilterBar 단순화:
- onSearch / onReset / loading / searchLabel / resetLabel prop 제거
- children + totalText 만 유지 (필드 컨테이너 + 합계 텍스트)
11개 페이지: <CompactFilterBar onSearch onReset loading> 3 prop 을
<PageHeader onSearch onReset loading> 로 이동
메모리: feedback_compact_search_pattern.md 에 "검색·초기화 위치 = PageHeader" 박제
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
RPS 는 탭 기반 라우터라 usePathname() 이 /main 으로 고정됨.
사용자 보고: M-BOM 페이지에서 PageHeader 가 메뉴명을 못 잡아 빈 상태.
수정: useCurrent2ndLevelMenuObjid 와 동일 패턴 적용
- useTabStore.selectTabs / selectActiveTabId 로 활성 탭 조회
- pathname='/main' 이면 활성 탭의 adminUrl 로 매칭
- stripCompanyPrefix 로 /COMPANY_NN 무시 → menu_info.menu_url 양방향 비교
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
CompactFilterBar 마이그레이션 과정에서 M-BOM 페이지 상단 메뉴명/설명이 사라진
회귀를 해결. customer-cs/cs 의 페이지 헤더 패턴을 공용 컴포넌트로 추출.
신설:
- components/common/PageHeader.tsx
· usePathname() + useMenu() 자동 매칭 → menu_info.menu_name_kor + menu_desc
· 명시 props (title/description/actions) 지원
· 동적 라우트 prefix fallback (/foo/123 → /foo 매칭)
적용:
- production/mbom/page.tsx 상단에 <PageHeader /> 1줄 추가
DB:
- menu_info.menu_desc 보강 (objid 100016/100032)
"생산용 BOM 트리 + read-only 조회 (운영판 mBomMgmtList 1:1)"
메모리: feedback_compact_search_pattern.md 갱신
- PageHeader 도 의무 사용 컴포넌트 목록에 추가
- 페이지 구조 표준 코드 예시 명시
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>