feat(dialog): 상세 팝업 SuperportDetailDialog 통합
- SuperportDetailDialog 위젯과 showSuperportDetailDialog 헬퍼를 추가하고 metadata/섹션 패턴을 표준화 - 결재/재고/마스터 각 상세 다이얼로그를 dialogs 디렉터리에 신설하고 기존 페이지를 신규 팝업으로 전환 - SuperportTable 행 선택과 우편번호 검색 다이얼로그 onRowTap 보정을 통해 헤더 오프셋 버그를 제거 - 상세 다이얼로그 및 트랜잭션/상세 뷰 전용 위젯 테스트와 tester_extensions 유틸을 추가하여 회귀를 방지 - detail_dialog_unification_plan.md로 작업 배경과 필드 통합 계획을 문서화
This commit is contained in:
35
test/helpers/tester_extensions.dart
Normal file
35
test/helpers/tester_extensions.dart
Normal file
@@ -0,0 +1,35 @@
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:flutter_test/flutter_test.dart';
|
||||
import 'package:shadcn_ui/shadcn_ui.dart';
|
||||
|
||||
extension WidgetTesterDialogActions on WidgetTester {
|
||||
/// 다이얼로그 내 `ShadButton`을 텍스트 라벨로 찾아 탭한다.
|
||||
Future<void> tapShadButton(String label, {bool settle = true}) async {
|
||||
final buttonFinder = find.widgetWithText(ShadButton, label);
|
||||
expect(
|
||||
buttonFinder,
|
||||
findsWidgets,
|
||||
reason: '텍스트 "$label" 를 가진 ShadButton을 찾지 못했습니다.',
|
||||
);
|
||||
final elements = buttonFinder.evaluate().toList(growable: false);
|
||||
final targetIndex = elements.lastIndexWhere((element) {
|
||||
final widget = element.widget;
|
||||
return widget is ShadButton && widget.onPressed != null;
|
||||
});
|
||||
expect(
|
||||
targetIndex,
|
||||
isNot(-1),
|
||||
reason: '눌러야 할 활성화된 "$label" 버튼을 찾을 수 없습니다.',
|
||||
);
|
||||
final targetButton = buttonFinder.at(targetIndex);
|
||||
final targetText = find.descendant(
|
||||
of: targetButton,
|
||||
matching: find.byType(Text),
|
||||
);
|
||||
await ensureVisible(targetText.first);
|
||||
await tap(targetText.first, warnIfMissed: false);
|
||||
if (settle) {
|
||||
await pumpAndSettle();
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user