feat: UniversalListPage 검색 기능 개선 및 리렌더링 버그 수정
- UniversalListPage 템플릿에 searchFilter, useClientSearch 지원 추가 - 검색 입력 시 리렌더링(포커스 유실) 버그 수정 - 29개 리스트 페이지에 searchFilter 함수 추가 - SiteBriefingListClient 누락된 searchFilter 추가 - IntegratedListTemplateV2 검색 로직 정리 - 검색 기능 수정내역 가이드 문서 추가 Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
@@ -203,6 +203,16 @@ export function AccountManagement() {
|
||||
|
||||
// 검색
|
||||
searchPlaceholder: '은행명, 계좌번호, 계좌명, 예금주 검색...',
|
||||
searchFilter: (item: Account, search: string) => {
|
||||
const s = search.toLowerCase();
|
||||
return (
|
||||
item.bankName?.toLowerCase().includes(s) ||
|
||||
item.accountNumber?.toLowerCase().includes(s) ||
|
||||
item.accountName?.toLowerCase().includes(s) ||
|
||||
item.accountHolder?.toLowerCase().includes(s) ||
|
||||
false
|
||||
);
|
||||
},
|
||||
|
||||
// 헤더 액션
|
||||
headerActions: () => (
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
'use client';
|
||||
|
||||
import { useState, useMemo, useCallback, useEffect } from 'react';
|
||||
import { useState, useMemo, useCallback, useEffect, useRef } from 'react';
|
||||
import { useRouter } from 'next/navigation';
|
||||
import { format } from 'date-fns';
|
||||
import {
|
||||
@@ -42,6 +42,7 @@ export function PermissionManagement() {
|
||||
const [roles, setRoles] = useState<Role[]>([]);
|
||||
const [stats, setStats] = useState<RoleStats | null>(null);
|
||||
const [isLoading, setIsLoading] = useState(true);
|
||||
const isInitialLoadDone = useRef(false);
|
||||
const [error, setError] = useState<string | null>(null);
|
||||
|
||||
// 삭제 확인 다이얼로그
|
||||
@@ -52,7 +53,9 @@ export function PermissionManagement() {
|
||||
|
||||
// API에서 데이터 로드
|
||||
const loadData = useCallback(async () => {
|
||||
setIsLoading(true);
|
||||
if (!isInitialLoadDone.current) {
|
||||
setIsLoading(true);
|
||||
}
|
||||
setError(null);
|
||||
|
||||
try {
|
||||
@@ -74,6 +77,7 @@ export function PermissionManagement() {
|
||||
setError(err instanceof Error ? err.message : '데이터 로드 실패');
|
||||
} finally {
|
||||
setIsLoading(false);
|
||||
isInitialLoadDone.current = true;
|
||||
}
|
||||
}, []);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user