summaryrefslogtreecommitdiff
path: root/includes/external/matrix/node_modules/matrix-events-sdk/lib/events/ExtensibleEvent.d.ts
blob: a82f9670224f827aeeee8ffe11367606e1915df7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
import { IPartialEvent } from "../IPartialEvent";
import { EventType } from "../utility/events";
/**
 * Represents an Extensible Event in Matrix.
 */
export declare abstract class ExtensibleEvent<TContent extends object = object> {
    readonly wireFormat: IPartialEvent<TContent>;
    protected constructor(wireFormat: IPartialEvent<TContent>);
    /**
     * Shortcut to wireFormat.content
     */
    get wireContent(): TContent;
    /**
     * Serializes the event into a format which can be used to send the
     * event to the room.
     * @returns {IPartialEvent<object>} The serialized event.
     */
    abstract serialize(): IPartialEvent<object>;
    /**
     * Determines if this event is equivalent to the provided event type.
     * This is recommended over `instanceof` checks due to issues in the JS
     * runtime (and layering of dependencies in some projects).
     *
     * Implementations should pass this check off to their super classes
     * if their own checks fail. Some primary implementations do not extend
     * fallback classes given they support the primary type first. Thus,
     * those classes may return false if asked about their fallback
     * representation.
     *
     * Note that this only checks primary event types: legacy events, like
     * m.room.message, should/will fail this check.
     * @param {EventType} primaryEventType The (potentially namespaced) event
     * type.
     * @returns {boolean} True if this event *could* be represented as the
     * given type.
     */
    abstract isEquivalentTo(primaryEventType: EventType): boolean;
}