mirror of
https://dev.azure.com/TeilRad/sharee.bike%20App/_git/Code
synced 2024-11-05 10:36:30 +01:00
169 lines
4.4 KiB
C#
169 lines
4.4 KiB
C#
using System;
|
|
|
|
namespace TINK.Model.State
|
|
{
|
|
/// <summary>
|
|
/// Types of rent states
|
|
/// </summary>
|
|
public enum InUseStateEnum
|
|
{
|
|
/// <summary>
|
|
/// Bike was returned but no feedback given.
|
|
/// This applies to COPRI locks only because returning of bike is not done using app (Status: Supported locks are ILockIt and COPRI).
|
|
/// </summary>
|
|
FeedbackPending,
|
|
|
|
/// <summary>
|
|
/// Bike is not in use. Corresponding COPRI state is "available".
|
|
/// </summary>
|
|
Disposable,
|
|
|
|
/// <summary>
|
|
/// Bike is reserved. Corresponding COPRI state is "requested".
|
|
/// </summary>
|
|
Reserved,
|
|
|
|
/// <summary>
|
|
/// Bike is booked. Corresponding COPRI statie is "occupied".
|
|
/// </summary>
|
|
Booked
|
|
}
|
|
|
|
/// <summary>
|
|
/// Manages the state of a bike.
|
|
/// </summary>
|
|
public class StateInfo : IStateInfo
|
|
{
|
|
// Holds the current disposable state value.
|
|
private readonly BaseState _InUseState;
|
|
|
|
/// <summary>
|
|
/// Constructs a state info object when state is available.
|
|
/// </summary>
|
|
/// <param name="isFeedbackPending">Specifieds whether feedback is pending or not.</param>
|
|
public StateInfo(bool isFeedbackPending = false)
|
|
{
|
|
_InUseState = isFeedbackPending
|
|
? (BaseState)new StateFeedbackPendingInfo()
|
|
: new StateAvailableInfo();
|
|
}
|
|
|
|
/// <summary>
|
|
/// Constructs a state info object when state is requested.
|
|
/// </summary>
|
|
/// <param name="requestedAt">Date time when bike was requested</param>
|
|
/// <param name="mailAddress">Mail address of user which requested bike.</param>
|
|
/// <param name="code">Booking code.</param>
|
|
/// <param name="dateTimeNowProvider">Date time provider to calculate reaining time.</param>
|
|
public StateInfo(
|
|
Func<DateTime> dateTimeNowProvider,
|
|
DateTime requestedAt,
|
|
string mailAddress,
|
|
string code)
|
|
{
|
|
// Todo: Handle p_oFrom == null here.
|
|
// Todo: Handle p_oDuration == null here.
|
|
_InUseState = new StateRequestedInfo(
|
|
dateTimeNowProvider ?? (() => DateTime.Now),
|
|
requestedAt,
|
|
mailAddress,
|
|
code);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Constructs a state info object when state is booked.
|
|
/// </summary>
|
|
/// <param name="p_oBookedAt">Date time when bike was booked</param>
|
|
/// <param name="p_strMailAddress">Mail address of user which booked bike.</param>
|
|
/// <param name="p_strCode">Booking code.</param>
|
|
public StateInfo(
|
|
DateTime p_oBookedAt,
|
|
string p_strMailAddress,
|
|
string p_strCode)
|
|
{
|
|
// Todo: Handle p_oFrom == null here.
|
|
// Todo: Clearify question: What to do if code changes form one value to another? This should never happen.
|
|
// Todo: Clearify question: What to do if from time changes form one value to another? This should never happen.
|
|
_InUseState = new StateOccupiedInfo(
|
|
p_oBookedAt,
|
|
p_strMailAddress,
|
|
p_strCode);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets the state value of object.
|
|
/// </summary>
|
|
public InUseStateEnum Value
|
|
{
|
|
get { return _InUseState.Value; }
|
|
}
|
|
|
|
/// <summary>
|
|
/// Member for serialization purposes.
|
|
/// </summary>
|
|
internal BaseState StateInfoObject
|
|
{
|
|
get { return _InUseState; }
|
|
}
|
|
/// Transforms object to string.
|
|
/// </summary>
|
|
/// <returns></returns>
|
|
public new string ToString()
|
|
{
|
|
return _InUseState.Value.ToString("g");
|
|
}
|
|
|
|
/// <summary>
|
|
/// Date of request/ bookeing action.
|
|
/// </summary>
|
|
public DateTime? From
|
|
{
|
|
get
|
|
{
|
|
var l_oNotDisposableInfo = _InUseState as INotAvailableState;
|
|
return l_oNotDisposableInfo != null ? l_oNotDisposableInfo.From : (DateTime?)null;
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Mail address.
|
|
/// </summary>
|
|
public string MailAddress
|
|
{
|
|
get
|
|
{
|
|
var l_oNotDisposableInfo = _InUseState as INotAvailableState;
|
|
return l_oNotDisposableInfo?.MailAddress;
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Reservation code.
|
|
/// </summary>
|
|
public string Code
|
|
{
|
|
get
|
|
{
|
|
var l_oNotDisposableInfo = _InUseState as INotAvailableState;
|
|
return l_oNotDisposableInfo?.Code;
|
|
}
|
|
}
|
|
|
|
/// <summary>
|
|
/// Tries update
|
|
/// </summary>
|
|
/// <returns>True if reservation span has not exeeded and state remains reserved, false otherwise.</returns>
|
|
/// <todo>Implement logging of time stamps.</todo>
|
|
public bool GetIsStillReserved(out TimeSpan? p_oRemainingTime)
|
|
{
|
|
var l_oReservedInfo = _InUseState as StateRequestedInfo;
|
|
if (l_oReservedInfo == null)
|
|
{
|
|
p_oRemainingTime = null;
|
|
return false;
|
|
}
|
|
|
|
return l_oReservedInfo.GetIsStillReserved(out p_oRemainingTime);
|
|
}
|
|
}
|
|
}
|