456 lines
20 KiB
Plaintext
456 lines
20 KiB
Plaintext
@page "/user/transfers"
|
|
@using BlazorAnimation
|
|
@using TIAM.Core.Enums
|
|
@using TIAM.Entities.ServiceProviders
|
|
@using TIAM.Entities.Transfers
|
|
@using TIAM.Models.Dtos.Users
|
|
@using TIAM.Resources
|
|
@using TIAMSharedUI.Pages.Components
|
|
@using TIAMSharedUI.Shared
|
|
@using TIAMWebApp.Shared.Application.Interfaces
|
|
@using TIAMWebApp.Shared.Application.Models
|
|
@using TIAMWebApp.Shared.Application.Models.ClientSide.UI
|
|
@using TIAMWebApp.Shared.Application.Models.ClientSide.UI.WizardModels
|
|
@using TIAMWebApp.Shared.Application.Models.ClientSide.Messages
|
|
@using TIAMWebApp.Shared.Application.Models.PageModels
|
|
@using TIAMWebApp.Shared.Application.Utility
|
|
@using AyCode.Core.Loggers
|
|
@using AyCode.Services.Loggers
|
|
@using TIAM.Core.Loggers
|
|
@layout AdminLayout
|
|
@inject IEnumerable<IAcLogWriterClientBase> LogWriters
|
|
@inject IStringLocalizer<TIAMResources> localizer
|
|
@inject IWizardProcessor wizardProcessor
|
|
@inject ITransferDataService transferDataService
|
|
@inject ISessionService sessionService
|
|
<PageTitle>Transfers</PageTitle>
|
|
|
|
<div class="text-center m-5">
|
|
<h1>Transfer management</h1>
|
|
<h2 style="font-size:small">Manage transfers here!</h2>
|
|
</div>
|
|
|
|
|
|
<DxPopup CssClass="popup-demo-events"
|
|
@bind-Visible="@PopupVisible"
|
|
ShowFooter="true"
|
|
CloseOnEscape="true"
|
|
CloseOnOutsideClick="false"
|
|
ShowCloseButton="false"
|
|
HeaderText="MessageBox"
|
|
Closing="EulaPopupClosing"
|
|
Closed="EulaPopupClosed">
|
|
<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">
|
|
<div class="row">
|
|
<div class=" col-12">
|
|
<Animation Effect="@Effect.Pulse" Class="glass" Speed="@Speed.Fast" Delay="@TimeSpan.FromMilliseconds(250)">
|
|
<div class="card">
|
|
|
|
<DxTabs>
|
|
|
|
<DxTabPage Text="DataGrid">
|
|
<div class="d-flex flex-column mb-4 pb-2">
|
|
<div class="align-self-end pl-2 pb-2">
|
|
<DxButton Text="Column Chooser"
|
|
RenderStyle="ButtonRenderStyle.Secondary"
|
|
IconCssClass="btn-column-chooser"
|
|
Click="ColumnChooserButton_Click" />
|
|
</div>
|
|
|
|
<DxGrid @ref="Grid2"
|
|
Data="TransferData"
|
|
AutoCollapseDetailRow="AutoCollapseDetailRow"
|
|
KeyboardNavigationEnabled="true"
|
|
CustomizeElement="Grid_CustomizeElement"
|
|
CustomizeEditModel="Grid_CustomizeEditModel"
|
|
EditModelSaving="Grid_EditModelSaving"
|
|
DataItemDeleting="Grid_DataItemDeleting"
|
|
EditMode="GridEditMode.EditForm"
|
|
ColumnResizeMode="GridColumnResizeMode.NextColumn"
|
|
ShowFilterRow="true"
|
|
KeyFieldName="Id">
|
|
|
|
<Columns>
|
|
<DxGridCommandColumn NewButtonVisible="false" Width="8%" FixedPosition="GridColumnFixedPosition.Left" />
|
|
<DxGridDataColumn FieldName="Id" ShowInColumnChooser="false" SortIndex="0" Visible="false" />
|
|
<DxGridDataColumn FieldName="OrderId" />
|
|
<DxGridDataColumn FieldName="FromAddress" />
|
|
<DxGridDataColumn FieldName="ToAddress" />
|
|
<DxGridDataColumn FieldName="Appointment" DisplayFormat="f" />
|
|
<DxGridDataColumn FieldName="FullName" />
|
|
<DxGridDataColumn FieldName="ContactPhone" />
|
|
<DxGridDataColumn FieldName="ContactEmail">
|
|
<CellDisplayTemplate>
|
|
@{
|
|
var keyField = context.Value;
|
|
var keyItem = (Transfer)context.DataItem;
|
|
string buttonText = "Contact";
|
|
<DxButton Click="() => SendMail(keyItem)" Text="@buttonText" RenderStyle="ButtonRenderStyle.Primary" />
|
|
}
|
|
</CellDisplayTemplate>
|
|
</DxGridDataColumn>
|
|
<DxGridDataColumn FieldName="PassengerCount" />
|
|
<DxGridDataColumn FieldName="TransferStatusType">
|
|
<CellDisplayTemplate>
|
|
@{
|
|
|
|
TransferStatusModel keyField = Statuses.FirstOrDefault(x => x.StatusValue == Convert.ToInt16(context.Value));
|
|
string transferStatusText = keyField.StatusName;
|
|
<p>@transferStatusText</p>
|
|
}
|
|
</CellDisplayTemplate>
|
|
</DxGridDataColumn>
|
|
</Columns>
|
|
<DetailRowTemplate>
|
|
<Grid_MasterDetail_NestedGrid_DetailContent Customer="(TIAM.Entities.Transfers.Transfer)context.DataItem" KeyboardNavigationEnabled="true" />
|
|
</DetailRowTemplate>
|
|
<EditFormTemplate Context="EditFormContext">
|
|
@{
|
|
var transfer2 = (Transfer)EditFormContext.EditModel;
|
|
}
|
|
<DxFormLayout CssClass="w-100">
|
|
<DxFormLayoutItem Caption=@localizer.GetString(ResourceKeys.FirstName) ColSpanMd="6">
|
|
@EditFormContext.GetEditor("FirstName")
|
|
</DxFormLayoutItem>
|
|
<DxFormLayoutItem Caption=@localizer.GetString(ResourceKeys.LastName) ColSpanMd="6">
|
|
@EditFormContext.GetEditor("LastName")
|
|
</DxFormLayoutItem>
|
|
<DxFormLayoutItem Caption=@localizer.GetString(ResourceKeys.DestinationAddress) ColSpanMd="6">
|
|
@EditFormContext.GetEditor("ToAddress")
|
|
</DxFormLayoutItem>
|
|
<DxFormLayoutItem Caption=@localizer.GetString(ResourceKeys.PickupAddress) ColSpanMd="6">
|
|
@EditFormContext.GetEditor("FromAddress")
|
|
</DxFormLayoutItem>
|
|
<DxFormLayoutItem Caption="Trip date:" ColSpanMd="6">
|
|
|
|
<DxDateEdit @bind-Date="@transfer2.Appointment"
|
|
TimeSectionVisible="true"
|
|
TimeSectionScrollPickerFormat="tt h m">
|
|
</DxDateEdit>
|
|
|
|
</DxFormLayoutItem>
|
|
<DxFormLayoutItem Caption="Passengers:" ColSpanMd="6">
|
|
@EditFormContext.GetEditor("PassengerCount")
|
|
</DxFormLayoutItem>
|
|
|
|
<DxFormLayoutItem Caption="Status:" ColSpanMd="6">
|
|
@EditFormContext.GetEditor("TransferStatusType")
|
|
</DxFormLayoutItem>
|
|
|
|
</DxFormLayout>
|
|
</EditFormTemplate>
|
|
|
|
|
|
</DxGrid>
|
|
|
|
</div>
|
|
</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>
|
|
</DxTabs>
|
|
|
|
|
|
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</Animation>
|
|
</div>
|
|
|
|
<div class=" col-12 col-xl-6">
|
|
</div>
|
|
|
|
</div>
|
|
</div>
|
|
|
|
|
|
@code {
|
|
private ILogger _logger;
|
|
|
|
public Transfer myModel = new Transfer();
|
|
|
|
public List<Transfer> TransferData { get; set; }
|
|
|
|
bool PopupVisible { get; set; }
|
|
public List<string> ignoreList = new List<string>
|
|
{
|
|
"ReceiverEmailAddress",
|
|
"ReceiverFullName",
|
|
"ReceiverId",
|
|
"SenderEmailAddress",
|
|
"SenderFullName",
|
|
"SenderId",
|
|
"ContextId"
|
|
};
|
|
|
|
public List<TransferStatusModel>? Statuses { get; set; }
|
|
|
|
public MessageWizardModel messageWizardModel = new MessageWizardModel();
|
|
|
|
public List<AppointmentModel>? AppoinmentData { get; set; }
|
|
|
|
DateTime StartDate { get; set; } = DateTime.Today;
|
|
DxSchedulerDataStorage DataStorage = new DxSchedulerDataStorage();
|
|
|
|
|
|
void SendMail(Transfer Item)
|
|
{
|
|
_logger.Info($"Sending mail to {Item.ContactEmail}, {Item.Id}");
|
|
|
|
Guid? nullableGuid = Item.Id;
|
|
if (nullableGuid.HasValue)
|
|
{
|
|
Guid nonNullableGuid = nullableGuid.Value;
|
|
messageWizardModel.ContextId = nonNullableGuid;
|
|
}
|
|
messageWizardModel.ReceiverEmailAddress = Item.ContactEmail;
|
|
messageWizardModel.ReceiverFullName = Item.FullName;
|
|
PopupVisible = true;
|
|
}
|
|
|
|
void CancelCreateClick()
|
|
{
|
|
|
|
PopupVisible = false;
|
|
}
|
|
void EulaPopupClosed()
|
|
{
|
|
//cancel clicked
|
|
|
|
}
|
|
void EulaPopupClosing(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.SenderFullName},</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}");
|
|
}
|
|
|
|
void Grid_CustomizeElement(GridCustomizeElementEventArgs e)
|
|
{
|
|
if (e.ElementType == GridElementType.DataRow && (System.Byte)e.Grid.GetRowValue(e.VisibleIndex, "TransferStatusType") == 5)
|
|
{
|
|
e.CssClass = "bg-important";
|
|
}
|
|
else if (e.ElementType == GridElementType.DataRow && (System.Byte)e.Grid.GetRowValue(e.VisibleIndex, "TransferStatusType") > 5 && (System.Byte)e.Grid.GetRowValue(e.VisibleIndex, "TransferStatusType") < 35)
|
|
{
|
|
e.CssClass = "bg-attention";
|
|
}
|
|
else if (e.ElementType == GridElementType.DataRow && (System.Byte)e.Grid.GetRowValue(e.VisibleIndex, "TransferStatusType") == 35)
|
|
{
|
|
e.CssClass = "bg-finished";
|
|
}
|
|
else if (e.ElementType == GridElementType.DataRow && (System.Byte)e.Grid.GetRowValue(e.VisibleIndex, "TransferStatusType") > 35)
|
|
{
|
|
e.CssClass = "bg-cancel";
|
|
}
|
|
if (e.ElementType == GridElementType.HeaderCell)
|
|
{
|
|
e.Style = "background-color: rgba(0, 0, 0, 0.08)";
|
|
e.CssClass = "header-bold";
|
|
}
|
|
}
|
|
|
|
void Grid_CustomizeEditModel(GridCustomizeEditModelEventArgs e)
|
|
{
|
|
if (e.IsNew)
|
|
{
|
|
var transferEditModel = (Transfer)e.EditModel; //TODO not valid cast
|
|
transferEditModel.Id = Guid.NewGuid();
|
|
transferEditModel.ToAddress = "Where to?";
|
|
transferEditModel.FromAddress = "From where?";
|
|
transferEditModel.Appointment = DateTime.UtcNow.AddDays(3);
|
|
transferEditModel.PassengerCount = 1;
|
|
transferEditModel.FirstName = "John";
|
|
transferEditModel.LastName = "Doe";
|
|
transferEditModel.ContactPhone = "+00000000000";
|
|
transferEditModel.ContactEmail = "your@email.address";
|
|
}
|
|
}
|
|
|
|
async Task Grid_EditModelSaving(GridEditModelSavingEventArgs e)
|
|
{
|
|
bool success = false;
|
|
if (e.IsNew)
|
|
{
|
|
//add new orderData to orderData array
|
|
_logger.Info("New orderData added");
|
|
//await transferDataService.CreateTransfer((TransferWizardModel)e.EditModel);
|
|
}
|
|
else
|
|
{
|
|
_logger.Info("orderData updated at id " + ((Transfer)e.EditModel).Id);
|
|
|
|
success = await transferDataService.UpdateTransferAsync((Transfer)e.EditModel);
|
|
|
|
}
|
|
//get transfer from TransferData by Id
|
|
|
|
// foreach (var transferToModify in (List<Transfer>)TransferData)
|
|
// {
|
|
// myModel = (Transfer)e.EditModel;
|
|
|
|
// if (transferToModify.Id == myModel.Id)
|
|
// {
|
|
// //transferToModify.Driver = myModel.Driver;
|
|
// }
|
|
// }
|
|
if (success)
|
|
await UpdateDataAsync();
|
|
}
|
|
async Task Grid_DataItemDeleting(GridDataItemDeletingEventArgs e)
|
|
{
|
|
//await NwindDataService.RemoveEmployeeAsync((EditableEmployee)e.DataItem);
|
|
//remove orderData from orderData array
|
|
_logger.Info("orderData deleted");
|
|
//await UpdateDataAsync();
|
|
}
|
|
async Task UpdateDataAsync()
|
|
{
|
|
//refresh grid
|
|
TransferData = await transferDataService.GetTransfersAsync();
|
|
_logger.Info("orderData grid refreshed");
|
|
}
|
|
|
|
protected override async Task OnInitializedAsync()
|
|
{
|
|
_logger = new LoggerClient<ManageTransfers>(LogWriters.ToArray());
|
|
|
|
Statuses = new List<TransferStatusModel>
|
|
{
|
|
new TransferStatusModel(Convert.ToInt16(TransferStatusType.OrderSubmitted), "Order submitted"),
|
|
new TransferStatusModel(Convert.ToInt16(TransferStatusType.OrderConfirmed), "Order confirmed"),
|
|
new TransferStatusModel(Convert.ToInt16(TransferStatusType.AssignedToDriver), "Assigned to driver"),
|
|
new TransferStatusModel(Convert.ToInt16(TransferStatusType.DriverConfirmed), "Driver confirmed"),
|
|
new TransferStatusModel(Convert.ToInt16(TransferStatusType.DriverEnRoute), "Driver enroute"),
|
|
new TransferStatusModel(Convert.ToInt16(TransferStatusType.PassengerPickup), "Passenger in car"),
|
|
new TransferStatusModel(Convert.ToInt16(TransferStatusType.Finished), "Finished"),
|
|
new TransferStatusModel(Convert.ToInt16(TransferStatusType.UserCanceled), "User cancelled"),
|
|
new TransferStatusModel(Convert.ToInt16(TransferStatusType.AdminDenied), "Admin cancelled")
|
|
};
|
|
TransferData = (await transferDataService.GetTransfersAsync()).OrderBy(x => x.TransferStatusType).ThenByDescending(x => x.OrderId).ToList();
|
|
AppoinmentData = new List<AppointmentModel>();
|
|
foreach (var transfer in TransferData)
|
|
{
|
|
// var bnm = DataStorage.CreateAppointmentItem();
|
|
// bnm.Start = transfer.Appointment;
|
|
// bnm.Description = $"{transfer.FullName}, {transfer.ToAddress}";
|
|
// bnm.Location = transfer.FromAddress;
|
|
// bnm.Subject = "Simple transfer";
|
|
|
|
AppoinmentData.Add(new AppointmentModel { StartDate = transfer.Appointment, EndDate=transfer.Appointment.AddMinutes(30), Description = $"{transfer.FullName}, {transfer.ToAddress}", Location = transfer.FromAddress, Caption = "Simple transfer" });
|
|
}
|
|
|
|
DataStorage = new DxSchedulerDataStorage();
|
|
DataStorage.AppointmentMappings = new DxSchedulerAppointmentMappings()
|
|
{
|
|
Type = "AppointmentType",
|
|
Start = "StartDate",
|
|
End = "EndDate",
|
|
Subject = "Caption",
|
|
AllDay = "AllDay",
|
|
Location = "Location",
|
|
Description = "Description",
|
|
LabelId = "Label",
|
|
StatusId = "Status",
|
|
RecurrenceInfo = "Recurrence"
|
|
};
|
|
DataStorage.AppointmentsSource = AppoinmentData;
|
|
|
|
|
|
base.OnInitialized();
|
|
|
|
}
|
|
|
|
void ColumnChooserButton_Click()
|
|
{
|
|
Grid2.ShowColumnChooser();
|
|
}
|
|
|
|
IGrid Grid2 { get; set; }
|
|
object MasterGridData { get; set; }
|
|
bool AutoCollapseDetailRow { get; set; }
|
|
|
|
protected override void OnAfterRender(bool firstRender)
|
|
{
|
|
if (firstRender)
|
|
{
|
|
Grid2.ExpandDetailRow(0);
|
|
}
|
|
}
|
|
void AutoCollapseDetailRow_Changed(bool newValue)
|
|
{
|
|
AutoCollapseDetailRow = newValue;
|
|
if (newValue)
|
|
{
|
|
Grid2.BeginUpdate();
|
|
Grid2.CollapseAllDetailRows();
|
|
Grid2.ExpandDetailRow(0);
|
|
Grid2.EndUpdate();
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
|