PWA Fundvelo der Caritas.
Ви не можете вибрати більше 25 тем Теми мають розпочинатися з літери або цифри, можуть містити дефіси (-) і не повинні перевищувати 35 символів.

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