2026-01-03 19:33:36 +01:00
|
|
|
using CommunityToolkit.Mvvm.Messaging;
|
|
|
|
|
using Wino.Core.Domain.Entities.Calendar;
|
|
|
|
|
using Wino.Core.Domain.Enums;
|
|
|
|
|
using Wino.Core.Domain.Models.Requests;
|
|
|
|
|
using Wino.Messaging.Client.Calendar;
|
|
|
|
|
|
|
|
|
|
namespace Wino.Core.Requests.Calendar;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Request to accept a calendar event invitation on the server.
|
|
|
|
|
/// The calendar item status should be updated locally before queuing this request.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public record AcceptEventRequest(CalendarItem Item, string ResponseMessage = null) : CalendarRequestBase(Item)
|
|
|
|
|
{
|
|
|
|
|
private readonly CalendarItemStatus _previousStatus = Item.Status;
|
|
|
|
|
|
|
|
|
|
public override CalendarSynchronizerOperation Operation => CalendarSynchronizerOperation.AcceptEvent;
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// After successful acceptance, we need to resync to get updated status.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public override int ResynchronizationDelay => 2000;
|
|
|
|
|
|
|
|
|
|
public override void ApplyUIChanges()
|
|
|
|
|
{
|
|
|
|
|
// Update the item status locally
|
|
|
|
|
Item.Status = CalendarItemStatus.Accepted;
|
|
|
|
|
|
|
|
|
|
// Notify UI that the event status was updated
|
2026-02-12 18:04:29 +01:00
|
|
|
WeakReferenceMessenger.Default.Send(new CalendarItemUpdated(Item, CalendarItemUpdateSource.ClientUpdated));
|
2026-01-03 19:33:36 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override void RevertUIChanges()
|
|
|
|
|
{
|
|
|
|
|
// If acceptance fails, revert to the previous status
|
|
|
|
|
Item.Status = _previousStatus;
|
2026-02-12 18:04:29 +01:00
|
|
|
WeakReferenceMessenger.Default.Send(new CalendarItemUpdated(Item, CalendarItemUpdateSource.ClientReverted));
|
2026-01-03 19:33:36 +01:00
|
|
|
}
|
|
|
|
|
}
|