2024-01-05 00:20:55 -05:00
|
|
|
import 'package:auto_route/auto_route.dart';
|
2023-04-17 00:02:07 -05:00
|
|
|
import 'package:easy_localization/easy_localization.dart';
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
2024-05-02 15:59:14 -05:00
|
|
|
import 'package:immich_mobile/providers/archive.provider.dart';
|
|
|
|
import 'package:immich_mobile/providers/multiselect.provider.dart';
|
2023-12-07 10:38:22 -05:00
|
|
|
import 'package:immich_mobile/shared/ui/asset_grid/multiselect_grid.dart';
|
2023-04-17 00:02:07 -05:00
|
|
|
|
2024-01-15 11:50:33 -05:00
|
|
|
@RoutePage()
|
2023-04-17 00:02:07 -05:00
|
|
|
class ArchivePage extends HookConsumerWidget {
|
|
|
|
const ArchivePage({super.key});
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context, WidgetRef ref) {
|
2023-12-07 10:38:22 -05:00
|
|
|
AppBar buildAppBar() {
|
|
|
|
final archivedAssets = ref.watch(archiveProvider);
|
|
|
|
final count = archivedAssets.value?.totalAssets.toString() ?? "?";
|
2023-04-17 00:02:07 -05:00
|
|
|
return AppBar(
|
|
|
|
leading: IconButton(
|
2024-01-05 00:20:55 -05:00
|
|
|
onPressed: () => context.popRoute(),
|
2023-04-17 00:02:07 -05:00
|
|
|
icon: const Icon(Icons.arrow_back_ios_rounded),
|
|
|
|
),
|
|
|
|
centerTitle: true,
|
|
|
|
automaticallyImplyLeading: false,
|
|
|
|
title: const Text(
|
|
|
|
'archive_page_title',
|
2023-05-17 12:36:02 -05:00
|
|
|
).tr(args: [count]),
|
2023-04-17 00:02:07 -05:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2023-11-28 23:17:29 -05:00
|
|
|
return Scaffold(
|
2023-12-07 10:38:22 -05:00
|
|
|
appBar: ref.watch(multiselectProvider) ? null : buildAppBar(),
|
|
|
|
body: MultiselectGrid(
|
|
|
|
renderListProvider: archiveProvider,
|
|
|
|
unarchive: true,
|
|
|
|
archiveEnabled: true,
|
|
|
|
deleteEnabled: true,
|
|
|
|
editEnabled: true,
|
2023-05-17 12:36:02 -05:00
|
|
|
),
|
2023-04-17 00:02:07 -05:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|