@effect-app/vue 4.0.0-beta.22 → 4.0.0-beta.221

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (106) hide show
  1. package/CHANGELOG.md +1613 -0
  2. package/dist/commander.d.ts +634 -0
  3. package/dist/commander.d.ts.map +1 -0
  4. package/dist/commander.js +1070 -0
  5. package/dist/confirm.d.ts +21 -0
  6. package/dist/confirm.d.ts.map +1 -0
  7. package/dist/confirm.js +26 -0
  8. package/dist/errorReporter.d.ts +7 -5
  9. package/dist/errorReporter.d.ts.map +1 -1
  10. package/dist/errorReporter.js +14 -19
  11. package/dist/form.d.ts +15 -6
  12. package/dist/form.d.ts.map +1 -1
  13. package/dist/form.js +46 -13
  14. package/dist/index.d.ts +1 -1
  15. package/dist/intl.d.ts +15 -0
  16. package/dist/intl.d.ts.map +1 -0
  17. package/dist/intl.js +9 -0
  18. package/dist/lib.d.ts +8 -10
  19. package/dist/lib.d.ts.map +1 -1
  20. package/dist/lib.js +35 -10
  21. package/dist/makeClient.d.ts +156 -339
  22. package/dist/makeClient.d.ts.map +1 -1
  23. package/dist/makeClient.js +225 -376
  24. package/dist/makeContext.d.ts +1 -1
  25. package/dist/makeContext.d.ts.map +1 -1
  26. package/dist/makeIntl.d.ts +1 -1
  27. package/dist/makeIntl.d.ts.map +1 -1
  28. package/dist/makeUseCommand.d.ts +9 -0
  29. package/dist/makeUseCommand.d.ts.map +1 -0
  30. package/dist/makeUseCommand.js +13 -0
  31. package/dist/mutate.d.ts +54 -34
  32. package/dist/mutate.d.ts.map +1 -1
  33. package/dist/mutate.js +139 -46
  34. package/dist/query.d.ts +20 -39
  35. package/dist/query.d.ts.map +1 -1
  36. package/dist/query.js +133 -72
  37. package/dist/routeParams.d.ts +3 -2
  38. package/dist/routeParams.d.ts.map +1 -1
  39. package/dist/routeParams.js +4 -3
  40. package/dist/runtime.d.ts +10 -6
  41. package/dist/runtime.d.ts.map +1 -1
  42. package/dist/runtime.js +32 -18
  43. package/dist/toast.d.ts +51 -0
  44. package/dist/toast.d.ts.map +1 -0
  45. package/dist/toast.js +34 -0
  46. package/dist/withToast.d.ts +30 -0
  47. package/dist/withToast.d.ts.map +1 -0
  48. package/dist/withToast.js +64 -0
  49. package/examples/streamMutation.ts +72 -0
  50. package/package.json +48 -50
  51. package/src/commander.ts +3406 -0
  52. package/src/{experimental/confirm.ts → confirm.ts} +12 -14
  53. package/src/errorReporter.ts +65 -75
  54. package/src/form.ts +61 -18
  55. package/src/intl.ts +12 -0
  56. package/src/lib.ts +48 -20
  57. package/src/makeClient.ts +574 -1134
  58. package/src/{experimental/makeUseCommand.ts → makeUseCommand.ts} +8 -5
  59. package/src/mutate.ts +268 -127
  60. package/src/query.ts +203 -183
  61. package/src/routeParams.ts +3 -2
  62. package/src/runtime.ts +46 -21
  63. package/src/{experimental/toast.ts → toast.ts} +15 -27
  64. package/src/{experimental/withToast.ts → withToast.ts} +46 -12
  65. package/test/Mutation.test.ts +181 -24
  66. package/test/dist/form.test.d.ts.map +1 -1
  67. package/test/dist/lib.test.d.ts.map +1 -0
  68. package/test/dist/streamFinal.test.d.ts.map +1 -0
  69. package/test/dist/streamFn.test.d.ts.map +1 -0
  70. package/test/dist/stubs.d.ts +3531 -122
  71. package/test/dist/stubs.d.ts.map +1 -1
  72. package/test/dist/stubs.js +187 -32
  73. package/test/form-validation-errors.test.ts +25 -20
  74. package/test/form.test.ts +22 -3
  75. package/test/lib.test.ts +240 -0
  76. package/test/makeClient.test.ts +292 -38
  77. package/test/streamFinal.test.ts +64 -0
  78. package/test/streamFn.test.ts +457 -0
  79. package/test/stubs.ts +223 -43
  80. package/tsconfig.examples.json +20 -0
  81. package/tsconfig.json +0 -1
  82. package/tsconfig.json.bak +5 -2
  83. package/tsconfig.src.json +34 -34
  84. package/tsconfig.test.json +2 -2
  85. package/vitest.config.ts +5 -5
  86. package/dist/experimental/commander.d.ts +0 -359
  87. package/dist/experimental/commander.d.ts.map +0 -1
  88. package/dist/experimental/commander.js +0 -557
  89. package/dist/experimental/confirm.d.ts +0 -19
  90. package/dist/experimental/confirm.d.ts.map +0 -1
  91. package/dist/experimental/confirm.js +0 -28
  92. package/dist/experimental/intl.d.ts +0 -16
  93. package/dist/experimental/intl.d.ts.map +0 -1
  94. package/dist/experimental/intl.js +0 -5
  95. package/dist/experimental/makeUseCommand.d.ts +0 -8
  96. package/dist/experimental/makeUseCommand.d.ts.map +0 -1
  97. package/dist/experimental/makeUseCommand.js +0 -13
  98. package/dist/experimental/toast.d.ts +0 -47
  99. package/dist/experimental/toast.d.ts.map +0 -1
  100. package/dist/experimental/toast.js +0 -41
  101. package/dist/experimental/withToast.d.ts +0 -25
  102. package/dist/experimental/withToast.d.ts.map +0 -1
  103. package/dist/experimental/withToast.js +0 -45
  104. package/eslint.config.mjs +0 -24
  105. package/src/experimental/commander.ts +0 -1835
  106. package/src/experimental/intl.ts +0 -9
@@ -0,0 +1,1070 @@
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+ import { reportMessage } from "@effect-app/vue/errorReporter";
3
+ import { deepToRaw, reportRuntimeError } from "@effect-app/vue/lib";
4
+ import { asResult, asStreamResult } from "@effect-app/vue/mutate";
5
+ import { SupportedErrors } from "effect-app/client";
6
+ import * as Context from "effect-app/Context";
7
+ import * as Effect from "effect-app/Effect";
8
+ import * as Layer from "effect-app/Layer";
9
+ import * as Option from "effect-app/Option";
10
+ import * as S from "effect-app/Schema";
11
+ import { isGeneratorFunction, wrapEffect } from "effect-app/utils";
12
+ import * as Cause from "effect/Cause";
13
+ import { flow } from "effect/Function";
14
+ import * as Match from "effect/Match";
15
+ import * as MutableHashMap from "effect/MutableHashMap";
16
+ import * as Predicate from "effect/Predicate";
17
+ import * as Stream from "effect/Stream";
18
+ import * as AsyncResult from "effect/unstable/reactivity/AsyncResult";
19
+ import { computed, reactive, ref, toRaw } from "vue";
20
+ import { Confirm } from "./confirm.js";
21
+ import { I18n } from "./intl.js";
22
+ import { CurrentToastId, Toast } from "./toast.js";
23
+ import { WithToast } from "./withToast.js";
24
+ export const DefaultIntl = {
25
+ de: {
26
+ "handle.confirmation": "{action} bestätigen?",
27
+ "handle.waiting": "{action} wird ausgeführt...",
28
+ "handle.success": "{action} erfolgreich",
29
+ "handle.with_errors": "{action} fehlgeschlagen",
30
+ "handle.with_warnings": "{action} erfolgreich, mit Warnungen",
31
+ "handle.error_response": "Die Anfrage war nicht erfolgreich:\n{error}\nWir wurden benachrichtigt und werden das Problem in Kürze beheben.",
32
+ "handle.response_error": "Die Antwort konnte nicht verarbeitet werden:\n{error}",
33
+ "handle.request_error": "Die Anfrage konnte nicht gesendet werden:\n{error}",
34
+ "handle.unexpected_error2": "{action} unerwarteter Fehler, probieren sie es in kurze nochmals.",
35
+ "handle.unexpected_error": "Unerwarteter Fehler:\n{error}",
36
+ "handle.not_found": "Das gesuchte war nicht gefunden"
37
+ },
38
+ en: {
39
+ "handle.confirmation": "Confirm {action}?",
40
+ "handle.waiting": "{action} executing...",
41
+ "handle.success": "{action} Success",
42
+ "handle.with_errors": "{action} Failed",
43
+ "handle.with_warnings": "{action}, with warnings",
44
+ "handle.error_response": "There was an error in processing the response:\n{error}\nWe have been notified and will fix the problem shortly.",
45
+ "handle.request_error": "There was an error in the request:\n{error}",
46
+ "handle.response_error": "The request was not successful:\n{error}",
47
+ "handle.unexpected_error2": "{action} unexpected error, please try again shortly.",
48
+ "handle.unexpected_error": "Unexpected Error:\n{error}",
49
+ "handle.not_found": "The requested item was not found."
50
+ }
51
+ };
52
+ export class CommandContext extends Context.Service()("CommandContext") {
53
+ }
54
+ /**
55
+ * Service available inside `streamFn` stream handlers that lets you imperatively push
56
+ * progress updates to the command's reactive `progress` ref.
57
+ *
58
+ * Use `Command.mapProgress(fn)` or `Command.updateProgress(progress)` to interact with this service.
59
+ *
60
+ * @example
61
+ * ```ts
62
+ * // Using mapProgress (recommended) — applied as a stream pipe operator:
63
+ * const exportCmd = Command.streamFn("exportData")(
64
+ * function*(arg, ctx) {
65
+ * return makeExportStream(arg.id).pipe(
66
+ * Command.mapProgress((r) =>
67
+ * AsyncResult.isSuccess(r) && r.value._tag === "OperationProgress"
68
+ * ? { text: `${r.value.completed}/${r.value.total}`, percentage: r.value.completed / r.value.total * 100 }
69
+ * : undefined
70
+ * )
71
+ * )
72
+ * }
73
+ * )
74
+ * // exportCmd.progress is updated for every OperationProgress event
75
+ * ```
76
+ */
77
+ export class CommandProgress extends Context.Reference("Commander.CommandProgress", {
78
+ defaultValue: () => ({ update: (_progress) => Effect.void })
79
+ }) {
80
+ }
81
+ /**
82
+ * Use to wrap emit calls with a callback to signal completion.
83
+ * Useful when the publisher wants to wait for the subscriber to finish processing.
84
+ */
85
+ export const wrapEmit = (emit, event) => (value) => new Promise((resolve) => emit(event, value, resolve));
86
+ export class CommanderErrorRenderers extends Context.Reference("Commander.ErrorRenderers", {
87
+ defaultValue: () => []
88
+ }) {
89
+ }
90
+ export const makeRegisteredErrorRenderer = (guard, render) => ({
91
+ guard,
92
+ render
93
+ });
94
+ const renderErrorMaker = Effect.gen(function* () {
95
+ const { intl } = yield* I18n;
96
+ const registeredRenderers = yield* CommanderErrorRenderers;
97
+ return ((action, errorRenderer) => (e, ...args) => {
98
+ if (errorRenderer) {
99
+ const m = errorRenderer(e, action, ...args);
100
+ if (m !== undefined) {
101
+ return m;
102
+ }
103
+ }
104
+ for (const entry of registeredRenderers) {
105
+ if (!entry.guard(e)) {
106
+ continue;
107
+ }
108
+ const m = entry.render(e);
109
+ if (m !== undefined) {
110
+ return m;
111
+ }
112
+ }
113
+ if (!S.is(SupportedErrors)(e) && !S.isSchemaError(e)) {
114
+ if (typeof e === "object" && e !== null) {
115
+ if ("message" in e) {
116
+ return `${e.message}`;
117
+ }
118
+ if ("_tag" in e) {
119
+ return `${e._tag}`;
120
+ }
121
+ }
122
+ return "";
123
+ }
124
+ const e2 = e;
125
+ return Match.value(e2).pipe(Match.tags({
126
+ NotFoundError: (e) => {
127
+ return intl.formatMessage({ id: "handle.not_found" }, { type: e.type, id: e.id });
128
+ },
129
+ SchemaError: (e) => {
130
+ console.warn(e.toString());
131
+ return intl.formatMessage({ id: "validation.failed" });
132
+ }
133
+ }), Match.orElse((e) => e.message ?? e._tag ?? e));
134
+ });
135
+ });
136
+ const defaultFailureMessageHandler = (actionMaker, errorRenderer) => Effect.fnUntraced(function* (o, ...args) {
137
+ const action = yield* wrapEffect(actionMaker)(o, ...args);
138
+ const { intl } = yield* I18n;
139
+ const renderError = yield* renderErrorMaker;
140
+ return Option.match(o, {
141
+ onNone: () => intl.formatMessage({ id: "handle.unexpected_error2" }, {
142
+ action,
143
+ error: "" // TODO consider again Cause.pretty(cause), // will be reported to Sentry/Otel anyway.. and we shouldn't bother users with error dumps?
144
+ }),
145
+ onSome: (e) => {
146
+ const rendered = renderError(action, errorRenderer)(e, ...args);
147
+ return {
148
+ level: "warn",
149
+ message: `${intl.formatMessage({ id: "handle.with_errors" }, { action })}:\n` + rendered
150
+ };
151
+ }
152
+ });
153
+ });
154
+ export const CommanderStatic = {
155
+ accessArgs: (cb) => (self, arg, arg2) => cb(arg, arg2)(self),
156
+ /**
157
+ * Stream pipe operator that maps each emitted value to a `Progress` entry and updates the
158
+ * command's reactive `progress` ref via the `CommandProgress` service.
159
+ *
160
+ * The mapper receives an `AsyncResult<A, E>` (each emitted value wrapped as
161
+ * `AsyncResult.success(value, { waiting: true })`), matching the same shape used by
162
+ * `CommandButton`'s `:progress-map` prop.
163
+ *
164
+ * Designed to be used inside a `streamFn` handler (either directly with `.pipe()`, or as
165
+ * a combinator argument):
166
+ *
167
+ * @example
168
+ * ```ts
169
+ * // Inside the handler body:
170
+ * Command.streamFn("exportData")(function*(arg, ctx) {
171
+ * return makeExportStream(arg.id).pipe(
172
+ * Command.mapProgress((r) =>
173
+ * AsyncResult.isSuccess(r) && r.value._tag === "OperationProgress"
174
+ * ? { text: `${r.value.completed}/${r.value.total}`, percentage: r.value.completed / r.value.total * 100 }
175
+ * : undefined
176
+ * )
177
+ * )
178
+ * })
179
+ *
180
+ * // Or as a stream combinator argument:
181
+ * Command.streamFn("exportData")(
182
+ * function*(arg, ctx) { return makeExportStream(arg.id) },
183
+ * (s) => s.pipe(Command.mapProgress((r) => AsyncResult.isSuccess(r) && r.value._tag === "OperationProgress" ? { text: `${r.value.completed}/${r.value.total}` } : undefined))
184
+ * )
185
+ * ```
186
+ */
187
+ mapProgress: (fn) => (stream) => stream.pipe(Stream.tap((v) => {
188
+ const p = fn(AsyncResult.success(v, { waiting: true }));
189
+ return p !== undefined ? CommandProgress.use((s) => s.update(p)) : Effect.void;
190
+ })),
191
+ /**
192
+ * Imperatively push a progress update from inside a `streamFn` handler.
193
+ * Requires `CommandProgress` to be in context — provided automatically for all `streamFn` streams.
194
+ *
195
+ * @example
196
+ * ```ts
197
+ * // In a streamFn handler:
198
+ * stream.pipe(
199
+ * Stream.tap((event) =>
200
+ * event._tag === "OperationProgress"
201
+ * ? Command.updateProgress({ text: `${event.completed}/${event.total}`, percentage: event.completed / event.total * 100 })
202
+ * : Effect.void
203
+ * )
204
+ * )
205
+ * ```
206
+ */
207
+ updateProgress: (progress) => CommandProgress.use((s) => s.update(progress)),
208
+ /** Version of @see confirmOrInterrupt that automatically includes the action name in the default messages */
209
+ confirmOrInterrupt: Effect.fnUntraced(function* (message) {
210
+ const context = yield* CommandContext;
211
+ const { intl } = yield* I18n;
212
+ yield* Confirm.confirmOrInterrupt(message
213
+ ?? intl.formatMessage({ id: "handle.confirmation" }, { action: context.action }));
214
+ }),
215
+ /** Version of @see confirm that automatically includes the action name in the default messages */
216
+ confirm: Effect.fnUntraced(function* (message) {
217
+ const context = yield* CommandContext;
218
+ const { intl } = yield* I18n;
219
+ return yield* Confirm.confirm(message
220
+ ?? intl.formatMessage({ id: "handle.confirmation" }, { action: context.action }));
221
+ }),
222
+ updateAction: (update) => (_, ...input) => Effect.updateService(_, CommandContext, (c) => ({ ...c, action: update(c.action, ...input) })),
223
+ registerErrorRenderer: (guard, render) => Layer.effect(CommanderErrorRenderers, Effect.gen(function* () {
224
+ const current = yield* CommanderErrorRenderers;
225
+ return [...current, makeRegisteredErrorRenderer(guard, render)];
226
+ })),
227
+ defaultFailureMessageHandler,
228
+ renderError: renderErrorMaker,
229
+ /**
230
+ * Version of withDefaultToast that automatically includes the action name in the default messages and uses intl.
231
+ * uses the Command id as i18n namespace. `action.{id}` is the main action name,
232
+ * and `action.{id}.waiting`, `action.{id}.success`, `action.{id}.failure` can be used to override the default messages for the respective states.
233
+ *
234
+ * the computed `state` provided to the Command can be used for interpolation in the i18n messages. (the state is captured at the start of each command execution and remains stable throughout)
235
+ *
236
+ * Note: if you provide `onWaiting` or `onSuccess` as `null`, no toast will be shown for that state.
237
+ * If you provide a string or function, it will be used instead of the i18n message.
238
+ * If you provide an `errorRenderer`, it will be used to render errors in the failure message.
239
+ */
240
+ withDefaultToast: (options) => Effect.fnUntraced(function* (self, ...args) {
241
+ const cc = yield* CommandContext;
242
+ const { intl } = yield* I18n;
243
+ const withToast = yield* WithToast;
244
+ const customWaiting = cc.namespaced("waiting");
245
+ const hasCustomWaiting = !!intl.messages[customWaiting];
246
+ const customSuccess = cc.namespaced("success");
247
+ const hasCustomSuccess = !!intl.messages[customSuccess];
248
+ const customFailure = cc.namespaced("failure");
249
+ const hasCustomFailure = !!intl.messages[customFailure];
250
+ const stableToastId = options?.stableToastId
251
+ ? typeof options.stableToastId === "string"
252
+ ? options.stableToastId
253
+ : typeof options.stableToastId === "boolean"
254
+ ? cc.id
255
+ : typeof options.stableToastId === "function"
256
+ ? (...args) => {
257
+ const r = options.stableToastId(cc.id, ...args);
258
+ if (typeof r === "string")
259
+ return r;
260
+ if (r === true)
261
+ return cc.id;
262
+ return undefined;
263
+ }
264
+ : undefined
265
+ : undefined;
266
+ return yield* self.pipe((_) => withToast({
267
+ onWaiting: options?.onWaiting === null ? null : hasCustomWaiting
268
+ ? intl.formatMessage({
269
+ id: customWaiting
270
+ }, cc.state)
271
+ : intl.formatMessage({ id: "handle.waiting" }, { action: cc.action }),
272
+ onSuccess: options?.onSuccess === null
273
+ ? null
274
+ : (_a, ..._args) => hasCustomSuccess
275
+ ? intl.formatMessage({ id: customSuccess }, cc.state)
276
+ : intl.formatMessage({ id: "handle.success" }, { action: cc.action }),
277
+ onFailure: defaultFailureMessageHandler(hasCustomFailure ? intl.formatMessage({ id: customFailure }, cc.state) : cc.action, options?.errorRenderer),
278
+ stableToastId,
279
+ groupId: cc.id,
280
+ ...options?.showSpanInfo === false ? { showSpanInfo: options.showSpanInfo } : {}
281
+ })(_, ...args));
282
+ }),
283
+ /**
284
+ * Stream-aware version of `withDefaultToast`. Use this as a combinator inside `streamFn`
285
+ * (or anywhere a `Stream` needs toast lifecycle handling) instead of `withDefaultToast`.
286
+ *
287
+ * Unlike `withDefaultToast` (which only wraps the initial `Effect`), this combinator:
288
+ * - Shows the "waiting" toast **before** the stream starts
289
+ * - Updates the waiting toast with progress text when `progress` is set and a new element arrives
290
+ * - Shows the "success" toast only **after** the stream drains fully without error
291
+ * - Shows the "failure" toast if the stream errors or fails
292
+ *
293
+ * Accepts either a `Stream<A, E, R>` or an `Effect<Stream<A, E, R>, EE, ER>` as input,
294
+ * so it works in both the `NonGenStream` and `StreamGen` overloads of `streamFn`.
295
+ *
296
+ * @example
297
+ * ```ts
298
+ * Command.streamFn("exportData")(
299
+ * function*(arg, ctx) { return makeExportStream(arg.id) },
300
+ * Command.withDefaultToastStream({
301
+ * progress: (r) =>
302
+ * AsyncResult.isSuccess(r) && r.value._tag === "OperationProgress"
303
+ * ? { text: `${r.value.completed}/${r.value.total}`, percentage: r.value.completed / r.value.total * 100 }
304
+ * : undefined
305
+ * })
306
+ * )
307
+ * ```
308
+ */
309
+ withDefaultToastStream: (options) => (self, ...args) => {
310
+ const rawStream = Stream.isStream(self)
311
+ ? self
312
+ : Stream.unwrap(self);
313
+ return Stream.unwrap(Effect.gen(function* () {
314
+ const cc = yield* CommandContext;
315
+ const { intl } = yield* I18n;
316
+ const toast = yield* Toast;
317
+ const customWaiting = cc.namespaced("waiting");
318
+ const hasCustomWaiting = !!intl.messages[customWaiting];
319
+ const customSuccess = cc.namespaced("success");
320
+ const hasCustomSuccess = !!intl.messages[customSuccess];
321
+ const customFailure = cc.namespaced("failure");
322
+ const hasCustomFailure = !!intl.messages[customFailure];
323
+ const stableToastId = options?.stableToastId
324
+ ? typeof options.stableToastId === "string"
325
+ ? options.stableToastId
326
+ : typeof options.stableToastId === "boolean"
327
+ ? cc.id
328
+ : typeof options.stableToastId === "function"
329
+ ? (() => {
330
+ const r = options.stableToastId(cc.id, ...args);
331
+ if (typeof r === "string")
332
+ return r;
333
+ if (r === true)
334
+ return cc.id;
335
+ return undefined;
336
+ })()
337
+ : undefined
338
+ : undefined;
339
+ const baseTimeout = 3_000;
340
+ const waitingMsg = options?.onWaiting === null
341
+ ? null
342
+ : typeof options?.onWaiting === "string"
343
+ ? options.onWaiting
344
+ : typeof options?.onWaiting === "function"
345
+ ? options.onWaiting(cc.id, ...args) ?? null
346
+ : hasCustomWaiting
347
+ ? intl.formatMessage({ id: customWaiting }, cc.state)
348
+ : intl.formatMessage({ id: "handle.waiting" }, { action: cc.action });
349
+ const toastId = waitingMsg === null
350
+ ? stableToastId
351
+ : stableToastId ?? `wait-${Math.random().toString(36).slice(2)}`;
352
+ const requestId = yield* Effect.currentSpan.pipe(Effect.map((span) => span.traceId), Effect.orElseSucceed(() => S.StringId.make()));
353
+ const meta = { groupId: cc.id, requestId };
354
+ if (waitingMsg !== null) {
355
+ yield* toast.info(waitingMsg, { id: toastId, timeout: Infinity, ...meta });
356
+ }
357
+ const failureHandler = defaultFailureMessageHandler(hasCustomFailure ? intl.formatMessage({ id: customFailure }, cc.state) : cc.action, options?.errorRenderer);
358
+ let lastValue = undefined;
359
+ let didFail = false;
360
+ const composed = rawStream.pipe(Stream.tap((v) => Effect.gen(function* () {
361
+ lastValue = v;
362
+ if (options?.progress !== undefined) {
363
+ const p = options.progress(AsyncResult.success(v, { waiting: true }));
364
+ if (p !== undefined) {
365
+ // Update CommandProgress so CommandButton progress indicator is also driven
366
+ yield* CommandProgress.use((s) => s.update(p));
367
+ if (toastId !== undefined) {
368
+ const progressText = typeof p === "string" ? p : p.text;
369
+ const msg = waitingMsg ? `${waitingMsg}\n${progressText}` : progressText;
370
+ yield* toast.info(msg, { id: toastId, timeout: Infinity, ...meta });
371
+ }
372
+ }
373
+ }
374
+ })), Stream.tapCause(Effect.fnUntraced(function* (cause) {
375
+ didFail = true;
376
+ if (Cause.hasInterruptsOnly(cause)) {
377
+ if (toastId !== undefined)
378
+ yield* toast.dismiss(toastId);
379
+ return;
380
+ }
381
+ const spanInfo = options?.showSpanInfo !== false
382
+ ? yield* Effect.currentSpan.pipe(Effect.map((span) => `\nTrace: ${span.traceId}\nSpan: ${span.spanId}`), Effect.orElseSucceed(() => ""))
383
+ : "";
384
+ const t = yield* failureHandler(Cause.findErrorOption(cause));
385
+ const opts = { timeout: baseTimeout * 2, ...meta };
386
+ if (typeof t === "object") {
387
+ const message = t.message + spanInfo;
388
+ yield* t.level === "warn"
389
+ ? toast.warning(message, toastId !== undefined ? { ...opts, id: toastId } : opts)
390
+ : toast.error(message, toastId !== undefined ? { ...opts, id: toastId } : opts);
391
+ }
392
+ else {
393
+ yield* toast.error(t + spanInfo, toastId !== undefined ? { ...opts, id: toastId } : opts);
394
+ }
395
+ }, Effect.uninterruptible)), Stream.ensuring(Effect.suspend(() => {
396
+ if (didFail)
397
+ return Effect.void;
398
+ if (options?.onSuccess === null)
399
+ return Effect.void;
400
+ const successMsg = typeof options?.onSuccess === "string"
401
+ ? options.onSuccess
402
+ : typeof options?.onSuccess === "function"
403
+ ? options.onSuccess(lastValue, cc.action, ...args) ?? null
404
+ : hasCustomSuccess
405
+ ? intl.formatMessage({ id: customSuccess }, cc.state)
406
+ : intl.formatMessage({ id: "handle.success" }, { action: cc.action });
407
+ if (successMsg === null)
408
+ return Effect.void;
409
+ return toast.success(successMsg, toastId !== undefined
410
+ ? { id: toastId, timeout: baseTimeout, ...meta }
411
+ : { timeout: baseTimeout, ...meta });
412
+ })));
413
+ return (toastId !== undefined
414
+ ? composed.pipe(Stream.provideService(CurrentToastId, CurrentToastId.of({ toastId })))
415
+ : composed);
416
+ }));
417
+ },
418
+ /** borrowing the idea from Families in Effect Atom */
419
+ family: (maker, keyMaker) => {
420
+ const commands = MutableHashMap.empty();
421
+ const registry = new FinalizationRegistry((arg) => {
422
+ MutableHashMap.remove(commands, arg);
423
+ });
424
+ return (_k) => {
425
+ const k = keyMaker ? keyMaker(_k) : _k;
426
+ // we want to compare structurally, unless custom equal/hash has been implemented
427
+ const item = MutableHashMap.get(commands, k).pipe(Option.flatMap((r) => Option.fromNullishOr(r.deref())));
428
+ if (item.value) {
429
+ return item.value;
430
+ }
431
+ const v = maker(k);
432
+ MutableHashMap.set(commands, k, new WeakRef(v));
433
+ registry.register(v, k);
434
+ return v;
435
+ };
436
+ }
437
+ };
438
+ const makeBaseInfo = (id, options) => {
439
+ if (!id)
440
+ throw new Error("must specify an id");
441
+ const i18nKey = options?.i18nCustomKey ?? id;
442
+ const namespace = `action.${i18nKey}`;
443
+ const context = {
444
+ id,
445
+ i18nKey,
446
+ namespace,
447
+ namespaced: (k) => `${namespace}.${k}`
448
+ };
449
+ return context;
450
+ };
451
+ const waitState = ref({});
452
+ const registerWait = (id) => {
453
+ // console.debug("register wait", id)
454
+ waitState.value[id] = waitState.value[id] ? waitState.value[id] + 1 : 1;
455
+ };
456
+ const unregisterWait = (id) => {
457
+ // console.debug("unregister wait", id)
458
+ if (waitState.value[id]) {
459
+ waitState.value[id] = waitState.value[id] - 1;
460
+ if (waitState.value[id] <= 0) {
461
+ delete waitState.value[id];
462
+ }
463
+ }
464
+ };
465
+ const getStateValues = (options) => {
466
+ const state_ = options?.state;
467
+ const state = !state_ ? computed(() => undefined) : typeof state_ === "function"
468
+ ? computed(state_)
469
+ : state_;
470
+ return state;
471
+ };
472
+ // class preserves JSDoc throughout..
473
+ export class CommanderImpl {
474
+ rt;
475
+ intl;
476
+ hooks;
477
+ constructor(rt, intl, hooks) {
478
+ this.rt = rt;
479
+ this.intl = intl;
480
+ this.hooks = hooks;
481
+ }
482
+ makeContext = (id, options) => {
483
+ if (!id)
484
+ throw new Error("must specify an id");
485
+ const i18nKey = options?.i18nCustomKey ?? id;
486
+ const namespace = `action.${i18nKey}`;
487
+ // must remain stable through out single call
488
+ const action = this.intl.formatMessage({
489
+ id: namespace,
490
+ defaultMessage: id
491
+ }, { ...options?.state, _isLabel: false });
492
+ const label = this.intl.formatMessage({
493
+ id: namespace,
494
+ defaultMessage: id
495
+ }, { ...options?.state, _isLabel: true });
496
+ const context = CommandContext.of({
497
+ ...makeBaseInfo(id, options),
498
+ action,
499
+ label,
500
+ state: options?.state
501
+ });
502
+ return context;
503
+ };
504
+ makeCommand = (id_, options, errorDef) => {
505
+ const id = typeof id_ === "string" ? id_ : id_.id;
506
+ const state = getStateValues(options);
507
+ return Object.assign((handler) => {
508
+ // we capture the definition stack here, so we can append it to later stack traces
509
+ const limit = Error.stackTraceLimit;
510
+ Error.stackTraceLimit = 2;
511
+ const localErrorDef = new Error();
512
+ Error.stackTraceLimit = limit;
513
+ if (!errorDef) {
514
+ errorDef = localErrorDef;
515
+ }
516
+ const key = `Commander.Command.${id}.state`;
517
+ const stateTag = Context.Service(key);
518
+ const makeContext_ = () => this.makeContext(id, { ...options, state: state?.value });
519
+ const initialContext = makeContext_();
520
+ const context = computed(() => makeContext_());
521
+ const action = computed(() => context.value.action);
522
+ const label = computed(() => context.value.label);
523
+ const errorReporter = (self) => self.pipe(Effect.tapCause(Effect.fnUntraced(function* (cause) {
524
+ if (Cause.hasInterruptsOnly(cause)) {
525
+ console.info(`Interrupted while trying to ${id}`);
526
+ return;
527
+ }
528
+ const fail = Cause.findErrorOption(cause);
529
+ if (Option.isSome(fail)) {
530
+ // if (fail.value._tag === "SuppressErrors") {
531
+ // console.info(
532
+ // `Suppressed error trying to ${action}`,
533
+ // fail.value,
534
+ // )
535
+ // return
536
+ // }
537
+ const message = `Failure trying to ${id}`;
538
+ yield* reportMessage(message, {
539
+ action: id,
540
+ error: fail.value
541
+ });
542
+ return;
543
+ }
544
+ const context = yield* CommandContext;
545
+ const extra = {
546
+ action: context.action,
547
+ message: `Unexpected Error trying to ${id}`
548
+ };
549
+ yield* reportRuntimeError(cause, extra);
550
+ }, Effect.uninterruptible)));
551
+ const currentState = Effect.sync(() => state.value);
552
+ const theHandler = flow(handler, errorReporter,
553
+ // all must be within the Effect.fn to fit within the Span
554
+ Effect.provideServiceEffect(stateTag, currentState), Effect.provideServiceEffect(CommandContext, Effect.sync(() => makeContext_())));
555
+ const waitId = options?.waitKey ? options.waitKey(id) : undefined;
556
+ const blockId = options?.blockKey ? options.blockKey(id) : undefined;
557
+ const [result, exec_] = asResult(theHandler);
558
+ const exec = Effect
559
+ .fnUntraced(function* (...args) {
560
+ if (waitId !== undefined)
561
+ registerWait(waitId);
562
+ if (blockId !== undefined && blockId !== waitId) {
563
+ registerWait(blockId);
564
+ }
565
+ return yield* exec_(...args);
566
+ }, Effect.onExit(() => Effect.sync(() => {
567
+ if (waitId !== undefined)
568
+ unregisterWait(waitId);
569
+ if (blockId !== undefined && blockId !== waitId) {
570
+ unregisterWait(blockId);
571
+ }
572
+ })));
573
+ const waiting = waitId !== undefined
574
+ ? computed(() => result.value.waiting || (waitState.value[waitId] ?? 0) > 0)
575
+ : computed(() => result.value.waiting);
576
+ const blocked = blockId !== undefined
577
+ ? computed(() => waiting.value || (waitState.value[blockId] ?? 0) > 0)
578
+ : computed(() => waiting.value);
579
+ const computeAllowed = options?.allowed;
580
+ const allowed = computeAllowed ? computed(() => computeAllowed(id, state)) : true;
581
+ const rt = Effect.context().pipe(Effect.provide(this.hooks)).pipe(Effect.runSyncWith(this.rt));
582
+ const runFork = Effect.runForkWith(rt);
583
+ const handle = Object.assign((arg) => {
584
+ arg = toRaw(arg); // remove outside vue proxy bs
585
+ // we capture the call site stack here
586
+ const limit = Error.stackTraceLimit;
587
+ Error.stackTraceLimit = 2;
588
+ const errorCall = new Error();
589
+ Error.stackTraceLimit = limit;
590
+ let cache = false;
591
+ const captureStackTrace = () => {
592
+ // in case of an error, we want to append the definition stack to the call site stack,
593
+ // so we can see where the handler was defined too
594
+ if (cache !== false) {
595
+ return cache;
596
+ }
597
+ if (errorCall.stack) {
598
+ const stackDef = errorDef.stack.trim().split("\n");
599
+ const stackCall = errorCall.stack.trim().split("\n");
600
+ let endStackDef = stackDef.slice(2).join("\n").trim();
601
+ if (!endStackDef.includes(`(`)) {
602
+ endStackDef = endStackDef.replace(/at (.*)/, "at ($1)");
603
+ }
604
+ let endStackCall = stackCall.slice(2).join("\n").trim();
605
+ if (!endStackCall.includes(`(`)) {
606
+ endStackCall = endStackCall.replace(/at (.*)/, "at ($1)");
607
+ }
608
+ cache = `${endStackDef}\n${endStackCall}`;
609
+ return cache;
610
+ }
611
+ };
612
+ const command = currentState.pipe(Effect.flatMap((state) => {
613
+ const rawArg = deepToRaw(arg);
614
+ const rawState = deepToRaw(state);
615
+ return Effect.withSpan(exec(arg, { ...context.value, state }), id, {
616
+ captureStackTrace,
617
+ attributes: {
618
+ input: rawArg,
619
+ state: rawState,
620
+ action: initialContext.action,
621
+ label: initialContext.label,
622
+ id: initialContext.id,
623
+ i18nKey: initialContext.i18nKey
624
+ }
625
+ });
626
+ }));
627
+ return runFork(command);
628
+ }, { action, label });
629
+ return reactive({
630
+ /** static */
631
+ id,
632
+ /** the base i18n key, based on id by default. static */
633
+ i18nKey: initialContext.i18nKey,
634
+ /** the `action.` namespace based on i18nKey.. static */
635
+ namespace: initialContext.namespace,
636
+ /** easy generate namespaced 18n keys, based on namespace. static */
637
+ namespaced: initialContext.namespaced,
638
+ /** reactive */
639
+ result,
640
+ /** always undefined for non-stream commands */
641
+ progress: undefined,
642
+ /** reactive */
643
+ waiting,
644
+ /** reactive */
645
+ blocked,
646
+ /** reactive */
647
+ allowed,
648
+ /** reactive */
649
+ action,
650
+ /** reactive */
651
+ label,
652
+ /** reactive */
653
+ state,
654
+ handle
655
+ });
656
+ }, { id });
657
+ };
658
+ // /** @experimental */
659
+ // takeOver:
660
+ // <Args extends any[], A, E, R, const Id extends string>(command: Commander.CommandOut<Args, A, E, R, Id,I18nKey>) =>
661
+ // (...args: Args) => {
662
+ // // we capture the call site stack here
663
+ // const limit = Error.stackTraceLimit
664
+ // Error.stackTraceLimit = 2
665
+ // const errorCall = new Error()
666
+ // const localErrorDef = new Error()
667
+ // Error.stackTraceLimit = limit
668
+ // // TODO
669
+ // const errorDef = localErrorDef
670
+ // let cache: false | string = false
671
+ // const captureStackTrace = () => {
672
+ // // in case of an error, we want to append the definition stack to the call site stack,
673
+ // // so we can see where the handler was defined too
674
+ // if (cache !== false) {
675
+ // return cache
676
+ // }
677
+ // if (errorCall.stack) {
678
+ // const stackDef = errorDef.stack!.trim().split("\n")
679
+ // const stackCall = errorCall.stack.trim().split("\n")
680
+ // let endStackDef = stackDef.slice(2).join("\n").trim()
681
+ // if (!endStackDef.includes(`(`)) {
682
+ // endStackDef = endStackDef.replace(/at (.*)/, "at ($1)")
683
+ // }
684
+ // let endStackCall = stackCall.slice(2).join("\n").trim()
685
+ // if (!endStackCall.includes(`(`)) {
686
+ // endStackCall = endStackCall.replace(/at (.*)/, "at ($1)")
687
+ // }
688
+ // cache = `${endStackDef}\n${endStackCall}`
689
+ // return cache
690
+ // }
691
+ // }
692
+ // return Effect.gen(function*() {
693
+ // const ctx = yield* CommandContext
694
+ // ctx.action = command.action
695
+ // return yield* command.exec(...args).pipe(
696
+ // Effect.flatten,
697
+ // Effect.withSpan(
698
+ // command.action,
699
+ // { captureStackTrace }
700
+ // )
701
+ // )
702
+ // })
703
+ // },
704
+ /**
705
+ * Define a Command for handling user actions with built-in error reporting and state management.
706
+ *
707
+ * @param id The internal identifier for the action. Used as a tracing span and to lookup
708
+ * the user-facing name via internationalization (`action.${id}`).
709
+ * @param options Optional configuration for internationalization and state.
710
+ * @param options.i18nCustomKey Custom i18n key to use instead of `id` (e.g., for grouping similar actions)
711
+ * @param options.state Optional reactive state object (or function returning one) that is
712
+ * made available to the command effects and can be used for i18n interpolation.
713
+ * The state is captured at the start of each command execution and remains stable throughout.
714
+ * @returns A function that executes the command when called (e.g., directly in `@click` handlers).
715
+ * Built-in error reporting handles failures automatically.
716
+ *
717
+ * **Effect Context**: Effects have access to the `CommandContext` service, which provides
718
+ * the user-facing action name.
719
+ *
720
+ * **Returned Properties**:
721
+ * - `action`: User-facing action name from intl messages (useful for button labels)
722
+ * - `result`: The command result state
723
+ * - `waiting`: Boolean indicating if the command is in progress (shorthand for `result.waiting`)
724
+ * - `handle`: Function to execute the command
725
+ * - `exec`: The raw Effect that will be executed when calling `handle` (for advanced use cases)
726
+ * - `i18nKey`, `namespace`, `namespaced`: Helpers for internationalization keys
727
+ *
728
+ * **User Feedback**: Use the `withDefaultToast` helper for status notifications, or render
729
+ * the `result` inline for custom UI feedback.
730
+ */
731
+ fn = (id, options) => {
732
+ const resolvedId = typeof id === "string" ? id : id.id;
733
+ return Object.assign((fn, ...combinators) => {
734
+ // we capture the definition stack here, so we can append it to later stack traces
735
+ const limit = Error.stackTraceLimit;
736
+ Error.stackTraceLimit = 2;
737
+ const errorDef = new Error();
738
+ Error.stackTraceLimit = limit;
739
+ return this.makeCommand(resolvedId, options, errorDef)(Effect.fnUntraced(
740
+ // fnUntraced only supports generators as first arg, so we convert to generator if needed
741
+ isGeneratorFunction(fn) ? fn : function* (...args) {
742
+ return yield* fn(...args);
743
+ }, ...combinators));
744
+ }, makeBaseInfo(resolvedId, options), {
745
+ state: Context.Service(`Commander.Command.${resolvedId}.state`)
746
+ });
747
+ };
748
+ /**
749
+ * Internal factory for stream-backed commands. Accepts a handler that returns a `Stream` directly.
750
+ * Services (`CommandContext`, `stateTag`) are provided to the stream via `Stream.provideServiceEffect`.
751
+ */
752
+ makeStreamCommand = (id_, options, errorDef) => {
753
+ const id = typeof id_ === "string" ? id_ : id_.id;
754
+ const state = getStateValues(options);
755
+ return Object.assign((handler) => {
756
+ const limit = Error.stackTraceLimit;
757
+ Error.stackTraceLimit = 2;
758
+ const localErrorDef = new Error();
759
+ Error.stackTraceLimit = limit;
760
+ if (!errorDef) {
761
+ errorDef = localErrorDef;
762
+ }
763
+ const key = `Commander.Command.${id}.state`;
764
+ const stateTag = Context.Service(key);
765
+ const makeContext_ = () => this.makeContext(id, { ...options, state: state?.value });
766
+ const initialContext = makeContext_();
767
+ const context = computed(() => makeContext_());
768
+ const action = computed(() => context.value.action);
769
+ const label = computed(() => context.value.label);
770
+ const currentState = Effect.sync(() => state.value);
771
+ // Reactive ref driven by the CommandProgress service — updated imperatively
772
+ // from inside the stream via `Command.mapProgress(fn)` or `Command.updateProgress(p)`.
773
+ const progressRef = ref(undefined);
774
+ const commandProgressService = {
775
+ update: (p) => Effect.sync(() => {
776
+ progressRef.value = p;
777
+ })
778
+ };
779
+ const streamErrorReporter = (self) => self.pipe(Stream.tapCause(Effect.fnUntraced(function* (cause) {
780
+ if (Cause.hasInterruptsOnly(cause)) {
781
+ console.info(`Interrupted while trying to ${id}`);
782
+ return;
783
+ }
784
+ const fail = Cause.findErrorOption(cause);
785
+ if (Option.isSome(fail)) {
786
+ const message = `Failure trying to ${id}`;
787
+ yield* reportMessage(message, {
788
+ action: id,
789
+ error: fail.value
790
+ });
791
+ return;
792
+ }
793
+ const ctx = yield* CommandContext;
794
+ const extra = {
795
+ action: ctx.action,
796
+ message: `Unexpected Error trying to ${id}`
797
+ };
798
+ yield* reportRuntimeError(cause, extra);
799
+ }, Effect.uninterruptible)));
800
+ const theStreamHandler = (arg, ctx) => handler(arg, ctx).pipe(streamErrorReporter, Stream.provideService(CommandProgress, commandProgressService), Stream.provideServiceEffect(stateTag, currentState), Stream.provideServiceEffect(CommandContext, Effect.sync(() => makeContext_())));
801
+ const waitId = options?.waitKey ? options.waitKey(id) : undefined;
802
+ const blockId = options?.blockKey ? options.blockKey(id) : undefined;
803
+ const [result, exec_] = asStreamResult(theStreamHandler);
804
+ const exec = Effect
805
+ .fnUntraced(function* (...args) {
806
+ if (waitId !== undefined)
807
+ registerWait(waitId);
808
+ if (blockId !== undefined && blockId !== waitId) {
809
+ registerWait(blockId);
810
+ }
811
+ return yield* exec_(...args);
812
+ }, Effect.onExit(() => Effect.sync(() => {
813
+ if (waitId !== undefined)
814
+ unregisterWait(waitId);
815
+ if (blockId !== undefined && blockId !== waitId) {
816
+ unregisterWait(blockId);
817
+ }
818
+ })));
819
+ const waiting = waitId !== undefined
820
+ ? computed(() => result.value.waiting || (waitState.value[waitId] ?? 0) > 0)
821
+ : computed(() => result.value.waiting);
822
+ const blocked = blockId !== undefined
823
+ ? computed(() => waiting.value || (waitState.value[blockId] ?? 0) > 0)
824
+ : computed(() => waiting.value);
825
+ const computeAllowed = options?.allowed;
826
+ const allowed = computeAllowed ? computed(() => computeAllowed(id, state)) : true;
827
+ const rt = Effect.context().pipe(Effect.provide(this.hooks)).pipe(Effect.runSyncWith(this.rt));
828
+ const runFork = Effect.runForkWith(rt);
829
+ const progress = progressRef;
830
+ const handle = Object.assign((arg) => {
831
+ arg = toRaw(arg);
832
+ progressRef.value = undefined; // reset progress on new invocation
833
+ const limit = Error.stackTraceLimit;
834
+ Error.stackTraceLimit = 2;
835
+ const errorCall = new Error();
836
+ Error.stackTraceLimit = limit;
837
+ let cache = false;
838
+ const captureStackTrace = () => {
839
+ if (cache !== false) {
840
+ return cache;
841
+ }
842
+ if (errorCall.stack) {
843
+ const stackDef = errorDef.stack.trim().split("\n");
844
+ const stackCall = errorCall.stack.trim().split("\n");
845
+ let endStackDef = stackDef.slice(2).join("\n").trim();
846
+ if (!endStackDef.includes(`(`)) {
847
+ endStackDef = endStackDef.replace(/at (.*)/, "at ($1)");
848
+ }
849
+ let endStackCall = stackCall.slice(2).join("\n").trim();
850
+ if (!endStackCall.includes(`(`)) {
851
+ endStackCall = endStackCall.replace(/at (.*)/, "at ($1)");
852
+ }
853
+ cache = `${endStackDef}\n${endStackCall}`;
854
+ return cache;
855
+ }
856
+ };
857
+ const command = currentState.pipe(Effect.flatMap((state) => {
858
+ const rawArg = deepToRaw(arg);
859
+ const rawState = deepToRaw(state);
860
+ return Effect.withSpan(exec(arg, { ...context.value, state }), id, {
861
+ captureStackTrace,
862
+ attributes: {
863
+ input: rawArg,
864
+ state: rawState,
865
+ action: initialContext.action,
866
+ label: initialContext.label,
867
+ id: initialContext.id,
868
+ i18nKey: initialContext.i18nKey
869
+ }
870
+ });
871
+ }));
872
+ return runFork(command);
873
+ }, { action, label });
874
+ return reactive({
875
+ id,
876
+ i18nKey: initialContext.i18nKey,
877
+ namespace: initialContext.namespace,
878
+ namespaced: initialContext.namespaced,
879
+ result,
880
+ /** reactive – progress driven by `Command.mapProgress` or `Command.updateProgress` inside the stream */
881
+ progress,
882
+ waiting,
883
+ blocked,
884
+ allowed,
885
+ action,
886
+ label,
887
+ state,
888
+ handle
889
+ });
890
+ }, { id });
891
+ };
892
+ /**
893
+ * Define a stream-backed Command for handling user actions.
894
+ *
895
+ * Like `fn`, but the body generator (or function) must **return** a `Stream` rather than
896
+ * an `Effect`. The command's `waiting` state stays `true` while the stream is running and
897
+ * is set to `false` once it terminates. The reactive `result` ref is updated for every
898
+ * value emitted by the stream.
899
+ *
900
+ * Three handler shapes are accepted:
901
+ * 1. **Generator returning a Stream** (primary) — may yield Effects freely before returning the stream:
902
+ * ```ts
903
+ * Command.streamFn("exportData")(
904
+ * function*(arg, ctx) {
905
+ * const token = yield* getAuthToken
906
+ * return Stream.fromEffect(startExport(token, arg.id)).pipe(
907
+ * Stream.flatMap((job) => pollProgress(job.id))
908
+ * )
909
+ * }
910
+ * )
911
+ * ```
912
+ * 2. **Function returning a Stream directly**: `(arg, ctx) => Stream.make(1, 2, 3)`
913
+ * 3. **Function returning `Effect<Stream>`**: `(arg, ctx) => Effect.map(setup, (s) => s.stream)`
914
+ *
915
+ * @param id The internal identifier for the action (used for tracing and i18n lookup).
916
+ * @param options Same options as `fn` (`state`, `blockKey`, `waitKey`, `allowed`, `i18nCustomKey`).
917
+ *
918
+ * **Progress** — use `Command.mapProgress(fn)` as a stream pipe operator; the mapper receives
919
+ * `AsyncResult<A, E>` (each value wrapped as `AsyncResult.success(v, { waiting: true })`),
920
+ * matching the same shape as CommandButton’s `:progress-map` prop. Or call
921
+ * `Command.updateProgress(p)` for imperative control:
922
+ *
923
+ * ```ts
924
+ * // mapProgress as a combinator arg (outside the handler):
925
+ * Command.streamFn("exportData")(
926
+ * function*(arg, ctx) { return makeExportStream(arg.id) },
927
+ * (s) => s.pipe(Command.mapProgress((r) => AsyncResult.isSuccess(r) && r.value._tag === "OperationProgress" ? { text: `${r.value.completed}/${r.value.total}` } : undefined))
928
+ * )
929
+ *
930
+ * // Or inline inside the handler body:
931
+ * Command.streamFn("exportData")(function*(arg, ctx) {
932
+ * return makeExportStream(arg.id).pipe(Command.mapProgress((r) => AsyncResult.isSuccess(r) ? ... : undefined))
933
+ * })
934
+ * ```
935
+ *
936
+ * **Pipeable combinators** — the 2nd–Nth args follow the same pattern as `fn`: each combinator
937
+ * receives `(stream, arg, ctx)` and returns a transformed stream:
938
+ * ```ts
939
+ * Command.streamFn("exportData")(
940
+ * handler,
941
+ * (s, arg, ctx) => s.pipe(Command.mapProgress(fn), Stream.take(100))
942
+ * )
943
+ * ```
944
+ *
945
+ * **Returned Properties**: `action`, `label`, `result`, `progress`, `waiting`, `blocked`,
946
+ * `allowed`, `handle`, `i18nKey`, `namespace`, `namespaced`.
947
+ */
948
+ streamFn = (id, options) => {
949
+ const resolvedId = typeof id === "string" ? id : id.id;
950
+ const toRawHandler = (fn) => {
951
+ if (isGeneratorFunction(fn)) {
952
+ return Effect.fnUntraced(function* (arg, ctx) {
953
+ return yield* fn(arg, ctx);
954
+ });
955
+ }
956
+ return fn;
957
+ };
958
+ const toFinalStream = (value) => Stream.isStream(value) ? value : Stream.unwrap(value);
959
+ return Object.assign((fn, ...combinators) => {
960
+ const limit = Error.stackTraceLimit;
961
+ Error.stackTraceLimit = 2;
962
+ const errorDef = new Error();
963
+ Error.stackTraceLimit = limit;
964
+ const rawHandler = toRawHandler(fn);
965
+ const handler = (arg, ctx) => {
966
+ let current = rawHandler(arg, ctx);
967
+ for (const combinator of combinators) {
968
+ current = combinator(current, arg, ctx);
969
+ }
970
+ return toFinalStream(current);
971
+ };
972
+ return this.makeStreamCommand(id, options, errorDef)(handler);
973
+ }, makeBaseInfo(resolvedId, options), {
974
+ state: Context.Service(`Commander.Command.${resolvedId}.state`)
975
+ });
976
+ };
977
+ /** @deprecated */
978
+ alt2 = (_id, options) => {
979
+ const isObject = Predicate.isObjectKeyword(_id);
980
+ const id = isObject ? _id.id : _id;
981
+ const baseInfo = makeBaseInfo(id, options);
982
+ const idCmd = this.makeCommand(id, options);
983
+ // TODO: implement proper tracing stack
984
+ return Object.assign((cb) => idCmd(cb(Object.assign((fn, ...combinators) => Effect.fnUntraced(
985
+ // fnUntraced only supports generators as first arg, so we convert to generator if needed
986
+ isGeneratorFunction(fn) ? fn : function* (...args) {
987
+ return yield* fn(...args);
988
+ }, ...combinators), baseInfo, isObject
989
+ ? { mutate: "mutate" in _id ? _id.mutate : typeof _id === "function" ? _id : undefined }
990
+ : {}))), baseInfo);
991
+ };
992
+ alt = this.makeCommand;
993
+ /**
994
+ * Define a Command for handling user actions with built-in error reporting and state management.
995
+ *
996
+ * @param mutation The mutation function to take the identifier and initial handler from. Used as a tracing span and to lookup
997
+ * the user-facing name via internationalization (`action.${id}`).
998
+ * @param options Optional configuration for internationalization and state.
999
+ * @param options.i18nCustomKey Custom i18n key to use instead of `id` (e.g., for grouping similar actions)
1000
+ * @param options.state Optional reactive state object (or function returning one) that is
1001
+ * made available to the command effects and can be used for i18n interpolation.
1002
+ * The state is captured at the start of each command execution and remains stable throughout.
1003
+ * @returns A function that executes the command when called (e.g., directly in `@click` handlers).
1004
+ * Built-in error reporting handles failures automatically.
1005
+ *
1006
+ * **Effect Context**: Effects have access to the `CommandContext` service, which provides
1007
+ * the user-facing action name.
1008
+ *
1009
+ * **Returned Properties**:
1010
+ * - `action`: User-facing action name from intl messages (useful for button labels)
1011
+ * - `result`: The command result state
1012
+ * - `waiting`: Boolean indicating if the command is in progress (shorthand for `result.waiting`)
1013
+ * - `handle`: Function to execute the command
1014
+ * - `exec`: The raw Effect that will be executed when calling `handle` (for advanced use cases)
1015
+ * - `i18nKey`, `namespace`, `namespaced`: Helpers for internationalization keys
1016
+ *
1017
+ * **User Feedback**: Use the `withDefaultToast` helper for status notifications, or render
1018
+ * the `result` inline for custom UI feedback.
1019
+ */
1020
+ streamWrap = (handler, id, options) => {
1021
+ return Object.assign((...combinators) => {
1022
+ const limit = Error.stackTraceLimit;
1023
+ Error.stackTraceLimit = 2;
1024
+ const errorDef = new Error();
1025
+ Error.stackTraceLimit = limit;
1026
+ return this.makeStreamCommand(id, options, errorDef)(combinators.length === 0
1027
+ ? handler
1028
+ : (arg, ctx) => {
1029
+ let current = handler(arg, ctx);
1030
+ for (const combinator of combinators) {
1031
+ current = combinator(current, arg, ctx);
1032
+ }
1033
+ return current;
1034
+ });
1035
+ }, makeBaseInfo(id, options), {
1036
+ state: Context.Service(`Commander.Command.${id}.state`)
1037
+ });
1038
+ };
1039
+ wrap = (mutation, options) => {
1040
+ const callMutation = mutation;
1041
+ return Object.assign((...combinators) => {
1042
+ // we capture the definition stack here, so we can append it to later stack traces
1043
+ const limit = Error.stackTraceLimit;
1044
+ Error.stackTraceLimit = 2;
1045
+ const errorDef = new Error();
1046
+ Error.stackTraceLimit = limit;
1047
+ const mutate = "mutate" in callMutation
1048
+ ? callMutation.mutate
1049
+ : callMutation;
1050
+ return this.makeCommand(callMutation.id, options, errorDef)(Effect.fnUntraced(
1051
+ // fnUntraced only supports generators as first arg, so we convert to generator if needed
1052
+ isGeneratorFunction(mutate) ? mutate : function* (arg) {
1053
+ return yield* mutate(arg);
1054
+ }, ...combinators));
1055
+ }, makeBaseInfo(callMutation.id, options), {
1056
+ state: Context.Service(`Commander.Command.${callMutation.id}.state`)
1057
+ });
1058
+ };
1059
+ }
1060
+ // @effect-diagnostics-next-line missingEffectServiceDependency:off
1061
+ export class Commander extends Context.Service()("Commander", {
1062
+ make: Effect.gen(function* () {
1063
+ const i18n = yield* I18n;
1064
+ return (rt, rtHooks) => new CommanderImpl(rt, i18n, rtHooks);
1065
+ })
1066
+ }) {
1067
+ static DefaultWithoutDependencies = Layer.effect(this, this.make);
1068
+ static Default = this.DefaultWithoutDependencies;
1069
+ }
1070
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbWFuZGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL2NvbW1hbmRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSx1REFBdUQ7QUFDdkQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLCtCQUErQixDQUFBO0FBQzdELE9BQU8sRUFBRSxTQUFTLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQTtBQUVuRSxPQUFPLEVBQUUsUUFBUSxFQUFFLGNBQWMsRUFBRSxNQUFNLHdCQUF3QixDQUFBO0FBQ2pFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQTtBQUNuRCxPQUFPLEtBQUssT0FBTyxNQUFNLG9CQUFvQixDQUFBO0FBQzdDLE9BQU8sS0FBSyxNQUFNLE1BQU0sbUJBQW1CLENBQUE7QUFDM0MsT0FBTyxLQUFLLEtBQUssTUFBTSxrQkFBa0IsQ0FBQTtBQUN6QyxPQUFPLEtBQUssTUFBTSxNQUFNLG1CQUFtQixDQUFBO0FBQzNDLE9BQU8sS0FBSyxDQUFDLE1BQU0sbUJBQW1CLENBQUE7QUFDdEMsT0FBTyxFQUFFLG1CQUFtQixFQUFFLFVBQVUsRUFBRSxNQUFNLGtCQUFrQixDQUFBO0FBQ2xFLE9BQU8sS0FBSyxLQUFLLE1BQU0sY0FBYyxDQUFBO0FBR3JDLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQTtBQUN0QyxPQUFPLEtBQUssS0FBSyxNQUFNLGNBQWMsQ0FBQTtBQUNyQyxPQUFPLEtBQUssY0FBYyxNQUFNLHVCQUF1QixDQUFBO0FBQ3ZELE9BQU8sS0FBSyxTQUFTLE1BQU0sa0JBQWtCLENBQUE7QUFFN0MsT0FBTyxLQUFLLE1BQU0sTUFBTSxlQUFlLENBQUE7QUFDdkMsT0FBTyxLQUFLLFdBQVcsTUFBTSx3Q0FBd0MsQ0FBQTtBQUVyRSxPQUFPLEVBQUUsUUFBUSxFQUFvQixRQUFRLEVBQUUsR0FBRyxFQUFFLEtBQUssRUFBRSxNQUFNLEtBQUssQ0FBQTtBQUN0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