relay-compiler 7.0.0 → 9.1.0
Sign up to get free protection for your applications and to get access to all the features.
- package/bin/RelayCompilerBin.js.flow +169 -0
- package/bin/RelayCompilerMain.js.flow +508 -0
- package/bin/__fixtures__/plugin-module.js.flow +17 -0
- package/bin/relay-compiler +8554 -8142
- package/codegen/CodegenDirectory.js.flow +375 -0
- package/codegen/CodegenRunner.js.flow +431 -0
- package/codegen/CodegenTypes.js.flow +28 -0
- package/codegen/CodegenWatcher.js.flow +254 -0
- package/codegen/NormalizationCodeGenerator.js.flow +499 -0
- package/codegen/ReaderCodeGenerator.js.flow +453 -0
- package/codegen/RelayCodeGenerator.js.flow +76 -0
- package/codegen/RelayFileWriter.js.flow +366 -0
- package/codegen/SourceControl.js.flow +58 -0
- package/codegen/compileRelayArtifacts.js.flow +182 -0
- package/codegen/createPrintRequireModuleDependency.js.flow +21 -0
- package/codegen/writeRelayGeneratedFile.js.flow +194 -0
- package/core/ASTCache.js.flow +73 -0
- package/core/ASTConvert.js.flow +233 -0
- package/core/CompilerContext.js.flow +190 -0
- package/core/CompilerError.js.flow +250 -0
- package/core/DotGraphQLParser.js.flow +39 -0
- package/core/GraphQLCompilerProfiler.js.flow +341 -0
- package/core/GraphQLDerivedFromMetadata.js.flow +48 -0
- package/core/GraphQLWatchmanClient.js.flow +111 -0
- package/core/IR.js.flow +329 -0
- package/core/IRPrinter.js.flow +488 -0
- package/core/IRTransformer.js.flow +377 -0
- package/core/IRValidator.js.flow +260 -0
- package/core/IRVisitor.js.flow +150 -0
- package/core/JSModuleParser.js.flow +24 -0
- package/core/RelayCompilerScope.js.flow +199 -0
- package/core/RelayFindGraphQLTags.js.flow +119 -0
- package/core/RelayGraphQLEnumsGenerator.js.flow +55 -0
- package/core/RelayIRTransforms.js.flow +130 -0
- package/core/RelayParser.js.flow +1759 -0
- package/core/RelaySourceModuleParser.js.flow +135 -0
- package/core/Schema.js.flow +1985 -0
- package/core/SchemaUtils.js.flow +109 -0
- package/core/filterContextForNode.js.flow +50 -0
- package/core/getFieldDefinition.js.flow +156 -0
- package/core/getIdentifierForArgumentValue.js.flow +49 -0
- package/core/getIdentifierForSelection.js.flow +69 -0
- package/core/getLiteralArgumentValues.js.flow +32 -0
- package/core/getNormalizationOperationName.js.flow +19 -0
- package/core/inferRootArgumentDefinitions.js.flow +323 -0
- package/index.js +1 -1
- package/index.js.flow +202 -0
- package/language/RelayLanguagePluginInterface.js.flow +283 -0
- package/language/javascript/FindGraphQLTags.js.flow +233 -0
- package/language/javascript/RelayFlowBabelFactories.js.flow +180 -0
- package/language/javascript/RelayFlowGenerator.js.flow +1040 -0
- package/language/javascript/RelayFlowTypeTransformers.js.flow +184 -0
- package/language/javascript/RelayLanguagePluginJavaScript.js.flow +34 -0
- package/language/javascript/formatGeneratedModule.js.flow +65 -0
- package/lib/bin/RelayCompilerBin.js +25 -7
- package/lib/bin/RelayCompilerMain.js +134 -125
- package/lib/bin/__fixtures__/plugin-module.js +1 -0
- package/lib/codegen/CodegenDirectory.js +14 -8
- package/lib/codegen/CodegenRunner.js +35 -75
- package/lib/codegen/CodegenTypes.js +1 -0
- package/lib/codegen/CodegenWatcher.js +14 -21
- package/lib/codegen/NormalizationCodeGenerator.js +80 -127
- package/lib/codegen/ReaderCodeGenerator.js +85 -111
- package/lib/codegen/RelayCodeGenerator.js +9 -6
- package/lib/codegen/RelayFileWriter.js +22 -41
- package/lib/codegen/SourceControl.js +1 -0
- package/lib/codegen/compileRelayArtifacts.js +18 -31
- package/lib/codegen/createPrintRequireModuleDependency.js +1 -0
- package/lib/codegen/writeRelayGeneratedFile.js +62 -90
- package/lib/core/ASTCache.js +4 -4
- package/lib/core/ASTConvert.js +1 -0
- package/lib/core/{GraphQLCompilerContext.js → CompilerContext.js} +10 -11
- package/lib/core/{RelayCompilerError.js → CompilerError.js} +29 -55
- package/lib/core/DotGraphQLParser.js +1 -0
- package/lib/core/GraphQLCompilerProfiler.js +9 -12
- package/lib/core/GraphQLDerivedFromMetadata.js +1 -0
- package/lib/core/GraphQLWatchmanClient.js +5 -12
- package/lib/core/{GraphQLIR.js → IR.js} +1 -0
- package/lib/core/{GraphQLIRPrinter.js → IRPrinter.js} +39 -17
- package/lib/core/{GraphQLIRTransformer.js → IRTransformer.js} +21 -16
- package/lib/core/{GraphQLIRValidator.js → IRValidator.js} +18 -10
- package/lib/core/{GraphQLIRVisitor.js → IRVisitor.js} +1 -2
- package/lib/core/JSModuleParser.js +18 -0
- package/lib/core/RelayCompilerScope.js +6 -5
- package/lib/core/RelayFindGraphQLTags.js +1 -0
- package/lib/core/RelayGraphQLEnumsGenerator.js +26 -12
- package/lib/core/RelayIRTransforms.js +12 -9
- package/lib/core/RelayParser.js +113 -75
- package/lib/core/RelaySourceModuleParser.js +4 -3
- package/lib/core/Schema.js +808 -317
- package/lib/core/SchemaUtils.js +1 -0
- package/lib/core/filterContextForNode.js +5 -4
- package/lib/core/getFieldDefinition.js +14 -16
- package/lib/core/getIdentifierForArgumentValue.js +18 -0
- package/lib/core/getIdentifierForSelection.js +4 -5
- package/lib/core/getLiteralArgumentValues.js +1 -0
- package/lib/core/getNormalizationOperationName.js +1 -0
- package/lib/core/inferRootArgumentDefinitions.js +79 -99
- package/lib/index.js +69 -19
- package/lib/language/RelayLanguagePluginInterface.js +1 -0
- package/lib/language/javascript/FindGraphQLTags.js +1 -0
- package/lib/language/javascript/RelayFlowBabelFactories.js +15 -0
- package/lib/language/javascript/RelayFlowGenerator.js +94 -173
- package/lib/language/javascript/RelayFlowTypeTransformers.js +2 -3
- package/lib/language/javascript/RelayLanguagePluginJavaScript.js +7 -4
- package/lib/language/javascript/formatGeneratedModule.js +14 -4
- package/lib/reporters/ConsoleReporter.js +2 -3
- package/lib/reporters/MultiReporter.js +2 -3
- package/lib/reporters/Reporter.js +1 -0
- package/lib/runner/Artifacts.js +327 -0
- package/lib/runner/BufferedFilesystem.js +265 -0
- package/lib/runner/GraphQLASTNodeGroup.js +260 -0
- package/lib/runner/GraphQLASTUtils.js +23 -0
- package/lib/runner/GraphQLNodeMap.js +85 -0
- package/lib/runner/Sources.js +266 -0
- package/lib/runner/StrictMap.js +136 -0
- package/lib/runner/compileArtifacts.js +39 -0
- package/lib/runner/extractAST.js +77 -0
- package/lib/runner/getChangedNodeNames.js +84 -0
- package/lib/runner/getSchemaInstance.js +30 -0
- package/lib/runner/types.js +12 -0
- package/lib/transforms/ApplyFragmentArgumentTransform.js +49 -55
- package/lib/transforms/ClientExtensionsTransform.js +11 -17
- package/lib/transforms/ConnectionTransform.js +35 -28
- package/lib/transforms/DeferStreamTransform.js +26 -74
- package/lib/transforms/DisallowIdAsAlias.js +5 -4
- package/lib/transforms/DisallowTypenameOnRoot.js +55 -0
- package/lib/transforms/FieldHandleTransform.js +8 -3
- package/lib/transforms/FilterDirectivesTransform.js +4 -3
- package/lib/transforms/FlattenTransform.js +23 -47
- package/lib/transforms/GenerateIDFieldTransform.js +9 -4
- package/lib/transforms/GenerateTypeNameTransform.js +8 -3
- package/lib/transforms/InlineDataFragmentTransform.js +11 -6
- package/lib/transforms/InlineFragmentsTransform.js +3 -2
- package/lib/transforms/MaskTransform.js +20 -19
- package/lib/transforms/MatchTransform.js +113 -34
- package/lib/transforms/RefetchableFragmentTransform.js +25 -41
- package/lib/transforms/RelayDirectiveTransform.js +13 -4
- package/lib/transforms/SkipClientExtensionsTransform.js +11 -2
- package/lib/transforms/SkipHandleFieldTransform.js +8 -3
- package/lib/transforms/SkipRedundantNodesTransform.js +9 -6
- package/lib/transforms/SkipSplitOperationTransform.js +32 -0
- package/lib/transforms/SkipUnreachableNodeTransform.js +12 -12
- package/lib/transforms/SkipUnusedVariablesTransform.js +19 -17
- package/lib/transforms/SplitModuleImportTransform.js +4 -3
- package/lib/transforms/TestOperationTransform.js +9 -6
- package/lib/transforms/TransformUtils.js +1 -0
- package/lib/transforms/ValidateGlobalVariablesTransform.js +20 -31
- package/lib/transforms/ValidateRequiredArgumentsTransform.js +17 -20
- package/lib/transforms/ValidateServerOnlyDirectivesTransform.js +20 -33
- package/lib/transforms/ValidateUnusedVariablesTransform.js +20 -31
- package/lib/transforms/query-generators/FetchableQueryGenerator.js +161 -0
- package/lib/transforms/query-generators/NodeQueryGenerator.js +9 -3
- package/lib/transforms/query-generators/QueryQueryGenerator.js +2 -0
- package/lib/transforms/query-generators/ViewerQueryGenerator.js +6 -3
- package/lib/transforms/query-generators/index.js +25 -7
- package/lib/transforms/query-generators/utils.js +13 -15
- package/lib/util/CodeMarker.js +1 -0
- package/lib/util/DefaultHandleKey.js +1 -0
- package/lib/util/RelayCompilerCache.js +2 -3
- package/lib/util/Rollout.js +1 -0
- package/lib/util/TimeReporter.js +83 -0
- package/lib/util/areEqualOSS.js +1 -0
- package/lib/util/dedupeJSONStringify.js +16 -12
- package/lib/util/getDefinitionNodeHash.js +22 -0
- package/lib/util/getModuleName.js +4 -5
- package/lib/util/joinArgumentDefinitions.js +2 -1
- package/lib/util/md5.js +17 -0
- package/lib/util/murmurHash.js +1 -0
- package/lib/util/nullthrowsOSS.js +1 -0
- package/lib/util/orList.js +2 -1
- package/lib/util/partitionArray.js +1 -0
- package/package.json +4 -4
- package/relay-compiler.js +4 -4
- package/relay-compiler.min.js +4 -4
- package/reporters/ConsoleReporter.js.flow +81 -0
- package/reporters/MultiReporter.js.flow +43 -0
- package/reporters/Reporter.js.flow +19 -0
- package/runner/Artifacts.js.flow +219 -0
- package/runner/BufferedFilesystem.js.flow +194 -0
- package/runner/GraphQLASTNodeGroup.js.flow +176 -0
- package/runner/GraphQLASTUtils.js.flow +26 -0
- package/runner/GraphQLNodeMap.js.flow +55 -0
- package/runner/Sources.js.flow +218 -0
- package/runner/StrictMap.js.flow +96 -0
- package/runner/compileArtifacts.js.flow +76 -0
- package/runner/extractAST.js.flow +100 -0
- package/runner/getChangedNodeNames.js.flow +48 -0
- package/runner/getSchemaInstance.js.flow +36 -0
- package/runner/types.js.flow +37 -0
- package/transforms/ApplyFragmentArgumentTransform.js.flow +474 -0
- package/transforms/ClientExtensionsTransform.js.flow +220 -0
- package/transforms/ConnectionTransform.js.flow +869 -0
- package/transforms/DeferStreamTransform.js.flow +258 -0
- package/transforms/DisallowIdAsAlias.js.flow +47 -0
- package/transforms/DisallowTypenameOnRoot.js.flow +45 -0
- package/transforms/FieldHandleTransform.js.flow +80 -0
- package/transforms/FilterDirectivesTransform.js.flow +45 -0
- package/transforms/FlattenTransform.js.flow +456 -0
- package/transforms/GenerateIDFieldTransform.js.flow +134 -0
- package/transforms/GenerateTypeNameTransform.js.flow +81 -0
- package/transforms/InlineDataFragmentTransform.js.flow +124 -0
- package/transforms/InlineFragmentsTransform.js.flow +71 -0
- package/transforms/MaskTransform.js.flow +126 -0
- package/transforms/MatchTransform.js.flow +583 -0
- package/transforms/RefetchableFragmentTransform.js.flow +272 -0
- package/transforms/RelayDirectiveTransform.js.flow +99 -0
- package/transforms/SkipClientExtensionsTransform.js.flow +54 -0
- package/transforms/SkipHandleFieldTransform.js.flow +44 -0
- package/transforms/SkipRedundantNodesTransform.js.flow +253 -0
- package/transforms/SkipSplitOperationTransform.js.flow +37 -0
- package/transforms/SkipUnreachableNodeTransform.js.flow +149 -0
- package/transforms/SkipUnusedVariablesTransform.js.flow +59 -0
- package/transforms/SplitModuleImportTransform.js.flow +98 -0
- package/transforms/TestOperationTransform.js.flow +138 -0
- package/transforms/TransformUtils.js.flow +26 -0
- package/transforms/ValidateGlobalVariablesTransform.js.flow +81 -0
- package/transforms/ValidateRequiredArgumentsTransform.js.flow +127 -0
- package/transforms/ValidateServerOnlyDirectivesTransform.js.flow +112 -0
- package/transforms/ValidateUnusedVariablesTransform.js.flow +89 -0
- package/transforms/query-generators/FetchableQueryGenerator.js.flow +190 -0
- package/transforms/query-generators/NodeQueryGenerator.js.flow +206 -0
- package/transforms/query-generators/QueryQueryGenerator.js.flow +57 -0
- package/transforms/query-generators/ViewerQueryGenerator.js.flow +97 -0
- package/transforms/query-generators/index.js.flow +90 -0
- package/transforms/query-generators/utils.js.flow +72 -0
- package/util/CodeMarker.js.flow +79 -0
- package/util/DefaultHandleKey.js.flow +17 -0
- package/util/RelayCompilerCache.js.flow +88 -0
- package/util/Rollout.js.flow +39 -0
- package/util/TimeReporter.js.flow +79 -0
- package/util/areEqualOSS.js.flow +123 -0
- package/util/dedupeJSONStringify.js.flow +152 -0
- package/util/getDefinitionNodeHash.js.flow +25 -0
- package/util/getModuleName.js.flow +39 -0
- package/util/joinArgumentDefinitions.js.flow +99 -0
- package/util/md5.js.flow +22 -0
- package/util/murmurHash.js.flow +94 -0
- package/util/nullthrowsOSS.js.flow +25 -0
- package/util/orList.js.flow +37 -0
- package/util/partitionArray.js.flow +37 -0
- package/lib/transforms/ConnectionFieldTransform.js +0 -275
@@ -7,6 +7,7 @@
|
|
7
7
|
*
|
8
8
|
* @format
|
9
9
|
*/
|
10
|
+
// flowlint ambiguous-object-type:error
|
10
11
|
'use strict';
|
11
12
|
|
12
13
|
var _asyncToGenerator = require("@babel/runtime/helpers/asyncToGenerator");
|
@@ -30,14 +31,12 @@ function queryFiles(_x, _x2, _x3) {
|
|
30
31
|
|
31
32
|
function _queryFiles() {
|
32
33
|
_queryFiles = _asyncToGenerator(function* (baseDir, expression, filter) {
|
33
|
-
return yield Profiler.waitFor('Watchman:query',
|
34
|
-
/*#__PURE__*/
|
35
|
-
_asyncToGenerator(function* () {
|
34
|
+
return yield Profiler.waitFor('Watchman:query', /*#__PURE__*/_asyncToGenerator(function* () {
|
36
35
|
var client = new GraphQLWatchmanClient(QUERY_RETRIES);
|
37
36
|
|
38
|
-
var
|
39
|
-
watchResp =
|
40
|
-
fields =
|
37
|
+
var _await$Promise$all = yield Promise.all([client.watchProject(baseDir), getFields(client)]),
|
38
|
+
watchResp = _await$Promise$all[0],
|
39
|
+
fields = _await$Promise$all[1];
|
41
40
|
|
42
41
|
var resp = yield client.command('query', watchResp.root, {
|
43
42
|
expression: expression,
|
@@ -57,9 +56,7 @@ function queryDirectories(_x4, _x5) {
|
|
57
56
|
|
58
57
|
function _queryDirectories() {
|
59
58
|
_queryDirectories = _asyncToGenerator(function* (baseDir, expression) {
|
60
|
-
return yield Profiler.waitFor('Watchman:query',
|
61
|
-
/*#__PURE__*/
|
62
|
-
_asyncToGenerator(function* () {
|
59
|
+
return yield Profiler.waitFor('Watchman:query', /*#__PURE__*/_asyncToGenerator(function* () {
|
63
60
|
var client = new GraphQLWatchmanClient();
|
64
61
|
var watchResp = yield client.watchProject(baseDir);
|
65
62
|
var resp = yield client.command('query', watchResp.root, {
|
@@ -124,9 +121,7 @@ function watch(_x10, _x11, _x12) {
|
|
124
121
|
|
125
122
|
function _watch() {
|
126
123
|
_watch = _asyncToGenerator(function* (baseDir, expression, callback) {
|
127
|
-
return yield Profiler.waitFor('Watchman:subscribe',
|
128
|
-
/*#__PURE__*/
|
129
|
-
_asyncToGenerator(function* () {
|
124
|
+
return yield Profiler.waitFor('Watchman:subscribe', /*#__PURE__*/_asyncToGenerator(function* () {
|
130
125
|
var client = new GraphQLWatchmanClient();
|
131
126
|
var watchResp = yield client.watchProject(baseDir);
|
132
127
|
yield makeSubscription(client, watchResp.root, watchResp.relativePath, expression, callback);
|
@@ -201,10 +196,8 @@ function _watchCompile() {
|
|
201
196
|
var compiling = false;
|
202
197
|
var needsCompiling = false;
|
203
198
|
var latestFiles = null;
|
204
|
-
watchFiles(baseDir, expression, filter,
|
205
|
-
|
206
|
-
function () {
|
207
|
-
var _ref6 = _asyncToGenerator(function* (files) {
|
199
|
+
watchFiles(baseDir, expression, filter, /*#__PURE__*/function () {
|
200
|
+
var _ref5 = _asyncToGenerator(function* (files) {
|
208
201
|
needsCompiling = true;
|
209
202
|
latestFiles = files;
|
210
203
|
|
@@ -223,7 +216,7 @@ function _watchCompile() {
|
|
223
216
|
});
|
224
217
|
|
225
218
|
return function (_x26) {
|
226
|
-
return
|
219
|
+
return _ref5.apply(this, arguments);
|
227
220
|
};
|
228
221
|
}());
|
229
222
|
});
|
@@ -235,10 +228,10 @@ function updateFiles(files, baseDir, filter, fileChanges) {
|
|
235
228
|
files.forEach(function (file) {
|
236
229
|
file.exists && fileMap.set(file.relPath, file);
|
237
230
|
});
|
238
|
-
fileChanges.forEach(function (
|
239
|
-
var name =
|
240
|
-
exists =
|
241
|
-
hash =
|
231
|
+
fileChanges.forEach(function (_ref) {
|
232
|
+
var name = _ref.name,
|
233
|
+
exists = _ref.exists,
|
234
|
+
hash = _ref['content.sha1hex'];
|
242
235
|
var shouldRemove = !exists;
|
243
236
|
|
244
237
|
if (!shouldRemove) {
|
@@ -7,20 +7,24 @@
|
|
7
7
|
*
|
8
8
|
* @format
|
9
9
|
*/
|
10
|
+
// flowlint ambiguous-object-type:error
|
10
11
|
'use strict';
|
11
12
|
|
12
13
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
13
14
|
|
14
|
-
var
|
15
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
15
16
|
|
16
17
|
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
17
18
|
|
18
|
-
var
|
19
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
|
20
|
+
|
21
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
22
|
+
|
23
|
+
var _require = require('../core/CompilerError'),
|
19
24
|
createCompilerError = _require.createCompilerError,
|
20
25
|
createUserError = _require.createUserError;
|
21
26
|
|
22
27
|
var _require2 = require('relay-runtime'),
|
23
|
-
ConnectionInterface = _require2.ConnectionInterface,
|
24
28
|
getStorageKey = _require2.getStorageKey,
|
25
29
|
stableCopy = _require2.stableCopy;
|
26
30
|
|
@@ -39,9 +43,9 @@ function generate(schema, node) {
|
|
39
43
|
|
40
44
|
function generateRoot(schema, node) {
|
41
45
|
return {
|
46
|
+
argumentDefinitions: generateArgumentDefinitions(schema, node.argumentDefinitions),
|
42
47
|
kind: 'Operation',
|
43
48
|
name: node.name,
|
44
|
-
argumentDefinitions: generateArgumentDefinitions(schema, node.argumentDefinitions),
|
45
49
|
selections: generateSelections(schema, node.selections)
|
46
50
|
};
|
47
51
|
}
|
@@ -49,8 +53,8 @@ function generateRoot(schema, node) {
|
|
49
53
|
function generateSplitOperation(schema, node) {
|
50
54
|
return {
|
51
55
|
kind: 'SplitOperation',
|
52
|
-
name: node.name,
|
53
56
|
metadata: node.metadata,
|
57
|
+
name: node.name,
|
54
58
|
selections: generateSelections(schema, node.selections)
|
55
59
|
};
|
56
60
|
}
|
@@ -83,14 +87,6 @@ function generateSelections(schema, selections) {
|
|
83
87
|
normalizationSelections.push.apply(normalizationSelections, (0, _toConsumableArray2["default"])(generateLinkedField(schema, selection)));
|
84
88
|
break;
|
85
89
|
|
86
|
-
case 'ConnectionField':
|
87
|
-
normalizationSelections.push.apply(normalizationSelections, (0, _toConsumableArray2["default"])(generateConnectionField(schema, selection)));
|
88
|
-
break;
|
89
|
-
|
90
|
-
case 'Connection':
|
91
|
-
normalizationSelections.push(generateConnection(schema, selection));
|
92
|
-
break;
|
93
|
-
|
94
90
|
case 'Defer':
|
95
91
|
normalizationSelections.push(generateDefer(schema, selection));
|
96
92
|
break;
|
@@ -114,10 +110,10 @@ function generateSelections(schema, selections) {
|
|
114
110
|
function generateArgumentDefinitions(schema, nodes) {
|
115
111
|
return nodes.map(function (node) {
|
116
112
|
return {
|
113
|
+
defaultValue: node.defaultValue,
|
117
114
|
kind: 'LocalArgument',
|
118
115
|
name: node.name,
|
119
|
-
type: schema.getTypeString(node.type)
|
120
|
-
defaultValue: node.defaultValue
|
116
|
+
type: schema.getTypeString(node.type)
|
121
117
|
};
|
122
118
|
});
|
123
119
|
}
|
@@ -135,25 +131,24 @@ function generateCondition(schema, node) {
|
|
135
131
|
}
|
136
132
|
|
137
133
|
return {
|
134
|
+
condition: node.condition.variableName,
|
138
135
|
kind: 'Condition',
|
139
136
|
passingValue: node.passingValue,
|
140
|
-
condition: node.condition.variableName,
|
141
137
|
selections: generateSelections(schema, node.selections)
|
142
138
|
};
|
143
139
|
}
|
144
140
|
|
145
141
|
function generateDefer(schema, node) {
|
146
142
|
if (!(node["if"] == null || node["if"].kind === 'Variable' || node["if"].kind === 'Literal' && node["if"].value === true)) {
|
147
|
-
var
|
143
|
+
var _node$if$loc, _node$if;
|
148
144
|
|
149
|
-
throw createCompilerError('NormalizationCodeGenerator: Expected @defer `if` condition to be ' + 'a variable, unspecified, or the literal `true`.', [(
|
145
|
+
throw createCompilerError('NormalizationCodeGenerator: Expected @defer `if` condition to be ' + 'a variable, unspecified, or the literal `true`.', [(_node$if$loc = (_node$if = node["if"]) === null || _node$if === void 0 ? void 0 : _node$if.loc) !== null && _node$if$loc !== void 0 ? _node$if$loc : node.loc]);
|
150
146
|
}
|
151
147
|
|
152
148
|
return {
|
153
149
|
"if": node["if"] != null && node["if"].kind === 'Variable' ? node["if"].variableName : null,
|
154
150
|
kind: 'Defer',
|
155
151
|
label: node.label,
|
156
|
-
metadata: node.metadata,
|
157
152
|
selections: generateSelections(schema, node.selections)
|
158
153
|
};
|
159
154
|
}
|
@@ -161,8 +156,8 @@ function generateDefer(schema, node) {
|
|
161
156
|
function generateInlineFragment(schema, node) {
|
162
157
|
return {
|
163
158
|
kind: 'InlineFragment',
|
164
|
-
|
165
|
-
|
159
|
+
selections: generateSelections(schema, node.selections),
|
160
|
+
type: schema.getTypeString(node.typeCondition)
|
166
161
|
};
|
167
162
|
}
|
168
163
|
|
@@ -172,13 +167,13 @@ function generateLinkedField(schema, node) {
|
|
172
167
|
// which may have originally appeared in different orders across an app.
|
173
168
|
var handles = node.handles && node.handles.map(function (handle) {
|
174
169
|
var handleNode = {
|
175
|
-
kind: 'LinkedHandle',
|
176
170
|
alias: node.alias === node.name ? null : node.alias,
|
177
|
-
name: node.name,
|
178
171
|
args: generateArgs(node.args),
|
172
|
+
filters: handle.filters,
|
179
173
|
handle: handle.name,
|
180
174
|
key: handle.key,
|
181
|
-
|
175
|
+
kind: 'LinkedHandle',
|
176
|
+
name: node.name
|
182
177
|
}; // T45504512: new connection model
|
183
178
|
// NOTE: this intentionally adds a dynamic key in order to avoid
|
184
179
|
// triggering updates to existing queries that do not use dynamic
|
@@ -186,7 +181,7 @@ function generateLinkedField(schema, node) {
|
|
186
181
|
|
187
182
|
if (handle.dynamicKey != null) {
|
188
183
|
var dynamicKeyArgName = '__dynamicKey';
|
189
|
-
handleNode = (
|
184
|
+
handleNode = _objectSpread({}, handleNode, {
|
190
185
|
dynamicKey: {
|
191
186
|
kind: 'Variable',
|
192
187
|
name: dynamicKeyArgName,
|
@@ -199,20 +194,20 @@ function generateLinkedField(schema, node) {
|
|
199
194
|
}) || [];
|
200
195
|
var type = schema.getRawType(node.type);
|
201
196
|
var field = {
|
202
|
-
kind: 'LinkedField',
|
203
197
|
alias: node.alias === node.name ? null : node.alias,
|
204
|
-
name: node.name,
|
205
|
-
storageKey: null,
|
206
198
|
args: generateArgs(node.args),
|
207
199
|
concreteType: !schema.isAbstractType(type) ? schema.getTypeString(type) : null,
|
200
|
+
kind: 'LinkedField',
|
201
|
+
name: node.name,
|
208
202
|
plural: isPlural(schema, node.type),
|
209
|
-
selections: generateSelections(schema, node.selections)
|
203
|
+
selections: generateSelections(schema, node.selections),
|
204
|
+
storageKey: null
|
210
205
|
}; // Precompute storageKey if possible
|
211
206
|
|
212
207
|
var storageKey = getStaticStorageKey(field, node.metadata);
|
213
208
|
|
214
209
|
if (storageKey != null) {
|
215
|
-
field = (
|
210
|
+
field = _objectSpread({}, field, {
|
216
211
|
storageKey: storageKey
|
217
212
|
});
|
218
213
|
}
|
@@ -220,91 +215,7 @@ function generateLinkedField(schema, node) {
|
|
220
215
|
return [field].concat(handles);
|
221
216
|
}
|
222
217
|
|
223
|
-
function
|
224
|
-
return generateLinkedField(schema, {
|
225
|
-
name: node.name,
|
226
|
-
alias: node.alias,
|
227
|
-
loc: node.loc,
|
228
|
-
directives: node.directives,
|
229
|
-
metadata: node.metadata,
|
230
|
-
selections: node.selections,
|
231
|
-
type: node.type,
|
232
|
-
handles: null,
|
233
|
-
connection: false,
|
234
|
-
// this is only on the linked fields with @conneciton
|
235
|
-
args: node.args.filter(function (arg) {
|
236
|
-
return !ConnectionInterface.isConnectionCall({
|
237
|
-
name: arg.name,
|
238
|
-
value: null
|
239
|
-
});
|
240
|
-
}),
|
241
|
-
kind: 'LinkedField'
|
242
|
-
});
|
243
|
-
}
|
244
|
-
|
245
|
-
function generateConnection(schema, node) {
|
246
|
-
var _ConnectionInterface$ = ConnectionInterface.get(),
|
247
|
-
EDGES = _ConnectionInterface$.EDGES,
|
248
|
-
PAGE_INFO = _ConnectionInterface$.PAGE_INFO;
|
249
|
-
|
250
|
-
var selections = generateSelections(schema, node.selections);
|
251
|
-
var edges;
|
252
|
-
var pageInfo;
|
253
|
-
selections.forEach(function (selection) {
|
254
|
-
if (selection.kind === 'LinkedField') {
|
255
|
-
if (selection.name === EDGES) {
|
256
|
-
edges = selection;
|
257
|
-
} else if (selection.name === PAGE_INFO) {
|
258
|
-
pageInfo = selection;
|
259
|
-
}
|
260
|
-
} else if (selection.kind === 'Stream') {
|
261
|
-
selection.selections.forEach(function (subselection) {
|
262
|
-
if (subselection.kind === 'LinkedField' && subselection.name === EDGES) {
|
263
|
-
edges = subselection;
|
264
|
-
}
|
265
|
-
});
|
266
|
-
} else if (selection.kind === 'Defer') {
|
267
|
-
selection.selections.forEach(function (subselection) {
|
268
|
-
if (subselection.kind === 'LinkedField' && subselection.name === PAGE_INFO) {
|
269
|
-
pageInfo = subselection;
|
270
|
-
}
|
271
|
-
});
|
272
|
-
}
|
273
|
-
});
|
274
|
-
|
275
|
-
if (edges == null || pageInfo == null) {
|
276
|
-
throw createUserError("Invalid connection, expected the '".concat(EDGES, "' and '").concat(PAGE_INFO, "' fields ") + 'to exist.', [node.loc]);
|
277
|
-
}
|
278
|
-
|
279
|
-
var stream = null;
|
280
|
-
|
281
|
-
if (node.stream != null) {
|
282
|
-
var _generateArgumentValu;
|
283
|
-
|
284
|
-
var trueLiteral = {
|
285
|
-
kind: 'Literal',
|
286
|
-
name: 'if',
|
287
|
-
value: true
|
288
|
-
};
|
289
|
-
stream = {
|
290
|
-
"if": node.stream["if"] != null ? (_generateArgumentValu = generateArgumentValue('if', node.stream["if"])) !== null && _generateArgumentValu !== void 0 ? _generateArgumentValu : trueLiteral : trueLiteral,
|
291
|
-
deferLabel: node.stream.deferLabel,
|
292
|
-
streamLabel: node.stream.streamLabel
|
293
|
-
};
|
294
|
-
}
|
295
|
-
|
296
|
-
return {
|
297
|
-
kind: 'Connection',
|
298
|
-
label: node.label,
|
299
|
-
name: node.name,
|
300
|
-
args: generateArgs(node.args),
|
301
|
-
edges: edges,
|
302
|
-
pageInfo: pageInfo,
|
303
|
-
stream: stream
|
304
|
-
};
|
305
|
-
}
|
306
|
-
|
307
|
-
function generateModuleImport(node, key) {
|
218
|
+
function generateModuleImport(node) {
|
308
219
|
var fragmentName = node.name;
|
309
220
|
var regExpMatch = fragmentName.match(/^([a-zA-Z][a-zA-Z0-9]*)(?:_([a-zA-Z][_a-zA-Z0-9]*))?$/);
|
310
221
|
|
@@ -319,16 +230,17 @@ function generateModuleImport(node, key) {
|
|
319
230
|
}
|
320
231
|
|
321
232
|
return {
|
322
|
-
|
323
|
-
documentName: node.documentName,
|
233
|
+
documentName: node.key,
|
324
234
|
fragmentName: fragmentName,
|
325
|
-
fragmentPropName: fragmentPropName
|
235
|
+
fragmentPropName: fragmentPropName,
|
236
|
+
kind: 'ModuleImport'
|
326
237
|
};
|
327
238
|
}
|
328
239
|
|
329
240
|
function generateScalarField(node) {
|
330
241
|
var _node$metadata;
|
331
242
|
|
243
|
+
// flowlint-next-line sketchy-null-mixed:off
|
332
244
|
if ((_node$metadata = node.metadata) === null || _node$metadata === void 0 ? void 0 : _node$metadata.skipNormalizationNode) {
|
333
245
|
return [];
|
334
246
|
} // Note: it is important that the arguments of this field be sorted to
|
@@ -342,27 +254,27 @@ function generateScalarField(node) {
|
|
342
254
|
}
|
343
255
|
|
344
256
|
return {
|
345
|
-
kind: 'ScalarHandle',
|
346
257
|
alias: node.alias === node.name ? null : node.alias,
|
347
|
-
name: node.name,
|
348
258
|
args: generateArgs(node.args),
|
259
|
+
filters: handle.filters,
|
349
260
|
handle: handle.name,
|
350
261
|
key: handle.key,
|
351
|
-
|
262
|
+
kind: 'ScalarHandle',
|
263
|
+
name: node.name
|
352
264
|
};
|
353
265
|
}) || [];
|
354
266
|
var field = {
|
355
|
-
kind: 'ScalarField',
|
356
267
|
alias: node.alias === node.name ? null : node.alias,
|
357
|
-
name: node.name,
|
358
268
|
args: generateArgs(node.args),
|
269
|
+
kind: 'ScalarField',
|
270
|
+
name: node.name,
|
359
271
|
storageKey: null
|
360
272
|
}; // Precompute storageKey if possible
|
361
273
|
|
362
274
|
var storageKey = getStaticStorageKey(field, node.metadata);
|
363
275
|
|
364
276
|
if (storageKey != null) {
|
365
|
-
field = (
|
277
|
+
field = _objectSpread({}, field, {
|
366
278
|
storageKey: storageKey
|
367
279
|
});
|
368
280
|
}
|
@@ -372,9 +284,9 @@ function generateScalarField(node) {
|
|
372
284
|
|
373
285
|
function generateStream(schema, node) {
|
374
286
|
if (!(node["if"] == null || node["if"].kind === 'Variable' || node["if"].kind === 'Literal' && node["if"].value === true)) {
|
375
|
-
var
|
287
|
+
var _node$if$loc2, _node$if2;
|
376
288
|
|
377
|
-
throw createCompilerError('NormalizationCodeGenerator: Expected @stream `if` condition to be ' + 'a variable, unspecified, or the literal `true`.', [(
|
289
|
+
throw createCompilerError('NormalizationCodeGenerator: Expected @stream `if` condition to be ' + 'a variable, unspecified, or the literal `true`.', [(_node$if$loc2 = (_node$if2 = node["if"]) === null || _node$if2 === void 0 ? void 0 : _node$if2.loc) !== null && _node$if$loc2 !== void 0 ? _node$if$loc2 : node.loc]);
|
378
290
|
}
|
379
291
|
|
380
292
|
return {
|
@@ -382,7 +294,8 @@ function generateStream(schema, node) {
|
|
382
294
|
kind: 'Stream',
|
383
295
|
label: node.label,
|
384
296
|
metadata: node.metadata,
|
385
|
-
selections: generateSelections(schema, node.selections)
|
297
|
+
selections: generateSelections(schema, node.selections),
|
298
|
+
useCustomizedBatch: node.useCustomizedBatch != null && node.useCustomizedBatch.kind === 'Variable' ? node.useCustomizedBatch.variableName : null
|
386
299
|
};
|
387
300
|
}
|
388
301
|
|
@@ -402,6 +315,46 @@ function generateArgumentValue(name, value) {
|
|
402
315
|
value: stableCopy(value.value)
|
403
316
|
};
|
404
317
|
|
318
|
+
case 'ObjectValue':
|
319
|
+
{
|
320
|
+
var objectKeys = value.fields.map(function (field) {
|
321
|
+
return field.name;
|
322
|
+
}).sort();
|
323
|
+
var objectValues = new Map(value.fields.map(function (field) {
|
324
|
+
return [field.name, field.value];
|
325
|
+
}));
|
326
|
+
return {
|
327
|
+
fields: objectKeys.map(function (fieldName) {
|
328
|
+
var _generateArgumentValu;
|
329
|
+
|
330
|
+
var fieldValue = objectValues.get(fieldName);
|
331
|
+
|
332
|
+
if (fieldValue == null) {
|
333
|
+
throw createCompilerError('Expected to have object field value');
|
334
|
+
}
|
335
|
+
|
336
|
+
return (_generateArgumentValu = generateArgumentValue(fieldName, fieldValue)) !== null && _generateArgumentValu !== void 0 ? _generateArgumentValu : {
|
337
|
+
kind: 'Literal',
|
338
|
+
name: fieldName,
|
339
|
+
value: null
|
340
|
+
};
|
341
|
+
}),
|
342
|
+
kind: 'ObjectValue',
|
343
|
+
name: name
|
344
|
+
};
|
345
|
+
}
|
346
|
+
|
347
|
+
case 'ListValue':
|
348
|
+
{
|
349
|
+
return {
|
350
|
+
items: value.items.map(function (item, index) {
|
351
|
+
return generateArgumentValue("".concat(name, ".").concat(index), item);
|
352
|
+
}),
|
353
|
+
kind: 'ListValue',
|
354
|
+
name: name
|
355
|
+
};
|
356
|
+
}
|
357
|
+
|
405
358
|
default:
|
406
359
|
throw createUserError('NormalizationCodeGenerator: Complex argument values (Lists or ' + 'InputObjects with nested variables) are not supported.', [value.loc]);
|
407
360
|
}
|