[typescript-react-apollo] Fix problem with unnecessary fragment imports for external mode #2360
+104
−1
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Normally, fragments are turned into document nodes so we can include them in the operations document nodes they are used in. In the case of
documentMode = 'external'
, the operation document nodes are created externally and imported into the generated files. Therefore, there's no need to print fragment variables in the generated file anymoreThis problem can be seen in this sandbox: https://codesandbox.io/s/gcg-15-experiments-c8l15. There are fragments in
webpack/GetProject_Status.fragment.graphql
andwebpack/CreateProject.operation.graphql
, and these will be converted into variables with suffixFragmentDoc
in generated files (Note that we are not even importing thegraphql-tag
module).This PR ensures that no fragments are generated when
external
mode is used.NOTE: I'm having problem running
validateTypeScript
in the new tests. I've tried looking at the implementation oftsDocumentsPlugin
and still not able to figure out what it's supposed to do. Would love some pointer please :)TODO:
validateTypeScript
does not work