PWA Fundvelo der Caritas.
Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

CaritasServiceFundVeloPendingOverviewPage.razor 6.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  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. @inject IMatDialogService MatDialogService;
  11. @inject ScrollLockRemover ScrollLockRemover;
  12. <div class="row px-3">
  13. <div class="row no-gutters align-items-start justify-content-center w-100" style="padding-top:1em">
  14. <h2>@I18n["Pending"]</h2>
  15. </div>
  16. <div class="row no-gutters align-items-start w-100">
  17. <MatTable RowClass="ReportRepositoryItem" Items="pendingReports" class="mat-elevation-z5" ShowPaging="false" UseSortHeaderRow="true"
  18. OnRowDbClick="OnReportDblClicked" AllowSelection="true">
  19. <MatTableHeader>
  20. <th>Id</th>
  21. <th>@I18n["Type"]</th>
  22. <th>@I18n["Date"]</th>
  23. <th>@I18n["Address"]</th>
  24. <th>@I18n["Picture"]</th>
  25. <th style="width:2400px">@I18n["Action"]</th>
  26. </MatTableHeader>
  27. <MatTableRow>
  28. <td style="display:inline-flex">
  29. <div>
  30. <MatIconButton Icon="play_circle_filled" OnClick="@(_ => SendReport(context))"></MatIconButton>
  31. </div>
  32. <div style="padding-top: 0.8rem">@context.ID</div>
  33. </td>
  34. <td style="@getTypeBackgroundStyle(context.ReportType)">@translateType(context.ReportType)</td>
  35. <td style="white-space: nowrap">@ReportRepositoryService.GetCurrentDateTimeFromMillis(context.ID)</td>
  36. <td style="white-space: nowrap">@getAddress(context)</td>
  37. <td>
  38. <MatIconButton Disabled="@HasNoPicture(context)" Icon="photo" OnClick="@(_ => ShowPicture(context))"></MatIconButton>
  39. </td>
  40. <td>
  41. <MatIconButton Icon="delete_forever" OnClick="@(_ => DeleteReport(context))"></MatIconButton>
  42. </td>
  43. </MatTableRow>
  44. </MatTable>
  45. </div>
  46. </div>
  47. @code {
  48. private List<ReportRepositoryItem> pendingReports = new();
  49. private ReportRepositoryItem selectedReport;
  50. protected async override void OnInitialized() {
  51. base.OnInitialized();
  52. PageHistoryManager.AddPageToHistory(NavigationManager.Uri);
  53. pendingReports.AddRange(await ReportRepositoryService.GetPendingFoundReports());
  54. pendingReports.AddRange(await ReportRepositoryService.GetPendingMissingReports());
  55. StateHasChanged();
  56. }
  57. private void OnReportDblClicked(object item) {
  58. var report = item as ReportRepositoryItem;
  59. if (report == null) {
  60. selectedReport = null;
  61. return;
  62. }
  63. selectedReport = report;
  64. }
  65. private string translateType(ReportRepositoryItem.Type type) {
  66. return I18n.GetString("ReportType." + type);
  67. }
  68. private string getTypeBackgroundStyle(ReportRepositoryItem.Type type) {
  69. return ReportRepositoryItem.Type.FOUND.Equals(type) ? "background: linear-gradient(45deg, darkseagreen, transparent)" : "background: linear-gradient(45deg, darksalmon, transparent)";
  70. }
  71. private string getAddress(ReportRepositoryItem item) {
  72. if (ReportRepositoryItem.Type.FOUND.Equals(item.ReportType)) {
  73. GeographicInfo geoInfo = ((FoundReportRepositoryItem)item).Report.GeographicInfo;
  74. return geoInfo.Address + ((!String.IsNullOrEmpty(geoInfo.Postcode) || !String.IsNullOrEmpty(geoInfo.Town)) ? ", " + geoInfo.Postcode + " " + geoInfo.Town: "");
  75. }
  76. return "";
  77. }
  78. private async Task ShowPicture(ReportRepositoryItem item) {
  79. string picData = ReportRepositoryItem.Type.FOUND.Equals(item.ReportType) ? ((FoundReportRepositoryItem)item).Report.FotoString : ((MissingReportRepositoryItem)item).Report.FotoString;
  80. await MatDialogService.OpenAsync(typeof(PictureDialog), new MatDialogOptions() {
  81. Attributes = new Dictionary<string, object>(){
  82. {"ImgUrl", picData},
  83. }
  84. });
  85. await ScrollLockRemover.removeScrollLockAsync();
  86. }
  87. private bool HasNoPicture(ReportRepositoryItem item) {
  88. string picData = ReportRepositoryItem.Type.FOUND.Equals(item.ReportType) ? ((FoundReportRepositoryItem)item).Report.FotoString : ((MissingReportRepositoryItem)item).Report.FotoString;
  89. return String.IsNullOrEmpty(picData);
  90. }
  91. private async void DeleteReport(ReportRepositoryItem item) {
  92. string yes = I18n.GetString("Yes");
  93. string no = I18n.GetString("No");
  94. string result = await MatDialogService.AskAsync(I18n.GetString("Pending." + item.ReportType + ".Delete"), new string[] { yes, no });
  95. await ScrollLockRemover.removeScrollLockAsync();
  96. if (result.Equals(yes)) {
  97. try {
  98. await ReportRepositoryService.DeleteReport(item);
  99. pendingReports.Remove(item);
  100. StateHasChanged();
  101. Toaster.ShowSuccess(I18n.GetString("Success.DeleteReport.Title"), I18n.GetString("Success.DeleteReport.Msg", item.ID));
  102. } catch (Exception ex) {
  103. Toaster.ShowWarning(I18n.GetString("Error.DeleteReport.Title"), I18n.GetString("Error.DeleteReport.Msg", item.ID));
  104. }
  105. }
  106. }
  107. private void SendReport(ReportRepositoryItem item) {
  108. ReportDataProvider.ReportRepositoryItem = item;
  109. if (ReportRepositoryItem.Type.FOUND.Equals(item.ReportType)) {
  110. ReportDataProvider.Report = ((FoundReportRepositoryItem)item).Report;
  111. NavigationManager.NavigateTo("fundvelo/keydata/Found");
  112. } else {
  113. ReportDataProvider.Report = ((MissingReportRepositoryItem)item).Report;
  114. NavigationManager.NavigateTo("fundvelo/keydata/Missing");
  115. }
  116. }
  117. }