452 lines
17 KiB
Plaintext
452 lines
17 KiB
Plaintext
@page "/user/transfers/{userId:guid}"
|
|
@using BlazorAnimation
|
|
@using TIAM.Core.Enums
|
|
@using TIAM.Entities.Emails
|
|
@using TIAM.Entities.Transfers
|
|
@using TIAM.Resources
|
|
@using TIAM.Services
|
|
@using TIAMSharedUI.Pages.Components
|
|
@using TIAMSharedUI.Pages.User.CardComponents
|
|
@using TIAMSharedUI.Pages.User.SysAdmins
|
|
@using TIAMSharedUI.Shared
|
|
@using TIAMWebApp.Shared.Application.Interfaces
|
|
@using TIAMWebApp.Shared.Application.Models.ClientSide.UI
|
|
@using TIAMWebApp.Shared.Application.Models.ClientSide.UI.WizardModels
|
|
@using TIAMWebApp.Shared.Application.Models.PageModels
|
|
@using TIAMWebApp.Shared.Application.Utility
|
|
@using AyCode.Services.Loggers
|
|
@using TIAMWebApp.Shared.Application.Services
|
|
@using TIAMSharedUI.Shared.Components.Grids
|
|
@using AyCode.Core.Enums
|
|
@using AyCode.Core.Extensions
|
|
@using AyCode.Core.Consts
|
|
@using AyCode.Core
|
|
@using AyCode.Core.Helpers
|
|
@using DevExpress.Data.Filtering
|
|
@using TIAM.Entities.Emails
|
|
@using TIAMSharedUI.Shared.Components.BaseComponents
|
|
@inherits UserBasePageComponent
|
|
@* @layout AdminLayout *@
|
|
@inject IEnumerable<IAcLogWriterClientBase> LogWriters
|
|
@inject IStringLocalizer<TIAMResources> localizer
|
|
@inject IWizardProcessor wizardProcessor
|
|
@inject ITransferDataService transferDataService
|
|
@inject ISessionService sessionService
|
|
@inject AdminSignalRClient AdminSignalRClient;
|
|
<PageTitle>Transfers</PageTitle>
|
|
|
|
<div class="text-center m-5">
|
|
<h1>Your orders</h1>
|
|
<h2 style="font-size:small">Manage your orders here!</h2>
|
|
</div>
|
|
|
|
|
|
<DxPopup CssClass="popup-demo-events"
|
|
@bind-Visible="@_popupVisible"
|
|
ShowFooter="true"
|
|
CloseOnEscape="true"
|
|
CloseOnOutsideClick="false"
|
|
ShowCloseButton="false"
|
|
HeaderText="MessageBox"
|
|
Closing="EmailPopupClosing"
|
|
Closed="EmailPopupClosed">
|
|
<BodyContentTemplate>
|
|
<InputWizard Data=@_messageWizardModel
|
|
OnSubmit="SubmitForm"
|
|
IgnoreReflection=@IgnoreList
|
|
TitleResourceString="NewMessage"
|
|
SubtitleResourceString="NewMessageSubtitle"
|
|
SubmitButtonText="@localizer.GetString("ButtonSend")"></InputWizard>
|
|
</BodyContentTemplate>
|
|
<FooterContentTemplate Context="Context">
|
|
<div class="popup-demo-events-footer">
|
|
<!--DxCheckBox CssClass="popup-demo-events-checkbox" @bind-Checked="@EulaAccepted">I accept the terms of the EULA</!--DxCheckBox-->
|
|
<!--DxButton CssClass="popup-demo-events-button ms-2" RenderStyle="ButtonRenderStyle.Primary" Text="OK" Click="Context.CloseCallback" /-->
|
|
<DxButton CssClass="popup-demo-events-button ms-2" RenderStyle="ButtonRenderStyle.Secondary" Text="Cancel" Click="CancelCreateClick" />
|
|
</div>
|
|
</FooterContentTemplate>
|
|
</DxPopup>
|
|
|
|
<div class="container-fluid">
|
|
<div class="row">
|
|
<div class=" col-12">
|
|
|
|
|
|
|
|
<DxTabs CssClass="no-padding">
|
|
<DxTabPage Text="Upcoming">
|
|
<DxAccordion CssClass="no-padding" SizeMode="@SizeMode.Small" ExpandMode="ExpandMode"
|
|
ExpandCollapseAction="ExpandCollapseAction"
|
|
AnimationType="LayoutAnimationType.Slide">
|
|
<Items>
|
|
@foreach (var (transfer, i) in Upcoming)
|
|
{
|
|
|
|
<DxAccordionItem IconCssClass="@GetCustomColor(transfer.TransferStatusType)" Expanded=@(i == 0)>
|
|
<HeaderTextTemplate>
|
|
<div style="flex-direction: column">
|
|
<p class="no-padding no-margin">@($"[#{transfer.OrderId}] {transfer.Appointment}")</p>
|
|
<p class="text-muted no-padding no-margin">@($"{transfer.FromAddress}")</p>
|
|
</div>
|
|
</HeaderTextTemplate>
|
|
<ContentTemplate>
|
|
|
|
<TransferCardComponent DataChanged="RefreshComponent" Context="@transfer" />
|
|
|
|
</ContentTemplate>
|
|
</DxAccordionItem>
|
|
}
|
|
</Items>
|
|
</DxAccordion>
|
|
</DxTabPage>
|
|
<DxTabPage Text="Unpaid">
|
|
<DxAccordion CssClass="no-padding" SizeMode="@SizeMode.Small" ExpandMode="ExpandMode"
|
|
ExpandCollapseAction="ExpandCollapseAction"
|
|
AnimationType="LayoutAnimationType.Slide">
|
|
<Items>
|
|
@foreach (var (transfer, i) in Problems)
|
|
{
|
|
|
|
<DxAccordionItem IconCssClass="@GetCustomColor(transfer.TransferStatusType)" Expanded=@(i == 0)>
|
|
<HeaderTextTemplate>
|
|
<div style="flex-direction: column">
|
|
<p class="no-padding no-margin">@($"[#{transfer.OrderId}] {transfer.Appointment}")</p>
|
|
<p class="text-muted no-padding no-margin">@($"{transfer.FromAddress}")</p>
|
|
</div>
|
|
</HeaderTextTemplate>
|
|
|
|
<ContentTemplate>
|
|
|
|
<TransferCardComponent Role="passenger" DataChanged="RefreshComponent" Context="@transfer" />
|
|
|
|
</ContentTemplate>
|
|
</DxAccordionItem>
|
|
}
|
|
</Items>
|
|
</DxAccordion>
|
|
</DxTabPage>
|
|
|
|
|
|
<DxTabPage Text="Calendar">
|
|
<div class="d-flex flex-column mb-4 pb-2">
|
|
<DxScheduler @bind-StartDate="@StartDate"
|
|
DataStorage="@_dataStorage"
|
|
CssClass="w-100">
|
|
<DxSchedulerTimelineView Duration="@TimeSpan.FromHours(48)" CellMinWidth="80">
|
|
<Scales>
|
|
<DxSchedulerTimeScale Unit="@SchedulerTimeScaleUnit.Day" UnitCount="1"></DxSchedulerTimeScale>
|
|
<DxSchedulerTimeScale Unit="@SchedulerTimeScaleUnit.Hour" UnitCount="2"></DxSchedulerTimeScale>
|
|
</Scales>
|
|
</DxSchedulerTimelineView>
|
|
<DxSchedulerWeekView ShowWorkTimeOnly="false"></DxSchedulerWeekView>
|
|
<DxSchedulerDayView DayCount="1" ShowWorkTimeOnly="false"></DxSchedulerDayView>
|
|
</DxScheduler>
|
|
</div>
|
|
</DxTabPage>
|
|
|
|
<DxTabPage Text="History">
|
|
<div class="d-flex flex-column mb-4 pb-2">
|
|
|
|
<TransferDetailGrid @ref="_gridTransfer"
|
|
Logger="_logger"
|
|
GetAllMessageTag="SignalRTags.GetTransfersByUserProductMappingId"
|
|
SignalRClient="AdminSignalRClient"
|
|
ContextIds="new object[] {userId}"
|
|
CustomizeElement="Grid_CustomizeElement"
|
|
ShowGroupPanel="true"
|
|
CustomGroup="Grid_CustomGroup"
|
|
CustomizeGroupValueDisplayText="Grid_CustomizeGroupValueDisplayText"
|
|
ColumnResizeMode="GridColumnResizeMode.NextColumn"
|
|
AllowSelectRowByClick="false"
|
|
PageSize="13"
|
|
ShowFilterRow="true">
|
|
|
|
<Columns>
|
|
<DxGridDataColumn FieldName="Id" ShowInColumnChooser="AcDomain.IsDeveloperVersion" Visible="AcDomain.IsDeveloperVersion" DisplayFormat="N" />
|
|
<DxGridDataColumn FieldName="Appointment" SortOrder="GridColumnSortOrder.Descending" GroupIndex="0" GroupInterval="GridColumnGroupInterval.Custom" DisplayFormat="g" Width="125" />
|
|
<DxGridDataColumn FieldName="OrderId" Caption="Order" SortIndex="1" SortOrder="GridColumnSortOrder.Descending" Width="70" />
|
|
<DxGridDataColumn FieldName="FromAddress" />
|
|
<DxGridDataColumn FieldName="ToAddress" />
|
|
<DxGridDataColumn FieldName="Created" DisplayFormat="g" Width="125" Visible="false" CaptionAlignment="GridTextAlignment.Center" TextAlignment="GridTextAlignment.Center" />
|
|
</Columns>
|
|
|
|
</TransferDetailGrid>
|
|
</div>
|
|
</DxTabPage>
|
|
|
|
</DxTabs>
|
|
|
|
</div>
|
|
|
|
<div class=" col-12 col-xl-6">
|
|
</div>
|
|
|
|
</div>
|
|
</div>
|
|
|
|
|
|
@code {
|
|
[Parameter] public Guid UserId { get; set; }
|
|
private Guid userId;
|
|
private LoggerClient<UserManageTransfers> _logger;
|
|
private TransferGrid _gridTransfer;
|
|
private bool _popupVisible;
|
|
|
|
private List<Transfer>? transfers = [];
|
|
IEnumerable<(Transfer, int)> Upcoming = [];
|
|
IEnumerable<(Transfer, int)> Problems = [];
|
|
|
|
AccordionExpandMode ExpandMode { get; set; } = AccordionExpandMode.SingleOrNone;
|
|
AccordionExpandCollapseAction ExpandCollapseAction { get; set; } = AccordionExpandCollapseAction.HeaderClick;
|
|
|
|
private MessageWizardModel _messageWizardModel = new();
|
|
|
|
public List<AppointmentModel> AppointmentModels { get; set; } = null!;
|
|
|
|
DateTime StartDate { get; set; } = DateTime.Today;
|
|
DxSchedulerDataStorage _dataStorage = new();
|
|
|
|
|
|
public List<string> IgnoreList =
|
|
[
|
|
"ReceiverEmailAddress",
|
|
"ReceiverFullName",
|
|
"ReceiverId",
|
|
"SenderEmailAddress",
|
|
"SenderFullName",
|
|
"SenderId",
|
|
"ContextId",
|
|
];
|
|
|
|
void Grid_CustomizeElement(GridCustomizeElementEventArgs e)
|
|
{
|
|
try
|
|
{
|
|
if (e.ElementType == GridElementType.HeaderCell)
|
|
{
|
|
e.Style = "background-color: rgba(0, 0, 0, 0.08)";
|
|
e.CssClass = "header-bold";
|
|
}
|
|
|
|
if (e.ElementType != GridElementType.DataRow) return;
|
|
|
|
var transferStatus = e.Grid?.GetRowValue(e.VisibleIndex, "TransferStatusType");
|
|
if (transferStatus == null) return;
|
|
|
|
var transferStatusByte = (byte)transferStatus;
|
|
|
|
switch (transferStatusByte)
|
|
{
|
|
case 5:
|
|
e.CssClass = "bg-important";
|
|
break;
|
|
case > 5 and < 35:
|
|
e.CssClass = "bg-attention";
|
|
break;
|
|
case 35:
|
|
e.CssClass = "bg-finished";
|
|
break;
|
|
case > 35:
|
|
e.CssClass = "bg-cancel";
|
|
break;
|
|
}
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
_logger.Error($"Grid_CustomizeElement; {ex.Message}", ex);
|
|
}
|
|
}
|
|
|
|
void Grid_CustomGroup(GridCustomGroupEventArgs e)
|
|
{
|
|
if (e.FieldName == "Appointment")
|
|
{
|
|
e.SameGroup = Grid_CompareColumnValues(((DateTime)e.Value1).Date, ((DateTime)e.Value2).Date);
|
|
e.Handled = true;
|
|
}
|
|
}
|
|
bool Grid_CompareColumnValues(DateTime value1, DateTime value2)
|
|
{
|
|
if (value1 == value2)
|
|
return true;
|
|
else
|
|
return false;
|
|
}
|
|
void Grid_CustomizeGroupValueDisplayText(GridCustomizeGroupValueDisplayTextEventArgs e)
|
|
{
|
|
if (e.FieldName == "Appointment")
|
|
{
|
|
|
|
string displayText = ((DateTime)e.Value).Date.ToString();
|
|
e.DisplayText = displayText;
|
|
}
|
|
}
|
|
|
|
|
|
private void RefreshComponent()
|
|
{
|
|
StateHasChanged();
|
|
}
|
|
|
|
protected override async Task OnParametersSetAsync()
|
|
{
|
|
userId = UserId;
|
|
// transfers = await AdminSignalRClient.GetByIdAsync<List<Transfer>>(SignalRTags.GetTransfersByUserProductMappingId, DriverId);
|
|
|
|
|
|
}
|
|
|
|
void SendMail(Transfer item)
|
|
{
|
|
_logger.Info($"Sending mail to {item.ContactEmail}, {item.Id}");
|
|
|
|
_messageWizardModel.ReceiverId = item.UserId;
|
|
_messageWizardModel.ContextId = item.Id;
|
|
_messageWizardModel.SenderEmailAddress = "info@touriam.com";
|
|
_messageWizardModel.ReceiverEmailAddress = item.ContactEmail;
|
|
_messageWizardModel.ReceiverFullName = item.FullName;
|
|
_popupVisible = true;
|
|
}
|
|
|
|
void CancelCreateClick()
|
|
{
|
|
|
|
_popupVisible = false;
|
|
}
|
|
|
|
void EmailPopupClosed()
|
|
{
|
|
//cancel clicked
|
|
|
|
}
|
|
|
|
void EmailPopupClosing(PopupClosingEventArgs args)
|
|
{
|
|
//myModel = new TransferWizardModel();
|
|
_messageWizardModel = new MessageWizardModel();
|
|
}
|
|
|
|
//-----------------------------------------------------------------------------------
|
|
|
|
|
|
public async Task SubmitForm(object result)
|
|
{
|
|
var messageModel = (result as MessageWizardModel)!;
|
|
messageModel.ContextId = _messageWizardModel.ContextId;
|
|
//messageModel.SenderId = sessionService.User.UserId;
|
|
|
|
string FormatEmailContent()
|
|
{
|
|
return $@"
|
|
<html>
|
|
<body>
|
|
<p>Dear {messageModel.ReceiverFullName},</p>
|
|
<p>{messageModel.Content}:</p>
|
|
<p>Best regards,<br/>Tour I Am team</p>
|
|
</body>
|
|
</html>";
|
|
}
|
|
|
|
messageModel.Content = FormatEmailContent();
|
|
|
|
_logger.Info(messageModel.Content);
|
|
var email = await wizardProcessor.ProcessWizardAsync<MessageWizardModel>(result.GetType(), messageModel);
|
|
|
|
_logger.Info($"Submitted nested form: {result.GetType().FullName}");
|
|
}
|
|
|
|
|
|
|
|
string GetCustomColor(TransferStatusType transferStatusType)
|
|
{
|
|
|
|
var transferStatusByte = (byte)transferStatusType;
|
|
|
|
switch (transferStatusByte)
|
|
{
|
|
case 5:
|
|
return "text-danger fa-solid fa-triangle-exclamation";
|
|
|
|
case > 5 and < 35:
|
|
|
|
return "text-primary fa-solid fa-clock-rotate-left";
|
|
|
|
case 35:
|
|
return "text-success fa-solid fa-circle-check";
|
|
|
|
case > 35:
|
|
return "text-muted fa-solid fa-circle-xmark";
|
|
|
|
default:
|
|
return "text-primary";
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
protected override async Task OnInitializedAsync()
|
|
{
|
|
_logger = new LoggerClient<UserManageTransfers>(LogWriters.ToArray());
|
|
if (transfers != null)
|
|
{
|
|
var test = UserId.ToString();
|
|
var result = await AdminSignalRClient.GetByIdAsync<List<Transfer>>(SignalRTags.GetTransfersByUserId, UserId);
|
|
transfers = result.Where(t => t.TransferStatusType != TransferStatusType.UserCanceled && t.TransferStatusType != TransferStatusType.AdminDenied).ToList();
|
|
Upcoming = transfers.Where(x => x.Appointment >= DateTime.Now).Select((item, index) => (item, index));
|
|
Problems = transfers.Where(x => x.Paid == false).Select((item, index) => (item, index));
|
|
InitializeAppointments(transfers);
|
|
}
|
|
|
|
await base.OnInitializedAsync();
|
|
}
|
|
|
|
private void GroupTransfers(List<Transfer> transferDataList)
|
|
{
|
|
|
|
}
|
|
|
|
private void InitializeAppointments(ICollection<Transfer> transferDataList)
|
|
{
|
|
_logger.Info("InitializeAppointments called");
|
|
|
|
AppointmentModels = new List<AppointmentModel>(transferDataList.Count);
|
|
|
|
foreach (var transfer in transferDataList)
|
|
{
|
|
// var bnm = DataStorage.CreateAppointmentItem();
|
|
// bnm.Start = transfer.Appointment;
|
|
// bnm.Description = $"{transfer.FullName}, {transfer.ToAddress}";
|
|
// bnm.Location = transfer.FromAddress;
|
|
// bnm.Subject = "Simple transfer";
|
|
|
|
AppointmentModels.Add(CreateAppointmentModel(transfer));
|
|
}
|
|
|
|
_dataStorage = new DxSchedulerDataStorage
|
|
{
|
|
AppointmentMappings = new DxSchedulerAppointmentMappings()
|
|
{
|
|
Type = "AppointmentType",
|
|
Start = "StartDate",
|
|
End = "EndDate",
|
|
Subject = "Caption",
|
|
AllDay = "AllDay",
|
|
Location = "Location",
|
|
Description = "Description",
|
|
LabelId = "Label",
|
|
StatusId = "Status",
|
|
RecurrenceInfo = "Recurrence"
|
|
},
|
|
|
|
AppointmentsSource = AppointmentModels
|
|
};
|
|
}
|
|
|
|
public AppointmentModel CreateAppointmentModel(Transfer transfer)
|
|
{
|
|
return new AppointmentModel { Id = transfer.Id, StartDate = transfer.Appointment, EndDate = transfer.Appointment.AddMinutes(30), Description = $"{transfer.FullName}, {transfer.ToAddress}", Location = transfer.FromAddress, Caption = "Simple transfer" };
|
|
}
|
|
|
|
|
|
} |