47 lines
1.6 KiB
Dart
47 lines
1.6 KiB
Dart
// lib/pages/entry/entry_list_page.dart
|
|
|
|
import 'package:flutter/material.dart';
|
|
import 'package:get/get.dart';
|
|
import 'package:rogapp/pages/entry/entry_controller.dart';
|
|
import 'package:rogapp/routes/app_pages.dart';
|
|
|
|
class EntryListPage extends GetView<EntryController> {
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return Scaffold(
|
|
appBar: AppBar(
|
|
title: Text('エントリー管理'),
|
|
actions: [
|
|
IconButton(
|
|
icon: Icon(Icons.add),
|
|
onPressed: () => Get.toNamed(AppPages.ENTRY_DETAIL, arguments: {'mode': 'new'}),
|
|
),
|
|
],
|
|
),
|
|
body: Obx((){
|
|
// エントリーを日付昇順にソート
|
|
final sortedEntries = controller.entries.toList()
|
|
..sort((a, b) => (a.date ?? DateTime(0)).compareTo(b.date ?? DateTime(0)));
|
|
|
|
return ListView.builder(
|
|
itemCount: sortedEntries.length,
|
|
itemBuilder: (context, index) {
|
|
final entry = sortedEntries[index];
|
|
return ListTile(
|
|
title: Text(entry.event?.eventName ?? 'イベント未設定'),
|
|
subtitle: Text(
|
|
'${entry.team?.teamName ?? 'チーム未設定'} - ${entry.category
|
|
?.categoryName ?? 'カテゴリ未設定'}'),
|
|
trailing: Text(
|
|
entry.date?.toString().substring(0, 10) ?? '日付未設定'),
|
|
onTap: () =>
|
|
Get.toNamed(AppPages.ENTRY_DETAIL,
|
|
arguments: {'mode': 'edit', 'entry': entry}),
|
|
);
|
|
},
|
|
);
|
|
}),
|
|
);
|
|
|
|
}
|
|
} |