-
-
Notifications
You must be signed in to change notification settings - Fork 822
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
@apollo/client
requires React to be installed when using @graphql-tools/links
#4901
Comments
@ardatan any update on this? |
If we use deep imports, ESM doesn't work properly because Apollo Client doesn't implement ESM properly. If anyone has a solution that uses deep imports with ESM support, PRs are welcome. And of course this needs to be tested properly. |
Duplicate of #4582 |
Normally, Deep imports examples:
So, technically, it's possible to make both ESM and CJS work without importing the whole package. That would avoid the React dependency problem. However, Bob the Bundler seems to do transpilation using TSC and doesn't allow much further modification(which is understandable given its current use cases). It doesn't support creating multi-variant source files either (index.ts + index.cts). So, with the current tooling, it doesn't seem possible to achieve this either. If the team is willing to update their tooling to allow this somehow, it would be great. Other than these two options, I see two alternative "solutions":
diff --git a/cjs/index.js b/cjs/index.js
index 8dbdfe0837090bf2c55c2d7369b6f7ecb408402f..ab18d21d83f77da0ef93864a10463f2de571766c 100644
--- a/cjs/index.js
+++ b/cjs/index.js
@@ -1,14 +1,11 @@
"use strict";
-var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.ExecutorLink = void 0;
-const tslib_1 = require("tslib");
-const apolloImport = tslib_1.__importStar(require("@apollo/client"));
+const { ApolloLink, Observable } = require("@apollo/client/core/core.cjs");
const utils_1 = require("@graphql-tools/utils");
-const apollo = (_a = apolloImport === null || apolloImport === void 0 ? void 0 : apolloImport.default) !== null && _a !== void 0 ? _a : apolloImport;
function createApolloRequestHandler(executor) {
return function ApolloRequestHandler(operation) {
- return new apollo.Observable(observer => {
+ return new Observable(observer => {
const executionRequest = {
document: operation.query,
variables: operation.variables,
@@ -40,7 +37,7 @@ function createApolloRequestHandler(executor) {
});
};
}
-class ExecutorLink extends apollo.ApolloLink {
+class ExecutorLink extends ApolloLink {
constructor(executor) {
super(createApolloRequestHandler(executor));
}
diff --git a/esm/index.js b/esm/index.js
index 8667c5ca9b135b88be2b387284875b66e75d9a93..d4a54383fc2131ade7be71507bc0c14760d80db2 100644
--- a/esm/index.js
+++ b/esm/index.js
@@ -1,10 +1,8 @@
-var _a;
-import * as apolloImport from '@apollo/client';
+import { ApolloLink, Observable } from "@apollo/client/core/index.js";
import { isAsyncIterable } from '@graphql-tools/utils';
-const apollo = (_a = apolloImport === null || apolloImport === void 0 ? void 0 : apolloImport.default) !== null && _a !== void 0 ? _a : apolloImport;
function createApolloRequestHandler(executor) {
return function ApolloRequestHandler(operation) {
- return new apollo.Observable(observer => {
+ return new Observable(observer => {
const executionRequest = {
document: operation.query,
variables: operation.variables,
@@ -36,7 +34,7 @@ function createApolloRequestHandler(executor) {
});
};
}
-export class ExecutorLink extends apollo.ApolloLink {
+export class ExecutorLink extends ApolloLink {
constructor(executor) {
super(createApolloRequestHandler(executor));
} Root "pnpm": {
"patchedDependencies": {
"@graphql-tools/[email protected]": "patches/@[email protected]"
}
} (or fully follow the regular patch process and make the changes yourself, start by executing |
Thank you @yusufkandemir for the great summary and documentation of possible workarounds. We are open to contributions in bob-the-bundler that allow working around this kind of limitation. |
In the meantime, I am closing this issue as it is a duplicate of #4582. |
Issue workflow progress
Progress of the issue based on the Contributor Workflow
Describe the bug
When using
@graphql-tools/links
it requires installingreact
as a dependency. My server package doesn't need react. This happens because when@apollo/client
is imported likeimport * as apolloClient from '@apollo/client
, it also imports modules that require React. To avoid that, the proper input should beimport ... from '@apollo/client/core'
. That is taken from@apollo/client
issue – apollographql/apollo-client#7318 (comment)To Reproduce
Steps to reproduce the behavior:
https://codesandbox.io/s/heuristic-morning-zm76mw?file=/src/index.ts
Expected behavior
It shouldn't require
react
in server modules that are not usingreact
and related functionality. Addingreact
as a dependency works as a workaround, but this is not how it should be IMO.Environment:
@graphql-tools/...
: links - 8.3.24The text was updated successfully, but these errors were encountered: