PWA Fundvelo der Caritas.
Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.

AccountPage.razor 4.0KB

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