mirror of
https://github.com/immich-app/immich.git
synced 2024-12-21 01:39:59 +02:00
76 lines
2.1 KiB
Dart
76 lines
2.1 KiB
Dart
|
import 'package:flutter/material.dart';
|
||
|
import 'package:immich_mobile/modules/activities/widgets/activity_tile.dart';
|
||
|
import 'package:immich_mobile/shared/ui/confirm_dialog.dart';
|
||
|
|
||
|
/// Wraps an [ActivityTile] and makes it dismissible
|
||
|
class DismissibleActivity extends StatelessWidget {
|
||
|
final String activityId;
|
||
|
final ActivityTile body;
|
||
|
final Function(String)? onDismiss;
|
||
|
|
||
|
const DismissibleActivity(
|
||
|
this.activityId,
|
||
|
this.body, {
|
||
|
this.onDismiss,
|
||
|
super.key,
|
||
|
});
|
||
|
|
||
|
@override
|
||
|
Widget build(BuildContext context) {
|
||
|
return Dismissible(
|
||
|
key: Key(activityId),
|
||
|
dismissThresholds: const {
|
||
|
DismissDirection.horizontal: 0.7,
|
||
|
},
|
||
|
direction: DismissDirection.horizontal,
|
||
|
confirmDismiss: (direction) => onDismiss != null
|
||
|
? showDialog(
|
||
|
context: context,
|
||
|
builder: (context) => ConfirmDialog(
|
||
|
onOk: () {},
|
||
|
title: "shared_album_activity_remove_title",
|
||
|
content: "shared_album_activity_remove_content",
|
||
|
ok: "delete_dialog_ok",
|
||
|
),
|
||
|
)
|
||
|
: Future.value(false),
|
||
|
onDismissed: (_) async => onDismiss?.call(activityId),
|
||
|
// LTR
|
||
|
background: _DismissBackground(withDeleteIcon: onDismiss != null),
|
||
|
// RTL
|
||
|
secondaryBackground: _DismissBackground(
|
||
|
withDeleteIcon: onDismiss != null,
|
||
|
alignment: AlignmentDirectional.centerEnd,
|
||
|
),
|
||
|
child: body,
|
||
|
);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
class _DismissBackground extends StatelessWidget {
|
||
|
final AlignmentDirectional alignment;
|
||
|
final bool withDeleteIcon;
|
||
|
|
||
|
const _DismissBackground({
|
||
|
required this.withDeleteIcon,
|
||
|
this.alignment = AlignmentDirectional.centerStart,
|
||
|
});
|
||
|
|
||
|
@override
|
||
|
Widget build(BuildContext context) {
|
||
|
return Container(
|
||
|
alignment: alignment,
|
||
|
color: withDeleteIcon ? Colors.red[400] : Colors.grey[600],
|
||
|
child: withDeleteIcon
|
||
|
? const Padding(
|
||
|
padding: EdgeInsets.all(15),
|
||
|
child: Icon(
|
||
|
Icons.delete_sweep_rounded,
|
||
|
color: Colors.black,
|
||
|
),
|
||
|
)
|
||
|
: null,
|
||
|
);
|
||
|
}
|
||
|
}
|