mirror of https://github.com/immich-app/immich.git
feat(mobile): separate delete buttons (#4505)
* feat(mobile): delete assets from device only * mobile: add backed up only toggle for delete device only * remove toggle inside alert and show different content * mobile: change content color for local only * mobile: delete local only button to dialog * style: display bottom action in two lines * feat: separate delete buttons * fix: incorrect error message for ownedRemoteSelection * fix: handle remoteOnly from delete everywhere * request confirmation for local only only when non-backed assets are in selection --------- Co-authored-by: shalong-tanwen <139912620+shalong-tanwen@users.noreply.github.com> Co-authored-by: Alex Tran <alex.tran1502@gmail.com>pull/6444/head
parent
78de4f1312
commit
4c2befc68c
@ -1,16 +1,80 @@
|
|||||||
|
// ignore_for_file: prefer-single-widget-per-file
|
||||||
|
|
||||||
|
import 'package:easy_localization/easy_localization.dart';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:immich_mobile/extensions/build_context_extensions.dart';
|
||||||
import 'package:immich_mobile/shared/ui/confirm_dialog.dart';
|
import 'package:immich_mobile/shared/ui/confirm_dialog.dart';
|
||||||
|
|
||||||
class DeleteDialog extends ConfirmDialog {
|
class DeleteDialog extends ConfirmDialog {
|
||||||
final Function onDelete;
|
const DeleteDialog({Key? key, String? alert, required Function onDelete})
|
||||||
|
|
||||||
const DeleteDialog({Key? key, required this.onDelete})
|
|
||||||
: super(
|
: super(
|
||||||
key: key,
|
key: key,
|
||||||
title: "delete_dialog_title",
|
title: "delete_dialog_title",
|
||||||
content: "delete_dialog_alert",
|
content: alert ?? "delete_dialog_alert",
|
||||||
cancel: "delete_dialog_cancel",
|
cancel: "delete_dialog_cancel",
|
||||||
ok: "delete_dialog_ok",
|
ok: "delete_dialog_ok",
|
||||||
onOk: onDelete,
|
onOk: onDelete,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class DeleteLocalOnlyDialog extends StatelessWidget {
|
||||||
|
final void Function(bool onlyMerged) onDeleteLocal;
|
||||||
|
|
||||||
|
const DeleteLocalOnlyDialog({
|
||||||
|
super.key,
|
||||||
|
required this.onDeleteLocal,
|
||||||
|
});
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
void onDeleteBackedUpOnly() {
|
||||||
|
context.pop();
|
||||||
|
onDeleteLocal(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
void onForceDelete() {
|
||||||
|
context.pop();
|
||||||
|
onDeleteLocal(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
return AlertDialog(
|
||||||
|
shape: const RoundedRectangleBorder(
|
||||||
|
borderRadius: BorderRadius.all(Radius.circular(10)),
|
||||||
|
),
|
||||||
|
title: const Text("delete_dialog_title").tr(),
|
||||||
|
content: const Text("delete_dialog_alert_local_non_backed_up").tr(),
|
||||||
|
actions: [
|
||||||
|
TextButton(
|
||||||
|
onPressed: () => context.pop(),
|
||||||
|
child: Text(
|
||||||
|
"delete_dialog_cancel",
|
||||||
|
style: TextStyle(
|
||||||
|
color: context.primaryColor,
|
||||||
|
fontWeight: FontWeight.bold,
|
||||||
|
),
|
||||||
|
).tr(),
|
||||||
|
),
|
||||||
|
TextButton(
|
||||||
|
onPressed: onDeleteBackedUpOnly,
|
||||||
|
child: Text(
|
||||||
|
"delete_local_dialog_ok_backed_up_only",
|
||||||
|
style: TextStyle(
|
||||||
|
color: context.colorScheme.tertiary,
|
||||||
|
fontWeight: FontWeight.bold,
|
||||||
|
),
|
||||||
|
).tr(),
|
||||||
|
),
|
||||||
|
TextButton(
|
||||||
|
onPressed: onForceDelete,
|
||||||
|
child: Text(
|
||||||
|
"delete_local_dialog_ok_force",
|
||||||
|
style: TextStyle(
|
||||||
|
color: Colors.red[400],
|
||||||
|
fontWeight: FontWeight.bold,
|
||||||
|
),
|
||||||
|
).tr(),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
Loading…
Reference in New Issue