1 | import { symbolObservable } from "./symbolObservable.js";
|
2 | import { AnyActorSystem, Clock } from "./system.js";
|
3 | import type { AnyActorLogic, AnyActorRef, ConditionalRequired, EmittedFrom, EventFromLogic, InputFrom, IsNotNever, Snapshot, SnapshotFrom } from "./types.js";
|
4 | import { ActorOptions, ActorRef, InteropSubscribable, Observer, Subscription } from "./types.js";
|
5 | export declare const $$ACTOR_TYPE = 1;
|
6 | export declare enum ProcessingStatus {
|
7 | NotStarted = 0,
|
8 | Running = 1,
|
9 | Stopped = 2
|
10 | }
|
11 |
|
12 |
|
13 |
|
14 |
|
15 |
|
16 | export declare class Actor<TLogic extends AnyActorLogic> implements ActorRef<SnapshotFrom<TLogic>, EventFromLogic<TLogic>, EmittedFrom<TLogic>> {
|
17 | logic: TLogic;
|
18 |
|
19 | private _snapshot;
|
20 | |
21 |
|
22 |
|
23 |
|
24 | clock: Clock;
|
25 | options: Readonly<ActorOptions<TLogic>>;
|
26 |
|
27 | id: string;
|
28 | private mailbox;
|
29 | private observers;
|
30 | private eventListeners;
|
31 | private logger;
|
32 | _parent?: AnyActorRef;
|
33 | ref: ActorRef<SnapshotFrom<TLogic>, EventFromLogic<TLogic>, EmittedFrom<TLogic>>;
|
34 | private _actorScope;
|
35 | private _systemId;
|
36 |
|
37 | sessionId: string;
|
38 |
|
39 | system: AnyActorSystem;
|
40 | private _doneEvent?;
|
41 | src: string | AnyActorLogic;
|
42 | |
43 |
|
44 |
|
45 |
|
46 |
|
47 |
|
48 |
|
49 | constructor(logic: TLogic, options?: ActorOptions<TLogic>);
|
50 | private _initState;
|
51 | private _deferred;
|
52 | private update;
|
53 | /**
|
54 | * Subscribe an observer to an actor’s snapshot values.
|
55 | *
|
56 | * @remarks
|
57 | * The observer will receive the actor’s snapshot value when it is emitted.
|
58 | * The observer can be:
|
59 | *
|
60 | * - A plain function that receives the latest snapshot, or
|
61 | * - An observer object whose `.next(snapshot)` method receives the latest
|
62 | * snapshot
|
63 | *
|
64 | * @example
|
65 | *
|
66 | * ```ts
|
67 | * // Observer as a plain function
|
68 | * const subscription = actor.subscribe((snapshot) => {
|
69 | * console.log(snapshot);
|
70 | * });
|
71 | * ```
|
72 | *
|
73 | * @example
|
74 | *
|
75 | * ```ts
|
76 | * // Observer as an object
|
77 | * const subscription = actor.subscribe({
|
78 | * next(snapshot) {
|
79 | * console.log(snapshot);
|
80 | * },
|
81 | * error(err) {
|
82 | *
|
83 | * },
|
84 | * complete() {
|
85 | *
|
86 | * }
|
87 | * });
|
88 | * ```
|
89 | *
|
90 | * The return value of `actor.subscribe(observer)` is a subscription object
|
91 | * that has an `.unsubscribe()` method. You can call
|
92 | * `subscription.unsubscribe()` to unsubscribe the observer:
|
93 | *
|
94 | * @example
|
95 | *
|
96 | * ```ts
|
97 | * const subscription = actor.subscribe((snapshot) => {
|
98 | *
|
99 | * });
|
100 | *
|
101 | * // Unsubscribe the observer
|
102 | * subscription.unsubscribe();
|
103 | * ```
|
104 | *
|
105 | * When the actor is stopped, all of its observers will automatically be
|
106 | * unsubscribed.
|
107 | *
|
108 | * @param observer - Either a plain function that receives the latest
|
109 | * snapshot, or an observer object whose `.next(snapshot)` method receives
|
110 | * the latest snapshot
|
111 | */
|
112 | subscribe(observer: Observer<SnapshotFrom<TLogic>>): Subscription;
|
113 | subscribe(nextListener?: (snapshot: SnapshotFrom<TLogic>) => void, errorListener?: (error: any) => void, completeListener?: () => void): Subscription;
|
114 | on<TType extends EmittedFrom<TLogic>['type'] | '*'>(type: TType, handler: (emitted: EmittedFrom<TLogic> & (TType extends '*' ? {} : {
|
115 | type: TType;
|
116 | })) => void): Subscription;
|
117 | /** Starts the Actor from the initial state */
|
118 | start(): this;
|
119 | private _process;
|
120 | private _stop;
|
121 | /** Stops the Actor and unsubscribe all listeners. */
|
122 | stop(): this;
|
123 | private _complete;
|
124 | private _reportError;
|
125 | private _error;
|
126 | private _stopProcedure;
|
127 | /**
|
128 | * Sends an event to the running Actor to trigger a transition.
|
129 | *
|
130 | * @param event The event to send
|
131 | */
|
132 | send(event: EventFromLogic<TLogic>): void;
|
133 | private attachDevTools;
|
134 | toJSON(): {
|
135 | xstate$$type: number;
|
136 | id: string;
|
137 | };
|
138 | |
139 |
|
140 |
|
141 |
|
142 |
|
143 |
|
144 |
|
145 |
|
146 |
|
147 |
|
148 |
|
149 |
|
150 |
|
151 | getPersistedSnapshot(): Snapshot<unknown>;
|
152 | [symbolObservable](): InteropSubscribable<SnapshotFrom<TLogic>>;
|
153 | |
154 |
|
155 |
|
156 |
|
157 |
|
158 |
|
159 |
|
160 |
|
161 |
|
162 |
|
163 |
|
164 |
|
165 |
|
166 |
|
167 | getSnapshot(): SnapshotFrom<TLogic>;
|
168 | }
|
169 | export type RequiredActorOptionsKeys<TLogic extends AnyActorLogic> = undefined extends InputFrom<TLogic> ? never : 'input';
|
170 |
|
171 |
|
172 |
|
173 |
|
174 |
|
175 |
|
176 |
|
177 |
|
178 |
|
179 |
|
180 |
|
181 |
|
182 |
|
183 |
|
184 |
|
185 |
|
186 |
|
187 |
|
188 |
|
189 |
|
190 |
|
191 |
|
192 |
|
193 |
|
194 |
|
195 |
|
196 |
|
197 |
|
198 |
|
199 |
|
200 |
|
201 |
|
202 |
|
203 |
|
204 |
|
205 |
|
206 |
|
207 |
|
208 | export declare function createActor<TLogic extends AnyActorLogic>(logic: TLogic, ...[options]: ConditionalRequired<[
|
209 | options?: ActorOptions<TLogic> & {
|
210 | [K in RequiredActorOptionsKeys<TLogic>]: unknown;
|
211 | }
|
212 | ], IsNotNever<RequiredActorOptionsKeys<TLogic>>>): Actor<TLogic>;
|
213 |
|
214 |
|
215 |
|
216 |
|
217 |
|
218 |
|
219 |
|
220 | export declare const interpret: typeof createActor;
|
221 |
|
222 |
|
223 |
|
224 |
|
225 | export type Interpreter = typeof Actor;
|