@isograph/react 0.0.0-main-0503387b → 0.0.0-main-e8f38c44
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/dist/core/PromiseWrapper.d.ts +1 -1
- package/dist/core/PromiseWrapper.d.ts.map +1 -1
- package/dist/core/makeNetworkRequest.d.ts.map +1 -1
- package/dist/core/makeNetworkRequest.js +0 -1
- package/dist/core/read.d.ts.map +1 -1
- package/dist/core/read.js +11 -2
- package/package.json +4 -4
- package/src/core/PromiseWrapper.ts +1 -1
- package/src/core/makeNetworkRequest.ts +0 -1
- package/src/core/read.ts +17 -2
- package/tsconfig.pkg.json +1 -2
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PromiseWrapper.d.ts","sourceRoot":"","sources":["../../src/core/PromiseWrapper.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,QAAQ,GAAG,GAAG,CAAC;AAE3B,QAAA,MAAM,OAAO,EAAE,MAA0B,CAAC;AAC1C,KAAK,MAAM,GAAG,OAAO,OAAO,CAAC;AAE7B,
|
|
1
|
+
{"version":3,"file":"PromiseWrapper.d.ts","sourceRoot":"","sources":["../../src/core/PromiseWrapper.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,QAAQ,GAAG,GAAG,CAAC;AAE3B,QAAA,MAAM,OAAO,EAAE,MAA0B,CAAC;AAC1C,KAAK,MAAM,GAAG,OAAO,OAAO,CAAC;AAE7B,MAAM,MAAM,MAAM,CAAC,CAAC,EAAE,CAAC,IACnB;IACE,IAAI,EAAE,IAAI,CAAC;IACX,KAAK,EAAE,CAAC,CAAC;CACV,GACD;IACE,IAAI,EAAE,KAAK,CAAC;IACZ,KAAK,EAAE,CAAC,CAAC;CACV,CAAC;AAEN;;;GAGG;AACH,MAAM,MAAM,cAAc,CAAC,CAAC,EAAE,CAAC,GAAG,GAAG,IAAI;IACvC,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IAC7B,MAAM,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC,GAAG,MAAM,CAAC;CAChD,CAAC;AAEF,wBAAgB,WAAW,CAAC,CAAC,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,GAAG,cAAc,CAAC,CAAC,EAAE,GAAG,CAAC,CAa1E;AAED,wBAAgB,iBAAiB,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,GAAG,cAAc,CAAC,CAAC,EAAE,KAAK,CAAC,CASvE;AAED,wBAAgB,WAAW,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,cAAc,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAa5D;AAED,MAAM,MAAM,YAAY,CAAC,CAAC,EAAE,CAAC,IACzB;IACE,IAAI,EAAE,SAAS,CAAC;IAChB,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;CACrB,GACD,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;AAEjB,wBAAgB,eAAe,CAAC,CAAC,EAAE,CAAC,EAClC,CAAC,EAAE,cAAc,CAAC,CAAC,EAAE,CAAC,CAAC,GACtB,YAAY,CAAC,CAAC,EAAE,CAAC,CAAC,CAWpB"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"makeNetworkRequest.d.ts","sourceRoot":"","sources":["../../src/core/makeNetworkRequest.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EACL,kBAAkB,EAClB,iCAAiC,EAClC,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAOxD,OAAO,EAAE,mBAAmB,EAAiB,MAAM,uBAAuB,CAAC;AAC3E,OAAO,EACL,QAAQ,EACR,cAAc,EAGf,MAAM,kBAAkB,CAAC;AAG1B,OAAO,EAAqC,YAAY,EAAE,MAAM,SAAS,CAAC;AAM1E,wBAAgB,uBAAuB,CACrC,cAAc,SAAS;IAAE,UAAU,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,EAC3D,iBAAiB,EAEjB,WAAW,EAAE,mBAAmB,EAChC,QAAQ,EACJ,iCAAiC,GACjC,kBAAkB,CAAC,cAAc,EAAE,iBAAiB,CAAC,EACzD,SAAS,EAAE,iBAAiB,CAAC,cAAc,CAAC,EAC5C,YAAY,CAAC,EAAE,YAAY,CAAC,iBAAiB,CAAC,GAC7C,eAAe,CAAC,cAAc,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,CA8BjD;AAED,wBAAgB,kBAAkB,CAChC,cAAc,SAAS;IAAE,UAAU,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,EAC3D,iBAAiB,EAEjB,WAAW,EAAE,mBAAmB,EAChC,QAAQ,EACJ,iCAAiC,GACjC,kBAAkB,CAAC,cAAc,EAAE,iBAAiB,CAAC,EACzD,SAAS,EAAE,iBAAiB,CAAC,cAAc,CAAC,EAC5C,YAAY,CAAC,EAAE,YAAY,CAAC,iBAAiB,CAAC,GAC7C,eAAe,CAAC,cAAc,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,
|
|
1
|
+
{"version":3,"file":"makeNetworkRequest.d.ts","sourceRoot":"","sources":["../../src/core/makeNetworkRequest.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC7D,OAAO,EACL,kBAAkB,EAClB,iCAAiC,EAClC,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAOxD,OAAO,EAAE,mBAAmB,EAAiB,MAAM,uBAAuB,CAAC;AAC3E,OAAO,EACL,QAAQ,EACR,cAAc,EAGf,MAAM,kBAAkB,CAAC;AAG1B,OAAO,EAAqC,YAAY,EAAE,MAAM,SAAS,CAAC;AAM1E,wBAAgB,uBAAuB,CACrC,cAAc,SAAS;IAAE,UAAU,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,EAC3D,iBAAiB,EAEjB,WAAW,EAAE,mBAAmB,EAChC,QAAQ,EACJ,iCAAiC,GACjC,kBAAkB,CAAC,cAAc,EAAE,iBAAiB,CAAC,EACzD,SAAS,EAAE,iBAAiB,CAAC,cAAc,CAAC,EAC5C,YAAY,CAAC,EAAE,YAAY,CAAC,iBAAiB,CAAC,GAC7C,eAAe,CAAC,cAAc,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,CA8BjD;AAED,wBAAgB,kBAAkB,CAChC,cAAc,SAAS;IAAE,UAAU,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,EAC3D,iBAAiB,EAEjB,WAAW,EAAE,mBAAmB,EAChC,QAAQ,EACJ,iCAAiC,GACjC,kBAAkB,CAAC,cAAc,EAAE,iBAAiB,CAAC,EACzD,SAAS,EAAE,iBAAiB,CAAC,cAAc,CAAC,EAC5C,YAAY,CAAC,EAAE,YAAY,CAAC,iBAAiB,CAAC,GAC7C,eAAe,CAAC,cAAc,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,CA6GjD"}
|
|
@@ -62,7 +62,6 @@ function makeNetworkRequest(environment, artifact, variables, fetchOptions) {
|
|
|
62
62
|
(_a = fetchOptions === null || fetchOptions === void 0 ? void 0 : fetchOptions.onError) === null || _a === void 0 ? void 0 : _a.call(fetchOptions);
|
|
63
63
|
}
|
|
64
64
|
catch (_c) { }
|
|
65
|
-
// @ts-expect-error Why are we getting the wrong constructor here?
|
|
66
65
|
throw new Error('GraphQL network response had errors', {
|
|
67
66
|
cause: networkResponse,
|
|
68
67
|
});
|
package/dist/core/read.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"read.d.ts","sourceRoot":"","sources":["../../src/core/read.ts"],"names":[],"mappings":"AAAA,OAAO,EAIL,KAAK,cAAc,EACpB,MAAM,SAAS,CAAC;AAMjB,OAAO,EACL,iBAAiB,EAEjB,WAAW,EAEZ,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAGL,mBAAmB,EACnB,KAAK,IAAI,EACV,MAAM,uBAAuB,CAAC;
|
|
1
|
+
{"version":3,"file":"read.d.ts","sourceRoot":"","sources":["../../src/core/read.ts"],"names":[],"mappings":"AAAA,OAAO,EAIL,KAAK,cAAc,EACpB,MAAM,SAAS,CAAC;AAMjB,OAAO,EACL,iBAAiB,EAEjB,WAAW,EAEZ,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAGL,mBAAmB,EACnB,KAAK,IAAI,EACV,MAAM,uBAAuB,CAAC;AAgB/B,MAAM,MAAM,sBAAsB,CAAC,CAAC,IAAI;IACtC,QAAQ,CAAC,kBAAkB,EAAE,cAAc,CAAC;IAC5C,QAAQ,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC;CAC/B,CAAC;AAEF,wBAAgB,oBAAoB,CAClC,cAAc,SAAS;IAAE,UAAU,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,EAE3D,WAAW,EAAE,mBAAmB,EAChC,iBAAiB,EAAE,iBAAiB,CAAC,cAAc,EAAE,OAAO,CAAC,EAC7D,qBAAqB,EAAE,2BAA2B,GACjD,sBAAsB,CAAC,cAAc,CAAC,CAiExC;AAED,MAAM,MAAM,cAAc,CAAC,cAAc,IACrC;IACE,QAAQ,CAAC,IAAI,EAAE,SAAS,CAAC;IACzB,QAAQ,CAAC,IAAI,EAAE,WAAW,CAAC,cAAc,CAAC,CAAC;IAC3C,QAAQ,CAAC,kBAAkB,EAAE,cAAc,CAAC;CAC7C,GACD;IACE,QAAQ,CAAC,IAAI,EAAE,aAAa,CAAC;IAC7B,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,YAAY,CAAC,EAAE,cAAc,CAAC,OAAO,CAAC,CAAC;IAChD,QAAQ,CAAC,UAAU,EAAE,IAAI,CAAC;CAC3B,CAAC;AAglBN,MAAM,MAAM,2BAA2B,GAAG;IACxC,iBAAiB,EAAE,OAAO,CAAC;IAC3B,mBAAmB,EAAE,OAAO,CAAC;CAC9B,CAAC;AAEF,wBAAgB,oCAAoC,CAClD,qBAAqB,CAAC,EAAE,OAAO,CAAC,2BAA2B,CAAC,GAAG,IAAI,GAClE,2BAA2B,CAK7B"}
|
package/dist/core/read.js
CHANGED
|
@@ -20,7 +20,7 @@ function readButDoNotEvaluate(environment, fragmentReference, networkRequestOpti
|
|
|
20
20
|
});
|
|
21
21
|
if (response.kind === 'MissingData') {
|
|
22
22
|
// There are two cases here that we care about:
|
|
23
|
-
// 1. the network request is in flight, we haven't
|
|
23
|
+
// 1. the network request is in flight, we haven't suspended on it, and we want
|
|
24
24
|
// to throw if it errors out. So, networkRequestOptions.suspendIfInFlight === false
|
|
25
25
|
// and networkRequestOptions.throwOnNetworkError === true.
|
|
26
26
|
// 2. everything else
|
|
@@ -30,7 +30,16 @@ function readButDoNotEvaluate(environment, fragmentReference, networkRequestOpti
|
|
|
30
30
|
// will not resolve.
|
|
31
31
|
if (!networkRequestOptions.suspendIfInFlight &&
|
|
32
32
|
networkRequestOptions.throwOnNetworkError) {
|
|
33
|
-
//
|
|
33
|
+
// What are we doing here? If the network response has errored out, we can do
|
|
34
|
+
// two things: throw a rejected promise, or throw an error. Both work identically
|
|
35
|
+
// in the browser. However, during initial SSR on NextJS, throwing a rejected
|
|
36
|
+
// promise results in an infinite loop (including re-issuing the query until the
|
|
37
|
+
// process OOM's or something.) Hence, we throw an error.
|
|
38
|
+
// TODO investigate why we cannot check against NOT_SET here and we have to cast
|
|
39
|
+
const result = fragmentReference.networkRequest.result;
|
|
40
|
+
if (result.kind === 'Err') {
|
|
41
|
+
throw new Error('NetworkError', { cause: result.error });
|
|
42
|
+
}
|
|
34
43
|
throw new Promise((resolve, reject) => {
|
|
35
44
|
(0, cache_1.onNextChangeToRecord)(environment, response.recordLink).then(resolve);
|
|
36
45
|
fragmentReference.networkRequest.promise.catch(reject);
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@isograph/react",
|
|
3
|
-
"version": "0.0.0-main-
|
|
3
|
+
"version": "0.0.0-main-e8f38c44",
|
|
4
4
|
"description": "Use Isograph with React",
|
|
5
5
|
"homepage": "https://isograph.dev",
|
|
6
6
|
"main": "dist/index.js",
|
|
@@ -19,9 +19,9 @@
|
|
|
19
19
|
"iso-watch": "../../target/debug/isograph_cli --config ./isograph.config.json --watch"
|
|
20
20
|
},
|
|
21
21
|
"dependencies": {
|
|
22
|
-
"@isograph/disposable-types": "0.0.0-main-
|
|
23
|
-
"@isograph/react-disposable-state": "0.0.0-main-
|
|
24
|
-
"@isograph/reference-counted-pointer": "0.0.0-main-
|
|
22
|
+
"@isograph/disposable-types": "0.0.0-main-e8f38c44",
|
|
23
|
+
"@isograph/react-disposable-state": "0.0.0-main-e8f38c44",
|
|
24
|
+
"@isograph/reference-counted-pointer": "0.0.0-main-e8f38c44"
|
|
25
25
|
},
|
|
26
26
|
"peerDependencies": {
|
|
27
27
|
"react": "18.3.1"
|
|
@@ -106,7 +106,6 @@ export function makeNetworkRequest<
|
|
|
106
106
|
try {
|
|
107
107
|
fetchOptions?.onError?.();
|
|
108
108
|
} catch {}
|
|
109
|
-
// @ts-expect-error Why are we getting the wrong constructor here?
|
|
110
109
|
throw new Error('GraphQL network response had errors', {
|
|
111
110
|
cause: networkResponse,
|
|
112
111
|
});
|
package/src/core/read.ts
CHANGED
|
@@ -26,6 +26,7 @@ import {
|
|
|
26
26
|
getPromiseState,
|
|
27
27
|
PromiseWrapper,
|
|
28
28
|
readPromise,
|
|
29
|
+
Result,
|
|
29
30
|
wrapPromise,
|
|
30
31
|
wrapResolvedValue,
|
|
31
32
|
} from './PromiseWrapper';
|
|
@@ -72,7 +73,7 @@ export function readButDoNotEvaluate<
|
|
|
72
73
|
|
|
73
74
|
if (response.kind === 'MissingData') {
|
|
74
75
|
// There are two cases here that we care about:
|
|
75
|
-
// 1. the network request is in flight, we haven't
|
|
76
|
+
// 1. the network request is in flight, we haven't suspended on it, and we want
|
|
76
77
|
// to throw if it errors out. So, networkRequestOptions.suspendIfInFlight === false
|
|
77
78
|
// and networkRequestOptions.throwOnNetworkError === true.
|
|
78
79
|
// 2. everything else
|
|
@@ -84,7 +85,21 @@ export function readButDoNotEvaluate<
|
|
|
84
85
|
!networkRequestOptions.suspendIfInFlight &&
|
|
85
86
|
networkRequestOptions.throwOnNetworkError
|
|
86
87
|
) {
|
|
87
|
-
//
|
|
88
|
+
// What are we doing here? If the network response has errored out, we can do
|
|
89
|
+
// two things: throw a rejected promise, or throw an error. Both work identically
|
|
90
|
+
// in the browser. However, during initial SSR on NextJS, throwing a rejected
|
|
91
|
+
// promise results in an infinite loop (including re-issuing the query until the
|
|
92
|
+
// process OOM's or something.) Hence, we throw an error.
|
|
93
|
+
|
|
94
|
+
// TODO investigate why we cannot check against NOT_SET here and we have to cast
|
|
95
|
+
const result = fragmentReference.networkRequest.result as Result<
|
|
96
|
+
any,
|
|
97
|
+
any
|
|
98
|
+
>;
|
|
99
|
+
if (result.kind === 'Err') {
|
|
100
|
+
throw new Error('NetworkError', { cause: result.error });
|
|
101
|
+
}
|
|
102
|
+
|
|
88
103
|
throw new Promise((resolve, reject) => {
|
|
89
104
|
onNextChangeToRecord(environment, response.recordLink).then(resolve);
|
|
90
105
|
fragmentReference.networkRequest.promise.catch(reject);
|