| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113 |
- @page "/fundvelo/pending_overview"
-
- @using cwebplusApp.Shared.Services;
- @using cwebplusApp.Shared.Models;
-
- @inject NavigationManager NavigationManager
- @inject PageHistoryManager PageHistoryManager
- @inject ReportDataProvider ReportDataProvider
- @inject ReportRepositoryService ReportRepositoryService
- @inject IStringLocalizer<Resources> i18n;
- @inject Toaster Toaster;
-
- <div class="row px-3 h-100">
- <div class="row no-gutters align-items-start w-100" style="padding-top: 1rem;">
- <div class="mat-layout-grid w-100">
- <div>
- <MatTable RowClass="ReportRepositoryItem" Items="pendingReports" class="mat-elevation-z5" ShowPaging="false" UseSortHeaderRow="true"
- OnRowDbClick="OnReportDblClicked" AllowSelection="true">
- <MatTableHeader>
- <th>Id</th>
- <th>@i18n["Type"]</th>
- <th>@i18n["Date"]</th>
- <th>@i18n["Address"]</th>
- <th>@i18n["Picture"]</th>
- <th>@i18n["Action"]</th>
- </MatTableHeader>
- <MatTableRow>
- <td style="display:inline-flex">
- <div>
- <MatIconButton Icon="play_circle_filled" OnClick="@(_ => SendReport(context))"></MatIconButton>
- </div>
- <div style="padding-top: 0.8rem">@context.ID</div>
- </td>
- <td style="@getTypeBackgroundStyle(context.ReportType)">@translateType(context.ReportType)</td>
- <td style="white-space: nowrap">@ReportRepositoryService.GetCurrentDateTimeFromMillis(context.ID)</td>
- <td style="white-space: nowrap">@getAddress(context)</td>
- <td>@getPicture(context)</td>
- <td>
- <MatIconButton Icon="delete_forever" OnClick="@(_ => DeleteReport(context))"></MatIconButton>
- </td>
- </MatTableRow>
- </MatTable>
- </div>
- </div>
- </div>
- </div>
-
-
- @code {
-
- private List<ReportRepositoryItem> pendingReports = new();
- private ReportRepositoryItem selectedReport;
-
- protected async override void OnInitialized() {
- base.OnInitialized();
- PageHistoryManager.AddPageToHistory(NavigationManager.Uri);
- pendingReports.AddRange(await ReportRepositoryService.GetPendingFoundReports());
- pendingReports.AddRange(await ReportRepositoryService.GetPendingMissingReports());
-
- StateHasChanged();
- }
-
- private void OnReportDblClicked(object item) {
- var report = item as ReportRepositoryItem;
- if (report == null) {
- selectedReport = null;
- return;
- }
-
- selectedReport = report;
- }
-
- private string translateType(ReportRepositoryItem.Type type) {
- return i18n.GetString("ReportType." + type);
- }
-
- private string getTypeBackgroundStyle(ReportRepositoryItem.Type type) {
- return ReportRepositoryItem.Type.FOUND.Equals(type) ? "background: linear-gradient(45deg, darkseagreen, transparent)" : "background: linear-gradient(45deg, darksalmon, transparent)";
- }
-
-
- private string getAddress(ReportRepositoryItem item) {
- return ReportRepositoryItem.Type.FOUND.Equals(item.ReportType) ? ((FoundReportRepositoryItem)item).Report.GeographicInfo.Address : "";
- }
-
- private string getPicture(ReportRepositoryItem item) {
- string picData = ReportRepositoryItem.Type.FOUND.Equals(item.ReportType) ? ((FoundReportRepositoryItem)item).Report.FotoString : ((MissingReportRepositoryItem)item).Report.FotoString;
- return "";
- }
-
- private async void DeleteReport(ReportRepositoryItem item) {
- try {
- await ReportRepositoryService.DeleteReport(item);
- pendingReports.Remove(item);
- StateHasChanged();
- Toaster.ShowSuccess(i18n.GetString("Success.DeleteReport.Title"), i18n.GetString("Success.DeleteReport.Msg", item.ID));
- } catch (Exception ex) {
- Toaster.ShowWarning(i18n.GetString("Error.DeleteReport.Title"), i18n.GetString("Error.DeleteReport.Msg", item.ID));
- }
- }
-
- private void SendReport(ReportRepositoryItem item) {
- ReportDataProvider.ReportRepositoryItem = item;
- if (ReportRepositoryItem.Type.FOUND.Equals(item.ReportType)) {
- ReportDataProvider.Report = ((FoundReportRepositoryItem)item).Report;
- NavigationManager.NavigateTo("fundvelo/keydata/Found");
- } else {
- ReportDataProvider.Report = ((MissingReportRepositoryItem)item).Report;
- NavigationManager.NavigateTo("fundvelo/keydata/Missing");
- }
- }
-
- }
|