@effect-app/vue 4.0.0-beta.19 → 4.0.0-beta.191
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 +1398 -0
- package/dist/commander.d.ts +620 -0
- package/dist/commander.d.ts.map +1 -0
- package/dist/commander.js +1056 -0
- package/dist/confirm.d.ts +19 -0
- package/dist/confirm.d.ts.map +1 -0
- package/dist/confirm.js +24 -0
- package/dist/errorReporter.d.ts +4 -4
- package/dist/errorReporter.d.ts.map +1 -1
- package/dist/errorReporter.js +12 -18
- package/dist/form.d.ts +14 -5
- package/dist/form.d.ts.map +1 -1
- package/dist/form.js +41 -12
- package/dist/index.d.ts +1 -1
- package/dist/intl.d.ts +15 -0
- package/dist/intl.d.ts.map +1 -0
- package/dist/intl.js +9 -0
- package/dist/lib.d.ts +6 -8
- package/dist/lib.d.ts.map +1 -1
- package/dist/lib.js +34 -7
- package/dist/makeClient.d.ts +191 -292
- package/dist/makeClient.d.ts.map +1 -1
- package/dist/makeClient.js +217 -369
- package/dist/makeContext.d.ts +1 -1
- package/dist/makeContext.d.ts.map +1 -1
- package/dist/makeIntl.d.ts +1 -1
- package/dist/makeIntl.d.ts.map +1 -1
- package/dist/makeUseCommand.d.ts +8 -0
- package/dist/makeUseCommand.d.ts.map +1 -0
- package/dist/makeUseCommand.js +13 -0
- package/dist/mutate.d.ts +56 -25
- package/dist/mutate.d.ts.map +1 -1
- package/dist/mutate.js +132 -33
- package/dist/query.d.ts +24 -16
- package/dist/query.d.ts.map +1 -1
- package/dist/query.js +119 -37
- package/dist/routeParams.d.ts +1 -1
- package/dist/runtime.d.ts +7 -4
- package/dist/runtime.d.ts.map +1 -1
- package/dist/runtime.js +27 -17
- package/dist/toast.d.ts +46 -0
- package/dist/toast.d.ts.map +1 -0
- package/dist/toast.js +32 -0
- package/dist/withToast.d.ts +26 -0
- package/dist/withToast.d.ts.map +1 -0
- package/dist/withToast.js +54 -0
- package/examples/streamMutation.ts +70 -0
- package/package.json +47 -49
- package/src/commander.ts +3378 -0
- package/src/{experimental/confirm.ts → confirm.ts} +10 -14
- package/src/errorReporter.ts +62 -74
- package/src/form.ts +56 -17
- package/src/intl.ts +12 -0
- package/src/lib.ts +46 -13
- package/src/makeClient.ts +623 -1043
- package/src/{experimental/makeUseCommand.ts → makeUseCommand.ts} +6 -4
- package/src/mutate.ts +273 -72
- package/src/query.ts +181 -68
- package/src/runtime.ts +41 -20
- package/src/{experimental/toast.ts → toast.ts} +11 -25
- package/src/{experimental/withToast.ts → withToast.ts} +28 -10
- package/test/Mutation.test.ts +176 -23
- package/test/dist/form.test.d.ts.map +1 -1
- package/test/dist/lib.test.d.ts.map +1 -0
- package/test/dist/streamFinal.test.d.ts.map +1 -0
- package/test/dist/streamFn.test.d.ts.map +1 -0
- package/test/dist/stubs.d.ts +3294 -115
- package/test/dist/stubs.d.ts.map +1 -1
- package/test/dist/stubs.js +177 -31
- package/test/form-validation-errors.test.ts +23 -19
- package/test/form.test.ts +20 -2
- package/test/lib.test.ts +240 -0
- package/test/makeClient.test.ts +286 -38
- package/test/streamFinal.test.ts +63 -0
- package/test/streamFn.test.ts +455 -0
- package/test/stubs.ts +213 -42
- package/tsconfig.examples.json +20 -0
- package/tsconfig.json +0 -1
- package/tsconfig.json.bak +5 -2
- package/tsconfig.src.json +34 -34
- package/tsconfig.test.json +2 -2
- package/vitest.config.ts +5 -5
- package/dist/experimental/commander.d.ts +0 -359
- package/dist/experimental/commander.d.ts.map +0 -1
- package/dist/experimental/commander.js +0 -557
- package/dist/experimental/confirm.d.ts +0 -19
- package/dist/experimental/confirm.d.ts.map +0 -1
- package/dist/experimental/confirm.js +0 -28
- package/dist/experimental/intl.d.ts +0 -16
- package/dist/experimental/intl.d.ts.map +0 -1
- package/dist/experimental/intl.js +0 -5
- package/dist/experimental/makeUseCommand.d.ts +0 -8
- package/dist/experimental/makeUseCommand.d.ts.map +0 -1
- package/dist/experimental/makeUseCommand.js +0 -13
- package/dist/experimental/toast.d.ts +0 -47
- package/dist/experimental/toast.d.ts.map +0 -1
- package/dist/experimental/toast.js +0 -41
- package/dist/experimental/withToast.d.ts +0 -25
- package/dist/experimental/withToast.d.ts.map +0 -1
- package/dist/experimental/withToast.js +0 -45
- package/eslint.config.mjs +0 -24
- package/src/experimental/commander.ts +0 -1835
- package/src/experimental/intl.ts +0 -9
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Example: stream-based mutation for a long-running operation.
|
|
3
|
+
*
|
|
4
|
+
* The server streams a tagged union of progress updates and a final result.
|
|
5
|
+
* The Vue ref is updated for every emitted value; `AsyncResult` stays in the
|
|
6
|
+
* `waiting` state until the stream ends.
|
|
7
|
+
*
|
|
8
|
+
* When using `makeClient` / `clientFor`, stream-type requests are exposed as
|
|
9
|
+
* `mutate` on the client object. Use `client.exportData.mutate` with `streamFn`
|
|
10
|
+
* combinators, or use `client.exportData.streamFn` to define a full command.
|
|
11
|
+
*
|
|
12
|
+
* The example below shows the low-level `asStreamResult` API.
|
|
13
|
+
*/
|
|
14
|
+
import { Effect, S, Stream } from "effect-app"
|
|
15
|
+
import { asStreamResult } from "../src/mutate.js"
|
|
16
|
+
|
|
17
|
+
// ---------------------------------------------------------------------------
|
|
18
|
+
// Domain model
|
|
19
|
+
// ---------------------------------------------------------------------------
|
|
20
|
+
|
|
21
|
+
/** Intermediate progress report, e.g. "5 of 400 items processed". */
|
|
22
|
+
export class OperationProgress extends S.TaggedClass<OperationProgress>()("OperationProgress", {
|
|
23
|
+
completed: S.NonNegativeInt,
|
|
24
|
+
total: S.NonNegativeInt
|
|
25
|
+
}) {}
|
|
26
|
+
|
|
27
|
+
/** The final result produced once the operation is complete. */
|
|
28
|
+
export class ExportComplete extends S.TaggedClass<ExportComplete>()("ExportComplete", {
|
|
29
|
+
fileUrl: S.NonEmptyString
|
|
30
|
+
}) {}
|
|
31
|
+
|
|
32
|
+
/** Tagged union emitted by the stream. */
|
|
33
|
+
export type ExportEvent = OperationProgress | ExportComplete
|
|
34
|
+
|
|
35
|
+
// ---------------------------------------------------------------------------
|
|
36
|
+
// Simulated stream (replace with a real RPC / SSE stream in production)
|
|
37
|
+
// ---------------------------------------------------------------------------
|
|
38
|
+
|
|
39
|
+
/**
|
|
40
|
+
* Produces `total` progress updates followed by a single `ExportComplete`.
|
|
41
|
+
* Each step is separated by a 50 ms delay to simulate real async work.
|
|
42
|
+
*/
|
|
43
|
+
const makeExportStream = (total: S.NonNegativeInt): Stream.Stream<ExportEvent> =>
|
|
44
|
+
Stream.concat(
|
|
45
|
+
Stream.range(1, total).pipe(
|
|
46
|
+
Stream.map((completed) => new OperationProgress({ completed: S.NonNegativeInt(completed), total })),
|
|
47
|
+
Stream.tap(() => Effect.sleep("50 millis"))
|
|
48
|
+
),
|
|
49
|
+
Stream.make(new ExportComplete({ fileUrl: S.NonEmptyString("https://example.com/export.csv") }))
|
|
50
|
+
)
|
|
51
|
+
|
|
52
|
+
// ---------------------------------------------------------------------------
|
|
53
|
+
// Option A: low-level `asStreamResult` (call inside a `setup()` function)
|
|
54
|
+
// ---------------------------------------------------------------------------
|
|
55
|
+
|
|
56
|
+
export const useExportMutation = () => {
|
|
57
|
+
/**
|
|
58
|
+
* `result` - reactive ref, always reflects the latest stream event.
|
|
59
|
+
* `AsyncResult` tag:
|
|
60
|
+
* - Initial (waiting=true) - operation in progress
|
|
61
|
+
* - Success (waiting=true) - progress update received, still running
|
|
62
|
+
* - Success (waiting=false) - final result, operation complete
|
|
63
|
+
* - Failure - operation failed
|
|
64
|
+
*
|
|
65
|
+
* `execute` - call with the desired `total` to kick off the stream.
|
|
66
|
+
*/
|
|
67
|
+
const [result, execute] = asStreamResult((total: S.NonNegativeInt) => makeExportStream(total))
|
|
68
|
+
|
|
69
|
+
return { result, execute }
|
|
70
|
+
}
|
package/package.json
CHANGED
|
@@ -1,36 +1,35 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@effect-app/vue",
|
|
3
|
-
"version": "4.0.0-beta.
|
|
3
|
+
"version": "4.0.0-beta.191",
|
|
4
4
|
"license": "MIT",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"homepage": "https://github.com/effect-ts-app/libs/tree/main/packages/vue",
|
|
7
7
|
"dependencies": {
|
|
8
|
-
"@formatjs/intl": "^4.1.
|
|
9
|
-
"@tanstack/query-core": "5.
|
|
10
|
-
"@tanstack/vue-query": "5.
|
|
8
|
+
"@formatjs/intl": "^4.1.7",
|
|
9
|
+
"@tanstack/query-core": "5.96.2",
|
|
10
|
+
"@tanstack/vue-query": "5.96.2",
|
|
11
11
|
"@vueuse/core": "^14.2.1",
|
|
12
12
|
"change-case": "^5.4.4",
|
|
13
13
|
"query-string": "^9.3.1",
|
|
14
|
-
"effect-app": "4.0.0-beta.
|
|
14
|
+
"effect-app": "4.0.0-beta.191"
|
|
15
15
|
},
|
|
16
16
|
"peerDependencies": {
|
|
17
|
-
"@effect/atom-vue": "^4.0.0-beta.
|
|
18
|
-
"@effect/platform-browser": "^4.0.0-beta.
|
|
19
|
-
"@sentry/browser": "^10.
|
|
20
|
-
"effect": "^4.0.0-beta.
|
|
21
|
-
"vue": "^3.5.
|
|
17
|
+
"@effect/atom-vue": "^4.0.0-beta.59",
|
|
18
|
+
"@effect/platform-browser": "^4.0.0-beta.59",
|
|
19
|
+
"@sentry/browser": "^10.50.0",
|
|
20
|
+
"effect": "^4.0.0-beta.60",
|
|
21
|
+
"vue": "^3.5.33"
|
|
22
22
|
},
|
|
23
23
|
"devDependencies": {
|
|
24
|
-
"@effect/vitest": "^4.0.0-beta.
|
|
25
|
-
"@formatjs/icu-messageformat-parser": "^3.5.
|
|
26
|
-
"@types/node": "25.
|
|
27
|
-
"@vitejs/plugin-vue": "^6.0.
|
|
28
|
-
"intl-messageformat": "^11.
|
|
24
|
+
"@effect/vitest": "^4.0.0-beta.59",
|
|
25
|
+
"@formatjs/icu-messageformat-parser": "^3.5.5",
|
|
26
|
+
"@types/node": "25.6.0",
|
|
27
|
+
"@vitejs/plugin-vue": "^6.0.6",
|
|
28
|
+
"intl-messageformat": "^11.2.2",
|
|
29
29
|
"json5": "^2.2.3",
|
|
30
|
-
"typescript": "~
|
|
31
|
-
"vite": "^
|
|
32
|
-
"vitest": "^4.
|
|
33
|
-
"@effect-app/eslint-shared-config": "0.5.7-beta.2"
|
|
30
|
+
"typescript": "~6.0.3",
|
|
31
|
+
"vite": "^8.0.10",
|
|
32
|
+
"vitest": "^4.1.5"
|
|
34
33
|
},
|
|
35
34
|
"typesVersions": {
|
|
36
35
|
"*": {
|
|
@@ -44,38 +43,26 @@
|
|
|
44
43
|
"types": "./dist/index.d.ts",
|
|
45
44
|
"default": "./dist/index.js"
|
|
46
45
|
},
|
|
46
|
+
"./commander": {
|
|
47
|
+
"types": "./dist/commander.d.ts",
|
|
48
|
+
"default": "./dist/commander.js"
|
|
49
|
+
},
|
|
50
|
+
"./confirm": {
|
|
51
|
+
"types": "./dist/confirm.d.ts",
|
|
52
|
+
"default": "./dist/confirm.js"
|
|
53
|
+
},
|
|
47
54
|
"./errorReporter": {
|
|
48
55
|
"types": "./dist/errorReporter.d.ts",
|
|
49
56
|
"default": "./dist/errorReporter.js"
|
|
50
57
|
},
|
|
51
|
-
"./experimental/commander": {
|
|
52
|
-
"types": "./dist/experimental/commander.d.ts",
|
|
53
|
-
"default": "./dist/experimental/commander.js"
|
|
54
|
-
},
|
|
55
|
-
"./experimental/confirm": {
|
|
56
|
-
"types": "./dist/experimental/confirm.d.ts",
|
|
57
|
-
"default": "./dist/experimental/confirm.js"
|
|
58
|
-
},
|
|
59
|
-
"./experimental/intl": {
|
|
60
|
-
"types": "./dist/experimental/intl.d.ts",
|
|
61
|
-
"default": "./dist/experimental/intl.js"
|
|
62
|
-
},
|
|
63
|
-
"./experimental/makeUseCommand": {
|
|
64
|
-
"types": "./dist/experimental/makeUseCommand.d.ts",
|
|
65
|
-
"default": "./dist/experimental/makeUseCommand.js"
|
|
66
|
-
},
|
|
67
|
-
"./experimental/toast": {
|
|
68
|
-
"types": "./dist/experimental/toast.d.ts",
|
|
69
|
-
"default": "./dist/experimental/toast.js"
|
|
70
|
-
},
|
|
71
|
-
"./experimental/withToast": {
|
|
72
|
-
"types": "./dist/experimental/withToast.d.ts",
|
|
73
|
-
"default": "./dist/experimental/withToast.js"
|
|
74
|
-
},
|
|
75
58
|
"./form": {
|
|
76
59
|
"types": "./dist/form.d.ts",
|
|
77
60
|
"default": "./dist/form.js"
|
|
78
61
|
},
|
|
62
|
+
"./intl": {
|
|
63
|
+
"types": "./dist/intl.d.ts",
|
|
64
|
+
"default": "./dist/intl.js"
|
|
65
|
+
},
|
|
79
66
|
"./lib": {
|
|
80
67
|
"types": "./dist/lib.d.ts",
|
|
81
68
|
"default": "./dist/lib.js"
|
|
@@ -92,6 +79,10 @@
|
|
|
92
79
|
"types": "./dist/makeIntl.d.ts",
|
|
93
80
|
"default": "./dist/makeIntl.js"
|
|
94
81
|
},
|
|
82
|
+
"./makeUseCommand": {
|
|
83
|
+
"types": "./dist/makeUseCommand.d.ts",
|
|
84
|
+
"default": "./dist/makeUseCommand.js"
|
|
85
|
+
},
|
|
95
86
|
"./mutate": {
|
|
96
87
|
"types": "./dist/mutate.d.ts",
|
|
97
88
|
"default": "./dist/mutate.js"
|
|
@@ -107,6 +98,14 @@
|
|
|
107
98
|
"./runtime": {
|
|
108
99
|
"types": "./dist/runtime.d.ts",
|
|
109
100
|
"default": "./dist/runtime.js"
|
|
101
|
+
},
|
|
102
|
+
"./toast": {
|
|
103
|
+
"types": "./dist/toast.d.ts",
|
|
104
|
+
"default": "./dist/toast.js"
|
|
105
|
+
},
|
|
106
|
+
"./withToast": {
|
|
107
|
+
"types": "./dist/withToast.d.ts",
|
|
108
|
+
"default": "./dist/withToast.js"
|
|
110
109
|
}
|
|
111
110
|
},
|
|
112
111
|
"gitHead": "bd8e27eea3eff97db8739d577d67e7336c078d28",
|
|
@@ -121,18 +120,17 @@
|
|
|
121
120
|
"scripts": {
|
|
122
121
|
"watch": "pnpm build:tsc -w",
|
|
123
122
|
"build:tsc": "pnpm clean-dist && effect-app-cli packagejson pnpm check",
|
|
124
|
-
"check": "
|
|
123
|
+
"check": "tsgo --build",
|
|
125
124
|
"build": "pnpm build:tsc",
|
|
126
|
-
"watch2": "pnpm clean-dist && NODE_OPTIONS=--max-old-space-size=6144
|
|
125
|
+
"watch2": "pnpm clean-dist && NODE_OPTIONS=--max-old-space-size=6144 tsgo -w",
|
|
127
126
|
"clean": "rm -rf dist",
|
|
128
127
|
"clean-dist": "sh ../../scripts/clean-dist.sh",
|
|
129
128
|
"circular": "pnpm circular:src && pnpm circular:dist",
|
|
130
129
|
"circular:src": "madge --circular --ts-config ./tsconfig.json --extensions ts ./src",
|
|
131
130
|
"circular:dist": "madge --circular --extensions js ./dist",
|
|
132
|
-
"compile": "NODE_OPTIONS=--max-old-space-size=6144
|
|
133
|
-
"lint": "
|
|
134
|
-
"lint
|
|
135
|
-
"lint-fix": "pnpm lint --fix",
|
|
131
|
+
"compile": "NODE_OPTIONS=--max-old-space-size=6144 tsgo --noEmit",
|
|
132
|
+
"lint": "oxlint --quiet --type-aware ./src && pnpm exec dprint check --config ../../dprint.jsonc .",
|
|
133
|
+
"lint-fix": "oxlint --quiet --type-aware --fix ./src && pnpm exec dprint fmt --config ../../dprint.jsonc .",
|
|
136
134
|
"test": "vitest",
|
|
137
135
|
"test:run": "pnpm run test run --passWithNoTests",
|
|
138
136
|
"testsuite": "pnpm lint && pnpm circular && pnpm run test:run",
|