주석화 진행상황 정리하고 핵심 모듈에 한글 주석 추가
This commit is contained in:
@@ -4,6 +4,7 @@ import 'package:superport_v2/core/common/models/paginated_result.dart';
|
||||
import '../../domain/entities/menu.dart';
|
||||
import '../../domain/repositories/menu_repository.dart';
|
||||
|
||||
/// 메뉴 사용 여부 필터.
|
||||
enum MenuStatusFilter { all, activeOnly, inactiveOnly }
|
||||
|
||||
/// 메뉴 마스터 상태 컨트롤러
|
||||
@@ -38,6 +39,7 @@ class MenuController extends ChangeNotifier {
|
||||
String? get errorMessage => _errorMessage;
|
||||
List<MenuItem> get parents => _parents;
|
||||
|
||||
/// 상위 메뉴 목록을 로드해 드롭다운에 표시한다.
|
||||
Future<void> loadParents() async {
|
||||
_isLoadingParents = true;
|
||||
notifyListeners();
|
||||
@@ -56,6 +58,7 @@ class MenuController extends ChangeNotifier {
|
||||
}
|
||||
}
|
||||
|
||||
/// 메뉴 목록을 조회한다.
|
||||
Future<void> fetch({int page = 1}) async {
|
||||
_isLoading = true;
|
||||
_errorMessage = null;
|
||||
@@ -83,26 +86,31 @@ class MenuController extends ChangeNotifier {
|
||||
}
|
||||
}
|
||||
|
||||
/// 검색어를 변경한다.
|
||||
void updateQuery(String value) {
|
||||
_query = value;
|
||||
notifyListeners();
|
||||
}
|
||||
|
||||
/// 상위 메뉴 필터를 변경한다.
|
||||
void updateParentFilter(int? parentId) {
|
||||
_parentFilter = parentId;
|
||||
notifyListeners();
|
||||
}
|
||||
|
||||
/// 메뉴 사용 여부 필터를 변경한다.
|
||||
void updateStatusFilter(MenuStatusFilter filter) {
|
||||
_statusFilter = filter;
|
||||
notifyListeners();
|
||||
}
|
||||
|
||||
/// 삭제 포함 여부를 변경한다.
|
||||
void updateIncludeDeleted(bool value) {
|
||||
_includeDeleted = value;
|
||||
notifyListeners();
|
||||
}
|
||||
|
||||
/// 메뉴를 생성한다.
|
||||
Future<MenuItem?> create(MenuInput input) async {
|
||||
_setSubmitting(true);
|
||||
try {
|
||||
@@ -119,6 +127,7 @@ class MenuController extends ChangeNotifier {
|
||||
}
|
||||
}
|
||||
|
||||
/// 메뉴 정보를 수정한다.
|
||||
Future<MenuItem?> update(int id, MenuInput input) async {
|
||||
_setSubmitting(true);
|
||||
try {
|
||||
@@ -135,6 +144,7 @@ class MenuController extends ChangeNotifier {
|
||||
}
|
||||
}
|
||||
|
||||
/// 메뉴를 삭제한다.
|
||||
Future<bool> delete(int id) async {
|
||||
_setSubmitting(true);
|
||||
try {
|
||||
@@ -151,6 +161,7 @@ class MenuController extends ChangeNotifier {
|
||||
}
|
||||
}
|
||||
|
||||
/// 삭제된 메뉴를 복구한다.
|
||||
Future<MenuItem?> restore(int id) async {
|
||||
_setSubmitting(true);
|
||||
try {
|
||||
@@ -167,11 +178,13 @@ class MenuController extends ChangeNotifier {
|
||||
}
|
||||
}
|
||||
|
||||
/// 에러 메시지를 초기화한다.
|
||||
void clearError() {
|
||||
_errorMessage = null;
|
||||
notifyListeners();
|
||||
}
|
||||
|
||||
/// 제출 상태 플래그를 갱신하고 리스너에 알린다.
|
||||
void _setSubmitting(bool value) {
|
||||
_isSubmitting = value;
|
||||
notifyListeners();
|
||||
|
||||
@@ -13,6 +13,7 @@ import '../../domain/entities/menu.dart';
|
||||
import '../../domain/repositories/menu_repository.dart';
|
||||
import '../controllers/menu_controller.dart' as menu;
|
||||
|
||||
/// 메뉴 관리 페이지. 기능 플래그에 따라 사양/실제 화면을 전환한다.
|
||||
class MenuPage extends StatelessWidget {
|
||||
const MenuPage({super.key});
|
||||
|
||||
@@ -89,6 +90,7 @@ class MenuPage extends StatelessWidget {
|
||||
}
|
||||
}
|
||||
|
||||
/// 메뉴 기능이 활성화된 경우 사용하는 실제 화면 위젯.
|
||||
class _MenuEnabledPage extends StatefulWidget {
|
||||
const _MenuEnabledPage();
|
||||
|
||||
@@ -96,6 +98,7 @@ class _MenuEnabledPage extends StatefulWidget {
|
||||
State<_MenuEnabledPage> createState() => _MenuEnabledPageState();
|
||||
}
|
||||
|
||||
/// 메뉴 목록과 필터를 관리하는 상태 클래스.
|
||||
class _MenuEnabledPageState extends State<_MenuEnabledPage> {
|
||||
late final menu.MenuController _controller;
|
||||
final TextEditingController _searchController = TextEditingController();
|
||||
|
||||
Reference in New Issue
Block a user