From 12fcb7cc6cde315457a5ad94acde4c9e03eddf2c Mon Sep 17 00:00:00 2001 From: KhaledNjim Date: Mon, 5 Aug 2024 19:37:37 +0100 Subject: [PATCH] LA-1358: Add validation for names ending with dot in workspace, workgroup, and folder creation/editing --- .../extensions/linshare_node_type_extension.dart | 13 +++++++++++-- .../shared_space_document_viewmodel.dart | 2 +- 2 files changed, 12 insertions(+), 3 deletions(-) diff --git a/lib/presentation/util/extensions/linshare_node_type_extension.dart b/lib/presentation/util/extensions/linshare_node_type_extension.dart index e0d08e5a7..1a27cb0f6 100644 --- a/lib/presentation/util/extensions/linshare_node_type_extension.dart +++ b/lib/presentation/util/extensions/linshare_node_type_extension.dart @@ -57,6 +57,10 @@ extension LinShareNodeTypeExtension on LinShareNodeType { return AppLocalizations.of(context).node_name_already_exists(AppLocalizations.of(context).workgroup); } else if (exception is SpecialCharacterException) { return AppLocalizations.of(context).node_name_contain_special_character(AppLocalizations.of(context).workgroup); + } else if (exception is LastDotException) { + return AppLocalizations.of(context).node_name_contain_last_dot( + AppLocalizations.of(context).workgroup); + } else { return null; } @@ -67,6 +71,9 @@ extension LinShareNodeTypeExtension on LinShareNodeType { return AppLocalizations.of(context).node_name_already_exists(AppLocalizations.of(context).workspace); } else if (exception is SpecialCharacterException) { return AppLocalizations.of(context).node_name_contain_special_character(AppLocalizations.of(context).workspace); + } else if (exception is LastDotException) { + return AppLocalizations.of(context).node_name_contain_last_dot( + AppLocalizations.of(context).workspace); } else { return null; } @@ -86,12 +93,14 @@ extension LinShareNodeTypeExtension on LinShareNodeType { return [ EmptyNameValidator(), DuplicateNameValidator(sharedSpaceNodes.map((node) => node.name).toList()), - SpecialCharacterValidator() + SpecialCharacterValidator(), + LastDotValidator() ]; case LinShareNodeType.WORK_SPACE: return [ EmptyNameValidator(), - SpecialCharacterValidator() + SpecialCharacterValidator(), + LastDotValidator() ]; } } diff --git a/lib/presentation/widget/shared_space_document/shared_space_document_viewmodel.dart b/lib/presentation/widget/shared_space_document/shared_space_document_viewmodel.dart index 3df1787f7..9dea56379 100644 --- a/lib/presentation/widget/shared_space_document/shared_space_document_viewmodel.dart +++ b/lib/presentation/widget/shared_space_document/shared_space_document_viewmodel.dart @@ -807,7 +807,7 @@ class SharedSpaceDocumentNodeViewModel extends BaseViewModel { EmptyNameValidator(), DuplicateNameValidator(listName), SpecialCharacterValidator(), - if (workGroupNode is WorkGroupDocument) LastDotValidator() + LastDotValidator() ]).fold((failure) { if (failure is VerifyNameFailure) { final nodeName = workGroupNode is WorkGroupDocument