@effect-app/vue 2.70.0 → 2.70.1
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.
- package/CHANGELOG.md +6 -0
- package/dist/experimental/makeUseCommand.d.ts +7 -7
- package/dist/makeClient.d.ts +20 -20
- package/dist/mutate.d.ts +6 -3
- package/dist/mutate.d.ts.map +1 -1
- package/dist/mutate.js +5 -8
- package/package.json +2 -2
- package/src/mutate.ts +9 -10
- package/test/dist/stubs.d.ts +9 -9
package/CHANGELOG.md
CHANGED
|
@@ -16,18 +16,18 @@ export declare const makeUseCommand: <R = never>() => Effect.Effect<{
|
|
|
16
16
|
}) => (self: Effect.Effect<A, E_1, R_2>, ...args: Args_2) => Effect.Effect<A, E_1, import("./intl.js").I18n | import("./withToast.js").WithToast | import("./commander.js").CommandContext | R_2>;
|
|
17
17
|
alt: <const Id extends string>(id: Id) => Commander.CommandContextLocal<Id> & (<Args_3 extends Array<unknown>, A, E_2, R_3 extends import("./commander.js").CommandContext | R>(handler: (...args: Args_3) => Effect.Effect<A, E_2, R_3>) => Commander.CommandOut<Args_3, A, E_2, R_3, Id>);
|
|
18
18
|
fn: <const Id extends string>(id: Id) => Commander.Gen<R, Id> & Commander.NonGen<R, Id>;
|
|
19
|
-
wrap: <const Id extends string, Args_3 extends Array<unknown>, A_1, E_3, R_4>(mutation:
|
|
20
|
-
id: Id;
|
|
21
|
-
}) | {
|
|
19
|
+
wrap: <const Id extends string, Args_3 extends Array<unknown>, A_1, E_3, R_4>(mutation: {
|
|
22
20
|
mutate: (...args: Args_3) => Effect.Effect<A_1, E_3, R_4>;
|
|
23
21
|
id: Id;
|
|
24
|
-
}) =>
|
|
25
|
-
alt2: <const Id extends string, MutArgs extends Array<unknown>, MutA, MutE, MutR>(id: Id | (((...args: MutArgs) => Effect.Effect<MutA, MutE, MutR>) & {
|
|
22
|
+
} | (((...args: Args_3) => Effect.Effect<A_1, E_3, R_4>) & {
|
|
26
23
|
id: Id;
|
|
27
|
-
})
|
|
24
|
+
})) => Commander.CommandContextLocal<Id> & Commander.GenWrap<R, Id, Args_3, A_1, E_3, R_4> & Commander.NonGenWrap<R, Id, Args_3, A_1, E_3, R_4>;
|
|
25
|
+
alt2: <const Id extends string, MutArgs extends Array<unknown>, MutA, MutE, MutR>(id: Id | {
|
|
28
26
|
id: Id;
|
|
29
27
|
mutate: (...args: MutArgs) => Effect.Effect<MutA, MutE, MutR>;
|
|
30
|
-
}
|
|
28
|
+
} | (((...args: MutArgs) => Effect.Effect<MutA, MutE, MutR>) & {
|
|
29
|
+
id: Id;
|
|
30
|
+
})) => Commander.CommandContextLocal<Id> & (<Args_4 extends Array<unknown>, A_2, E_4, R_5 extends import("./commander.js").CommandContext | R>(handler: (ctx: Effect.fn.Gen & Effect.fn.NonGen & Commander.CommandContextLocal<Id> & {
|
|
31
31
|
mutate: (...args: MutArgs) => Effect.Effect<MutA, MutE, MutR>;
|
|
32
32
|
}) => (...args: Args_4) => Effect.Effect<A_2, E_4, R_5>) => Commander.CommandOut<Args_4, A_2, E_4, R_5, Id>);
|
|
33
33
|
_tag: "Commander";
|
package/dist/makeClient.d.ts
CHANGED
|
@@ -155,20 +155,20 @@ export declare const makeClient: <RT, RE, RL>(getBaseMrt: () => ManagedRuntime.M
|
|
|
155
155
|
onWaiting?: null | undefined | string | ((action: string, ...args: Args_2) => string | null | undefined);
|
|
156
156
|
onSuccess?: null | undefined | string | ((a: A, action: string, ...args: Args_2) => string | null | undefined);
|
|
157
157
|
}) => (self: Effect.Effect<A, E_1, R_1>, ...args: Args_2) => Effect.Effect<A, E_1, I18n | import("./experimental/withToast.js").WithToast | import("./experimental/commander.js").CommandContext | R_1>;
|
|
158
|
-
alt: <const Id extends string>(id: Id) => Commander.CommandContextLocal<Id> & (<Args_3 extends Array<unknown>, A, E_2, R_2 extends I18n | Toast |
|
|
158
|
+
alt: <const Id extends string>(id: Id) => Commander.CommandContextLocal<Id> & (<Args_3 extends Array<unknown>, A, E_2, R_2 extends I18n | Toast | import("./experimental/commander.js").CommandContext | RL>(handler: (...args: Args_3) => Effect.Effect<A, E_2, R_2>) => Commander.CommandOut<Args_3, A, E_2, R_2, Id>);
|
|
159
159
|
fn: <const Id extends string>(id: Id) => Commander.Gen<I18n | Toast | RL, Id> & Commander.NonGen<I18n | Toast | RL, Id>;
|
|
160
|
-
wrap: <const Id extends string, Args_3 extends Array<unknown>, A_1, E_3, R_3>(mutation:
|
|
161
|
-
id: Id;
|
|
162
|
-
}) | {
|
|
160
|
+
wrap: <const Id extends string, Args_3 extends Array<unknown>, A_1, E_3, R_3>(mutation: {
|
|
163
161
|
mutate: (...args: Args_3) => Effect.Effect<A_1, E_3, R_3>;
|
|
164
162
|
id: Id;
|
|
165
|
-
}) =>
|
|
166
|
-
alt2: <const Id extends string, MutArgs extends Array<unknown>, MutA, MutE, MutR>(id: Id | (((...args: MutArgs) => Effect.Effect<MutA, MutE, MutR>) & {
|
|
163
|
+
} | (((...args: Args_3) => Effect.Effect<A_1, E_3, R_3>) & {
|
|
167
164
|
id: Id;
|
|
168
|
-
}) |
|
|
165
|
+
})) => Commander.CommandContextLocal<Id> & Commander.GenWrap<I18n | Toast | RL, Id, Args_3, A_1, E_3, R_3> & Commander.NonGenWrap<I18n | Toast | RL, Id, Args_3, A_1, E_3, R_3>;
|
|
166
|
+
alt2: <const Id extends string, MutArgs extends Array<unknown>, MutA, MutE, MutR>(id: Id | {
|
|
169
167
|
id: Id;
|
|
170
168
|
mutate: (...args: MutArgs) => Effect.Effect<MutA, MutE, MutR>;
|
|
171
|
-
}
|
|
169
|
+
} | (((...args: MutArgs) => Effect.Effect<MutA, MutE, MutR>) & {
|
|
170
|
+
id: Id;
|
|
171
|
+
})) => Commander.CommandContextLocal<Id> & (<Args_4 extends Array<unknown>, A_2, E_4, R_4 extends I18n | Toast | import("./experimental/commander.js").CommandContext | RL>(handler: (ctx: Effect.fn.Gen & Effect.fn.NonGen & Commander.CommandContextLocal<Id> & {
|
|
172
172
|
mutate: (...args: MutArgs) => Effect.Effect<MutA, MutE, MutR>;
|
|
173
173
|
}) => (...args: Args_4) => Effect.Effect<A_2, E_4, R_4>) => Commander.CommandOut<Args_4, A_2, E_4, R_4, Id>);
|
|
174
174
|
_tag: "Commander";
|
|
@@ -187,20 +187,20 @@ export declare const makeClient: <RT, RE, RL>(getBaseMrt: () => ManagedRuntime.M
|
|
|
187
187
|
onWaiting?: null | undefined | string | ((action: string, ...args: Args_2) => string | null | undefined);
|
|
188
188
|
onSuccess?: null | undefined | string | ((a: A_3, action: string, ...args: Args_2) => string | null | undefined);
|
|
189
189
|
}) => (self: Effect.Effect<A_3, E_1, R_1>, ...args: Args_2) => Effect.Effect<A_3, E_1, I18n | import("./experimental/withToast.js").WithToast | import("./experimental/commander.js").CommandContext | R_1>;
|
|
190
|
-
alt: <const Id extends string>(id: Id) => Commander.CommandContextLocal<Id> & (<Args_4 extends Array<unknown>, A, E_2, R_2 extends I18n | Toast |
|
|
190
|
+
alt: <const Id extends string>(id: Id) => Commander.CommandContextLocal<Id> & (<Args_4 extends Array<unknown>, A, E_2, R_2 extends I18n | Toast | import("./experimental/commander.js").CommandContext | RL>(handler: (...args: Args_4) => Effect.Effect<A, E_2, R_2>) => Commander.CommandOut<Args_4, A, E_2, R_2, Id>);
|
|
191
191
|
fn: <const Id extends string>(id: Id) => Commander.Gen<I18n | Toast | RL, Id> & Commander.NonGen<I18n | Toast | RL, Id>;
|
|
192
|
-
wrap: <const Id extends string, Args_3 extends Array<unknown>, A_1, E_3, R_3>(mutation:
|
|
193
|
-
id: Id;
|
|
194
|
-
}) | {
|
|
192
|
+
wrap: <const Id extends string, Args_3 extends Array<unknown>, A_1, E_3, R_3>(mutation: {
|
|
195
193
|
mutate: (...args: Args_3) => Effect.Effect<A_1, E_3, R_3>;
|
|
196
194
|
id: Id;
|
|
197
|
-
}) =>
|
|
198
|
-
alt2: <const Id extends string, MutArgs extends Array<unknown>, MutA, MutE, MutR>(id: Id | (((...args: MutArgs) => Effect.Effect<MutA, MutE, MutR>) & {
|
|
195
|
+
} | (((...args: Args_3) => Effect.Effect<A_1, E_3, R_3>) & {
|
|
199
196
|
id: Id;
|
|
200
|
-
}) |
|
|
197
|
+
})) => Commander.CommandContextLocal<Id> & Commander.GenWrap<I18n | Toast | RL, Id, Args_3, A_1, E_3, R_3> & Commander.NonGenWrap<I18n | Toast | RL, Id, Args_3, A_1, E_3, R_3>;
|
|
198
|
+
alt2: <const Id extends string, MutArgs extends Array<unknown>, MutA, MutE, MutR>(id: Id | {
|
|
201
199
|
id: Id;
|
|
202
200
|
mutate: (...args: MutArgs) => Effect.Effect<MutA, MutE, MutR>;
|
|
203
|
-
}
|
|
201
|
+
} | (((...args: MutArgs) => Effect.Effect<MutA, MutE, MutR>) & {
|
|
202
|
+
id: Id;
|
|
203
|
+
})) => Commander.CommandContextLocal<Id> & (<Args_4 extends Array<unknown>, A_2, E_4, R_4 extends I18n | Toast | import("./experimental/commander.js").CommandContext | RL>(handler: (ctx: Effect.fn.Gen & Effect.fn.NonGen & Commander.CommandContextLocal<Id> & {
|
|
204
204
|
mutate: (...args: MutArgs) => Effect.Effect<MutA, MutE, MutR>;
|
|
205
205
|
}) => (...args: Args_4) => Effect.Effect<A_2, E_4, R_4>) => Commander.CommandOut<Args_4, A_2, E_4, R_4, Id>);
|
|
206
206
|
_tag: "Commander";
|
|
@@ -440,16 +440,16 @@ export declare const makeClient: <RT, RE, RL>(getBaseMrt: () => ManagedRuntime.M
|
|
|
440
440
|
};
|
|
441
441
|
makeUseAndHandleMutation: (defaultOptions?: Opts<any, any, any, any, any, any, any, any, any>) => {
|
|
442
442
|
<I, E_12 extends ResponseErrors, A_17, R_15, Request_14 extends TaggedRequestClassAny, Name_14 extends string, A2_10 = A_17, E2_10 extends ResponseErrors = E_12, R2_10 = R_15, ESuccess_8 = never, RSuccess_8 = never, EError_8 = never, RError_8 = never, EDefect_8 = never, RDefect_8 = never>(self: RequestHandlerWithInput<I, A_17, E_12, R_15, Request_14, Name_14>, action: string, options?: Opts<A_17, E_12, R_15, I, A2_10, E2_10, R2_10, ESuccess_8, RSuccess_8, EError_8, RError_8, EDefect_8, RDefect_8> | undefined): Resp<I, A2_10, E2_10, R2_10, ComputedRef<Res<A2_10, E2_10>>>;
|
|
443
|
-
<E_13 extends ResponseErrors, A_18, Request_15 extends TaggedRequestClassAny, Name_15 extends string, A2_11 = A_18, E2_11 extends ResponseErrors = E_13, R2_11 = LegacyMutation |
|
|
443
|
+
<E_13 extends ResponseErrors, A_18, Request_15 extends TaggedRequestClassAny, Name_15 extends string, A2_11 = A_18, E2_11 extends ResponseErrors = E_13, R2_11 = LegacyMutation | Base | RL, ESuccess_9 = never, RSuccess_9 = never, EError_9 = never, RError_9 = never, EDefect_9 = never, RDefect_9 = never>(self: RequestHandler<A_18, E_13, LegacyMutation | Base | RL, Request_15, Name_15>, action: string, options?: Opts<A_18, E_13, LegacyMutation | Base | RL, void, A2_11, E2_11, R2_11, ESuccess_9, RSuccess_9, EError_9, RError_9, EDefect_9, RDefect_9> | undefined): ActResp<A2_11, E2_11, R2_11, ComputedRef<Res<A2_11, E2_11>>>;
|
|
444
444
|
};
|
|
445
445
|
useHandleRequestWithToast: () => <A_19, E_13 extends ResponseErrors, R_16, I = void, A2_12 = A_19, E2_12 extends ResponseErrors = E_13, R2_12 = R_16, ESuccess_10 = never, RSuccess_10 = never, EError_10 = never, RError_10 = never, EDefect_10 = never, RDefect_10 = never>(f: Effect.Effect<Exit.Exit<A2_12, E2_12>, never, R2_12> | ((i: I) => Effect.Effect<Exit.Exit<A2_12, E2_12>, never, R2_12>), id: string, action: string, options?: Opts<A_19, E_13, R_16, I, A2_12, E2_12, R2_12, ESuccess_10, RSuccess_10, EError_10, RError_10, EDefect_10, RDefect_10>) => (Effect.Effect<Exit.Exit<A2_12, E2_12>, ESuccess_10 | EError_10 | EDefect_10, Exclude<R2_12, import("effect/Tracer").ParentSpan> | Exclude<RSuccess_10, import("effect/Tracer").ParentSpan> | Exclude<RError_10, import("effect/Tracer").ParentSpan> | Exclude<RDefect_10, import("effect/Tracer").ParentSpan>> | ((i: any) => Effect.Effect<Exit.Exit<A2_12, E2_12>, ESuccess_10 | EError_10 | EDefect_10, Exclude<R2_12, import("effect/Tracer").ParentSpan> | Exclude<RSuccess_10, import("effect/Tracer").ParentSpan> | Exclude<RError_10, import("effect/Tracer").ParentSpan> | Exclude<RDefect_10, import("effect/Tracer").ParentSpan>>)) & {
|
|
446
446
|
action: string;
|
|
447
447
|
};
|
|
448
|
-
buildFormFromSchema: <From extends Record<PropertyKey, any>, To extends Record<PropertyKey, any>, C extends Record<PropertyKey, any>, OnSubmitA>(s: S.Schema<To, From, LegacyMutation |
|
|
448
|
+
buildFormFromSchema: <From extends Record<PropertyKey, any>, To extends Record<PropertyKey, any>, C extends Record<PropertyKey, any>, OnSubmitA>(s: S.Schema<To, From, LegacyMutation | Base | RL> & {
|
|
449
449
|
new (c: C): any;
|
|
450
450
|
extend: any;
|
|
451
451
|
fields: S.Struct.Fields;
|
|
452
|
-
}, state: Ref<Omit<From, "_tag">, Omit<From, "_tag">>, onSubmit: (a: To) => Effect.Effect<OnSubmitA, never, LegacyMutation |
|
|
452
|
+
}, state: Ref<Omit<From, "_tag">, Omit<From, "_tag">>, onSubmit: (a: To) => Effect.Effect<OnSubmitA, never, LegacyMutation | Base | RL>) => {
|
|
453
453
|
fields: { [K in keyof To]-?: {
|
|
454
454
|
true: {
|
|
455
455
|
true: To[K] extends {
|
|
@@ -464,7 +464,7 @@ export declare const makeClient: <RT, RE, RL>(getBaseMrt: () => ManagedRuntime.M
|
|
|
464
464
|
valid: boolean;
|
|
465
465
|
}>>(e: T) => Promise<OnSubmitA | undefined>;
|
|
466
466
|
/** optimized for Native form submit callback or general use */
|
|
467
|
-
submitFromState: Effect.Effect<OnSubmitA, S.ParseResult.ParseError, LegacyMutation |
|
|
467
|
+
submitFromState: Effect.Effect<OnSubmitA, S.ParseResult.ParseError, LegacyMutation | Base | RL>;
|
|
468
468
|
submitFromStatePromise: () => Promise<OnSubmitA>;
|
|
469
469
|
isDirty: Ref<boolean, boolean>;
|
|
470
470
|
isValid: Ref<boolean, boolean>;
|
package/dist/mutate.d.ts
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import * as Result from "@effect-atom/atom/Result";
|
|
2
2
|
import { type InvalidateOptions, type InvalidateQueryFilters } from "@tanstack/vue-query";
|
|
3
3
|
import { type Cause, Effect, type Exit } from "effect-app";
|
|
4
|
-
import type { RequestHandler, RequestHandlerWithInput, TaggedRequestClassAny } from "effect-app/client/clientFor";
|
|
4
|
+
import type { ClientForOptions, RequestHandler, RequestHandlerWithInput, TaggedRequestClassAny } from "effect-app/client/clientFor";
|
|
5
5
|
import { type ComputedRef } from "vue";
|
|
6
6
|
export declare const getQueryKey: (h: {
|
|
7
7
|
id: string;
|
|
8
|
+
options?: ClientForOptions;
|
|
8
9
|
}) => string[];
|
|
9
|
-
export declare const getQueryKeyInt: (id: string) => string[];
|
|
10
10
|
export declare function mutationResultToVue<A, E>(mutationResult: Result.Result<A, E>): Res<A, E>;
|
|
11
11
|
export interface Res<A, E> {
|
|
12
12
|
readonly loading: boolean;
|
|
@@ -38,7 +38,10 @@ export declare const asResult: {
|
|
|
38
38
|
<A, E, R>(handler: Effect.Effect<A, E, R>): readonly [ComputedRef<Result.Result<A, E>>, Effect.Effect<Exit.Exit<A, E>, never, R>];
|
|
39
39
|
<Args extends readonly any[], A, E, R>(handler: (...args: Args) => Effect.Effect<A, E, R>): readonly [ComputedRef<Result.Result<A, E>>, (...args: Args) => Effect.Effect<Exit.Exit<A, E>, never, R>];
|
|
40
40
|
};
|
|
41
|
-
export declare const useInvalidateQueries: (
|
|
41
|
+
export declare const useInvalidateQueries: (self: {
|
|
42
|
+
id: string;
|
|
43
|
+
options?: ClientForOptions;
|
|
44
|
+
}, options?: MutationOptionsBase["queryInvalidation"]) => <A, E, R>(self: Effect.Effect<A, E, R>) => Effect.Effect<A, E, R>;
|
|
42
45
|
export declare const makeMutation: () => {
|
|
43
46
|
<I, E, A, R, Request extends TaggedRequestClassAny, Id extends string>(self: RequestHandlerWithInput<I, A, E, R, Request, Id>, options?: MutationOptionsBase): ((i: I) => Effect.Effect<A, E, R>) & {
|
|
44
47
|
readonly id: Id;
|
package/dist/mutate.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mutate.d.ts","sourceRoot":"","sources":["../src/mutate.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,MAAM,0BAA0B,CAAA;AAClD,OAAO,EAAE,KAAK,iBAAiB,EAAE,KAAK,sBAAsB,EAAkB,MAAM,qBAAqB,CAAA;AACzG,OAAO,EAAE,KAAK,KAAK,EAAE,MAAM,EAAE,KAAK,IAAI,EAAU,MAAM,YAAY,CAAA;AAClE,OAAO,KAAK,EAAE,cAAc,EAAE,uBAAuB,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAA;
|
|
1
|
+
{"version":3,"file":"mutate.d.ts","sourceRoot":"","sources":["../src/mutate.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,MAAM,0BAA0B,CAAA;AAClD,OAAO,EAAE,KAAK,iBAAiB,EAAE,KAAK,sBAAsB,EAAkB,MAAM,qBAAqB,CAAA;AACzG,OAAO,EAAE,KAAK,KAAK,EAAE,MAAM,EAAE,KAAK,IAAI,EAAU,MAAM,YAAY,CAAA;AAClE,OAAO,KAAK,EAAE,gBAAgB,EAAE,cAAc,EAAE,uBAAuB,EAAE,qBAAqB,EAAE,MAAM,6BAA6B,CAAA;AAEnI,OAAO,EAAY,KAAK,WAAW,EAAc,MAAM,KAAK,CAAA;AAG5D,eAAO,MAAM,WAAW,GAAI,GAAG;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,OAAO,CAAC,EAAE,gBAAgB,CAAA;CAAE,aAQxE,CAAA;AAED,wBAAgB,mBAAmB,CAAC,CAAC,EAAE,CAAC,EACtC,cAAc,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,GAClC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAoBX;AAED,MAAM,WAAW,GAAG,CAAC,CAAC,EAAE,CAAC;IACvB,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAA;IACzB,QAAQ,CAAC,IAAI,EAAE,CAAC,GAAG,SAAS,CAAA;IAC5B,QAAQ,CAAC,KAAK,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,SAAS,CAAA;CAC3C;AAED,wBAAgB,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,mLAiBzD;AAED,MAAM,WAAW,mBAAmB;IAClC;;;OAGG;IACH,iBAAiB,CAAC,EAAE,CAAC,UAAU,EAAE,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,KAAK;QAC1D,OAAO,CAAC,EAAE,sBAAsB,GAAG,SAAS,CAAA;QAC5C,OAAO,CAAC,EAAE,iBAAiB,GAAG,SAAS,CAAA;KACxC,EAAE,CAAA;CACJ;AAED,sGAAsG;AACtG,MAAM,WAAW,eAAe,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE,GAAG,CAAC,EAAE,EAAE,GAAG,CAAC,EAAE,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAE,SAAQ,mBAAmB;IACrG;;;;;OAKG;IACH,UAAU,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,KAAK,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAA;CACtF;AAaD,eAAO,MAAM,QAAQ,EAAE;IACrB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EACN,OAAO,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAC9B,SAAS,CAAC,WAAW,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,CAAA;IACxF,CAAC,IAAI,SAAS,SAAS,GAAG,EAAE,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EACnC,OAAO,EAAE,CAAC,GAAG,IAAI,EAAE,IAAI,KAAK,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GACjD,SAAS,CAAC,WAAW,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,IAAI,KAAK,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,CAAA;CAkC5G,CAAA;AAED,eAAO,MAAM,oBAAoB,GAC/B,MAAM;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,OAAO,CAAC,EAAE,gBAAgB,CAAA;CAAE,EAChD,UAAU,mBAAmB,CAAC,mBAAmB,CAAC,MAyClC,CAAC,EAAE,CAAC,EAAE,CAAC,QAAQ,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,2BAItD,CAAA;AAED,eAAO,MAAM,YAAY;KAMpB,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,OAAO,SAAS,qBAAqB,EAAE,EAAE,SAAS,MAAM,QAC7D,uBAAuB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,CAAC,YAC5C,mBAAmB,GAC5B,CAAC,CAAC,CAAC,EAAE,CAAC,KAAK,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG;QAAE,QAAQ,CAAC,EAAE,EAAE,EAAE,CAAA;KAAE;KAK1D,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,OAAO,SAAS,qBAAqB,EAAE,EAAE,SAAS,MAAM,QAC1D,cAAc,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,CAAC,YAChC,mBAAmB,GAC5B,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG;QAAE,QAAQ,CAAC,EAAE,EAAE,EAAE,CAAA;KAAE;CAYlD,CAAA"}
|
package/dist/mutate.js
CHANGED
|
@@ -15,9 +15,6 @@ export const getQueryKey = (h) => {
|
|
|
15
15
|
throw new Error("empty query key for: " + h.id);
|
|
16
16
|
return k;
|
|
17
17
|
};
|
|
18
|
-
export const getQueryKeyInt = (id) => {
|
|
19
|
-
return getQueryKey({ id });
|
|
20
|
-
};
|
|
21
18
|
export function mutationResultToVue(mutationResult) {
|
|
22
19
|
switch (mutationResult._tag) {
|
|
23
20
|
case "Initial": {
|
|
@@ -74,13 +71,13 @@ export const asResult = (handler) => {
|
|
|
74
71
|
.pipe(Effect.zipRight(Effect.suspend(() => handler(...args).pipe(Effect.exit, Effect.tap((exit) => Effect.sync(() => (state.value = Result.fromExit(exit))))))));
|
|
75
72
|
return tuple(computed(() => state.value), act);
|
|
76
73
|
};
|
|
77
|
-
export const useInvalidateQueries = (
|
|
74
|
+
export const useInvalidateQueries = (self, options) => {
|
|
78
75
|
const queryClient = useQueryClient();
|
|
79
76
|
const invalidateQueries = (filters, options) => Effect.currentSpan.pipe(Effect.orElseSucceed(() => null), Effect.flatMap((span) => Effect.promise(() => queryClient.invalidateQueries(filters, { ...options, updateMeta: { span } }))));
|
|
80
77
|
const invalidateCache = Effect.suspend(() => {
|
|
81
|
-
const queryKey =
|
|
78
|
+
const queryKey = getQueryKey(self);
|
|
82
79
|
if (options) {
|
|
83
|
-
const opts = options(queryKey, id);
|
|
80
|
+
const opts = options(queryKey, self.id);
|
|
84
81
|
if (!opts.length) {
|
|
85
82
|
return Effect.void;
|
|
86
83
|
}
|
|
@@ -99,11 +96,11 @@ export const useInvalidateQueries = (id, options) => {
|
|
|
99
96
|
};
|
|
100
97
|
export const makeMutation = () => {
|
|
101
98
|
const useMutation = (self, options) => {
|
|
102
|
-
const handle = useInvalidateQueries(self
|
|
99
|
+
const handle = useInvalidateQueries(self, options?.queryInvalidation);
|
|
103
100
|
const handler = self.handler;
|
|
104
101
|
const r = Effect.isEffect(handler) ? handle(handler) : (i) => handle(handler(i));
|
|
105
102
|
return Object.assign(r, { id: self.id });
|
|
106
103
|
};
|
|
107
104
|
return useMutation;
|
|
108
105
|
};
|
|
109
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
106
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibXV0YXRlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL211dGF0ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSx1REFBdUQ7QUFDdkQsT0FBTyxLQUFLLE1BQU0sTUFBTSwwQkFBMEIsQ0FBQTtBQUNsRCxPQUFPLEVBQXVELGNBQWMsRUFBRSxNQUFNLHFCQUFxQixDQUFBO0FBQ3pHLE9BQU8sRUFBYyxNQUFNLEVBQWEsTUFBTSxFQUFFLE1BQU0sWUFBWSxDQUFBO0FBRWxFLE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQTtBQUMzQyxPQUFPLEVBQUUsUUFBUSxFQUFvQixVQUFVLEVBQUUsTUFBTSxLQUFLLENBQUE7QUFDNUQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLFVBQVUsQ0FBQTtBQUV2QyxNQUFNLENBQUMsTUFBTSxXQUFXLEdBQUcsQ0FBQyxDQUE2QyxFQUFFLEVBQUU7SUFDM0UsTUFBTSxHQUFHLEdBQUcsWUFBWSxDQUFDLENBQUMsQ0FBQyxDQUFBO0lBQzNCLE1BQU0sRUFBRSxHQUFHLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQTtJQUMvQyw2RkFBNkY7SUFDN0Ysb0ZBQW9GO0lBQ3BGLE1BQU0sQ0FBQyxHQUFHLEVBQUUsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQTtJQUNqRixJQUFJLENBQUMsQ0FBQztRQUFFLE1BQU0sSUFBSSxLQUFLLENBQUMsdUJBQXVCLEdBQUcsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFBO0lBQ3ZELE9B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
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@effect-app/vue",
|
|
3
|
-
"version": "2.70.
|
|
3
|
+
"version": "2.70.1",
|
|
4
4
|
"license": "MIT",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"homepage": "https://github.com/effect-ts-app/libs/tree/main/packages/vue",
|
|
@@ -32,7 +32,7 @@
|
|
|
32
32
|
"typescript": "~5.9.2",
|
|
33
33
|
"vite": "^7.1.5",
|
|
34
34
|
"vitest": "^3.2.4",
|
|
35
|
-
"@effect-app/eslint-shared-config": "0.1.
|
|
35
|
+
"@effect-app/eslint-shared-config": "0.1.1"
|
|
36
36
|
},
|
|
37
37
|
"typesVersions": {
|
|
38
38
|
"*": {
|
package/src/mutate.ts
CHANGED
|
@@ -2,12 +2,12 @@
|
|
|
2
2
|
import * as Result from "@effect-atom/atom/Result"
|
|
3
3
|
import { type InvalidateOptions, type InvalidateQueryFilters, useQueryClient } from "@tanstack/vue-query"
|
|
4
4
|
import { type Cause, Effect, type Exit, Option } from "effect-app"
|
|
5
|
-
import type { RequestHandler, RequestHandlerWithInput, TaggedRequestClassAny } from "effect-app/client/clientFor"
|
|
5
|
+
import type { ClientForOptions, RequestHandler, RequestHandlerWithInput, TaggedRequestClassAny } from "effect-app/client/clientFor"
|
|
6
6
|
import { tuple } from "effect-app/Function"
|
|
7
7
|
import { computed, type ComputedRef, shallowRef } from "vue"
|
|
8
8
|
import { makeQueryKey } from "./lib.js"
|
|
9
9
|
|
|
10
|
-
export const getQueryKey = (h: { id: string }) => {
|
|
10
|
+
export const getQueryKey = (h: { id: string; options?: ClientForOptions }) => {
|
|
11
11
|
const key = makeQueryKey(h)
|
|
12
12
|
const ns = key.filter((_) => _.startsWith("$"))
|
|
13
13
|
// we invalidate the parent namespace e.g $project/$configuration.get, we invalidate $project
|
|
@@ -17,10 +17,6 @@ export const getQueryKey = (h: { id: string }) => {
|
|
|
17
17
|
return k
|
|
18
18
|
}
|
|
19
19
|
|
|
20
|
-
export const getQueryKeyInt = (id: string) => {
|
|
21
|
-
return getQueryKey({ id })
|
|
22
|
-
}
|
|
23
|
-
|
|
24
20
|
export function mutationResultToVue<A, E>(
|
|
25
21
|
mutationResult: Result.Result<A, E>
|
|
26
22
|
): Res<A, E> {
|
|
@@ -145,7 +141,10 @@ export const asResult: {
|
|
|
145
141
|
return tuple(computed(() => state.value), act) as any
|
|
146
142
|
}
|
|
147
143
|
|
|
148
|
-
export const useInvalidateQueries = (
|
|
144
|
+
export const useInvalidateQueries = (
|
|
145
|
+
self: { id: string; options?: ClientForOptions },
|
|
146
|
+
options?: MutationOptionsBase["queryInvalidation"]
|
|
147
|
+
) => {
|
|
149
148
|
const queryClient = useQueryClient()
|
|
150
149
|
|
|
151
150
|
const invalidateQueries = (
|
|
@@ -160,10 +159,10 @@ export const useInvalidateQueries = (id: string, options?: MutationOptionsBase["
|
|
|
160
159
|
)
|
|
161
160
|
|
|
162
161
|
const invalidateCache = Effect.suspend(() => {
|
|
163
|
-
const queryKey =
|
|
162
|
+
const queryKey = getQueryKey(self)
|
|
164
163
|
|
|
165
164
|
if (options) {
|
|
166
|
-
const opts = options(queryKey, id)
|
|
165
|
+
const opts = options(queryKey, self.id)
|
|
167
166
|
if (!opts.length) {
|
|
168
167
|
return Effect.void
|
|
169
168
|
}
|
|
@@ -213,7 +212,7 @@ export const makeMutation = () => {
|
|
|
213
212
|
self: RequestHandlerWithInput<I, A, E, R, Request, Id> | RequestHandler<A, E, R, Request, Id>,
|
|
214
213
|
options?: MutationOptionsBase
|
|
215
214
|
) => {
|
|
216
|
-
const handle = useInvalidateQueries(self
|
|
215
|
+
const handle = useInvalidateQueries(self, options?.queryInvalidation)
|
|
217
216
|
const handler = self.handler
|
|
218
217
|
const r = Effect.isEffect(handler) ? handle(handler) : (i: I) => handle(handler(i))
|
|
219
218
|
|
package/test/dist/stubs.d.ts
CHANGED
|
@@ -22,20 +22,20 @@ export declare const useExperimental: (options?: {
|
|
|
22
22
|
onWaiting?: null | undefined | string | ((action: string, ...args: Args_2) => string | null | undefined);
|
|
23
23
|
onSuccess?: null | undefined | string | ((a: A, action: string, ...args: Args_2) => string | null | undefined);
|
|
24
24
|
}) => (self: Effect.Effect<A, E_1, R_2>, ...args: Args_2) => Effect.Effect<A, E_1, import("../src/experimental/intl.js").I18n | import("../src/experimental/withToast.js").WithToast | import("../src/experimental/commander.js").CommandContext | R_2>;
|
|
25
|
-
alt: <const Id extends string>(id: Id) => Commander.CommandContextLocal<Id> & (<Args_3 extends Array<unknown>, A, E_2, R_3 extends
|
|
26
|
-
fn: <const Id extends string>(id: Id) => Commander.Gen<
|
|
27
|
-
wrap: <const Id extends string, Args_3 extends Array<unknown>, A_1, E_3, R_4>(mutation:
|
|
28
|
-
id: Id;
|
|
29
|
-
}) | {
|
|
25
|
+
alt: <const Id extends string>(id: Id) => Commander.CommandContextLocal<Id> & (<Args_3 extends Array<unknown>, A, E_2, R_3 extends I18n | WithToast | Toast.Toast | import("../src/experimental/commander.js").CommandContext>(handler: (...args: Args_3) => Effect.Effect<A, E_2, R_3>) => Commander.CommandOut<Args_3, A, E_2, R_3, Id>);
|
|
26
|
+
fn: <const Id extends string>(id: Id) => Commander.Gen<I18n | WithToast | Toast.Toast, Id> & Commander.NonGen<I18n | WithToast | Toast.Toast, Id>;
|
|
27
|
+
wrap: <const Id extends string, Args_3 extends Array<unknown>, A_1, E_3, R_4>(mutation: {
|
|
30
28
|
mutate: (...args: Args_3) => Effect.Effect<A_1, E_3, R_4>;
|
|
31
29
|
id: Id;
|
|
32
|
-
}) =>
|
|
33
|
-
alt2: <const Id extends string, MutArgs extends Array<unknown>, MutA, MutE, MutR>(id: Id | (((...args: MutArgs) => Effect.Effect<MutA, MutE, MutR>) & {
|
|
30
|
+
} | (((...args: Args_3) => Effect.Effect<A_1, E_3, R_4>) & {
|
|
34
31
|
id: Id;
|
|
35
|
-
}) |
|
|
32
|
+
})) => Commander.CommandContextLocal<Id> & Commander.GenWrap<I18n | WithToast | Toast.Toast, Id, Args_3, A_1, E_3, R_4> & Commander.NonGenWrap<I18n | WithToast | Toast.Toast, Id, Args_3, A_1, E_3, R_4>;
|
|
33
|
+
alt2: <const Id extends string, MutArgs extends Array<unknown>, MutA, MutE, MutR>(id: Id | {
|
|
36
34
|
id: Id;
|
|
37
35
|
mutate: (...args: MutArgs) => Effect.Effect<MutA, MutE, MutR>;
|
|
38
|
-
}
|
|
36
|
+
} | (((...args: MutArgs) => Effect.Effect<MutA, MutE, MutR>) & {
|
|
37
|
+
id: Id;
|
|
38
|
+
})) => Commander.CommandContextLocal<Id> & (<Args_4 extends Array<unknown>, A_2, E_4, R_5 extends I18n | WithToast | Toast.Toast | import("../src/experimental/commander.js").CommandContext>(handler: (ctx: Effect.fn.Gen & Effect.fn.NonGen & Commander.CommandContextLocal<Id> & {
|
|
39
39
|
mutate: (...args: MutArgs) => Effect.Effect<MutA, MutE, MutR>;
|
|
40
40
|
}) => (...args: Args_4) => Effect.Effect<A_2, E_4, R_5>) => Commander.CommandOut<Args_4, A_2, E_4, R_5, Id>);
|
|
41
41
|
_tag: "Commander";
|