diff --git a/.editorconfig b/.editorconfig new file mode 100644 index 00000000..b9a82bce --- /dev/null +++ b/.editorconfig @@ -0,0 +1,53 @@ +root = true + +[*] +end_of_line = crlf +charset = utf-8 +indent_style = space +indent_size = 4 + +[*.{json,csproj,props,targets}] +indent_size = 2 + +[*.cs] +# Prefer "var" everywhere +csharp_style_var_for_built_in_types = true : suggestion +csharp_style_var_when_type_is_apparent = true : suggestion +csharp_style_var_elsewhere = true : suggestion + +# Newline settings +csharp_new_line_before_open_brace = all +csharp_new_line_before_else = true +csharp_new_line_before_catch = true +csharp_new_line_before_finally = true +csharp_new_line_before_members_in_object_initializers = true +csharp_new_line_before_members_in_anonymous_types = true + +# Sort using and Import directives with System.* appearing first +dotnet_sort_system_directives_first = true + +# Avoid "this." if not necessary +dotnet_style_qualification_for_field = false : suggestion +dotnet_style_qualification_for_property = false : suggestion +dotnet_style_qualification_for_method = false : suggestion +dotnet_style_qualification_for_event = false : suggestion + +# Use language keywords instead of framework type names for type references +dotnet_style_predefined_type_for_locals_parameters_members = true : suggestion +dotnet_style_predefined_type_for_member_access = false : suggestion + +# Suggest more modern language features when available +csharp_style_pattern_matching_over_is_with_cast_check = true : none +csharp_style_pattern_matching_over_as_with_null_check = true : none +csharp_style_inlined_variable_declaration = true : none +csharp_style_throw_expression = true : none +csharp_style_conditional_delegate_call = true : none + +dotnet_style_object_initializer = true : suggestion +dotnet_style_collection_initializer = true : suggestion +dotnet_style_coalesce_expression = true : suggestion +dotnet_style_null_propagation = true : suggestion +dotnet_style_explicit_tuple_names = true : suggestion + +trim_trailing_whitespace = true +insert_final_newline = true \ No newline at end of file diff --git a/Oqtane.Client/AssemblyInfo.cs b/Oqtane.Client/AssemblyInfo.cs new file mode 100644 index 00000000..d598bfb9 --- /dev/null +++ b/Oqtane.Client/AssemblyInfo.cs @@ -0,0 +1,3 @@ +using Microsoft.Extensions.Localization; + +[assembly: RootNamespace("Oqtane")] diff --git a/Oqtane.Client/Modules/Admin/Error/Index.razor b/Oqtane.Client/Modules/Admin/Error/Index.razor index 9e0df574..7ddb0ce3 100644 --- a/Oqtane.Client/Modules/Admin/Error/Index.razor +++ b/Oqtane.Client/Modules/Admin/Error/Index.razor @@ -8,7 +8,7 @@ protected override async Task OnInitializedAsync() { Module module = await ModuleService.GetModuleAsync(ModuleState.ModuleId); - if (UserSecurity.IsAuthorized(PageState.User, Constants.HostRole)) + if (UserSecurity.IsAuthorized(PageState.User, RoleNames.Host)) { string message = "A Problem Was Encountered Loading Module " + module.ModuleDefinitionName; AddModuleMessage(message, MessageType.Error); diff --git a/Oqtane.Client/Modules/Admin/Files/Edit.razor b/Oqtane.Client/Modules/Admin/Files/Edit.razor index 2c502690..73cac84d 100644 --- a/Oqtane.Client/Modules/Admin/Files/Edit.razor +++ b/Oqtane.Client/Modules/Admin/Files/Edit.razor @@ -1,6 +1,7 @@ @namespace Oqtane.Modules.Admin.Files @inherits ModuleBase @inject IFolderService FolderService +@inject IFileService FileService @inject NavigationManager NavigationManager @if (_folders != null) @@ -45,7 +46,7 @@ Cancel @if (!_isSystem && PageState.QueryString.ContainsKey("id")) { - + }

@@ -193,13 +194,21 @@ } if (!isparent) { - await FolderService.DeleteFolderAsync(_folderId); - await logger.LogInformation("Folder Deleted {Folder}", _folderId); - NavigationManager.NavigateTo(NavigateUrl()); + var files = await FileService.GetFilesAsync(_folderId); + if (files.Count == 0) + { + await FolderService.DeleteFolderAsync(_folderId); + await logger.LogInformation("Folder Deleted {Folder}", _folderId); + NavigationManager.NavigateTo(NavigateUrl()); + } + else + { + AddModuleMessage("Folder Has Files And Cannot Be Deleted", MessageType.Warning); + } } else { - AddModuleMessage("Folder Has Child Folders And Cannot Be Deleted", MessageType.Warning); + AddModuleMessage("Folder Has Subfolders And Cannot Be Deleted", MessageType.Warning); } } catch (Exception ex) diff --git a/Oqtane.Client/Modules/Admin/Login/Index.razor b/Oqtane.Client/Modules/Admin/Login/Index.razor index 91248ec7..49815187 100644 --- a/Oqtane.Client/Modules/Admin/Login/Index.razor +++ b/Oqtane.Client/Modules/Admin/Login/Index.razor @@ -1,4 +1,4 @@ -@namespace Oqtane.Modules.Admin.Login +@namespace Oqtane.Modules.Admin.Login @inherits ModuleBase @inject NavigationManager NavigationManager @inject IUserService UserService @@ -16,14 +16,14 @@ -
+