2023-08-18 06:26:12 +02:00
|
|
|
import 'package:easy_localization/easy_localization.dart';
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:flutter_hooks/flutter_hooks.dart';
|
|
|
|
import 'package:fluttertoast/fluttertoast.dart';
|
|
|
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
2023-11-09 18:19:53 +02:00
|
|
|
import 'package:immich_mobile/extensions/build_context_extensions.dart';
|
2023-08-18 06:26:12 +02:00
|
|
|
import 'package:immich_mobile/modules/album/providers/shared_album.provider.dart';
|
|
|
|
import 'package:immich_mobile/modules/login/providers/authentication.provider.dart';
|
|
|
|
import 'package:immich_mobile/routing/router.dart';
|
|
|
|
import 'package:immich_mobile/shared/models/album.dart';
|
|
|
|
import 'package:immich_mobile/shared/models/user.dart';
|
|
|
|
import 'package:immich_mobile/shared/ui/immich_toast.dart';
|
|
|
|
import 'package:immich_mobile/shared/ui/user_circle_avatar.dart';
|
|
|
|
import 'package:immich_mobile/shared/views/immich_loading_overlay.dart';
|
|
|
|
|
|
|
|
class AlbumOptionsPage extends HookConsumerWidget {
|
|
|
|
final Album album;
|
|
|
|
|
|
|
|
const AlbumOptionsPage({super.key, required this.album});
|
|
|
|
|
|
|
|
@override
|
|
|
|
Widget build(BuildContext context, WidgetRef ref) {
|
|
|
|
final sharedUsers = useState(album.sharedUsers.toList());
|
|
|
|
final owner = album.owner.value;
|
|
|
|
final userId = ref.watch(authenticationProvider).userId;
|
2023-11-08 05:07:43 +02:00
|
|
|
final activityEnabled = useState(album.activityEnabled);
|
2023-08-18 06:26:12 +02:00
|
|
|
final isOwner = owner?.id == userId;
|
|
|
|
|
|
|
|
void showErrorMessage() {
|
|
|
|
Navigator.pop(context);
|
|
|
|
ImmichToast.show(
|
|
|
|
context: context,
|
2023-11-19 04:32:28 +02:00
|
|
|
msg: "shared_album_section_people_action_error".tr(),
|
2023-08-18 06:26:12 +02:00
|
|
|
toastType: ToastType.error,
|
|
|
|
gravity: ToastGravity.BOTTOM,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
void leaveAlbum() async {
|
|
|
|
ImmichLoadingOverlayController.appLoader.show();
|
|
|
|
|
|
|
|
try {
|
|
|
|
final isSuccess =
|
|
|
|
await ref.read(sharedAlbumProvider.notifier).leaveAlbum(album);
|
|
|
|
|
|
|
|
if (isSuccess) {
|
2023-11-09 18:19:53 +02:00
|
|
|
context.autoNavigate(
|
|
|
|
const TabControllerRoute(children: [SharingRoute()]),
|
|
|
|
);
|
2023-08-18 06:26:12 +02:00
|
|
|
} else {
|
|
|
|
showErrorMessage();
|
|
|
|
}
|
|
|
|
} catch (_) {
|
|
|
|
showErrorMessage();
|
|
|
|
}
|
|
|
|
|
|
|
|
ImmichLoadingOverlayController.appLoader.hide();
|
|
|
|
}
|
|
|
|
|
|
|
|
void removeUserFromAlbum(User user) async {
|
|
|
|
ImmichLoadingOverlayController.appLoader.show();
|
|
|
|
|
|
|
|
try {
|
|
|
|
await ref
|
|
|
|
.read(sharedAlbumProvider.notifier)
|
|
|
|
.removeUserFromAlbum(album, user);
|
|
|
|
album.sharedUsers.remove(user);
|
|
|
|
sharedUsers.value = album.sharedUsers.toList();
|
|
|
|
} catch (error) {
|
|
|
|
showErrorMessage();
|
|
|
|
}
|
|
|
|
|
|
|
|
Navigator.pop(context);
|
|
|
|
ImmichLoadingOverlayController.appLoader.hide();
|
|
|
|
}
|
|
|
|
|
|
|
|
void handleUserClick(User user) {
|
|
|
|
var actions = [];
|
|
|
|
|
|
|
|
if (user.id == userId) {
|
|
|
|
actions = [
|
|
|
|
ListTile(
|
|
|
|
leading: const Icon(Icons.exit_to_app_rounded),
|
2023-11-19 04:32:28 +02:00
|
|
|
title: const Text("shared_album_section_people_action_leave").tr(),
|
2023-08-18 06:26:12 +02:00
|
|
|
onTap: leaveAlbum,
|
|
|
|
),
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isOwner) {
|
|
|
|
actions = [
|
|
|
|
ListTile(
|
|
|
|
leading: const Icon(Icons.person_remove_rounded),
|
2023-11-19 04:32:28 +02:00
|
|
|
title: const Text("shared_album_section_people_remove_user").tr(),
|
2023-08-18 06:26:12 +02:00
|
|
|
onTap: () => removeUserFromAlbum(user),
|
|
|
|
),
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
showModalBottomSheet(
|
2023-11-09 18:19:53 +02:00
|
|
|
backgroundColor: context.scaffoldBackgroundColor,
|
2023-08-18 06:26:12 +02:00
|
|
|
isScrollControlled: false,
|
|
|
|
context: context,
|
|
|
|
builder: (context) {
|
|
|
|
return SafeArea(
|
|
|
|
child: Padding(
|
|
|
|
padding: const EdgeInsets.only(top: 24.0),
|
|
|
|
child: Column(
|
|
|
|
mainAxisSize: MainAxisSize.min,
|
|
|
|
children: [...actions],
|
|
|
|
),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
},
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
buildOwnerInfo() {
|
|
|
|
return ListTile(
|
2023-11-14 05:10:35 +02:00
|
|
|
leading:
|
|
|
|
owner != null ? UserCircleAvatar(user: owner) : const SizedBox(),
|
2023-08-18 06:26:12 +02:00
|
|
|
title: Text(
|
2023-11-12 03:03:32 +02:00
|
|
|
album.owner.value?.name ?? "",
|
2023-08-18 06:26:12 +02:00
|
|
|
style: const TextStyle(
|
|
|
|
fontWeight: FontWeight.bold,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
subtitle: Text(
|
|
|
|
album.owner.value?.email ?? "",
|
|
|
|
style: TextStyle(color: Colors.grey[500]),
|
|
|
|
),
|
|
|
|
trailing: const Text(
|
2023-11-19 04:32:28 +02:00
|
|
|
"shared_album_section_people_owner_label",
|
2023-08-18 06:26:12 +02:00
|
|
|
style: TextStyle(
|
|
|
|
fontWeight: FontWeight.bold,
|
|
|
|
),
|
2023-11-19 04:32:28 +02:00
|
|
|
).tr(),
|
2023-08-18 06:26:12 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
buildSharedUsersList() {
|
|
|
|
return ListView.builder(
|
|
|
|
shrinkWrap: true,
|
|
|
|
itemCount: sharedUsers.value.length,
|
|
|
|
itemBuilder: (context, index) {
|
|
|
|
final user = sharedUsers.value[index];
|
|
|
|
return ListTile(
|
|
|
|
leading: UserCircleAvatar(
|
|
|
|
user: user,
|
|
|
|
radius: 22,
|
|
|
|
),
|
|
|
|
title: Text(
|
2023-11-12 03:03:32 +02:00
|
|
|
user.name,
|
2023-08-18 06:26:12 +02:00
|
|
|
style: const TextStyle(
|
|
|
|
fontWeight: FontWeight.bold,
|
|
|
|
),
|
|
|
|
),
|
|
|
|
subtitle: Text(
|
|
|
|
user.email,
|
|
|
|
style: TextStyle(color: Colors.grey[500]),
|
|
|
|
),
|
|
|
|
trailing: userId == user.id || isOwner
|
|
|
|
? const Icon(Icons.more_horiz_rounded)
|
|
|
|
: const SizedBox(),
|
|
|
|
onTap: userId == user.id || isOwner
|
|
|
|
? () => handleUserClick(user)
|
|
|
|
: null,
|
|
|
|
);
|
|
|
|
},
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
buildSectionTitle(String text) {
|
|
|
|
return Padding(
|
|
|
|
padding: const EdgeInsets.all(16.0),
|
2023-11-09 18:19:53 +02:00
|
|
|
child: Text(text, style: context.textTheme.bodySmall),
|
2023-08-18 06:26:12 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return Scaffold(
|
|
|
|
appBar: AppBar(
|
|
|
|
leading: IconButton(
|
|
|
|
icon: const Icon(Icons.arrow_back_ios_new_rounded),
|
|
|
|
onPressed: () {
|
2023-11-09 18:19:53 +02:00
|
|
|
context.autoPop(null);
|
2023-08-18 06:26:12 +02:00
|
|
|
},
|
|
|
|
),
|
|
|
|
centerTitle: true,
|
|
|
|
title: Text("translated_text_options".tr()),
|
|
|
|
),
|
|
|
|
body: Column(
|
|
|
|
mainAxisAlignment: MainAxisAlignment.start,
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
|
|
children: [
|
2023-11-08 05:07:43 +02:00
|
|
|
if (isOwner && album.shared)
|
|
|
|
SwitchListTile.adaptive(
|
|
|
|
value: activityEnabled.value,
|
|
|
|
onChanged: (bool value) async {
|
|
|
|
activityEnabled.value = value;
|
|
|
|
if (await ref
|
|
|
|
.read(sharedAlbumProvider.notifier)
|
|
|
|
.setActivityEnabled(album, value)) {
|
|
|
|
album.activityEnabled = value;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
activeColor: activityEnabled.value
|
2023-11-09 18:19:53 +02:00
|
|
|
? context.primaryColor
|
|
|
|
: context.themeData.disabledColor,
|
2023-11-08 05:07:43 +02:00
|
|
|
dense: true,
|
|
|
|
title: Text(
|
|
|
|
"shared_album_activity_setting_title",
|
2023-11-09 18:19:53 +02:00
|
|
|
style: context.textTheme.labelLarge
|
2023-11-08 05:07:43 +02:00
|
|
|
?.copyWith(fontWeight: FontWeight.bold),
|
|
|
|
).tr(),
|
|
|
|
subtitle:
|
|
|
|
const Text("shared_album_activity_setting_subtitle").tr(),
|
|
|
|
),
|
2023-11-19 04:32:28 +02:00
|
|
|
buildSectionTitle("shared_album_section_people_title".tr()),
|
2023-08-18 06:26:12 +02:00
|
|
|
buildOwnerInfo(),
|
|
|
|
buildSharedUsersList(),
|
|
|
|
],
|
|
|
|
),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|