feat: improve confirm deletion dialog

This commit is contained in:
Lucas.Xu 2024-07-03 10:47:59 +08:00
parent 38f49d617f
commit 59b36f67c8
6 changed files with 113 additions and 100 deletions

View File

@ -19,6 +19,7 @@ import 'package:flowy_infra_ui/style_widget/hover.dart';
import 'package:flowy_infra_ui/widget/flowy_tooltip.dart'; import 'package:flowy_infra_ui/widget/flowy_tooltip.dart';
import 'package:flutter/cupertino.dart'; import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:flutter_bloc/flutter_bloc.dart'; import 'package:flutter_bloc/flutter_bloc.dart';
class SpacePermissionSwitch extends StatefulWidget { class SpacePermissionSwitch extends StatefulWidget {
@ -222,7 +223,7 @@ class SpaceCancelOrConfirmButton extends StatelessWidget {
} }
} }
class ConfirmDeletionPopup extends StatelessWidget { class ConfirmDeletionPopup extends StatefulWidget {
const ConfirmDeletionPopup({ const ConfirmDeletionPopup({
super.key, super.key,
required this.title, required this.title,
@ -234,9 +235,25 @@ class ConfirmDeletionPopup extends StatelessWidget {
final String description; final String description;
final VoidCallback onConfirm; final VoidCallback onConfirm;
@override
State<ConfirmDeletionPopup> createState() => _ConfirmDeletionPopupState();
}
class _ConfirmDeletionPopupState extends State<ConfirmDeletionPopup> {
final focusNode = FocusNode();
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
return Padding( return KeyboardListener(
focusNode: focusNode,
autofocus: true,
onKeyEvent: (event) {
if (event is KeyDownEvent &&
event.logicalKey == LogicalKeyboardKey.escape) {
Navigator.of(context).pop();
}
},
child: Padding(
padding: const EdgeInsets.symmetric( padding: const EdgeInsets.symmetric(
vertical: 20.0, vertical: 20.0,
horizontal: 20.0, horizontal: 20.0,
@ -248,7 +265,7 @@ class ConfirmDeletionPopup extends StatelessWidget {
Row( Row(
children: [ children: [
FlowyText( FlowyText(
title, widget.title,
fontSize: 14.0, fontSize: 14.0,
), ),
const Spacer(), const Spacer(),
@ -261,7 +278,7 @@ class ConfirmDeletionPopup extends StatelessWidget {
), ),
const VSpace(8.0), const VSpace(8.0),
FlowyText.regular( FlowyText.regular(
description, widget.description,
fontSize: 12.0, fontSize: 12.0,
color: Theme.of(context).hintColor, color: Theme.of(context).hintColor,
maxLines: 3, maxLines: 3,
@ -271,7 +288,7 @@ class ConfirmDeletionPopup extends StatelessWidget {
SpaceCancelOrConfirmButton( SpaceCancelOrConfirmButton(
onCancel: () => Navigator.of(context).pop(), onCancel: () => Navigator.of(context).pop(),
onConfirm: () { onConfirm: () {
onConfirm(); widget.onConfirm();
Navigator.of(context).pop(); Navigator.of(context).pop();
}, },
confirmButtonName: LocaleKeys.space_delete.tr(), confirmButtonName: LocaleKeys.space_delete.tr(),
@ -279,6 +296,7 @@ class ConfirmDeletionPopup extends StatelessWidget {
), ),
], ],
), ),
),
); );
} }
} }

View File

@ -227,32 +227,15 @@ class _SidebarSpaceHeaderState extends State<SidebarSpaceHeader> {
void _showDeleteSpaceDialog(BuildContext context) { void _showDeleteSpaceDialog(BuildContext context) {
final spaceBloc = context.read<SpaceBloc>(); final spaceBloc = context.read<SpaceBloc>();
showDialog(
context: context,
builder: (_) {
final space = spaceBloc.state.currentSpace; final space = spaceBloc.state.currentSpace;
final name = space != null ? space.name : ''; final name = space != null ? space.name : '';
final title = LocaleKeys.space_deleteConfirmation.tr() + name; showConfirmDeletionDialog(
return Dialog( context: context,
shape: RoundedRectangleBorder( name: name,
borderRadius: BorderRadius.circular(12.0), description: LocaleKeys.space_deleteConfirmationDescription.tr(),
),
child: BlocProvider.value(
value: spaceBloc,
child: SizedBox(
width: 440,
child: ConfirmDeletionPopup(
title: title,
description:
LocaleKeys.space_deleteConfirmationDescription.tr(),
onConfirm: () { onConfirm: () {
context.read<SpaceBloc>().add(const SpaceEvent.delete(null)); context.read<SpaceBloc>().add(const SpaceEvent.delete(null));
}, },
),
),
),
);
},
); );
} }
} }

View File

@ -105,14 +105,16 @@ class _WorkspaceMoreActionWrapper extends CustomActionCell {
case WorkspaceMoreAction.divider: case WorkspaceMoreAction.divider:
break; break;
case WorkspaceMoreAction.delete: case WorkspaceMoreAction.delete:
await NavigatorAlertDialog( await showConfirmDeletionDialog(
title: LocaleKeys.workspace_deleteWorkspaceHintText.tr(), context: context,
confirm: () { name: workspace.name,
description: LocaleKeys.workspace_deleteWorkspaceHintText.tr(),
onConfirm: () {
workspaceBloc.add( workspaceBloc.add(
UserWorkspaceEvent.deleteWorkspace(workspace.workspaceId), UserWorkspaceEvent.deleteWorkspace(workspace.workspaceId),
); );
}, },
).show(context); );
case WorkspaceMoreAction.rename: case WorkspaceMoreAction.rename:
await NavigatorTextFieldDialog( await NavigatorTextFieldDialog(
title: LocaleKeys.workspace_renameWorkspace.tr(), title: LocaleKeys.workspace_renameWorkspace.tr(),

View File

@ -14,7 +14,6 @@ import 'package:appflowy/workspace/application/view/view_ext.dart';
import 'package:appflowy/workspace/presentation/home/home_sizes.dart'; import 'package:appflowy/workspace/presentation/home/home_sizes.dart';
import 'package:appflowy/workspace/presentation/home/menu/menu_shared_state.dart'; import 'package:appflowy/workspace/presentation/home/menu/menu_shared_state.dart';
import 'package:appflowy/workspace/presentation/home/menu/sidebar/shared/rename_view_dialog.dart'; import 'package:appflowy/workspace/presentation/home/menu/sidebar/shared/rename_view_dialog.dart';
import 'package:appflowy/workspace/presentation/home/menu/sidebar/space/shared_widget.dart';
import 'package:appflowy/workspace/presentation/home/menu/view/draggable_view_item.dart'; import 'package:appflowy/workspace/presentation/home/menu/view/draggable_view_item.dart';
import 'package:appflowy/workspace/presentation/home/menu/view/view_action_type.dart'; import 'package:appflowy/workspace/presentation/home/menu/view/view_action_type.dart';
import 'package:appflowy/workspace/presentation/home/menu/view/view_add_button.dart'; import 'package:appflowy/workspace/presentation/home/menu/view/view_add_button.dart';
@ -726,7 +725,14 @@ class _SingleInnerViewItemState extends State<SingleInnerViewItem> {
views.map((e) => ViewBackendService.getPublishInfo(e)), views.map((e) => ViewBackendService.getPublishInfo(e)),
).then((value) => value.where((e) => e.isSuccess)); ).then((value) => value.where((e) => e.isSuccess));
if (containPublishedPage.isNotEmpty && context.mounted) { if (containPublishedPage.isNotEmpty && context.mounted) {
_showDeleteDialog(context); await showConfirmDeletionDialog(
context: context,
name: widget.view.name,
description: LocaleKeys.publish_containsPublishedPage.tr(),
onConfirm: () {
context.read<ViewBloc>().add(const ViewEvent.delete());
},
);
} else if (context.mounted) { } else if (context.mounted) {
context.read<ViewBloc>().add(const ViewEvent.delete()); context.read<ViewBloc>().add(const ViewEvent.delete());
} }
@ -790,30 +796,6 @@ class _SingleInnerViewItemState extends State<SingleInnerViewItem> {
} }
return LocaleKeys.newPageText.tr(); return LocaleKeys.newPageText.tr();
} }
void _showDeleteDialog(BuildContext context) {
showDialog(
context: context,
builder: (_) {
return Dialog(
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(12.0),
),
child: SizedBox(
width: 440,
child: ConfirmDeletionPopup(
title:
LocaleKeys.space_deleteConfirmation.tr() + widget.view.name,
description: LocaleKeys.publish_containsPublishedPage.tr(),
onConfirm: () {
context.read<ViewBloc>().add(const ViewEvent.delete());
},
),
),
);
},
);
}
} }
class _DotIconWidget extends StatelessWidget { class _DotIconWidget extends StatelessWidget {

View File

@ -1,5 +1,6 @@
import 'package:appflowy/generated/locale_keys.g.dart'; import 'package:appflowy/generated/locale_keys.g.dart';
import 'package:appflowy/startup/tasks/app_widget.dart'; import 'package:appflowy/startup/tasks/app_widget.dart';
import 'package:appflowy/workspace/presentation/home/menu/sidebar/space/shared_widget.dart';
import 'package:easy_localization/easy_localization.dart'; import 'package:easy_localization/easy_localization.dart';
import 'package:flowy_infra/size.dart'; import 'package:flowy_infra/size.dart';
import 'package:flowy_infra_ui/style_widget/text.dart'; import 'package:flowy_infra_ui/style_widget/text.dart';
@ -300,3 +301,30 @@ void showToastNotification(
showProgressBar: false, showProgressBar: false,
); );
} }
Future<void> showConfirmDeletionDialog({
required BuildContext context,
required String name,
required String description,
required VoidCallback onConfirm,
}) {
return showDialog(
context: context,
builder: (_) {
final title = LocaleKeys.space_deleteConfirmation.tr() + name;
return Dialog(
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(12.0),
),
child: SizedBox(
width: 440,
child: ConfirmDeletionPopup(
title: title,
description: description,
onConfirm: onConfirm,
),
),
);
},
);
}

View File

@ -82,7 +82,7 @@
"reachOut": "Reach out on Discord" "reachOut": "Reach out on Discord"
}, },
"menuTitle": "Workspaces", "menuTitle": "Workspaces",
"deleteWorkspaceHintText": "Are you sure you want to delete the workspace? This action cannot be undone.", "deleteWorkspaceHintText": "Are you sure you want to delete the workspace? This action cannot be undone, and any pages you have published will be unpublished.",
"createSuccess": "Workspace created successfully", "createSuccess": "Workspace created successfully",
"createFailed": "Failed to create workspace", "createFailed": "Failed to create workspace",
"createLimitExceeded": "You've reached the maximum workspace limit allowed for your account. If you need additional workspaces to continue your work, please request on Github", "createLimitExceeded": "You've reached the maximum workspace limit allowed for your account. If you need additional workspaces to continue your work, please request on Github",
@ -439,7 +439,7 @@
}, },
"deleteWorkspacePrompt": { "deleteWorkspacePrompt": {
"title": "Delete workspace", "title": "Delete workspace",
"content": "Are you sure you want to delete this workspace? This action cannot be undone." "content": "Are you sure you want to delete this workspace? This action cannot be undone, and any pages you have published will be unpublished."
}, },
"leaveWorkspacePrompt": { "leaveWorkspacePrompt": {
"title": "Leave workspace", "title": "Leave workspace",
@ -2008,7 +2008,7 @@
"space": { "space": {
"delete": "Delete", "delete": "Delete",
"deleteConfirmation": "Delete: ", "deleteConfirmation": "Delete: ",
"deleteConfirmationDescription": "All pages within this Space will be deleted and moved to Trash.", "deleteConfirmationDescription": "All pages within this Space will be deleted and moved to the Trash, and any published pages will be unpublished.",
"rename": "Rename Space", "rename": "Rename Space",
"changeIcon": "Change icon", "changeIcon": "Change icon",
"manage": "Manage Space", "manage": "Manage Space",