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

CaritasServiceFundVeloPendingOverviewPage.razor 4.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. @page "/fundvelo/pending_overview"
  2. @using cwebplusApp.Shared.Services;
  3. @using cwebplusApp.Shared.Models;
  4. @inject NavigationManager NavigationManager
  5. @inject PageHistoryManager PageHistoryManager
  6. @inject ReportDataProvider ReportDataProvider
  7. @inject ReportRepositoryService ReportRepositoryService
  8. @inject IStringLocalizer<Resources> i18n;
  9. @inject Toaster Toaster;
  10. <div class="row px-3 h-100">
  11. <div class="row no-gutters align-items-start w-100" style="padding-top: 1rem;">
  12. <div class="mat-layout-grid w-100">
  13. <div>
  14. <MatTable RowClass="ReportRepositoryItem" Items="pendingReports" class="mat-elevation-z5" ShowPaging="false" UseSortHeaderRow="true"
  15. OnRowDbClick="OnReportDblClicked" AllowSelection="true">
  16. <MatTableHeader>
  17. <th>Id</th>
  18. <th>@i18n["Type"]</th>
  19. <th>@i18n["Date"]</th>
  20. <th>@i18n["Address"]</th>
  21. <th>@i18n["Picture"]</th>
  22. <th>@i18n["Action"]</th>
  23. </MatTableHeader>
  24. <MatTableRow>
  25. <td style="display:inline-flex">
  26. <div>
  27. <MatIconButton Icon="play_circle_filled" OnClick="@(_ => SendReport(context))"></MatIconButton>
  28. </div>
  29. <div style="padding-top: 0.8rem">@context.ID</div>
  30. </td>
  31. <td style="@getTypeBackgroundStyle(context.ReportType)">@translateType(context.ReportType)</td>
  32. <td style="white-space: nowrap">@ReportRepositoryService.GetCurrentDateTimeFromMillis(context.ID)</td>
  33. <td style="white-space: nowrap">@getAddress(context)</td>
  34. <td>@getPicture(context)</td>
  35. <td>
  36. <MatIconButton Icon="delete_forever" OnClick="@(_ => DeleteReport(context))"></MatIconButton>
  37. </td>
  38. </MatTableRow>
  39. </MatTable>
  40. </div>
  41. </div>
  42. </div>
  43. </div>
  44. @code {
  45. private List<ReportRepositoryItem> pendingReports = new();
  46. private ReportRepositoryItem selectedReport;
  47. protected async override void OnInitialized() {
  48. base.OnInitialized();
  49. PageHistoryManager.AddPageToHistory(NavigationManager.Uri);
  50. pendingReports.AddRange(await ReportRepositoryService.GetPendingFoundReports());
  51. pendingReports.AddRange(await ReportRepositoryService.GetPendingMissingReports());
  52. StateHasChanged();
  53. }
  54. private void OnReportDblClicked(object item) {
  55. var report = item as ReportRepositoryItem;
  56. if (report == null) {
  57. selectedReport = null;
  58. return;
  59. }
  60. selectedReport = report;
  61. }
  62. private string translateType(ReportRepositoryItem.Type type) {
  63. return i18n.GetString("ReportType." + type);
  64. }
  65. private string getTypeBackgroundStyle(ReportRepositoryItem.Type type) {
  66. return ReportRepositoryItem.Type.FOUND.Equals(type) ? "background: linear-gradient(45deg, darkseagreen, transparent)" : "background: linear-gradient(45deg, darksalmon, transparent)";
  67. }
  68. private string getAddress(ReportRepositoryItem item) {
  69. return ReportRepositoryItem.Type.FOUND.Equals(item.ReportType) ? ((FoundReportRepositoryItem)item).Report.GeographicInfo.Address : "";
  70. }
  71. private string getPicture(ReportRepositoryItem item) {
  72. string picData = ReportRepositoryItem.Type.FOUND.Equals(item.ReportType) ? ((FoundReportRepositoryItem)item).Report.FotoString : ((MissingReportRepositoryItem)item).Report.FotoString;
  73. return "";
  74. }
  75. private async void DeleteReport(ReportRepositoryItem item) {
  76. try {
  77. await ReportRepositoryService.DeleteReport(item);
  78. pendingReports.Remove(item);
  79. StateHasChanged();
  80. Toaster.ShowSuccess(i18n.GetString("Success.DeleteReport.Title"), i18n.GetString("Success.DeleteReport.Msg", item.ID));
  81. } catch (Exception ex) {
  82. Toaster.ShowWarning(i18n.GetString("Error.DeleteReport.Title"), i18n.GetString("Error.DeleteReport.Msg", item.ID));
  83. }
  84. }
  85. private void SendReport(ReportRepositoryItem item) {
  86. ReportDataProvider.ReportRepositoryItem = item;
  87. if (ReportRepositoryItem.Type.FOUND.Equals(item.ReportType)) {
  88. ReportDataProvider.Report = ((FoundReportRepositoryItem)item).Report;
  89. NavigationManager.NavigateTo("fundvelo/keydata/Found");
  90. } else {
  91. ReportDataProvider.Report = ((MissingReportRepositoryItem)item).Report;
  92. NavigationManager.NavigateTo("fundvelo/keydata/Missing");
  93. }
  94. }
  95. }