PWA Fundvelo der Caritas.
您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

CaritasServiceFundVeloLostFoundPage.razor 4.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. @page "/fundvelo/lost_found"
  2. @using cwebplusApp.Shared.Services;
  3. @using cwebplusApp.Shared.Models;
  4. @inject NavigationManager NavigationManager
  5. @inject PageHistoryManager PageHistoryManager
  6. @inject ReportDataProvider ReportDataProvider
  7. @inject UserDataProvider UserDataProvider
  8. @inject ReportRepositoryService ReportRepositoryService
  9. <div class="row px-3 h-100">
  10. <div class="row no-gutters align-items-center w-100">
  11. <div class="mat-layout-grid w-100">
  12. <div class="mat-layout-grid-inner">
  13. <div class="mat-layout-grid-cell mat-layout-grid-cell-span-1">
  14. </div>
  15. <div class="mat-layout-grid-cell mat-layout-grid-cell-span-2">
  16. <MatCard Class="fv-mat-card">
  17. <MatCardContent>
  18. <MatCardMedia Square="true" ImageUrl="./images/batch_found.png" @onclick="Found"></MatCardMedia>
  19. </MatCardContent>
  20. </MatCard>
  21. </div>
  22. <div class="mat-layout-grid-cell mat-layout-grid-cell-span-1">
  23. </div>
  24. <div class="mat-layout-grid-cell mat-layout-grid-cell-span-1">
  25. </div>
  26. <div class="mat-layout-grid-cell mat-layout-grid-cell-span-2">
  27. <MatCard Class="fv-mat-card">
  28. <MatCardContent>
  29. <MatCardMedia Square="true" ImageUrl="./images/batch_missing.png" @onclick="Missing"></MatCardMedia>
  30. </MatCardContent>
  31. </MatCard>
  32. </div>
  33. <div class="mat-layout-grid-cell mat-layout-grid-cell-span-1">
  34. </div>
  35. <div class="mat-layout-grid-cell mat-layout-grid-cell-span-1">
  36. </div>
  37. <div class="mat-layout-grid-cell mat-layout-grid-cell-span-2" style="text-align:end">
  38. @if (NbrPendingReports > 0) {
  39. <div>
  40. <MatChip Label="@NbrPendingReports.ToString()" Class="pending_batch"></MatChip>
  41. </div>
  42. }
  43. <MatCard Class="fv-mat-card">
  44. <MatCardContent>
  45. <MatCardMedia Square="true" ImageUrl="./images/batch_pending.png" @onclick="Pending" Style="@getOpacity()"></MatCardMedia>
  46. </MatCardContent>
  47. </MatCard>
  48. </div>
  49. <div class="mat-layout-grid-cell mat-layout-grid-cell-span-1">
  50. </div>
  51. </div>
  52. </div>
  53. </div>
  54. </div>
  55. @code {
  56. private int NbrPendingReports = 0;
  57. protected async override void OnInitialized() {
  58. base.OnInitialized();
  59. PageHistoryManager.AddPageToHistory(NavigationManager.Uri);
  60. ReportDataProvider.Report = null;
  61. ReportDataProvider.ReportRepositoryItem = null;
  62. StateHasChanged();
  63. NbrPendingReports = await ReportRepositoryService.GetNbrOfPendingReports();
  64. StateHasChanged();
  65. }
  66. private async void Found() {
  67. Report report = new FoundReport();
  68. UserDataProvider.mapReport(report, await UserDataProvider.Get());
  69. ReportDataProvider.Report = report;
  70. NavigationManager.NavigateTo("fundvelo/keydata/Found");
  71. }
  72. private async void Missing() {
  73. Report report = new MissingReport();
  74. UserDataProvider.mapReport(report, await UserDataProvider.Get());
  75. ReportDataProvider.Report = report;
  76. NavigationManager.NavigateTo("fundvelo/keydata/Missing");
  77. }
  78. private void Pending() {
  79. if(NbrPendingReports > 0) {
  80. NavigationManager.NavigateTo("fundvelo/pending_overview");
  81. }
  82. }
  83. private string getOpacity() {
  84. return NbrPendingReports > 0 ? "opacity:1.0" : "opacity:0.5";
  85. }
  86. }