Events
In addition to intent and context events, the FDC3 API and PrivateChannel API may be used to listen for other types of events via their addEventListener() functions.
ApiEvent
Type defining a basic event object that may be emitted by an FDC3 API interface such as DesktopAgent or PrivateChannel. There are more specific event types defined for each interface.
- TypeScript/JavaScript
- .NET
- Go
interface ApiEvent {
  readonly type: string;
  readonly details: any;
}
Not implemented, as ApiEvent and Fdc3Event definitions are the same, given .NET can not restrict on a string enum. Use IFdc3Event instead
type ApiEvent struct {
  Type string 
  Details any
}
See also:
EventHandler
- TypeScript/JavaScript
- .NET
- Go
type EventHandler = (event: ApiEvent) => void;
public delegate void Fdc3EventHandler(IFdc3Event fdc3Event);
type EventHandler func(ApiEvent)
Describes a callback that handles non-context and non-intent events. Provides the details of the event.
Used when attaching listeners to events.
See also:
FDC3EventTypes
- TypeScript/JavaScript
- .NET
- Go
type FDC3EventTypes = "userChannelChanged";
public static class Fdc3EventType
{
    public const string UserChannelChanged = "userChannelChanged";
}
type FDC3EventTypes string
const (
	UserChannelChanged     FDC3EventTypes = "userChannelChanged"
)
Type defining valid type strings for DesktopAgent interface events.
See also:
FDC3Event
- TypeScript/JavaScript
- .NET
- Go
interface FDC3Event extends ApiEvent{
  readonly type: FDC3EventTypes;
  readonly details: any;
}
public interface IFdc3Event
{
    public string Type { get; }
    public object? Details { get; }
}
public class Fdc3Event : IFdc3Event
{
    public string Type { get; }
    public object? Details { get; }
    public Fdc3Event(string type, object? details = null)
    {
        this.Type = type ?? throw new ArgumentNullException(nameof(type));
        this.Details = details;
    }
}
type FDC3Event struct {
  ApiEvent
  Type FDC3EventTypes
}
Type representing the format of event objects that may be received via the FDC3 API's addEventListener function.
Events will always include both type and details properties, which describe the type of the event and any additional details respectively.
See also:
FDC3ChannelChangedEvent
- TypeScript/JavaScript
- .NET
- Go
interface FDC3ChannelChangedEvent extends FDC3Event {
  readonly type: "userChannelChanged";
  readonly details: {
    currentChannelId: string | null
  };
}
public interface IFdc3ChannelChangedEventDetails
{
    string? CurrentChannelId { get; }
}
public class Fdc3ChannelChangedEventDetails : IFdc3ChannelChangedEventDetails
{
    public string? CurrentChannelId { get; }
    public Fdc3ChannelChangedEventDetails(string? channelId)
    {
        this.CurrentChannelId = channelId;
    }
}
public class Fdc3ChannelChangedEvent : Fdc3Event
{
    public Fdc3ChannelChangedEvent(string? channelId)
        : base(Fdc3EventType.UserChannelChanged, new Fdc3ChannelChangedEventDetails(channelId))
    {
    }
}
type FDC3ChannelChangedEvent struct {
  FDC3Event
  Details FDC3ChannelChangedEventDetails
}
type FDC3ChannelChangedEventDetails struct {
  currentChannelId *string
}
Type representing the format of userChannelChanged  events.
The identity of the channel joined is provided as details.currentChannelId, which will be null if the app is no longer joined to any channel.
PrivateChannelEventTypes
- TypeScript/JavaScript
- .NET
- Go
type PrivateChannelEventTypes = "addContextListener" | "unsubscribe" | "disconnect";
public static class Fdc3PrivateChannelEventType
{
    public const string AddContextListener = "addContextListener";
    public const string Unsubscribe = "unsubscribe";
    public const string Disconnect = "disconnect";
}
type PrivateChannelEventTypes string 
const (
  AddContextListenerPrivateChannelEventType PrivateChannelEventTypes = "addContextListener"
  UnsubscribePrivateChannelEventType PrivateChannelEventTypes = "unsubscribe"
  DisconnectPrivateChannelEventType PrivateChannelEventTypes = "disconnect"
)
Type defining valid type strings for Private Channel events.
See also:
PrivateChannelEvent
- TypeScript/JavaScript
- .NET
- Go
interface PrivateChannelEvent extends ApiEvent {
  readonly type: PrivateChannelEventTypes;
  readonly details: any;
}
public interface IFdc3PrivateChannelEventDetails
{
    string? ContextType { get; }
}
public class Fdc3PrivateChannelEventDetails : IFdc3PrivateChannelEventDetails
{
    public string? ContextType { get; }
    public Fdc3PrivateChannelEventDetails(string? contextType)
    {
        this.ContextType = contextType;
    }
}
type PrivateChannelEvent struct {
  ApiEvent
  Type PrivateChannelEventTypes
}
Type defining the format of event objects that may be received via a PrivateChannel's addEventListener function.
See also:
PrivateChannelAddContextListenerEvent
- TypeScript/JavaScript
- .NET
- Go
interface PrivateChannelAddContextListenerEvent extends PrivateChannelEvent {
  readonly type: "addContextListener";
  readonly details: {
    contextType: string | null
  };
}
public class Fdc3PrivateChannelAddContextListenerEvent : Fdc3Event
{
    public Fdc3PrivateChannelAddContextListenerEvent(string? contextType)
        : base(Fdc3PrivateChannelEventType.AddContextListener, new Fdc3PrivateChannelEventDetails(contextType))
  {
  }
}
type PrivateChannelAddContextListenerEvent struct {
  PrivateChannelEvent
  Details PrivateChannelAddContextListenerEventDetails
}
type PrivateChannelAddContextListenerEventDetails struct {
  contextType *string
}
Type defining the format of events representing a context listener being added to the channel (addContextListener). Desktop Agents MUST fire this event for each invocation of addContextListener on the channel, including those that occurred before this handler was registered (to prevent race conditions).
The context type of the listener added is provided as details.contextType, which will be null if all event types are being listened to.
PrivateChannelUnsubscribeEvent
- TypeScript/JavaScript
- .NET
- Go
interface PrivateChannelUnsubscribeEvent extends PrivateChannelEvent {
  readonly type: "unsubscribe";
  readonly details: {
    contextType: string | null
  };
}
public class Fdc3PrivateChannelUnsubscribeListenerEvent : Fdc3Event
{
    public Fdc3PrivateChannelUnsubscribeListenerEvent(string? contextType)
            : base(Fdc3PrivateChannelEventType.Unsubscribe, new Fdc3PrivateChannelEventDetails(contextType))
    {
    }
}
type PrivateChannelUnsubscribeEvent struct {
  PrivateChannelEvent
  Details PrivateChannelUnsubscribeEventDetails
}
type PrivateChannelUnsubscribeEventDetails struct {
  contextType *string
}
Type defining the format of events representing a context listener removed from the channel (Listener.unsubscribe()). Desktop Agents MUST call this when disconnect() is called by the other party, for each listener that they had added.
The context type of the  listener removed is provided as details.contextType, which will be null if all event types were being listened to.
PrivateChannelDisconnectEvent
- TypeScript/JavaScript
- .NET
- Go
export interface PrivateChannelDisconnectEvent extends PrivateChannelEvent {
  readonly type: "disconnect";
  readonly details: null | undefined;
}
public class Fdc3PrivateChanneDisconnectEvent : Fdc3Event
{
    public Fdc3PrivateChanneDisconnectEvent()
        : base(Fdc3PrivateChannelEventType.Disconnect)
    {
    }
}
type PrivateChannelDisconnectEvent struct {
  PrivateChannelEvent
}
Type defining the format of events representing a remote app being terminated or is otherwise disconnecting from the PrivateChannel. This event is fired in addition to unsubscribe events that will also be fired for any context listeners the disconnecting app had added.
No details are provided.