diff --git a/.editorconfig b/.editorconfig new file mode 100644 index 0000000..a899bb6 --- /dev/null +++ b/.editorconfig @@ -0,0 +1,132 @@ +############################### +# Core EditorConfig Options # +############################### +root = true +# All files +[*] +indent_style = space + +# XML project files +[*.{csproj,vbproj,vcxproj,vcxproj.filters,proj,projitems,shproj}] +indent_size = 2 + +# XML config files +[*.{props,targets,ruleset,config,nuspec,resx,vsixmanifest,vsct}] +indent_size = 2 + +# Code files +[*.{cs,csx,vb,vbx,xaml}] +indent_size = 4 +insert_final_newline = false +charset = utf-8-bom +############################### +# .NET Coding Conventions # +############################### +[*.{cs,vb}] +# Organize usings +dotnet_sort_system_directives_first = true +# this. preferences +dotnet_style_qualification_for_field = false:silent +dotnet_style_qualification_for_property = false:silent +dotnet_style_qualification_for_method = false:silent +dotnet_style_qualification_for_event = false:silent +# Language keywords vs BCL types preferences +dotnet_style_predefined_type_for_locals_parameters_members = true:silent +dotnet_style_predefined_type_for_member_access = true:silent +# Parentheses preferences +dotnet_style_parentheses_in_arithmetic_binary_operators = always_for_clarity:silent +dotnet_style_parentheses_in_relational_binary_operators = always_for_clarity:silent +dotnet_style_parentheses_in_other_binary_operators = always_for_clarity:silent +dotnet_style_parentheses_in_other_operators = never_if_unnecessary:silent +# Modifier preferences +dotnet_style_require_accessibility_modifiers = for_non_interface_members:silent +dotnet_style_readonly_field = true:suggestion +# Expression-level preferences +dotnet_style_object_initializer = true:suggestion +dotnet_style_collection_initializer = true:suggestion +dotnet_style_explicit_tuple_names = true:suggestion +dotnet_style_null_propagation = true:suggestion +dotnet_style_coalesce_expression = true:suggestion +dotnet_style_prefer_is_null_check_over_reference_equality_method = true:silent +dotnet_style_prefer_inferred_tuple_names = true:suggestion +dotnet_style_prefer_inferred_anonymous_type_member_names = true:suggestion +dotnet_style_prefer_auto_properties = true:silent +dotnet_style_prefer_conditional_expression_over_assignment = true:silent +dotnet_style_prefer_conditional_expression_over_return = true:silent +############################### +# Naming Conventions # +############################### +# Style Definitions +dotnet_naming_style.pascal_case_style.capitalization = pascal_case +# Use PascalCase for constant fields +dotnet_naming_rule.constant_fields_should_be_pascal_case.severity = suggestion +dotnet_naming_rule.constant_fields_should_be_pascal_case.symbols = constant_fields +dotnet_naming_rule.constant_fields_should_be_pascal_case.style = pascal_case_style +dotnet_naming_symbols.constant_fields.applicable_kinds = field +dotnet_naming_symbols.constant_fields.applicable_accessibilities = * +dotnet_naming_symbols.constant_fields.required_modifiers = const +############################### +# C# Coding Conventions # +############################### +[*.cs] +# var preferences +csharp_style_var_for_built_in_types = true:silent +csharp_style_var_when_type_is_apparent = true:silent +csharp_style_var_elsewhere = true:silent +# Expression-bodied members +csharp_style_expression_bodied_methods = false:silent +csharp_style_expression_bodied_constructors = false:silent +csharp_style_expression_bodied_operators = false:silent +csharp_style_expression_bodied_properties = true:silent +csharp_style_expression_bodied_indexers = true:silent +csharp_style_expression_bodied_accessors = true:silent +# Pattern matching preferences +csharp_style_pattern_matching_over_is_with_cast_check = true:suggestion +csharp_style_pattern_matching_over_as_with_null_check = true:suggestion +# Null-checking preferences +csharp_style_throw_expression = true:suggestion +csharp_style_conditional_delegate_call = true:suggestion +# Modifier preferences +csharp_preferred_modifier_order = public,private,protected,internal,static,extern,new,virtual,abstract,sealed,override,readonly,unsafe,volatile,async:suggestion +# Expression-level preferences +csharp_prefer_braces = true:silent +csharp_style_deconstructed_variable_declaration = true:suggestion +csharp_prefer_simple_default_expression = true:suggestion +csharp_style_prefer_local_over_anonymous_function = true:suggestion +csharp_style_inlined_variable_declaration = true:suggestion +############################### +# C# Formatting Rules # +############################### +# New line preferences +csharp_new_line_before_open_brace = none +csharp_new_line_before_else = false +csharp_new_line_before_catch = false +csharp_new_line_before_finally = false +csharp_new_line_before_members_in_object_initializers = false +csharp_new_line_before_members_in_anonymous_types = false +csharp_new_line_between_query_expression_clauses = false +# Indentation preferences +csharp_indent_case_contents = false +csharp_indent_switch_labels = true +csharp_indent_labels = flush_left +# Space preferences +csharp_space_after_cast = true +csharp_space_after_keywords_in_control_flow_statements = false +csharp_space_between_method_call_parameter_list_parentheses = false +csharp_space_between_method_declaration_parameter_list_parentheses = false +csharp_space_between_parentheses = false +csharp_space_before_colon_in_inheritance_clause = true +csharp_space_after_colon_in_inheritance_clause = true +csharp_space_around_binary_operators = before_and_after +csharp_space_between_method_declaration_empty_parameter_list_parentheses = false +csharp_space_between_method_call_name_and_opening_parenthesis = false +csharp_space_between_method_call_empty_parameter_list_parentheses = false +# Wrapping preferences +csharp_preserve_single_line_statements = true +csharp_preserve_single_line_blocks = true +############################### +# VB Coding Conventions # +############################### +[*.vb] +# Modifier preferences +visual_basic_preferred_modifier_order = Partial,Default,Private,Protected,Public,Friend,NotOverridable,Overridable,MustOverride,Overloads,Overrides,MustInherit,NotInheritable,Static,Shared,Shadows,ReadOnly,WriteOnly,Dim,Const,WithEvents,Widening,Narrowing,Custom,Async:suggestion diff --git a/App.xaml.cs b/App.xaml.cs index 21df0fa..e135e75 100644 --- a/App.xaml.cs +++ b/App.xaml.cs @@ -1,10 +1,9 @@ namespace YOUserbase; -public partial class App : Application { - public App () - { - InitializeComponent (); - - MainPage = new LoginShell (); - } -} +public partial class App : Application { + public App() { + InitializeComponent(); + + MainPage = new LoginShell(); + } +} \ No newline at end of file diff --git a/AppShell.xaml.cs b/AppShell.xaml.cs index 94fe0b5..3cc5e5f 100644 --- a/AppShell.xaml.cs +++ b/AppShell.xaml.cs @@ -1,10 +1,8 @@ namespace YOUserbase; -public partial class AppShell : Shell -{ - public AppShell() - { - InitializeComponent(); - Routing.RegisterRoute(nameof(UserOverviewPage), typeof(UserOverviewPage)); - } -} +public partial class AppShell : Shell { + public AppShell() { + InitializeComponent(); + Routing.RegisterRoute(nameof(UserOverviewPage), typeof(UserOverviewPage)); + } +} \ No newline at end of file diff --git a/CreateGroupPage.xaml.cs b/CreateGroupPage.xaml.cs index bee4da4..0f7b9ab 100644 --- a/CreateGroupPage.xaml.cs +++ b/CreateGroupPage.xaml.cs @@ -1,63 +1,59 @@ namespace YOUserbase; -public partial class CreateGroupPage : ContentPage -{ +public partial class CreateGroupPage : ContentPage { - private Group group; + private Group group; - public CreateGroupPage() - { + public CreateGroupPage() { InitializeComponent(); - } + } - public CreateGroupPage(Group group) { - InitializeComponent(); - this.group = group; - NameEntry.Text = group.Name; - DetailsEntry.Text = group.Details; - btnCreate.Text = "Save"; + public CreateGroupPage(Group group) { + InitializeComponent(); + this.group = group; + NameEntry.Text = group.Name; + DetailsEntry.Text = group.Details; + btnCreate.Text = "Save"; contentPage.Title = "Edit user"; } - private void OnCreateClicked (object sender, EventArgs e) - { - var isValid = true; + private void OnCreateClicked(object sender, EventArgs e) { + var isValid = true; string text = NameEntry.Text; - errName.Text = ""; - if (String.IsNullOrWhiteSpace(text)) { - isValid = false; - errName.Text = "First name cannot be empty"; - } else if (text.Length > 20) { - isValid = false; - errName.Text = "First name cannot be longer than 20 characters"; + errName.Text = ""; + if(String.IsNullOrWhiteSpace(text)) { + isValid = false; + errName.Text = "First name cannot be empty"; + } else if(text.Length > 20) { + isValid = false; + errName.Text = "First name cannot be longer than 20 characters"; } - text = DetailsEntry.Text; - errDetails.Text = ""; - if (String.IsNullOrWhiteSpace(text)) { - isValid = false; - errDetails.Text = "Last name cannot be empty"; - } else if (text.Length > 500) { - isValid = false; - errDetails.Text = "Last name cannot be longer than 20 characters"; + text = DetailsEntry.Text; + errDetails.Text = ""; + if(String.IsNullOrWhiteSpace(text)) { + isValid = false; + errDetails.Text = "Last name cannot be empty"; + } else if(text.Length > 500) { + isValid = false; + errDetails.Text = "Last name cannot be longer than 20 characters"; } - errAll.Text = ""; - if (Data.Groups.Where(x => x.Name == NameEntry.Text).Any()) { - isValid = false; - errAll.Text = "Group with the same name already exists"; + errAll.Text = ""; + if(Data.Groups.Where(x => x.Name == NameEntry.Text).Any()) { + isValid = false; + errAll.Text = "Group with the same name already exists"; } - if (isValid) { - if (group != null) { // Update - var grp = Data.Groups.FirstOrDefault(gr => gr.Id == group.Id); + if(isValid) { + if(group != null) { // Update + var grp = Data.Groups.FirstOrDefault(gr => gr.Id == group.Id); grp.Name = NameEntry.Text; grp.Details = DetailsEntry.Text; } else { // Create - Data.Groups.Add(new Group - { + Data.Groups.Add(new Group { Name = NameEntry.Text, Details = DetailsEntry.Text, }); } - Navigation.PopAsync(); + Navigation.PopAsync(); } - } -} + } +} \ No newline at end of file diff --git a/CreateUserPage.xaml.cs b/CreateUserPage.xaml.cs index bf08e63..01d836d 100644 --- a/CreateUserPage.xaml.cs +++ b/CreateUserPage.xaml.cs @@ -5,97 +5,94 @@ namespace YOUserbase; public partial class CreateUserPage : ContentPage { - private User user; + private User user; - public CreateUserPage () - { - InitializeComponent (); - groupPicker.ItemsSource = new List (Data.Groups.Select (x => x.Name)); - } + public CreateUserPage() { + InitializeComponent(); + groupPicker.ItemsSource = new List(Data.Groups.Select(x => x.Name)); + } - public CreateUserPage (User user) - { - InitializeComponent (); - this.user = user; - FirstnameEntry.Text = user.Firstname; - LastnameEntry.Text = user.Lastname; - birthdatePicker.Date = user.BirthDate; - FullTimeSwitch.IsToggled = user.IsFullTime; - DetailsEntry.Text = user.Details; - IsExternalCheck.IsChecked = user.IsExternal; - IsRemoteCheck.IsChecked = user.IsRemote; - NbProjectsStepper.Value = user.NbProjects; - groupPicker.ItemsSource = new List (Data.Groups.Select (x => x.Name)); - groupPicker.SelectedIndex = Data.Groups.IndexOf (user.WorkingGroup); - btnCreate.Text = "Save"; - contentPage.Title = "Edit user"; - } + public CreateUserPage(User user) { + InitializeComponent(); + this.user = user; + FirstnameEntry.Text = user.Firstname; + LastnameEntry.Text = user.Lastname; + birthdatePicker.Date = user.BirthDate; + FullTimeSwitch.IsToggled = user.IsFullTime; + DetailsEntry.Text = user.Details; + IsExternalCheck.IsChecked = user.IsExternal; + IsRemoteCheck.IsChecked = user.IsRemote; + NbProjectsStepper.Value = user.NbProjects; + groupPicker.ItemsSource = new List(Data.Groups.Select(x => x.Name)); + groupPicker.SelectedIndex = Data.Groups.IndexOf(user.WorkingGroup); + btnCreate.Text = "Save"; + contentPage.Title = "Edit user"; + } - private async void OnCreateClicked (object sender, EventArgs e) - { - var isValid = true; - string text = FirstnameEntry.Text; - errFirstname.Text = ""; - if (String.IsNullOrWhiteSpace (text)) { - isValid = false; - errFirstname.Text = "First name cannot be empty"; - } else if (text.Length > 20) { - isValid = false; - errFirstname.Text = "First name cannot be longer than 20 characters"; - } - text = LastnameEntry.Text; - errLastname.Text = ""; - if (String.IsNullOrWhiteSpace (text)) { - isValid = false; - errLastname.Text = "Last name cannot be empty"; - } else if (text.Length > 20) { - isValid = false; - errLastname.Text = "Last name cannot be longer than 20 characters"; - } - var date = birthdatePicker.Date; - errBirthDate.Text = ""; - if (DateTime.Compare (date, DateTime.Today) > 0) { - isValid = false; - errBirthDate.Text = "Birth date cannot be in the future"; - } - errGroup.Text = ""; - if (groupPicker.SelectedIndex == -1) { - errGroup.Text = "You have to select a valid group"; - } - errDetails.Text = ""; - if (DetailsEntry.Text.Length > 100) { - errDetails.Text = "Detail cannot be longer than 100 characters"; - } - if (isValid) { - // Update - if (user != null) { - var usr = Data.Users.FirstOrDefault (usr => usr.Id == user.Id); - usr.Firstname = FirstnameEntry.Text; - usr.Lastname = LastnameEntry.Text; - usr.BirthDate = birthdatePicker.Date.Date; - usr.WorkingGroup = Data.Groups [groupPicker.SelectedIndex]; - usr.Details = DetailsEntry.Text; - usr.IsFullTime = FullTimeSwitch.IsToggled; - usr.IsExternal = IsExternalCheck.IsChecked; - usr.IsRemote = IsRemoteCheck.IsChecked; - usr.NbProjects = (int)NbProjectsStepper.Value; - } else { // Create - Data.Users.Add (new User { - Firstname = FirstnameEntry.Text, - Lastname = LastnameEntry.Text, - BirthDate = birthdatePicker.Date.Date, - WorkingGroup = Data.Groups [groupPicker.SelectedIndex], - Details = DetailsEntry.Text, - IsFullTime = FullTimeSwitch.IsToggled, - IsExternal = IsExternalCheck.IsChecked, - IsRemote = IsRemoteCheck.IsChecked, - NbProjects = (int)NbProjectsStepper.Value, - }); - } - await Navigation.PopAsync (); - } - } + private async void OnCreateClicked(object sender, EventArgs e) { + var isValid = true; + string text = FirstnameEntry.Text; + errFirstname.Text = ""; + if(String.IsNullOrWhiteSpace(text)) { + isValid = false; + errFirstname.Text = "First name cannot be empty"; + } else if(text.Length > 20) { + isValid = false; + errFirstname.Text = "First name cannot be longer than 20 characters"; + } + text = LastnameEntry.Text; + errLastname.Text = ""; + if(String.IsNullOrWhiteSpace(text)) { + isValid = false; + errLastname.Text = "Last name cannot be empty"; + } else if(text.Length > 20) { + isValid = false; + errLastname.Text = "Last name cannot be longer than 20 characters"; + } + var date = birthdatePicker.Date; + errBirthDate.Text = ""; + if(DateTime.Compare(date, DateTime.Today) > 0) { + isValid = false; + errBirthDate.Text = "Birth date cannot be in the future"; + } + errGroup.Text = ""; + if(groupPicker.SelectedIndex == -1) { + errGroup.Text = "You have to select a valid group"; + } + errDetails.Text = ""; + if(DetailsEntry.Text.Length > 100) { + errDetails.Text = "Detail cannot be longer than 100 characters"; + } + if(isValid) { + // Update + if(user != null) { + var usr = Data.Users.FirstOrDefault(usr => usr.Id == user.Id); + usr.Firstname = FirstnameEntry.Text; + usr.Lastname = LastnameEntry.Text; + usr.BirthDate = birthdatePicker.Date.Date; + usr.WorkingGroup = Data.Groups[groupPicker.SelectedIndex]; + usr.Details = DetailsEntry.Text; + usr.IsFullTime = FullTimeSwitch.IsToggled; + usr.IsExternal = IsExternalCheck.IsChecked; + usr.IsRemote = IsRemoteCheck.IsChecked; + usr.NbProjects = (int) NbProjectsStepper.Value; + } else { // Create + Data.Users.Add(new User { + Firstname = FirstnameEntry.Text, + Lastname = LastnameEntry.Text, + BirthDate = birthdatePicker.Date.Date, + WorkingGroup = Data.Groups[groupPicker.SelectedIndex], + Details = DetailsEntry.Text, + IsFullTime = FullTimeSwitch.IsToggled, + IsExternal = IsExternalCheck.IsChecked, + IsRemote = IsRemoteCheck.IsChecked, + NbProjects = (int) NbProjectsStepper.Value, + }); + } + await Navigation.PopAsync(); + } + } - void OnStepperChanged (System.Object sender, Microsoft.Maui.Controls.ValueChangedEventArgs e) => - lblNbProj.Text = ((Stepper)sender).Value.ToString (); -} + void OnStepperChanged(System.Object sender, Microsoft.Maui.Controls.ValueChangedEventArgs e) => + lblNbProj.Text = ((Stepper) sender).Value.ToString(); +} \ No newline at end of file diff --git a/Data.cs b/Data.cs index a40f47e..aa217ce 100644 --- a/Data.cs +++ b/Data.cs @@ -4,8 +4,8 @@ using System.ComponentModel; using System.Runtime.CompilerServices; namespace YOUserbase { - public static class Data { - public static ObservableCollection Groups = new ObservableCollection { + public static class Data { + public static ObservableCollection Groups = new ObservableCollection { new Group { Name = "Computer Scientists", Details = "Those weird guys", @@ -17,7 +17,7 @@ namespace YOUserbase { }; - public static ObservableCollection Users = new ObservableCollection { + public static ObservableCollection Users = new ObservableCollection { new User { Firstname = "Kimi", Lastname = "Loeffel", @@ -41,5 +41,5 @@ namespace YOUserbase { }, }; - } + } } \ No newline at end of file diff --git a/FAQPage.xaml.cs b/FAQPage.xaml.cs index 9a50cf1..c7c0d85 100644 --- a/FAQPage.xaml.cs +++ b/FAQPage.xaml.cs @@ -1,9 +1,7 @@ namespace YOUserbase; -public partial class FAQPage : ContentPage -{ - public FAQPage() - { - InitializeComponent(); - } -} +public partial class FAQPage : ContentPage { + public FAQPage() { + InitializeComponent(); + } +} \ No newline at end of file diff --git a/Group.cs b/Group.cs index a062ed9..caee3a7 100644 --- a/Group.cs +++ b/Group.cs @@ -1,37 +1,36 @@ -using System.ComponentModel; +using System.ComponentModel; using System.Runtime.CompilerServices; namespace YOUserbase { - public class Group : INotifyPropertyChanged { - int id; - string name; - string details; - public int Id { get => id; set => ChangeValue(ref id, value); } - public string Name { get => name; set => ChangeValue(ref name, value); } - public string Details { get => details; set => ChangeValue(ref details, value); } + public class Group : INotifyPropertyChanged { + int id; + string name; + string details; + public int Id { get => id; set => ChangeValue(ref id, value); } + public string Name { get => name; set => ChangeValue(ref name, value); } + public string Details { get => details; set => ChangeValue(ref details, value); } - private static int index = 0; + private static int index = 0; - public Group() { - Id = ++index; + public Group() { + Id = ++index; } - // Change value so setter looks a bit nicer :) - private void ChangeValue(ref T field, T value) { - if (!value.Equals(field)) { - field = value; - NotifyPropertyChanged(); + // Change value so setter looks a bit nicer :) + private void ChangeValue(ref T field, T value) { + if(!value.Equals(field)) { + field = value; + NotifyPropertyChanged(); } } - // This method is called by the Set accessor of each property. - // The CallerMemberName attribute that is applied to the optional propertyName - // parameter causes the property name of the caller to be substituted as an argument. - private void NotifyPropertyChanged ([CallerMemberName] string propertyName = "") - { - if (PropertyChanged != null) { PropertyChanged (this, new PropertyChangedEventArgs (propertyName)); } - } + // This method is called by the Set accessor of each property. + // The CallerMemberName attribute that is applied to the optional propertyName + // parameter causes the property name of the caller to be substituted as an argument. + private void NotifyPropertyChanged([CallerMemberName] string propertyName = "") { + if(PropertyChanged != null) { PropertyChanged(this, new PropertyChangedEventArgs(propertyName)); } + } - public event PropertyChangedEventHandler PropertyChanged; - } -} + public event PropertyChangedEventHandler PropertyChanged; + } +} \ No newline at end of file diff --git a/GroupOverviewPage.xaml.cs b/GroupOverviewPage.xaml.cs index 3bbf09d..f3b87d5 100644 --- a/GroupOverviewPage.xaml.cs +++ b/GroupOverviewPage.xaml.cs @@ -5,55 +5,50 @@ using System.Runtime.CompilerServices; namespace YOUserbase; public partial class GroupOverviewPage : ContentPage { - public int _index = 0; - - private string details; - private string name; - public string Details { get => details; set => SetProperty (ref details, value); } - public string Name { get => name; set => SetProperty (ref name, value); } - - public GroupOverviewPage () - { - InitializeComponent (); - groups.ItemsSource = Data.Groups; - } - - private async void OnAdd (object sender, EventArgs e) - { - await Navigation.PushAsync (new CreateGroupPage ()); - } - - private async void OnDeleteItem (object sender, EventArgs e) - { - Button btn = (Button)sender; - var id = Int32.Parse (btn.ClassId); - var group = Data.Groups.FirstOrDefault (usr => usr.Id == id); - var action = await DisplayAlert ("Irreversible action", "Do you really want to delete this group?\nThis will also delete every User that that belongs to this group", "Yes", "No"); - if (action) { - while (Data.Users.FirstOrDefault (usr => usr.WorkingGroup == group) != null) { - Data.Users.Remove (Data.Users.FirstOrDefault (usr => usr.WorkingGroup == group)); - } - Data.Groups.Remove (group); - } - } - - private async void OnEditItem (object sender, EventArgs e) - { - Button btn = (Button)sender; - var id = Int32.Parse (btn.ClassId); - var group = Data.Groups.FirstOrDefault (usr => usr.Id == id); - Console.WriteLine("there"); - await Navigation.PushAsync(new CreateGroupPage(group)); - Console.WriteLine("and there"); - } - - protected bool SetProperty (ref T field, T newValue, [CallerMemberName] string propertyName = null) - { - if (!Equals (field, newValue)) { - field = newValue; - return true; - } - - return false; - } -} + public int _index = 0; + + private string details; + private string name; + public string Details { get => details; set => SetProperty(ref details, value); } + public string Name { get => name; set => SetProperty(ref name, value); } + + public GroupOverviewPage() { + InitializeComponent(); + groups.ItemsSource = Data.Groups; + } + + private async void OnAdd(object sender, EventArgs e) { + await Navigation.PushAsync(new CreateGroupPage()); + } + + private async void OnDeleteItem(object sender, EventArgs e) { + Button btn = (Button) sender; + var id = Int32.Parse(btn.ClassId); + var group = Data.Groups.FirstOrDefault(usr => usr.Id == id); + var action = await DisplayAlert("Irreversible action", "Do you really want to delete this group?\nThis will also delete every User that that belongs to this group", "Yes", "No"); + if(action) { + while(Data.Users.FirstOrDefault(usr => usr.WorkingGroup == group) != null) { + Data.Users.Remove(Data.Users.FirstOrDefault(usr => usr.WorkingGroup == group)); + } + Data.Groups.Remove(group); + } + } + + private async void OnEditItem(object sender, EventArgs e) { + Button btn = (Button) sender; + var id = Int32.Parse(btn.ClassId); + var group = Data.Groups.FirstOrDefault(usr => usr.Id == id); + Console.WriteLine("there"); + await Navigation.PushAsync(new CreateGroupPage(group)); + Console.WriteLine("and there"); + } + + protected bool SetProperty(ref T field, T newValue, [CallerMemberName] string propertyName = null) { + if(!Equals(field, newValue)) { + field = newValue; + return true; + } + + return false; + } +} \ No newline at end of file diff --git a/ImpressumPage.xaml.cs b/ImpressumPage.xaml.cs index 8b72c02..ad7229f 100644 --- a/ImpressumPage.xaml.cs +++ b/ImpressumPage.xaml.cs @@ -1,9 +1,7 @@ namespace YOUserbase; -public partial class ImpressumPage : ContentPage -{ - public ImpressumPage() - { - InitializeComponent(); - } -} +public partial class ImpressumPage : ContentPage { + public ImpressumPage() { + InitializeComponent(); + } +} \ No newline at end of file diff --git a/LoginPage.xaml.cs b/LoginPage.xaml.cs index 0dda76e..eac2112 100644 --- a/LoginPage.xaml.cs +++ b/LoginPage.xaml.cs @@ -1,17 +1,15 @@ namespace YOUserbase; public partial class LoginPage : ContentPage { - public LoginPage () - { - InitializeComponent (); - } + public LoginPage() { + InitializeComponent(); + } - private async void OnLoginClicked (object sender, EventArgs e) - { - if (UsernameEntry.Text == "admin" && UsernameEntry.Text == "admin") { - Application.Current.MainPage = new AppShell (); - } else { - await DisplayAlert ("Error", "Invalid username or password", "OK"); - } - } -} + private async void OnLoginClicked(object sender, EventArgs e) { + if(UsernameEntry.Text == "admin" && UsernameEntry.Text == "admin") { + Application.Current.MainPage = new AppShell(); + } else { + await DisplayAlert("Error", "Invalid username or password", "OK"); + } + } +} \ No newline at end of file diff --git a/LoginShell.xaml.cs b/LoginShell.xaml.cs index dca57a1..b9ef8f9 100644 --- a/LoginShell.xaml.cs +++ b/LoginShell.xaml.cs @@ -1,9 +1,7 @@ namespace YOUserbase; -public partial class LoginShell : Shell -{ - public LoginShell() - { - InitializeComponent(); - } -} +public partial class LoginShell : Shell { + public LoginShell() { + InitializeComponent(); + } +} \ No newline at end of file diff --git a/MainPage.xaml.cs b/MainPage.xaml.cs index 63ad64f..a3704c6 100644 --- a/MainPage.xaml.cs +++ b/MainPage.xaml.cs @@ -1,9 +1,7 @@ namespace YOUserbase; -public partial class MainPage : ContentPage -{ - public MainPage() - { - InitializeComponent(); - } -} +public partial class MainPage : ContentPage { + public MainPage() { + InitializeComponent(); + } +} \ No newline at end of file diff --git a/MauiProgram.cs b/MauiProgram.cs index 2560246..29129c3 100644 --- a/MauiProgram.cs +++ b/MauiProgram.cs @@ -1,18 +1,15 @@ using Microsoft.Extensions.Logging; namespace YOUserbase; -public static class MauiProgram -{ - public static MauiApp CreateMauiApp() - { +public static class MauiProgram { + public static MauiApp CreateMauiApp() { var builder = MauiApp.CreateBuilder(); builder .UseMauiApp() - .ConfigureFonts(fonts => - { - fonts.AddFont("Blimone-Regular.ttf", "BlimoneRegular"); - fonts.AddFont("Alliance-No1-Regular.ttf", "AllianceNo1Regular"); - }); + .ConfigureFonts(fonts => { + fonts.AddFont("Blimone-Regular.ttf", "BlimoneRegular"); + fonts.AddFont("Alliance-No1-Regular.ttf", "AllianceNo1Regular"); + }); #if DEBUG builder.Logging.AddDebug(); #endif diff --git a/Platforms/MacCatalyst/AppDelegate.cs b/Platforms/MacCatalyst/AppDelegate.cs index 28bade8..0dec9c7 100644 --- a/Platforms/MacCatalyst/AppDelegate.cs +++ b/Platforms/MacCatalyst/AppDelegate.cs @@ -3,7 +3,6 @@ namespace YOUserbase; [Register("AppDelegate")] -public class AppDelegate : MauiUIApplicationDelegate -{ - protected override MauiApp CreateMauiApp() => MauiProgram.CreateMauiApp(); -} +public class AppDelegate : MauiUIApplicationDelegate { + protected override MauiApp CreateMauiApp() => MauiProgram.CreateMauiApp(); +} \ No newline at end of file diff --git a/Platforms/MacCatalyst/Program.cs b/Platforms/MacCatalyst/Program.cs index 340f88d..f37353e 100644 --- a/Platforms/MacCatalyst/Program.cs +++ b/Platforms/MacCatalyst/Program.cs @@ -3,13 +3,11 @@ using UIKit; namespace YOUserbase; -public class Program -{ - // This is the main entry point of the application. - static void Main(string[] args) - { - // if you want to use a different Application Delegate class from "AppDelegate" - // you can specify it here. - UIApplication.Main(args, null, typeof(AppDelegate)); - } -} +public class Program { + // This is the main entry point of the application. + static void Main(string[] args) { + // if you want to use a different Application Delegate class from "AppDelegate" + // you can specify it here. + UIApplication.Main(args, null, typeof(AppDelegate)); + } +} \ No newline at end of file diff --git a/User.cs b/User.cs index a09e1ea..787f249 100644 --- a/User.cs +++ b/User.cs @@ -1,56 +1,55 @@ -using System.ComponentModel; +using System.ComponentModel; using System.Runtime.CompilerServices; namespace YOUserbase { - public class User : INotifyPropertyChanged { - int id; - string firstname; - string lastname; - DateTime birthDate; - string details; - Group workingGroup; - bool isFullTime; - bool isExternal; - bool isRemote; - int nbProjects; - public int Id { get => id; set => ChangeValue(ref id, value); } - public string Firstname { get => firstname; set => ChangeValue(ref firstname, value); } - public string Lastname { get => lastname; set => ChangeValue(ref lastname, value); } - public DateTime BirthDate { get => birthDate; set => ChangeValue(ref birthDate, value); } - public string Details { get => details; set => ChangeValue(ref details, value); } - public Group WorkingGroup { get => workingGroup; set => ChangeValue(ref workingGroup, value); } - public bool IsFullTime { get => isFullTime; set => ChangeValue(ref isFullTime, value); } - public bool IsExternal { get => isExternal; set => ChangeValue(ref isExternal, value); } - public bool IsRemote { get => isRemote; set => ChangeValue(ref isRemote, value); } - public int NbProjects { get => nbProjects; set => ChangeValue(ref nbProjects, value); } + public class User : INotifyPropertyChanged { + int id; + string firstname; + string lastname; + DateTime birthDate; + string details; + Group workingGroup; + bool isFullTime; + bool isExternal; + bool isRemote; + int nbProjects; + public int Id { get => id; set => ChangeValue(ref id, value); } + public string Firstname { get => firstname; set => ChangeValue(ref firstname, value); } + public string Lastname { get => lastname; set => ChangeValue(ref lastname, value); } + public DateTime BirthDate { get => birthDate; set => ChangeValue(ref birthDate, value); } + public string Details { get => details; set => ChangeValue(ref details, value); } + public Group WorkingGroup { get => workingGroup; set => ChangeValue(ref workingGroup, value); } + public bool IsFullTime { get => isFullTime; set => ChangeValue(ref isFullTime, value); } + public bool IsExternal { get => isExternal; set => ChangeValue(ref isExternal, value); } + public bool IsRemote { get => isRemote; set => ChangeValue(ref isRemote, value); } + public int NbProjects { get => nbProjects; set => ChangeValue(ref nbProjects, value); } - private static int index = 0; + private static int index = 0; - public User() { - Id = ++index; + public User() { + Id = ++index; } - public User(int id) { - Id = id; + public User(int id) { + Id = id; } - // Change value so setter looks a bit nicer :) - private void ChangeValue(ref T field, T value, [CallerMemberName] string propertyName = "") { - if (!value.Equals(field)) { - field = value; - NotifyPropertyChanged(propertyName); + // Change value so setter looks a bit nicer :) + private void ChangeValue(ref T field, T value, [CallerMemberName] string propertyName = "") { + if(!value.Equals(field)) { + field = value; + NotifyPropertyChanged(propertyName); } } - // This method is called by the Set accessor of each property. - // The CallerMemberName attribute that is applied to the optional propertyName - // parameter causes the property name of the caller to be substituted as an argument. - private void NotifyPropertyChanged ([CallerMemberName] string propertyName = "") - { - Console.WriteLine(propertyName); - if (PropertyChanged != null) { PropertyChanged (this, new PropertyChangedEventArgs (propertyName)); } - } + // This method is called by the Set accessor of each property. + // The CallerMemberName attribute that is applied to the optional propertyName + // parameter causes the property name of the caller to be substituted as an argument. + private void NotifyPropertyChanged([CallerMemberName] string propertyName = "") { + Console.WriteLine(propertyName); + if(PropertyChanged != null) { PropertyChanged(this, new PropertyChangedEventArgs(propertyName)); } + } - public event PropertyChangedEventHandler PropertyChanged; - } -} + public event PropertyChangedEventHandler PropertyChanged; + } +} \ No newline at end of file diff --git a/UserOverviewPage.xaml.cs b/UserOverviewPage.xaml.cs index 34602e5..491318f 100644 --- a/UserOverviewPage.xaml.cs +++ b/UserOverviewPage.xaml.cs @@ -5,55 +5,51 @@ using System.Runtime.CompilerServices; namespace YOUserbase; public partial class UserOverviewPage : ContentPage { - public int _index = 0; - - private string details; - private string firstname; - private string lastname; - private string birthDate; - public string Details { get => details; set => SetProperty (ref details, value); } - public string Firstname { get => firstname; set => SetProperty (ref firstname, value); } - public string Lastname { get => lastname; set => SetProperty (ref lastname, value); } - public string BirthDate { get => birthDate; set => SetProperty (ref birthDate, value); } - - public UserOverviewPage () - { - InitializeComponent (); - users.ItemsSource = Data.Users; - } - - private async void OnAdd (object sender, EventArgs e) - { - await Navigation.PushAsync (new CreateUserPage ()); - Console.WriteLine(Data.Users); - } - - private async void OnDeleteItem(object sender, EventArgs e) { - Button btn = (Button)sender; - var id = Int32.Parse(btn.ClassId); - var user = Data.Users.FirstOrDefault(usr => usr.Id == id); - var action = await DisplayAlert("Irreversible action", "Do you really want to delete this user?", "Yes", "No"); - if (action) { + public int _index = 0; + + private string details; + private string firstname; + private string lastname; + private string birthDate; + public string Details { get => details; set => SetProperty(ref details, value); } + public string Firstname { get => firstname; set => SetProperty(ref firstname, value); } + public string Lastname { get => lastname; set => SetProperty(ref lastname, value); } + public string BirthDate { get => birthDate; set => SetProperty(ref birthDate, value); } + + public UserOverviewPage() { + InitializeComponent(); + users.ItemsSource = Data.Users; + } + + private async void OnAdd(object sender, EventArgs e) { + await Navigation.PushAsync(new CreateUserPage()); + Console.WriteLine(Data.Users); + } + + private async void OnDeleteItem(object sender, EventArgs e) { + Button btn = (Button) sender; + var id = Int32.Parse(btn.ClassId); + var user = Data.Users.FirstOrDefault(usr => usr.Id == id); + var action = await DisplayAlert("Irreversible action", "Do you really want to delete this user?", "Yes", "No"); + if(action) { Data.Users.Remove(user); } } - private async void OnEditItem (object sender, EventArgs e) - { - Button btn = (Button)sender; - var id = Int32.Parse(btn.ClassId); - var user = Data.Users.FirstOrDefault(usr => usr.Id == id); - await Navigation.PushAsync(new CreateUserPage(user)); - } - - protected bool SetProperty (ref T field, T newValue, [CallerMemberName] string propertyName = null) - { - if (!Equals (field, newValue)) { - field = newValue; - // PropertyChanged?.Invoke (this, new PropertyChangedEventArgs (propertyName)); - return true; - } - - return false; - } -} + private async void OnEditItem(object sender, EventArgs e) { + Button btn = (Button) sender; + var id = Int32.Parse(btn.ClassId); + var user = Data.Users.FirstOrDefault(usr => usr.Id == id); + await Navigation.PushAsync(new CreateUserPage(user)); + } + + protected bool SetProperty(ref T field, T newValue, [CallerMemberName] string propertyName = null) { + if(!Equals(field, newValue)) { + field = newValue; + // PropertyChanged?.Invoke (this, new PropertyChangedEventArgs (propertyName)); + return true; + } + + return false; + } +} \ No newline at end of file