From 75b0efc568e30958d2557e645cf13db29f7b4cb1 Mon Sep 17 00:00:00 2001 From: Lenz Weber-Tronic Date: Thu, 4 Jul 2024 17:07:37 +0200 Subject: [PATCH 1/4] `watchFragment`: forward additional options to `diffOptions` fixes #11924 --- .changeset/good-suns-happen.md | 5 ++ .size-limits.json | 4 +- src/__tests__/ApolloClient.ts | 96 ++++++++++++++++++++++++++++++++++ src/cache/core/cache.ts | 9 +++- 4 files changed, 111 insertions(+), 3 deletions(-) create mode 100644 .changeset/good-suns-happen.md diff --git a/.changeset/good-suns-happen.md b/.changeset/good-suns-happen.md new file mode 100644 index 00000000000..e184b2c1d09 --- /dev/null +++ b/.changeset/good-suns-happen.md @@ -0,0 +1,5 @@ +--- +"@apollo/client": patch +--- + +`watchFragment`: forward additional options to `diffOptions` diff --git a/.size-limits.json b/.size-limits.json index 957c176449a..44b7c3aa8b6 100644 --- a/.size-limits.json +++ b/.size-limits.json @@ -1,4 +1,4 @@ { - "dist/apollo-client.min.cjs": 39619, - "import { ApolloClient, InMemoryCache, HttpLink } from \"dist/index.js\" (production)": 32852 + "dist/apollo-client.min.cjs": 39642, + "import { ApolloClient, InMemoryCache, HttpLink } from \"dist/index.js\" (production)": 32870 } diff --git a/src/__tests__/ApolloClient.ts b/src/__tests__/ApolloClient.ts index 8ba8ccf7ab5..599a29f9a39 100644 --- a/src/__tests__/ApolloClient.ts +++ b/src/__tests__/ApolloClient.ts @@ -2419,6 +2419,102 @@ describe("ApolloClient", () => { new Error("Timeout waiting for next event") ); }); + it("works with `variables`", async () => { + const cache = new InMemoryCache(); + const client = new ApolloClient({ + cache, + link: ApolloLink.empty(), + }); + const ItemFragment = gql` + fragment ItemFragment on Item { + id + text(language: $language) + } + `; + + cache.writeFragment({ + fragment: ItemFragment, + data: { + __typename: "Item", + id: 5, + text: "Item #5", + }, + variables: { language: "Esperanto" }, + }); + + const observable = client.watchFragment({ + fragment: ItemFragment, + from: { __typename: "Item", id: 5 }, + variables: { language: "Esperanto" }, + }); + + const stream = new ObservableStream(observable); + + { + const result = await stream.takeNext(); + + expect(result).toStrictEqual({ + data: { + __typename: "Item", + id: 5, + text: "Item #5", + }, + complete: true, + }); + } + }); + it("supports the @includes directive with `variables`", async () => { + const cache = new InMemoryCache(); + const client = new ApolloClient({ + cache, + link: ApolloLink.empty(), + }); + const ItemFragment = gql` + fragment ItemFragment on Item { + id + text @include(if: $withText) + } + `; + + cache.writeFragment({ + fragment: ItemFragment, + data: { + __typename: "Item", + id: 5, + text: "Item #5", + }, + variables: { withText: true }, + }); + cache.writeFragment({ + fragment: ItemFragment, + data: { + __typename: "Item", + id: 5, + }, + variables: { withText: false }, + }); + + const observable = client.watchFragment({ + fragment: ItemFragment, + from: { __typename: "Item", id: 5 }, + variables: { withText: true }, + }); + + const stream = new ObservableStream(observable); + + { + const result = await stream.takeNext(); + + expect(result).toStrictEqual({ + data: { + __typename: "Item", + id: 5, + text: "Item #5", + }, + complete: true, + }); + } + }); }); describe("defaultOptions", () => { diff --git a/src/cache/core/cache.ts b/src/cache/core/cache.ts index d25c5928332..f4b7dd9b599 100644 --- a/src/cache/core/cache.ts +++ b/src/cache/core/cache.ts @@ -228,10 +228,17 @@ export abstract class ApolloCache implements DataProxy { public watchFragment( options: WatchFragmentOptions ): Observable> { - const { fragment, fragmentName, from, optimistic = true } = options; + const { + fragment, + fragmentName, + from, + optimistic = true, + ...otherOptions + } = options; const query = this.getFragmentDoc(fragment, fragmentName); const diffOptions: Cache.DiffOptions = { + ...otherOptions, returnPartialData: true, id: typeof from === "string" ? from : this.identify(from), query, From ca86bd95892a0252bb9149aa7586a45932cd9891 Mon Sep 17 00:00:00 2001 From: Alessia Bellisario Date: Wed, 10 Jul 2024 13:46:07 -0400 Subject: [PATCH 2/4] chore: bump .size-limits.json --- .size-limits.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.size-limits.json b/.size-limits.json index d8cc123efe5..488e9d3233e 100644 --- a/.size-limits.json +++ b/.size-limits.json @@ -1,4 +1,4 @@ { "dist/apollo-client.min.cjs": 40185, - "import { ApolloClient, InMemoryCache, HttpLink } from \"dist/index.js\" (production)": 32977 + "import { ApolloClient, InMemoryCache, HttpLink } from \"dist/index.js\" (production)": 33000 } From 493dc63d75cc0534073ce7d39903cb12a6bd7400 Mon Sep 17 00:00:00 2001 From: Alessia Bellisario Date: Wed, 10 Jul 2024 13:48:21 -0400 Subject: [PATCH 3/4] chore: bump .size-limits.json --- .size-limits.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.size-limits.json b/.size-limits.json index 488e9d3233e..a68ef55125b 100644 --- a/.size-limits.json +++ b/.size-limits.json @@ -1,4 +1,4 @@ { - "dist/apollo-client.min.cjs": 40185, + "dist/apollo-client.min.cjs": 40207, "import { ApolloClient, InMemoryCache, HttpLink } from \"dist/index.js\" (production)": 33000 } From 9b4ead4be7c2e518090d534ae37e11248b051a6b Mon Sep 17 00:00:00 2001 From: alessbell Date: Wed, 10 Jul 2024 17:50:48 +0000 Subject: [PATCH 4/4] Clean up Prettier, Size-limit, and Api-Extractor --- .size-limits.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.size-limits.json b/.size-limits.json index a68ef55125b..c6da4a36f8f 100644 --- a/.size-limits.json +++ b/.size-limits.json @@ -1,4 +1,4 @@ { - "dist/apollo-client.min.cjs": 40207, - "import { ApolloClient, InMemoryCache, HttpLink } from \"dist/index.js\" (production)": 33000 + "dist/apollo-client.min.cjs": 40206, + "import { ApolloClient, InMemoryCache, HttpLink } from \"dist/index.js\" (production)": 32999 }