PWA Fundvelo der Caritas.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

AccountPage.razor 5.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. @page "/account"
  2. @page "/fundvelo/account/{FromRoute}"
  3. @using cwebplusApp.Shared.Models;
  4. @using cwebplusApp.Shared.Services;
  5. @inject NavigationManager NavigationManager
  6. @inject UserDataProvider UserDataProvider
  7. @inject IStringLocalizer<Resources> i18n
  8. @inject PageHistoryManager PageHistoryManager
  9. @inject ReportDataProvider ReportDataProvider
  10. <div class="row px-3 h-100">
  11. <div class="row no-gutters align-items-start w-100">
  12. <div class="row no-gutters align-items-center w-100" style="padding-top:2em">
  13. <div class="col-12">
  14. <MatSelect Class="w-100" Label="@i18n["Salutation"]" Outlined="true" @bind-Value="@Account.Salutation" Style="margin-bottom: 0.5rem" Required="true">
  15. <MatOptionString Value="sir">@i18n["Man"]</MatOptionString>
  16. <MatOptionString Value="madam">@i18n["Woman"]</MatOptionString>
  17. </MatSelect>
  18. </div>
  19. </div>
  20. <div class="row no-gutters w-100">
  21. <div class="col-6" style="padding-right:0.5em">
  22. <MatStringField Class="w-100" Label="@i18n["Firstname"]" Outlined="true" type="text" @bind-Value="@Account.Firstname" Required="true"></MatStringField>
  23. </div>
  24. <div class="col-6" style="padding-left:0.5em">
  25. <MatStringField Class="w-100" Label="@i18n["Lastname"]" Outlined="true" type="text" @bind-Value="@Account.Lastname" Required="true"></MatStringField>
  26. </div>
  27. </div>
  28. <div class="row no-gutters align-items-center w-100">
  29. <div class="col-12">
  30. <MatStringField Class="w-100" Label="@i18n["Address"]" Outlined="true" type="text" @bind-Value="@Account.Address" Required="true"></MatStringField>
  31. </div>
  32. </div>
  33. <div class="row no-gutters align-items-center w-100">
  34. <div class="col-4" style="padding-right:0.5em">
  35. <MatStringField Class="w-100" Label="@i18n["Zip"]" Outlined="true" type="text" @bind-Value="@Account.Zip" Required="true"></MatStringField>
  36. </div>
  37. <div class="col-8" style="padding-left:0.5em">
  38. <MatStringField Class="w-100" Label="@i18n["City"]" Outlined="true" type="text" @bind-Value="@Account.City" Required="true"></MatStringField>
  39. </div>
  40. </div>
  41. <div class="row no-gutters align-items-center w-100">
  42. <div class="col-12">
  43. <MatStringField Class="w-100" Label="@i18n["Phone"]" Outlined="true" type="text" @bind-Value="@Account.Phone" Required="true"></MatStringField>
  44. </div>
  45. </div>
  46. <div class="row no-gutters align-items-center w-100">
  47. <div class="col-12">
  48. <MatStringField Class="w-100" Label="@i18n["Mail"]" Outlined="true" type="text" @bind-Value="@Account.Email"></MatStringField>
  49. </div>
  50. </div>
  51. </div>
  52. @if (string.IsNullOrEmpty(FromRoute)) {
  53. <div class="row no-gutters align-items-end justify-content-center w-100" style="padding-bottom:2em">
  54. <MatButton Class="w-100" Raised="true" @onclick="SaveUserData">@i18n["Save"]</MatButton>
  55. </div>
  56. } else {
  57. <div class="row no-gutters align-items-end justify-content-center w-100" style="padding-bottom:2em">
  58. <div class="col" style="padding-right:0.5em">
  59. <MatButton Class="w-100" Outlined="true" @onclick="Cancel">@i18n["Cancel"]</MatButton>
  60. </div>
  61. <div class="col" style="padding-left:0.5em">
  62. <MatButton Class="w-100" Raised="true" @onclick="Next">@i18n["Send"]</MatButton>
  63. </div>
  64. </div>
  65. }
  66. </div>
  67. @code {
  68. [Parameter]
  69. public string FromRoute { get; set; }
  70. private UserData Account = new();
  71. protected async override void OnInitialized() {
  72. PageHistoryManager.OnBeforeNavigateBack = new EventCallback(this, (Action)OnBeforeNavigateBack);
  73. PageHistoryManager.AddPageToHistory(NavigationManager.Uri);
  74. Account = await GetUserData();
  75. UserDataProvider.mapUserData(Account, ReportDataProvider.Report);
  76. base.OnInitialized();
  77. StateHasChanged();
  78. }
  79. private void OnBeforeNavigateBack() {
  80. UserDataProvider.mapReport(ReportDataProvider.Report, Account);
  81. }
  82. private async void SaveUserData() {
  83. await UserDataProvider.Save(Account);
  84. NavigationManager.NavigateTo("caritas_services");
  85. }
  86. private async Task<UserData> GetUserData() {
  87. return await UserDataProvider.Get();
  88. }
  89. private void Next() {
  90. UserDataProvider.mapReport(ReportDataProvider.Report, Account);
  91. if ("Found".Equals(FromRoute)) {
  92. NavigationManager.NavigateTo("fundvelo/conclusion_found");
  93. } else {
  94. NavigationManager.NavigateTo("fundvelo/conclusion_missing");
  95. }
  96. }
  97. private void Cancel() {
  98. NavigationManager.NavigateTo("caritas_services");
  99. }
  100. }