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 3.8KB

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