relay-compiler 11.0.0-rc.0 → 12.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (85) hide show
  1. package/bin/relay-compiler +136 -52
  2. package/codegen/CodegenDirectory.js.flow +1 -1
  3. package/codegen/NormalizationCodeGenerator.js.flow +1 -6
  4. package/codegen/createPrintRequireModuleDependency.js.flow +2 -4
  5. package/codegen/writeRelayGeneratedFile.js.flow +17 -1
  6. package/core/IRPrinter.js.flow +1 -0
  7. package/core/RelayParser.js.flow +3 -0
  8. package/index.js +1 -1
  9. package/language/javascript/RelayFlowGenerator.js.flow +1 -0
  10. package/language/javascript/RelayFlowTypeTransformers.js.flow +3 -3
  11. package/lib/bin/RelayCompilerMain.js +1 -1
  12. package/lib/codegen/CodegenDirectory.js +1 -1
  13. package/lib/codegen/CodegenRunner.js +1 -1
  14. package/lib/codegen/NormalizationCodeGenerator.js +2 -3
  15. package/lib/codegen/RelayFileWriter.js +1 -1
  16. package/lib/codegen/createPrintRequireModuleDependency.js +2 -2
  17. package/lib/codegen/writeRelayGeneratedFile.js +23 -7
  18. package/lib/core/CompilerContext.js +1 -1
  19. package/lib/core/GraphQLCompilerProfiler.js +1 -1
  20. package/lib/core/IRPrinter.js +3 -2
  21. package/lib/core/IRTransformer.js +1 -1
  22. package/lib/core/IRValidator.js +1 -1
  23. package/lib/core/RelayParser.js +5 -2
  24. package/lib/core/RelaySourceModuleParser.js +1 -1
  25. package/lib/core/getIdentifierForArgumentValue.js +1 -1
  26. package/lib/core/getIdentifierForSelection.js +1 -1
  27. package/lib/language/javascript/RelayFlowBabelFactories.js +1 -1
  28. package/lib/language/javascript/RelayFlowGenerator.js +3 -2
  29. package/lib/runner/BufferedFilesystem.js +1 -1
  30. package/lib/runner/Sources.js +1 -1
  31. package/lib/runner/StrictMap.js +1 -1
  32. package/lib/runner/extractAST.js +1 -1
  33. package/lib/transforms/ClientExtensionsTransform.js +1 -0
  34. package/lib/transforms/ConnectionTransform.js +6 -2
  35. package/lib/transforms/DeclarativeConnectionMutationTransform.js +5 -2
  36. package/lib/transforms/DeferStreamTransform.js +2 -1
  37. package/lib/transforms/DisallowIdAsAlias.js +2 -1
  38. package/lib/transforms/FieldHandleTransform.js +4 -2
  39. package/lib/transforms/FlattenTransform.js +10 -5
  40. package/lib/transforms/GenerateIDFieldTransform.js +3 -1
  41. package/lib/transforms/GenerateTypeNameTransform.js +9 -3
  42. package/lib/transforms/InlineDataFragmentTransform.js +6 -2
  43. package/lib/transforms/InlineFragmentsTransform.js +5 -3
  44. package/lib/transforms/MaskTransform.js +8 -4
  45. package/lib/transforms/MatchTransform.js +5 -1
  46. package/lib/transforms/ReactFlightComponentTransform.js +3 -0
  47. package/lib/transforms/RelayDirectiveTransform.js +4 -2
  48. package/lib/transforms/RequiredFieldTransform.js +6 -2
  49. package/lib/transforms/SkipClientExtensionsTransform.js +3 -0
  50. package/lib/transforms/SkipHandleFieldTransform.js +1 -0
  51. package/lib/transforms/SkipRedundantNodesTransform.js +5 -3
  52. package/lib/transforms/SkipUnreachableNodeTransform.js +1 -1
  53. package/lib/transforms/SplitModuleImportTransform.js +4 -1
  54. package/lib/transforms/TestOperationTransform.js +1 -0
  55. package/lib/transforms/ValidateRequiredArgumentsTransform.js +5 -1
  56. package/lib/transforms/ValidateServerOnlyDirectivesTransform.js +4 -1
  57. package/lib/util/{areEqualOSS.js → areEqualArgValues.js} +6 -4
  58. package/package.json +8 -7
  59. package/relay-compiler.js +3 -3
  60. package/relay-compiler.min.js +3 -3
  61. package/runner/BufferedFilesystem.js.flow +1 -1
  62. package/transforms/ClientExtensionsTransform.js.flow +1 -0
  63. package/transforms/ConnectionTransform.js.flow +4 -0
  64. package/transforms/DeclarativeConnectionMutationTransform.js.flow +3 -0
  65. package/transforms/DeferStreamTransform.js.flow +1 -0
  66. package/transforms/DisallowIdAsAlias.js.flow +1 -0
  67. package/transforms/FieldHandleTransform.js.flow +2 -0
  68. package/transforms/FlattenTransform.js.flow +10 -2
  69. package/transforms/GenerateIDFieldTransform.js.flow +2 -0
  70. package/transforms/GenerateTypeNameTransform.js.flow +6 -0
  71. package/transforms/InlineDataFragmentTransform.js.flow +4 -0
  72. package/transforms/InlineFragmentsTransform.js.flow +2 -0
  73. package/transforms/MaskTransform.js.flow +4 -0
  74. package/transforms/MatchTransform.js.flow +4 -0
  75. package/transforms/ReactFlightComponentTransform.js.flow +3 -0
  76. package/transforms/RelayDirectiveTransform.js.flow +2 -0
  77. package/transforms/RequiredFieldTransform.js.flow +4 -0
  78. package/transforms/SkipClientExtensionsTransform.js.flow +3 -0
  79. package/transforms/SkipHandleFieldTransform.js.flow +1 -0
  80. package/transforms/SkipRedundantNodesTransform.js.flow +2 -0
  81. package/transforms/SplitModuleImportTransform.js.flow +3 -0
  82. package/transforms/TestOperationTransform.js.flow +1 -0
  83. package/transforms/ValidateRequiredArgumentsTransform.js.flow +4 -0
  84. package/transforms/ValidateServerOnlyDirectivesTransform.js.flow +3 -0
  85. package/util/{areEqualOSS.js.flow → areEqualArgValues.js.flow} +6 -3
@@ -1,6 +1,6 @@
1
1
  #!/usr/bin/env node
2
2
  /**
3
- * Relay v11.0.0-rc.0
3
+ * Relay v12.0.0
4
4
  *
5
5
  * Copyright (c) Facebook, Inc. and its affiliates.
6
6
  *
@@ -730,7 +730,7 @@ module.exports = require("@babel/runtime/helpers/toConsumableArray");
730
730
  /* 6 */
731
731
  /***/ (function(module, exports) {
732
732
 
733
- module.exports = require("fbjs/lib/invariant");
733
+ module.exports = require("invariant");
734
734
 
735
735
  /***/ }),
736
736
  /* 7 */
@@ -2821,13 +2821,15 @@ var RelayParser = /*#__PURE__*/function () {
2821
2821
  var typeFromAST = _this3._schema.getTypeFromAST(parseType(typeString));
2822
2822
 
2823
2823
  if (typeFromAST == null) {
2824
- throw createUserError("Unknown type \"".concat(typeString, "\" referenced in the argument definitions."), null, [arg]);
2824
+ throw createUserError( // $FlowFixMe[incompatible-type]
2825
+ "Unknown type \"".concat(typeString, "\" referenced in the argument definitions."), null, [arg]);
2825
2826
  }
2826
2827
 
2827
2828
  var type = _this3._schema.asInputType(typeFromAST);
2828
2829
 
2829
2830
  if (type == null) {
2830
- throw createUserError("Expected type \"".concat(typeString, "\" to be an input type in the \"").concat(arg.name.value, "\" argument definitions."), null, [arg.value]);
2831
+ throw createUserError( // $FlowFixMe[incompatible-type]
2832
+ "Expected type \"".concat(typeString, "\" to be an input type in the \"").concat(arg.name.value, "\" argument definitions."), null, [arg.value]);
2831
2833
  }
2832
2834
 
2833
2835
  var defaultValue = defaultValueNode != null ? transformValue(_this3._schema, defaultValueNode, type, function (variableAst) {
@@ -3174,6 +3176,7 @@ var GraphQLDefinitionParser = /*#__PURE__*/function () {
3174
3176
  argumentDefinitions: argumentDefinitions,
3175
3177
  directives: directives,
3176
3178
  selections: selections,
3179
+ // $FlowFixMe[incompatible-return]
3177
3180
  type: type
3178
3181
  };
3179
3182
  };
@@ -4379,7 +4382,8 @@ function printFragmentArgumentDefinitions(schema, argumentDefinitions) {
4379
4382
  str += ", defaultValue: ".concat(printLiteral(schema, def.defaultValue, def.type));
4380
4383
  }
4381
4384
 
4382
- str += '}';
4385
+ str += '}'; // $FlowFixMe[incompatible-use]
4386
+
4383
4387
  printed.push(str);
4384
4388
  });
4385
4389
  return printed && printed.length ? " @argumentDefinitions(\n".concat(INDENT).concat(printed.join('\n' + INDENT), "\n)") : '';
@@ -5111,7 +5115,7 @@ var _objectSpread2 = _interopRequireDefault(__webpack_require__(2));
5111
5115
 
5112
5116
  var IRTransformer = __webpack_require__(3);
5113
5117
 
5114
- var areEqual = __webpack_require__(89);
5118
+ var areEqualArgValues = __webpack_require__(89);
5115
5119
 
5116
5120
  var getIdentifierForSelection = __webpack_require__(41);
5117
5121
 
@@ -5149,6 +5153,7 @@ function flattenTransformImpl(context, options) {
5149
5153
 
5150
5154
  function memoizedFlattenSelection(cache) {
5151
5155
  return function flattenSelectionsFn(node, state) {
5156
+ // $FlowFixMe[incompatible-use]
5152
5157
  var context = this.getContext();
5153
5158
  var nodeCache = cache.get(node);
5154
5159
 
@@ -5179,7 +5184,8 @@ function memoizedFlattenSelection(cache) {
5179
5184
  var flattenedNode = hasFlattened ? (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, node), {}, {
5180
5185
  selections: Array.from(nextSelections.values())
5181
5186
  }) : node;
5182
- state.parentType = type;
5187
+ state.parentType = type; // $FlowFixMe[incompatible-use]
5188
+
5183
5189
  var deeplyFlattenedNode = this.traverse(flattenedNode, state);
5184
5190
  state.parentType = parentType;
5185
5191
  nodeCache.set(parentType, deeplyFlattenedNode);
@@ -5363,7 +5369,7 @@ function areEqualFields(thisField, thatField) {
5363
5369
  function areEqualArgs(thisArgs, thatArgs) {
5364
5370
  return thisArgs.length === thatArgs.length && thisArgs.every(function (thisArg, index) {
5365
5371
  var thatArg = thatArgs[index];
5366
- return thisArg.name === thatArg.name && thisArg.value.kind === thatArg.value.kind && thisArg.value.variableName === thatArg.value.variableName && areEqual(thisArg.value.value, thatArg.value.value);
5372
+ return thisArg.name === thatArg.name && thisArg.value.kind === thatArg.value.kind && thisArg.value.variableName === thatArg.value.variableName && areEqualArgValues(thisArg.value.value, thatArg.value.value);
5367
5373
  });
5368
5374
  }
5369
5375
  /**
@@ -5381,9 +5387,12 @@ function mergeHandles(nodeA, nodeB) {
5381
5387
  }
5382
5388
 
5383
5389
  var uniqueItems = new Map();
5384
- nodeA.handles.concat(nodeB.handles).forEach(function (item) {
5390
+ nodeA.handles // $FlowFixMe[incompatible-use]
5391
+ .concat(nodeB.handles) // $FlowFixMe[incompatible-use]
5392
+ .forEach(function (item) {
5385
5393
  return uniqueItems.set(item.name + item.key, item);
5386
- });
5394
+ }); // $FlowFixMe[incompatible-return]
5395
+
5387
5396
  return Array.from(uniqueItems.values());
5388
5397
  }
5389
5398
 
@@ -5526,13 +5535,15 @@ function maskTransform(context) {
5526
5535
  }
5527
5536
 
5528
5537
  function visitFragment(fragment, state) {
5538
+ // $FlowFixMe[incompatible-use]
5529
5539
  var result = this.traverse(fragment, state);
5530
5540
 
5531
5541
  if (state.reachableArguments.length === 0) {
5532
5542
  return result;
5533
5543
  }
5534
5544
 
5535
- var joinedArgumentDefinitions = joinArgumentDefinitions(this.getContext().getSchema(), fragment, state.reachableArguments, '@relay(unmask: true)');
5545
+ var joinedArgumentDefinitions = joinArgumentDefinitions( // $FlowFixMe[incompatible-use]
5546
+ this.getContext().getSchema(), fragment, state.reachableArguments, '@relay(unmask: true)');
5536
5547
  return (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, result), {}, {
5537
5548
  argumentDefinitions: joinedArgumentDefinitions
5538
5549
  });
@@ -5543,7 +5554,8 @@ function visitFragmentSpread(fragmentSpread, state) {
5543
5554
  return fragmentSpread;
5544
5555
  }
5545
5556
 
5546
- !(fragmentSpread.args.length === 0) ? true ? invariant(false, 'MaskTransform: Cannot unmask fragment spread `%s` with ' + 'arguments. Use the `ApplyFragmentArgumentTransform` before flattening', fragmentSpread.name) : undefined : void 0;
5557
+ !(fragmentSpread.args.length === 0) ? true ? invariant(false, 'MaskTransform: Cannot unmask fragment spread `%s` with ' + 'arguments. Use the `ApplyFragmentArgumentTransform` before flattening', fragmentSpread.name) : undefined : void 0; // $FlowFixMe[incompatible-use]
5558
+
5547
5559
  var context = this.getContext();
5548
5560
  var fragment = context.getFragment(fragmentSpread.name);
5549
5561
  var result = {
@@ -5579,7 +5591,8 @@ function visitFragmentSpread(fragmentSpread, state) {
5579
5591
  for (_iterator.s(); !(_step = _iterator.n()).done;) {
5580
5592
  var argDef = _step.value;
5581
5593
  state.reachableArguments.push(argDef);
5582
- }
5594
+ } // $FlowFixMe[incompatible-use]
5595
+
5583
5596
  } catch (err) {
5584
5597
  _iterator.e(err);
5585
5598
  } finally {
@@ -5668,12 +5681,14 @@ function matchTransform(context) {
5668
5681
  }
5669
5682
 
5670
5683
  function visitInlineFragment(node, state) {
5684
+ // $FlowFixMe[incompatible-use]
5671
5685
  return this.traverse(node, (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, state), {}, {
5672
5686
  parentType: node.typeCondition
5673
5687
  }));
5674
5688
  }
5675
5689
 
5676
5690
  function visitScalarField(field) {
5691
+ // $FlowFixMe[incompatible-use]
5677
5692
  var context = this.getContext();
5678
5693
  var schema = context.getSchema();
5679
5694
 
@@ -5693,6 +5708,7 @@ function visitScalarField(field) {
5693
5708
  }
5694
5709
 
5695
5710
  function visitLinkedField(node, state) {
5711
+ // $FlowFixMe[incompatible-use]
5696
5712
  var context = this.getContext();
5697
5713
  var schema = context.getSchema();
5698
5714
  var matchDirective = node.directives.find(function (directive) {
@@ -5714,7 +5730,8 @@ function visitLinkedField(node, state) {
5714
5730
  }
5715
5731
  }
5716
5732
 
5717
- state.path.push(node);
5733
+ state.path.push(node); // $FlowFixMe[incompatible-use]
5734
+
5718
5735
  var transformedNode = this.traverse(node, (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, state), {}, {
5719
5736
  moduleKey: moduleKey,
5720
5737
  parentType: node.type
@@ -6368,11 +6385,13 @@ function visitRelayMetadata(metadataFn) {
6368
6385
  });
6369
6386
 
6370
6387
  if (!relayDirective) {
6388
+ // $FlowFixMe[incompatible-use]
6371
6389
  return this.traverse(node);
6372
6390
  }
6373
6391
 
6374
6392
  var argValues = getLiteralArgumentValues(relayDirective.args);
6375
- var metadata = metadataFn(argValues);
6393
+ var metadata = metadataFn(argValues); // $FlowFixMe[incompatible-use]
6394
+
6376
6395
  return this.traverse((0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, node), {}, {
6377
6396
  directives: node.directives.filter(function (directive) {
6378
6397
  return directive !== relayDirective;
@@ -6733,7 +6752,8 @@ function createVisitor(schema, options) {
6733
6752
  babelNodes.push(rawResponseType);
6734
6753
  }
6735
6754
 
6736
- babelNodes.push(exportType(node.name, exactObjectTypeAnnotation(operationTypes)));
6755
+ babelNodes.push(exportType(node.name, exactObjectTypeAnnotation(operationTypes))); // $FlowFixMe[incompatible-call]
6756
+
6737
6757
  return t.program(babelNodes);
6738
6758
  },
6739
6759
  Fragment: function Fragment(node) {
@@ -7335,10 +7355,12 @@ function requiredFieldTransform(context) {
7335
7355
  }
7336
7356
 
7337
7357
  function visitFragment(fragment, state) {
7358
+ // $FlowFixMe[incompatible-use]
7338
7359
  return addChildrenCanBubbleMetadata(this.traverse(fragment, state), state);
7339
7360
  }
7340
7361
 
7341
7362
  function visitRoot(root, state) {
7363
+ // $FlowFixMe[incompatible-use]
7342
7364
  return addChildrenCanBubbleMetadata(this.traverse(root, state), state);
7343
7365
  }
7344
7366
 
@@ -7348,7 +7370,8 @@ function visitInlineFragment(fragment, state) {
7348
7370
  // Ideally we could allow @required when the direct parent inline fragment was
7349
7371
  // on a concrete type, but we would need to solve this bug in our Flow type
7350
7372
  // generation first: T65695438
7351
- var parentAbstractInlineFragment = (_state$parentAbstract = state.parentAbstractInlineFragment) !== null && _state$parentAbstract !== void 0 ? _state$parentAbstract : getAbstractInlineFragment(fragment, state.schema);
7373
+ var parentAbstractInlineFragment = (_state$parentAbstract = state.parentAbstractInlineFragment) !== null && _state$parentAbstract !== void 0 ? _state$parentAbstract : getAbstractInlineFragment(fragment, state.schema); // $FlowFixMe[incompatible-use]
7374
+
7352
7375
  return this.traverse(fragment, (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, state), {}, {
7353
7376
  parentAbstractInlineFragment: parentAbstractInlineFragment
7354
7377
  }));
@@ -7388,7 +7411,8 @@ function visitLinkedField(field, state) {
7388
7411
  currentNodeRequiredChildren: new Map(),
7389
7412
  path: path,
7390
7413
  parentAbstractInlineFragment: null
7391
- });
7414
+ }); // $FlowFixMe[incompatible-use]
7415
+
7392
7416
  var newField = this.traverse(field, newState);
7393
7417
  var pathName = path.join('.');
7394
7418
  assertCompatibleRequiredChildren(field, pathName, newState);
@@ -12252,6 +12276,7 @@ function generateModuleImport(node) {
12252
12276
  }
12253
12277
 
12254
12278
  return {
12279
+ args: null,
12255
12280
  documentName: node.key,
12256
12281
  fragmentName: fragmentName,
12257
12282
  fragmentPropName: fragmentPropName,
@@ -12335,9 +12360,7 @@ function generateStream(schema, node) {
12335
12360
  "if": node["if"] != null && node["if"].kind === 'Variable' ? node["if"].variableName : null,
12336
12361
  kind: 'Stream',
12337
12362
  label: node.label,
12338
- metadata: sortObjectByKey(node.metadata),
12339
- selections: generateSelections(schema, node.selections),
12340
- useCustomizedBatch: node.useCustomizedBatch != null && node.useCustomizedBatch.kind === 'Variable' ? node.useCustomizedBatch.variableName : null
12363
+ selections: generateSelections(schema, node.selections)
12341
12364
  };
12342
12365
  }
12343
12366
 
@@ -13038,7 +13061,7 @@ function getConcreteType(node) {
13038
13061
  }
13039
13062
 
13040
13063
  function writeRelayGeneratedFile(schema, codegenDir, definition, _generatedNode, formatModule, typeText, _persistQuery, sourceHash, extension) {
13041
- var printModuleDependency = arguments.length > 9 && arguments[9] !== undefined ? arguments[9] : createPrintRequireModuleDependency(extension);
13064
+ var printModuleDependency = arguments.length > 9 && arguments[9] !== undefined ? arguments[9] : createPrintRequireModuleDependency();
13042
13065
  var shouldRepersist = arguments.length > 10 ? arguments[10] : undefined;
13043
13066
  var writeQueryParameters = arguments.length > 11 ? arguments[11] : undefined;
13044
13067
  var languagePlugin = arguments.length > 12 ? arguments[12] : undefined;
@@ -13088,13 +13111,18 @@ function writeRelayGeneratedFile(schema, codegenDir, definition, _generatedNode,
13088
13111
  }
13089
13112
 
13090
13113
  if (id == null) {
13114
+ // $FlowFixMe[incompatible-call]
13091
13115
  id = yield persistQuery(docText);
13092
13116
  }
13093
13117
 
13094
13118
  nextRequestParams = {
13095
13119
  id: id,
13096
13120
  metadata: nextMetadata,
13121
+ // $FlowFixMe[prop-missing]
13122
+ // $FlowFixMe[incompatible-use]
13097
13123
  name: generatedNode.params.name,
13124
+ // $FlowFixMe[prop-missing]
13125
+ // $FlowFixMe[incompatible-use]
13098
13126
  operationKind: generatedNode.params.operationKind,
13099
13127
  text: null
13100
13128
  };
@@ -13103,13 +13131,19 @@ function writeRelayGeneratedFile(schema, codegenDir, definition, _generatedNode,
13103
13131
  cacheID: md5(docText),
13104
13132
  id: null,
13105
13133
  metadata: nextMetadata,
13134
+ // $FlowFixMe[prop-missing]
13135
+ // $FlowFixMe[incompatible-use]
13106
13136
  name: generatedNode.params.name,
13137
+ // $FlowFixMe[prop-missing]
13138
+ // $FlowFixMe[incompatible-use]
13107
13139
  operationKind: generatedNode.params.operationKind,
13108
13140
  text: docText
13109
13141
  };
13110
- }
13142
+ } // $FlowFixMe[incompatible-type]
13143
+
13111
13144
 
13112
13145
  generatedNode = (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, generatedNode), {}, {
13146
+ // $FlowFixMe[incompatible-type]
13113
13147
  params: nextRequestParams
13114
13148
  });
13115
13149
  } // Strip metadata only used within the compiler
@@ -13118,7 +13152,8 @@ function writeRelayGeneratedFile(schema, codegenDir, definition, _generatedNode,
13118
13152
  if (generatedNode.kind === RelayConcreteNode.SPLIT_OPERATION && ((_generatedNode$metada = generatedNode.metadata) === null || _generatedNode$metada === void 0 ? void 0 : _generatedNode$metada.derivedFrom) != null) {
13119
13153
  var _generatedNode$metada2 = generatedNode.metadata,
13120
13154
  _ignored3 = _generatedNode$metada2.derivedFrom,
13121
- metadata = (0, _objectWithoutPropertiesLoose2["default"])(_generatedNode$metada2, ["derivedFrom"]);
13155
+ metadata = (0, _objectWithoutPropertiesLoose2["default"])(_generatedNode$metada2, ["derivedFrom"]); // $FlowFixMe[incompatible-type]
13156
+
13122
13157
  generatedNode = (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, generatedNode), {}, {
13123
13158
  metadata: metadata
13124
13159
  });
@@ -13134,14 +13169,18 @@ function writeRelayGeneratedFile(schema, codegenDir, definition, _generatedNode,
13134
13169
  hash: hash != null ? "@relayHash ".concat(hash) : null,
13135
13170
  concreteText: CodeMarker.postProcess(dedupeJSONStringify(generatedNode), printModuleDependency),
13136
13171
  sourceHash: sourceHash,
13172
+ // $FlowFixMe[incompatible-call]
13137
13173
  node: generatedNode,
13138
13174
  schema: schema
13139
13175
  });
13140
13176
  codegenDir.writeFile(filename, moduleText, shouldRepersist);
13141
13177
 
13142
- if (writeQueryParameters && queryParametersFilename != null && generatedNode.kind === RelayConcreteNode.REQUEST && generatedNode.params.operationKind === 'query') {
13143
- writeQueryParameters(codegenDir, queryParametersFilename, moduleName, generatedNode.params);
13144
- }
13178
+ if (writeQueryParameters && queryParametersFilename != null && generatedNode.kind === RelayConcreteNode.REQUEST && // $FlowFixMe[incompatible-type]
13179
+ generatedNode.params.operationKind === 'query') {
13180
+ writeQueryParameters(codegenDir, queryParametersFilename, moduleName, // $FlowFixMe[incompatible-call]
13181
+ generatedNode.params);
13182
+ } // $FlowFixMe[incompatible-call]
13183
+
13145
13184
 
13146
13185
  return generatedNode;
13147
13186
  }));
@@ -13200,9 +13239,9 @@ module.exports = require("@babel/runtime/helpers/objectWithoutPropertiesLoose");
13200
13239
  // flowlint ambiguous-object-type:error
13201
13240
 
13202
13241
 
13203
- function createPrintRequireModuleDependency(extension) {
13242
+ function createPrintRequireModuleDependency() {
13204
13243
  return function (moduleName) {
13205
- return "require('./".concat(moduleName, ".").concat(extension, "')");
13244
+ return "require('./".concat(moduleName, "')");
13206
13245
  };
13207
13246
  }
13208
13247
 
@@ -14121,6 +14160,7 @@ function clientExtensionTransform(context) {
14121
14160
  }
14122
14161
 
14123
14162
  function traverseDefinition(node) {
14163
+ // $FlowFixMe[incompatible-use]
14124
14164
  var compilerContext = this.getContext();
14125
14165
  var schema = compilerContext.getSchema();
14126
14166
  var rootType;
@@ -14388,6 +14428,7 @@ var SCHEMA_EXTENSION = "\n directive @connection(\n key: String!\n filter
14388
14428
  */
14389
14429
 
14390
14430
  function visitFragmentOrRoot(node, options) {
14431
+ // $FlowFixMe[incompatible-use]
14391
14432
  var transformedNode = this.traverse(node, options);
14392
14433
  var connectionMetadata = options.connectionMetadata;
14393
14434
 
@@ -14409,11 +14450,13 @@ function visitFragmentOrRoot(node, options) {
14409
14450
  function visitLinkedField(field, options) {
14410
14451
  var _connectionArguments$;
14411
14452
 
14453
+ // $FlowFixMe[incompatible-use]
14412
14454
  var context = this.getContext();
14413
14455
  var schema = context.getSchema();
14414
14456
  var nullableType = schema.getNullableType(field.type);
14415
14457
  var isPlural = schema.isList(nullableType);
14416
- var path = options.path.concat(isPlural ? null : field.alias || field.name);
14458
+ var path = options.path.concat(isPlural ? null : field.alias || field.name); // $FlowFixMe[incompatible-use]
14459
+
14417
14460
  var transformedField = this.traverse(field, (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, options), {}, {
14418
14461
  path: path
14419
14462
  }));
@@ -14443,7 +14486,8 @@ function visitLinkedField(field, options) {
14443
14486
  var direction = connectionMetadata.direction;
14444
14487
 
14445
14488
  if (direction != null) {
14446
- var selections = transformConnectionSelections(this.getContext(), transformedField, schema.assertCompositeType(nullableType), direction, connectionArguments, connectionDirective.loc, options.documentName);
14489
+ var selections = transformConnectionSelections( // $FlowFixMe[incompatible-use]
14490
+ this.getContext(), transformedField, schema.assertCompositeType(nullableType), direction, connectionArguments, connectionDirective.loc, options.documentName);
14447
14491
  transformedField = (0, _objectSpread2["default"])((0, _objectSpread2["default"])({}, transformedField), {}, {
14448
14492
  selections: selections
14449
14493
  });
@@ -15033,7 +15077,8 @@ function visitScalarField(field) {
15033
15077
 
15034
15078
  if (targetDirective == null) {
15035
15079
  return field;
15036
- }
15080
+ } // $FlowFixMe[incompatible-use]
15081
+
15037
15082
 
15038
15083
  var schema = this.getContext().getSchema();
15039
15084
 
@@ -15060,6 +15105,7 @@ function visitScalarField(field) {
15060
15105
  }
15061
15106
 
15062
15107
  function visitLinkedField(field) {
15108
+ // $FlowFixMe[incompatible-use]
15063
15109
  var transformedField = this.traverse(field);
15064
15110
  var deleteDirective = transformedField.directives.find(function (directive) {
15065
15111
  return directive.name === DELETE_RECORD;
@@ -15091,7 +15137,8 @@ function visitLinkedField(field) {
15091
15137
 
15092
15138
  if (connectionsArg == null) {
15093
15139
  throw createUserError("Expected the 'connections' argument to be defined on @".concat(targetDirective.name, "."), [targetDirective.loc]);
15094
- }
15140
+ } // $FlowFixMe[incompatible-use]
15141
+
15095
15142
 
15096
15143
  var schema = this.getContext().getSchema();
15097
15144
 
@@ -15323,7 +15370,8 @@ function visitScalarField(field, state) {
15323
15370
 
15324
15371
  if (streamDirective != null) {
15325
15372
  throw createUserError("Invalid use of @stream on scalar field '".concat(field.name, "'"), [streamDirective.loc]);
15326
- }
15373
+ } // $FlowFixMe[incompatible-use]
15374
+
15327
15375
 
15328
15376
  return this.traverse(field, state);
15329
15377
  }
@@ -15453,7 +15501,8 @@ var _require = __webpack_require__(1),
15453
15501
  function visitField(field) {
15454
15502
  if (field.alias === 'id' && field.name !== 'id') {
15455
15503
  throw createUserError('Relay does not allow aliasing fields to `id`. ' + 'This name is reserved for the globally unique `id` field on ' + '`Node`.', [field.loc]);
15456
- }
15504
+ } // $FlowFixMe[incompatible-use]
15505
+
15457
15506
 
15458
15507
  return this.traverse(field);
15459
15508
  }
@@ -15577,6 +15626,7 @@ function fieldHandleTransform(context) {
15577
15626
 
15578
15627
 
15579
15628
  function visitField(field) {
15629
+ // $FlowFixMe[incompatible-use]
15580
15630
  var nextField = field.kind === 'LinkedField' ? this.traverse(field) : field;
15581
15631
  var handles = nextField.handles;
15582
15632
 
@@ -15585,7 +15635,8 @@ function visitField(field) {
15585
15635
  } // ensure exactly one handle
15586
15636
 
15587
15637
 
15588
- !(handles.length === 1) ? true ? invariant(false, 'FieldHandleTransform: Expected fields to have at most one ' + '"handle" property, got `%s`.', handles.join(', ')) : undefined : void 0;
15638
+ !(handles.length === 1) ? true ? invariant(false, 'FieldHandleTransform: Expected fields to have at most one ' + '"handle" property, got `%s`.', handles.join(', ')) : undefined : void 0; // $FlowFixMe[incompatible-use]
15639
+
15589
15640
  var context = this.getContext();
15590
15641
  var schema = context.getSchema();
15591
15642
  var alias = nextField.alias;
@@ -15714,6 +15765,7 @@ module.exports = {
15714
15765
  *
15715
15766
  * @format
15716
15767
  */
15768
+ // TODO: This is only used with `ArgumentValue` types, so it could be simpler.
15717
15769
  // flowlint ambiguous-object-type:error
15718
15770
 
15719
15771
 
@@ -15728,7 +15780,7 @@ var bStackPool = [];
15728
15780
  * @license MIT
15729
15781
  */
15730
15782
 
15731
- function areEqual(a, b) {
15783
+ function areEqualArgValues(a, b) {
15732
15784
  var aStack = aStackPool.length ? aStackPool.pop() : [];
15733
15785
  var bStack = bStackPool.length ? bStackPool.pop() : [];
15734
15786
  var result = eq(a, b, aStack, bStack);
@@ -15752,7 +15804,8 @@ function eq(a, b, aStack, bStack) {
15752
15804
 
15753
15805
  if (typeof a !== 'object' || typeof b !== 'object') {
15754
15806
  return false;
15755
- }
15807
+ } // $FlowFixMe[method-unbinding] added when improving typing for this parameters
15808
+
15756
15809
 
15757
15810
  var objToStr = Object.prototype.toString;
15758
15811
  var className = objToStr.call(a);
@@ -15822,7 +15875,7 @@ function eq(a, b, aStack, bStack) {
15822
15875
  // HACK: Comparing deeply nested React trees is slow since you end up
15823
15876
  // comparing the entire tree (all ancestors and all children) and
15824
15877
  // likely not what you want if you're comparing two elements with
15825
- // areEqual. We bail out here for now.
15878
+ // areEqualArgValues. We bail out here for now.
15826
15879
  continue;
15827
15880
  }
15828
15881
 
@@ -15837,7 +15890,7 @@ function eq(a, b, aStack, bStack) {
15837
15890
  return true;
15838
15891
  }
15839
15892
 
15840
- module.exports = areEqual;
15893
+ module.exports = areEqualArgValues;
15841
15894
 
15842
15895
  /***/ }),
15843
15896
  /* 90 */
@@ -15926,11 +15979,13 @@ function generateIDFieldTransform(context) {
15926
15979
  }
15927
15980
 
15928
15981
  function visitLinkedField(field, state) {
15982
+ // $FlowFixMe[incompatible-use]
15929
15983
  var transformedNode = this.traverse(field, state); // If the field already has an unaliased `id` field, do nothing
15930
15984
 
15931
15985
  if (hasUnaliasedSelection(field, ID)) {
15932
15986
  return transformedNode;
15933
- }
15987
+ } // $FlowFixMe[incompatible-use]
15988
+
15934
15989
 
15935
15990
  var context = this.getContext();
15936
15991
  var schema = context.getSchema();
@@ -16045,8 +16100,10 @@ function generateTypeNameTransform(context) {
16045
16100
  }
16046
16101
 
16047
16102
  function visitFragment(fragment, state) {
16103
+ // $FlowFixMe[incompatible-use]
16048
16104
  var schema = this.getContext().getSchema();
16049
- var rawType = schema.getRawType(fragment.type);
16105
+ var rawType = schema.getRawType(fragment.type); // $FlowFixMe[incompatible-use]
16106
+
16050
16107
  var transformedNode = this.traverse(fragment, state);
16051
16108
  var isClientType = !schema.isServerType(rawType);
16052
16109
 
@@ -16075,6 +16132,7 @@ function visitFragment(fragment, state) {
16075
16132
  }
16076
16133
 
16077
16134
  function visitInlineFragment(fragment, state) {
16135
+ // $FlowFixMe[incompatible-use]
16078
16136
  var schema = this.getContext().getSchema();
16079
16137
  var transformedNode = cache.get(fragment);
16080
16138
 
@@ -16082,7 +16140,8 @@ function visitInlineFragment(fragment, state) {
16082
16140
  return transformedNode;
16083
16141
  }
16084
16142
 
16085
- var rawType = schema.getRawType(fragment.typeCondition);
16143
+ var rawType = schema.getRawType(fragment.typeCondition); // $FlowFixMe[incompatible-use]
16144
+
16086
16145
  transformedNode = this.traverse(fragment, state);
16087
16146
  var isClientType = !schema.isServerType(rawType);
16088
16147
 
@@ -16112,12 +16171,14 @@ function visitInlineFragment(fragment, state) {
16112
16171
  }
16113
16172
 
16114
16173
  function visitLinkedField(field, state) {
16174
+ // $FlowFixMe[incompatible-use]
16115
16175
  var schema = this.getContext().getSchema();
16116
16176
  var transformedNode = cache.get(field);
16117
16177
 
16118
16178
  if (transformedNode != null && transformedNode.kind === 'LinkedField') {
16119
16179
  return transformedNode;
16120
- }
16180
+ } // $FlowFixMe[incompatible-use]
16181
+
16121
16182
 
16122
16183
  transformedNode = this.traverse(field, state);
16123
16184
 
@@ -16178,6 +16239,7 @@ function inlineDataFragmentTransform(context) {
16178
16239
  }
16179
16240
 
16180
16241
  function visitFragment(fragment) {
16242
+ // $FlowFixMe[incompatible-use]
16181
16243
  var transformedFragment = this.traverse(fragment);
16182
16244
  var inlineDirective = transformedFragment.directives.find(function (directive) {
16183
16245
  return directive.name === 'inline';
@@ -16198,7 +16260,9 @@ function visitFragment(fragment) {
16198
16260
  }
16199
16261
 
16200
16262
  function visitFragmentSpread(fragmentSpread) {
16201
- var transformedFragmentSpread = this.traverse(fragmentSpread);
16263
+ // $FlowFixMe[incompatible-use]
16264
+ var transformedFragmentSpread = this.traverse(fragmentSpread); // $FlowFixMe[incompatible-use]
16265
+
16202
16266
  var context = this.getContext();
16203
16267
  var fragment = context.get(transformedFragmentSpread.name);
16204
16268
 
@@ -16214,7 +16278,8 @@ function visitFragmentSpread(fragmentSpread) {
16214
16278
 
16215
16279
  if (transformedFragmentSpread.directives.length > 0) {
16216
16280
  throw createUserError('Directives on fragment spreads for @inline fragments are not yet ' + 'supported', [transformedFragmentSpread.loc]);
16217
- }
16281
+ } // $FlowFixMe[incompatible-use]
16282
+
16218
16283
 
16219
16284
  var transformedFragment = this.visit(fragment);
16220
16285
  return {
@@ -16285,7 +16350,8 @@ function fragmentSpreadVisitor(cache) {
16285
16350
  return traverseResult;
16286
16351
  }
16287
16352
 
16288
- !(fragmentSpread.args.length === 0) ? true ? invariant(false, 'InlineFragmentsTransform: Cannot flatten fragment spread `%s` with ' + 'arguments. Use the `ApplyFragmentArgumentTransform` before flattening', fragmentSpread.name) : undefined : void 0;
16353
+ !(fragmentSpread.args.length === 0) ? true ? invariant(false, 'InlineFragmentsTransform: Cannot flatten fragment spread `%s` with ' + 'arguments. Use the `ApplyFragmentArgumentTransform` before flattening', fragmentSpread.name) : undefined : void 0; // $FlowFixMe[incompatible-use]
16354
+
16289
16355
  var fragment = this.getContext().getFragment(fragmentSpread.name, fragmentSpread.loc);
16290
16356
  var result = {
16291
16357
  kind: 'InlineFragment',
@@ -16297,7 +16363,8 @@ function fragmentSpreadVisitor(cache) {
16297
16363
  metadata: fragmentSpread.metadata,
16298
16364
  selections: fragment.selections,
16299
16365
  typeCondition: fragment.type
16300
- };
16366
+ }; // $FlowFixMe[incompatible-use]
16367
+
16301
16368
  traverseResult = this.traverse(result);
16302
16369
  cache.set(fragmentSpread, traverseResult);
16303
16370
  return traverseResult;
@@ -16449,6 +16516,7 @@ function reactFlightComponentTransform(context) {
16449
16516
  function visitInlineFragment(fragment, state) {
16450
16517
  var _fragment$typeConditi;
16451
16518
 
16519
+ // $FlowFixMe[incompatible-use]
16452
16520
  return this.traverse(fragment, {
16453
16521
  parentType: (_fragment$typeConditi = fragment.typeCondition) !== null && _fragment$typeConditi !== void 0 ? _fragment$typeConditi : state.parentType,
16454
16522
  types: state.types
@@ -16456,6 +16524,7 @@ function visitInlineFragment(fragment, state) {
16456
16524
  }
16457
16525
 
16458
16526
  function visitLinkedField(field, state) {
16527
+ // $FlowFixMe[incompatible-use]
16459
16528
  return this.traverse(field, {
16460
16529
  parentType: field.type,
16461
16530
  types: state.types
@@ -16464,6 +16533,7 @@ function visitLinkedField(field, state) {
16464
16533
 
16465
16534
  function visitScalarField(field, state) {
16466
16535
  // use the return type to quickly determine if this is a flight field
16536
+ // $FlowFixMe[incompatible-use]
16467
16537
  var schema = this.getContext().getSchema();
16468
16538
 
16469
16539
  if (schema.getRawType(field.type) !== state.types.componentType) {
@@ -17241,9 +17311,11 @@ function skipClientExtensionTransform(context) {
17241
17311
  }
17242
17312
 
17243
17313
  function visitFragment(node) {
17314
+ // $FlowFixMe[incompatible-use]
17244
17315
  var context = this.getContext();
17245
17316
 
17246
17317
  if (context.getSchema().isServerType(node.type)) {
17318
+ // $FlowFixMe[incompatible-use]
17247
17319
  return this.traverse(node);
17248
17320
  }
17249
17321
 
@@ -17251,6 +17323,7 @@ function visitFragment(node) {
17251
17323
  }
17252
17324
 
17253
17325
  function vistFragmentSpread(node) {
17326
+ // $FlowFixMe[incompatible-use]
17254
17327
  var context = this.getContext();
17255
17328
  var fragment = context.getFragment(node.name, node.loc);
17256
17329
  var isServer = context.getSchema().isServerType(fragment.type);
@@ -17300,6 +17373,7 @@ function skipHandleFieldTransform(context) {
17300
17373
  }
17301
17374
 
17302
17375
  function visitField(field) {
17376
+ // $FlowFixMe[incompatible-use]
17303
17377
  var transformedNode = this.traverse(field);
17304
17378
 
17305
17379
  if (transformedNode.handles) {
@@ -17450,7 +17524,8 @@ function skipRedundantNodesTransform(context) {
17450
17524
  var cache = new Map();
17451
17525
 
17452
17526
  function visitNode(node) {
17453
- cache = new Map();
17527
+ cache = new Map(); // $FlowFixMe[incompatible-use]
17528
+
17454
17529
  var context = this.getContext();
17455
17530
  return transformNode(context.getSchema(), node, new IMap()).node;
17456
17531
  }
@@ -17549,7 +17624,8 @@ function transformNode(schema, node, selectionMap) {
17549
17624
  if (isEmptySelectionMap) {
17550
17625
  // $FlowFixMe[escaped-generic]
17551
17626
  cache.set(node, result);
17552
- }
17627
+ } // $FlowFixMe[incompatible-return]
17628
+
17553
17629
 
17554
17630
  return result;
17555
17631
  }
@@ -17896,6 +17972,7 @@ function splitMatchTransform(context) {
17896
17972
  }
17897
17973
 
17898
17974
  function visitLinkedField(field, state) {
17975
+ // $FlowFixMe[incompatible-use]
17899
17976
  return this.traverse(field, {
17900
17977
  parentType: field.type,
17901
17978
  splitOperations: state.splitOperations
@@ -17903,6 +17980,7 @@ function visitLinkedField(field, state) {
17903
17980
  }
17904
17981
 
17905
17982
  function visitInlineFragment(fragment, state) {
17983
+ // $FlowFixMe[incompatible-use]
17906
17984
  return this.traverse(fragment, {
17907
17985
  parentType: fragment.typeCondition,
17908
17986
  splitOperations: state.splitOperations
@@ -17919,7 +17997,8 @@ function visitModuleImport(node, state) {
17919
17997
  if (createdSplitOperation) {
17920
17998
  createdSplitOperation.parentSources.add(node.sourceDocument);
17921
17999
  return node;
17922
- }
18000
+ } // $FlowFixMe[incompatible-use]
18001
+
17923
18002
 
17924
18003
  var transformedNode = this.traverse(node, state);
17925
18004
  var splitOperation = {
@@ -17999,6 +18078,7 @@ function getTypeDetails(schema, fieldType) {
17999
18078
  }
18000
18079
 
18001
18080
  function visitRoot(node) {
18081
+ // $FlowFixMe[incompatible-use]
18002
18082
  var schema = this.getContext().getSchema();
18003
18083
  var testDirective = node.directives.find(function (directive) {
18004
18084
  return directive.name === 'relay_test_operation';
@@ -18241,6 +18321,7 @@ function validateRequiredArguments(context) {
18241
18321
 
18242
18322
  function visitDirective(node, _ref) {
18243
18323
  var rootNode = _ref.rootNode;
18324
+ // $FlowFixMe[incompatible-use]
18244
18325
  var context = this.getContext();
18245
18326
  var directiveDef = context.getSchema().getDirective(node.name);
18246
18327
 
@@ -18253,6 +18334,7 @@ function visitDirective(node, _ref) {
18253
18334
 
18254
18335
  function visitInlineFragment(fragment, _ref2) {
18255
18336
  var rootNode = _ref2.rootNode;
18337
+ // $FlowFixMe[incompatible-use]
18256
18338
  this.traverse(fragment, {
18257
18339
  rootNode: rootNode,
18258
18340
  parentType: fragment.typeCondition
@@ -18262,6 +18344,7 @@ function visitInlineFragment(fragment, _ref2) {
18262
18344
  function visitField(node, _ref3) {
18263
18345
  var parentType = _ref3.parentType,
18264
18346
  rootNode = _ref3.rootNode;
18347
+ // $FlowFixMe[incompatible-use]
18265
18348
  var context = this.getContext();
18266
18349
  var schema = context.getSchema();
18267
18350
  var definition = getFieldDefinitionStrict(schema, parentType, node.name);
@@ -18276,7 +18359,8 @@ function visitField(node, _ref3) {
18276
18359
  }
18277
18360
  } else {
18278
18361
  validateRequiredArgumentsOnNode(schema, node, schema.getFieldConfig(definition).args, rootNode);
18279
- }
18362
+ } // $FlowFixMe[incompatible-use]
18363
+
18280
18364
 
18281
18365
  this.traverse(node, {
18282
18366
  rootNode: rootNode,