relay-runtime 12.0.0 → 13.0.0-rc.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (138) hide show
  1. package/handlers/RelayDefaultHandlerProvider.js.flow +2 -2
  2. package/handlers/connection/ConnectionHandler.js.flow +8 -17
  3. package/handlers/connection/MutationHandlers.js.flow +7 -11
  4. package/index.js +1 -1
  5. package/index.js.flow +40 -33
  6. package/lib/handlers/connection/ConnectionHandler.js +12 -18
  7. package/lib/handlers/connection/MutationHandlers.js +3 -6
  8. package/lib/index.js +45 -45
  9. package/lib/multi-actor-environment/ActorSpecificEnvironment.js +8 -4
  10. package/lib/multi-actor-environment/MultiActorEnvironment.js +35 -22
  11. package/lib/multi-actor-environment/index.js +2 -2
  12. package/lib/mutations/RelayDeclarativeMutationConfig.js +4 -1
  13. package/lib/mutations/RelayRecordProxy.js +3 -2
  14. package/lib/mutations/RelayRecordSourceMutator.js +3 -2
  15. package/lib/mutations/RelayRecordSourceProxy.js +12 -4
  16. package/lib/mutations/RelayRecordSourceSelectorProxy.js +12 -4
  17. package/lib/mutations/applyOptimisticMutation.js +6 -6
  18. package/lib/mutations/commitMutation.js +15 -14
  19. package/lib/mutations/readUpdatableQuery_EXPERIMENTAL.js +238 -0
  20. package/lib/mutations/validateMutation.js +6 -6
  21. package/lib/network/ConvertToExecuteFunction.js +2 -1
  22. package/lib/network/RelayNetwork.js +3 -2
  23. package/lib/network/RelayObservable.js +1 -3
  24. package/lib/network/RelayQueryResponseCache.js +2 -2
  25. package/lib/network/wrapNetworkWithLogObserver.js +2 -1
  26. package/lib/query/GraphQLTag.js +2 -1
  27. package/lib/query/fetchQuery.js +6 -5
  28. package/lib/query/fetchQuery_DEPRECATED.js +2 -1
  29. package/lib/store/ClientID.js +7 -1
  30. package/lib/store/DataChecker.js +16 -17
  31. package/lib/store/OperationExecutor.js +13 -13
  32. package/lib/store/RelayConcreteVariables.js +6 -9
  33. package/lib/store/RelayModernEnvironment.js +66 -42
  34. package/lib/store/RelayModernFragmentSpecResolver.js +8 -8
  35. package/lib/store/RelayModernOperationDescriptor.js +2 -1
  36. package/lib/store/RelayModernRecord.js +12 -11
  37. package/lib/store/RelayModernSelector.js +14 -8
  38. package/lib/store/RelayModernStore.js +14 -15
  39. package/lib/store/RelayPublishQueue.js +11 -5
  40. package/lib/store/RelayReader.js +130 -37
  41. package/lib/store/RelayReferenceMarker.js +10 -11
  42. package/lib/store/RelayResponseNormalizer.js +25 -22
  43. package/lib/store/RelayStoreReactFlightUtils.js +3 -3
  44. package/lib/store/RelayStoreSubscriptions.js +6 -4
  45. package/lib/store/RelayStoreUtils.js +5 -5
  46. package/lib/store/ResolverCache.js +6 -6
  47. package/lib/store/ResolverFragments.js +9 -5
  48. package/lib/store/cloneRelayHandleSourceField.js +5 -4
  49. package/lib/store/cloneRelayScalarHandleSourceField.js +5 -4
  50. package/lib/store/createRelayContext.js +3 -1
  51. package/lib/store/readInlineData.js +6 -2
  52. package/lib/subscription/requestSubscription.js +5 -5
  53. package/lib/util/RelayConcreteNode.js +1 -0
  54. package/lib/util/RelayFeatureFlags.js +7 -1
  55. package/lib/util/RelayRuntimeTypes.js +0 -6
  56. package/lib/util/StringInterner.js +71 -0
  57. package/lib/util/getFragmentIdentifier.js +15 -7
  58. package/lib/util/getOperation.js +2 -1
  59. package/lib/util/getPaginationVariables.js +2 -3
  60. package/lib/util/getRelayHandleKey.js +2 -2
  61. package/lib/util/getRequestIdentifier.js +2 -2
  62. package/multi-actor-environment/ActorSpecificEnvironment.js.flow +27 -19
  63. package/multi-actor-environment/ActorUtils.js.flow +2 -2
  64. package/multi-actor-environment/MultiActorEnvironment.js.flow +45 -24
  65. package/multi-actor-environment/MultiActorEnvironmentTypes.js.flow +27 -11
  66. package/multi-actor-environment/index.js.flow +1 -2
  67. package/mutations/RelayDeclarativeMutationConfig.js.flow +32 -26
  68. package/mutations/RelayRecordProxy.js.flow +4 -5
  69. package/mutations/RelayRecordSourceMutator.js.flow +4 -6
  70. package/mutations/RelayRecordSourceProxy.js.flow +19 -10
  71. package/mutations/RelayRecordSourceSelectorProxy.js.flow +15 -5
  72. package/mutations/applyOptimisticMutation.js.flow +13 -14
  73. package/mutations/commitLocalUpdate.js.flow +1 -1
  74. package/mutations/commitMutation.js.flow +35 -48
  75. package/mutations/readUpdatableQuery_EXPERIMENTAL.js.flow +309 -0
  76. package/mutations/validateMutation.js.flow +19 -17
  77. package/network/ConvertToExecuteFunction.js.flow +2 -2
  78. package/network/RelayNetwork.js.flow +4 -5
  79. package/network/RelayObservable.js.flow +1 -3
  80. package/network/RelayQueryResponseCache.js.flow +3 -3
  81. package/network/wrapNetworkWithLogObserver.js.flow +8 -7
  82. package/package.json +1 -1
  83. package/query/GraphQLTag.js.flow +9 -9
  84. package/query/PreloadableQueryRegistry.js.flow +2 -1
  85. package/query/fetchQuery.js.flow +11 -13
  86. package/query/fetchQueryInternal.js.flow +6 -9
  87. package/query/fetchQuery_DEPRECATED.js.flow +6 -6
  88. package/relay-runtime.js +2 -2
  89. package/relay-runtime.min.js +2 -2
  90. package/store/ClientID.js.flow +9 -2
  91. package/store/DataChecker.js.flow +20 -29
  92. package/store/OperationExecutor.js.flow +54 -62
  93. package/store/RelayConcreteVariables.js.flow +4 -10
  94. package/store/RelayModernEnvironment.js.flow +56 -27
  95. package/store/RelayModernFragmentSpecResolver.js.flow +17 -19
  96. package/store/RelayModernOperationDescriptor.js.flow +10 -11
  97. package/store/RelayModernRecord.js.flow +19 -12
  98. package/store/RelayModernSelector.js.flow +24 -14
  99. package/store/RelayModernStore.js.flow +21 -24
  100. package/store/RelayOperationTracker.js.flow +11 -17
  101. package/store/RelayOptimisticRecordSource.js.flow +2 -2
  102. package/store/RelayPublishQueue.js.flow +42 -23
  103. package/store/RelayReader.js.flow +180 -60
  104. package/store/RelayRecordSource.js.flow +2 -2
  105. package/store/RelayReferenceMarker.js.flow +12 -15
  106. package/store/RelayResponseNormalizer.js.flow +43 -41
  107. package/store/RelayStoreReactFlightUtils.js.flow +3 -4
  108. package/store/RelayStoreSubscriptions.js.flow +9 -8
  109. package/store/RelayStoreTypes.js.flow +72 -29
  110. package/store/RelayStoreUtils.js.flow +8 -9
  111. package/store/ResolverCache.js.flow +16 -14
  112. package/store/ResolverFragments.js.flow +15 -22
  113. package/store/StoreInspector.js.flow +2 -2
  114. package/store/TypeID.js.flow +1 -1
  115. package/store/ViewerPattern.js.flow +2 -2
  116. package/store/cloneRelayHandleSourceField.js.flow +5 -6
  117. package/store/cloneRelayScalarHandleSourceField.js.flow +5 -6
  118. package/store/createFragmentSpecResolver.js.flow +3 -4
  119. package/store/createRelayContext.js.flow +2 -2
  120. package/store/normalizeRelayPayload.js.flow +6 -7
  121. package/store/readInlineData.js.flow +7 -8
  122. package/subscription/requestSubscription.js.flow +16 -24
  123. package/util/ReaderNode.js.flow +9 -0
  124. package/util/RelayConcreteNode.js.flow +1 -0
  125. package/util/RelayFeatureFlags.js.flow +14 -2
  126. package/util/RelayReplaySubject.js.flow +2 -3
  127. package/util/RelayRuntimeTypes.js.flow +69 -2
  128. package/util/StringInterner.js.flow +69 -0
  129. package/util/createPayloadFor3DField.js.flow +3 -3
  130. package/util/getFragmentIdentifier.js.flow +27 -15
  131. package/util/getOperation.js.flow +2 -2
  132. package/util/getPaginationMetadata.js.flow +5 -7
  133. package/util/getPaginationVariables.js.flow +5 -9
  134. package/util/getPendingOperationsForFragment.js.flow +2 -2
  135. package/util/getRefetchMetadata.js.flow +6 -7
  136. package/util/getRelayHandleKey.js.flow +1 -2
  137. package/util/getRequestIdentifier.js.flow +3 -3
  138. package/util/resolveImmediate.js.flow +1 -1
@@ -14,14 +14,14 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
14
14
 
15
15
  var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
16
16
 
17
- var RelayConcreteNode = require('../util/RelayConcreteNode');
18
-
19
17
  var getRelayHandleKey = require('../util/getRelayHandleKey');
20
18
 
21
- var invariant = require('invariant');
19
+ var RelayConcreteNode = require('../util/RelayConcreteNode');
22
20
 
23
21
  var stableCopy = require('../util/stableCopy');
24
22
 
23
+ var invariant = require('invariant');
24
+
25
25
  var VARIABLE = RelayConcreteNode.VARIABLE,
26
26
  LITERAL = RelayConcreteNode.LITERAL,
27
27
  OBJECT_VALUE = RelayConcreteNode.OBJECT_VALUE,
@@ -175,8 +175,7 @@ function formatStorageKey(name, argValues) {
175
175
 
176
176
 
177
177
  function getStableVariableValue(name, variables) {
178
- !variables.hasOwnProperty(name) ? process.env.NODE_ENV !== "production" ? invariant(false, 'getVariableValue(): Undefined variable `%s`.', name) : invariant(false) : void 0; // $FlowFixMe[cannot-write]
179
-
178
+ !variables.hasOwnProperty(name) ? process.env.NODE_ENV !== "production" ? invariant(false, 'getVariableValue(): Undefined variable `%s`.', name) : invariant(false) : void 0;
180
179
  return stableCopy(variables[name]);
181
180
  }
182
181
 
@@ -194,6 +193,7 @@ function getModuleOperationKey(documentName) {
194
193
 
195
194
  var RelayStoreUtils = {
196
195
  ACTOR_IDENTIFIER_KEY: '__actorIdentifier',
196
+ CLIENT_EDGE_TRAVERSAL_PATH: '__clientEdgeTraversalPath',
197
197
  FRAGMENTS_KEY: '__fragments',
198
198
  FRAGMENT_OWNER_KEY: '__fragmentOwner',
199
199
  FRAGMENT_PROP_NAME_KEY: '__fragmentPropName',
@@ -14,22 +14,22 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
14
14
 
15
15
  var _createForOfIteratorHelper2 = _interopRequireDefault(require("@babel/runtime/helpers/createForOfIteratorHelper"));
16
16
 
17
- var RelayModernRecord = require('./RelayModernRecord');
18
-
19
17
  var recycleNodesInto = require('../util/recycleNodesInto');
20
18
 
21
- var warning = require("fbjs/lib/warning");
22
-
23
19
  var _require = require('./ClientID'),
24
20
  generateClientID = _require.generateClientID;
25
21
 
22
+ var RelayModernRecord = require('./RelayModernRecord');
23
+
26
24
  var _require2 = require('./RelayStoreUtils'),
27
- RELAY_RESOLVER_VALUE_KEY = _require2.RELAY_RESOLVER_VALUE_KEY,
28
- RELAY_RESOLVER_INVALIDATION_KEY = _require2.RELAY_RESOLVER_INVALIDATION_KEY,
29
25
  RELAY_RESOLVER_INPUTS_KEY = _require2.RELAY_RESOLVER_INPUTS_KEY,
26
+ RELAY_RESOLVER_INVALIDATION_KEY = _require2.RELAY_RESOLVER_INVALIDATION_KEY,
30
27
  RELAY_RESOLVER_READER_SELECTOR_KEY = _require2.RELAY_RESOLVER_READER_SELECTOR_KEY,
28
+ RELAY_RESOLVER_VALUE_KEY = _require2.RELAY_RESOLVER_VALUE_KEY,
31
29
  getStorageKey = _require2.getStorageKey;
32
30
 
31
+ var warning = require("fbjs/lib/warning");
32
+
33
33
  // $FlowFixMe[unclear-type] - will always be empty
34
34
  var emptySet = new Set();
35
35
 
@@ -10,14 +10,18 @@
10
10
  // flowlint ambiguous-object-type:error
11
11
  'use strict';
12
12
 
13
- var invariant = require('invariant');
14
-
15
13
  var _require = require('../query/GraphQLTag'),
16
14
  getFragment = _require.getFragment;
17
15
 
18
16
  var _require2 = require('./RelayModernSelector'),
19
17
  getSelector = _require2.getSelector;
20
18
 
19
+ var invariant = require('invariant'); // When we call the user-supplied resolver function, it will in turn call
20
+ // `readFragment`, but that's a global function -- it needs information
21
+ // about what resolver is being executed, which is supplied by putting the
22
+ // info on this stack before we call the resolver function.
23
+
24
+
21
25
  var contextStack = [];
22
26
 
23
27
  function withResolverContext(context, cb) {
@@ -38,17 +42,17 @@ function withResolverContext(context, cb) {
38
42
  // - array of nullable if the privoided ref type is an array of nullable refs
39
43
 
40
44
 
41
- function readFragment(fragmentInput, fragmentRef) {
45
+ function readFragment(fragmentInput, fragmentKey) {
42
46
  if (!contextStack.length) {
43
47
  throw new Error('readFragment should be called only from within a Relay Resolver function.');
44
48
  }
45
49
 
46
50
  var context = contextStack[contextStack.length - 1];
47
51
  var fragmentNode = getFragment(fragmentInput);
48
- var fragmentSelector = getSelector(fragmentNode, fragmentRef);
52
+ var fragmentSelector = getSelector(fragmentNode, fragmentKey);
49
53
  !(fragmentSelector != null) ? process.env.NODE_ENV !== "production" ? invariant(false, "Expected a selector for the fragment of the resolver ".concat(fragmentNode.name, ", but got null.")) : invariant(false) : void 0;
50
54
  !(fragmentSelector.kind === 'SingularReaderSelector') ? process.env.NODE_ENV !== "production" ? invariant(false, "Expected a singular reader selector for the fragment of the resolver ".concat(fragmentNode.name, ", but it was plural.")) : invariant(false) : void 0;
51
- return context.getDataForResolverFragment(fragmentSelector, fragmentRef);
55
+ return context.getDataForResolverFragment(fragmentSelector, fragmentKey);
52
56
  }
53
57
 
54
58
  module.exports = {
@@ -10,16 +10,15 @@
10
10
  // flowlint ambiguous-object-type:error
11
11
  'use strict';
12
12
 
13
- var areEqual = require("fbjs/lib/areEqual");
14
-
15
- var invariant = require('invariant');
16
-
17
13
  var _require = require('../util/RelayConcreteNode'),
18
14
  LINKED_FIELD = _require.LINKED_FIELD;
19
15
 
20
16
  var _require2 = require('./RelayStoreUtils'),
21
17
  getHandleStorageKey = _require2.getHandleStorageKey;
22
18
 
19
+ var areEqual = require("fbjs/lib/areEqual");
20
+
21
+ var invariant = require('invariant');
23
22
  /**
24
23
  * @private
25
24
  *
@@ -27,6 +26,8 @@ var _require2 = require('./RelayStoreUtils'),
27
26
  * field (on which the handle was declared) among the sibling `selections`, and
28
27
  * copying its selections into the clone.
29
28
  */
29
+
30
+
30
31
  function cloneRelayHandleSourceField(handleField, selections, variables) {
31
32
  var sourceField = selections.find(function (source) {
32
33
  return source.kind === LINKED_FIELD && source.name === handleField.name && source.alias === handleField.alias && areEqual(source.args, handleField.args);
@@ -10,22 +10,23 @@
10
10
  // flowlint ambiguous-object-type:error
11
11
  'use strict';
12
12
 
13
- var areEqual = require("fbjs/lib/areEqual");
14
-
15
- var invariant = require('invariant');
16
-
17
13
  var _require = require('../util/RelayConcreteNode'),
18
14
  SCALAR_FIELD = _require.SCALAR_FIELD;
19
15
 
20
16
  var _require2 = require('./RelayStoreUtils'),
21
17
  getHandleStorageKey = _require2.getHandleStorageKey;
22
18
 
19
+ var areEqual = require("fbjs/lib/areEqual");
20
+
21
+ var invariant = require('invariant');
23
22
  /**
24
23
  * @private
25
24
  *
26
25
  * Creates a clone of the supplied `handleField` by finding the original scalar
27
26
  * field (on which the handle was declared) among the sibling `selections`.
28
27
  */
28
+
29
+
29
30
  function cloneRelayScalarHandleSourceField(handleField, selections, variables) {
30
31
  var sourceField = selections.find(function (source) {
31
32
  return source.kind === SCALAR_FIELD && source.name === handleField.name && source.alias === handleField.alias && areEqual(source.args, handleField.args);
@@ -10,7 +10,9 @@
10
10
  // flowlint ambiguous-object-type:error
11
11
  'use strict';
12
12
 
13
- var invariant = require('invariant');
13
+ var invariant = require('invariant'); // Ideally, we'd just import the type of the react module, but this causes Flow
14
+ // problems.
15
+
14
16
 
15
17
  var relayContext;
16
18
  var firstReact;
@@ -10,14 +10,18 @@
10
10
  // flowlint ambiguous-object-type:error
11
11
  'use strict';
12
12
 
13
- var invariant = require('invariant');
14
-
15
13
  var _require = require('../query/GraphQLTag'),
16
14
  getInlineDataFragment = _require.getInlineDataFragment;
17
15
 
18
16
  var _require2 = require('./RelayStoreUtils'),
19
17
  FRAGMENTS_KEY = _require2.FRAGMENTS_KEY;
20
18
 
19
+ var invariant = require('invariant');
20
+ /**
21
+ * Reads an @inline data fragment that was spread into the parent fragment.
22
+ */
23
+
24
+
21
25
  function readInlineData(fragment, fragmentRef) {
22
26
  var _fragmentRef$FRAGMENT;
23
27
 
@@ -12,10 +12,6 @@
12
12
 
13
13
  var RelayDeclarativeMutationConfig = require('../mutations/RelayDeclarativeMutationConfig');
14
14
 
15
- var RelayFeatureFlags = require('../util/RelayFeatureFlags');
16
-
17
- var warning = require("fbjs/lib/warning");
18
-
19
15
  var _require = require('../query/GraphQLTag'),
20
16
  getRequest = _require.getRequest;
21
17
 
@@ -25,6 +21,10 @@ var _require2 = require('../store/RelayModernOperationDescriptor'),
25
21
  var _require3 = require('../store/RelayModernSelector'),
26
22
  createReaderSelector = _require3.createReaderSelector;
27
23
 
24
+ var RelayFeatureFlags = require('../util/RelayFeatureFlags');
25
+
26
+ var warning = require("fbjs/lib/warning");
27
+
28
28
  function requestSubscription(environment, config) {
29
29
  var subscription = getRequest(config.subscription);
30
30
 
@@ -48,7 +48,7 @@ function requestSubscription(environment, config) {
48
48
  config.updater) : config,
49
49
  updater = _ref.updater;
50
50
 
51
- var sub = environment.execute({
51
+ var sub = environment.executeSubscription({
52
52
  operation: operation,
53
53
  updater: updater
54
54
  }).subscribe({
@@ -27,6 +27,7 @@ var RelayConcreteNode = {
27
27
  ACTOR_CHANGE: 'ActorChange',
28
28
  CONDITION: 'Condition',
29
29
  CLIENT_COMPONENT: 'ClientComponent',
30
+ CLIENT_EDGE: 'ClientEdge',
30
31
  CLIENT_EXTENSION: 'ClientExtension',
31
32
  DEFER: 'Defer',
32
33
  CONNECTION: 'Connection',
@@ -11,6 +11,8 @@
11
11
  'use strict';
12
12
 
13
13
  var RelayFeatureFlags = {
14
+ DELAY_CLEANUP_OF_PENDING_PRELOAD_QUERIES: false,
15
+ ENABLE_CLIENT_EDGES: false,
14
16
  ENABLE_VARIABLE_CONNECTION_KEY: false,
15
17
  ENABLE_PARTIAL_RENDERING_DEFAULT: true,
16
18
  ENABLE_REACT_FLIGHT_COMPONENT_FIELD: false,
@@ -23,6 +25,10 @@ var RelayFeatureFlags = {
23
25
  ENABLE_NOTIFY_SUBSCRIPTION: false,
24
26
  BATCH_ASYNC_MODULE_UPDATES_FN: null,
25
27
  ENABLE_CONTAINERS_SUBSCRIBE_ON_COMMIT: false,
26
- ENABLE_QUERY_RENDERER_OFFSCREEN_SUPPORT: false
28
+ ENABLE_QUERY_RENDERER_OFFSCREEN_SUPPORT: false,
29
+ MAX_DATA_ID_LENGTH: null,
30
+ REFACTOR_SUSPENSE_RESOURCE: true,
31
+ STRING_INTERN_LEVEL: 0,
32
+ USE_REACT_CACHE: false
27
33
  };
28
34
  module.exports = RelayFeatureFlags;
@@ -11,10 +11,4 @@
11
11
  'use strict';
12
12
  /**
13
13
  * Basic types used throughout Relay.
14
- */
15
-
16
- /**
17
- * Represents any resource that must be explicitly disposed of. The most common
18
- * use-case is as a return value for subscriptions, where calling `dispose()`
19
- * would cancel the subscription.
20
14
  */
@@ -0,0 +1,71 @@
1
+ /**
2
+ * Copyright (c) Facebook, Inc. and its affiliates.
3
+ *
4
+ * This source code is licensed under the MIT license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ *
7
+ *
8
+ * @format
9
+ */
10
+ // flowlint ambiguous-object-type:error
11
+ 'use strict';
12
+
13
+ var internTable = new Map();
14
+ var nextIndex = 1;
15
+ var digits = initDigitTable(); // Character used as the prefix for interned strings. The specific character is
16
+ // chosen to reduce the likelihood that non-interned input strings need to be
17
+ // escaped (choosing eg a-Z would increase the likelihood we need to escape)
18
+
19
+ var INTERN_PREFIX = '\t'; // Character used as the prefix of escaped strings. As above, this is also
20
+ // chosen to be unlikely in normal input strings.
21
+
22
+ var ESCAPE_PREFIX = '\v';
23
+
24
+ function initDigitTable() {
25
+ // disable lint because digits isn't defined when this function is called
26
+ // eslint-disable-next-line no-shadow
27
+ var digits = new Set();
28
+
29
+ for (var i = 0; i < 10; ++i) {
30
+ digits.add(i.toString());
31
+ }
32
+
33
+ return digits;
34
+ } // Escape a string so that it cannot conflict with an interned string
35
+
36
+
37
+ function escape(str) {
38
+ if ( // "\t<digit>..." -> "\v\t<digit>..."
39
+ str[0] === INTERN_PREFIX && digits.has(str[1]) || // "\v..." -> "\v\v..."
40
+ str[0] === ESCAPE_PREFIX) {
41
+ return ESCAPE_PREFIX + str;
42
+ }
43
+
44
+ return str;
45
+ } // Interns the input string if its length equals or exceeds the given `limit`,
46
+ // returning a shorter replacement string that is uniquely associated with the
47
+ // input: multiple calls to intern() for the equivalent input strings (and limit)
48
+ // will always return the exact same string.
49
+ // Strings shorter than the limit are not interned but are escaped if they
50
+ // could conflict with interned strings.
51
+
52
+
53
+ function intern(str, limit) {
54
+ if (limit == null || str.length < limit) {
55
+ return escape(str);
56
+ }
57
+
58
+ var internedString = internTable.get(str);
59
+
60
+ if (internedString != null) {
61
+ return internedString;
62
+ }
63
+
64
+ internedString = INTERN_PREFIX + nextIndex++;
65
+ internTable.set(str, internedString);
66
+ return internedString;
67
+ }
68
+
69
+ module.exports = {
70
+ intern: intern
71
+ };
@@ -11,16 +11,19 @@
11
11
  // flowlint ambiguous-object-type:error
12
12
  'use strict';
13
13
 
14
- var RelayFeatureFlags = require('./RelayFeatureFlags');
14
+ var _require = require('../store/RelayModernSelector'),
15
+ getDataIDsFromFragment = _require.getDataIDsFromFragment,
16
+ getSelector = _require.getSelector,
17
+ getVariablesFromFragment = _require.getVariablesFromFragment;
15
18
 
16
19
  var isEmptyObject = require('./isEmptyObject');
17
20
 
21
+ var RelayFeatureFlags = require('./RelayFeatureFlags');
22
+
18
23
  var stableCopy = require('./stableCopy');
19
24
 
20
- var _require = require('../store/RelayModernSelector'),
21
- getDataIDsFromFragment = _require.getDataIDsFromFragment,
22
- getVariablesFromFragment = _require.getVariablesFromFragment,
23
- getSelector = _require.getSelector;
25
+ var _require2 = require('./StringInterner'),
26
+ intern = _require2.intern;
24
27
 
25
28
  function getFragmentIdentifier(fragmentNode, fragmentRef) {
26
29
  var selector = getSelector(fragmentNode, fragmentRef);
@@ -31,11 +34,16 @@ function getFragmentIdentifier(fragmentNode, fragmentRef) {
31
34
  var dataIDs = getDataIDsFromFragment(fragmentNode, fragmentRef);
32
35
 
33
36
  if (RelayFeatureFlags.ENABLE_GETFRAGMENTIDENTIFIER_OPTIMIZATION) {
34
- return fragmentOwnerIdentifier + '/' + fragmentNode.name + '/' + (fragmentVariables == null || isEmptyObject(fragmentVariables) ? '{}' : JSON.stringify(stableCopy(fragmentVariables))) + '/' + (typeof dataIDs === 'undefined' ? 'missing' : dataIDs == null ? 'null' : Array.isArray(dataIDs) ? '[' + dataIDs.join(',') + ']' : dataIDs);
37
+ var ids = typeof dataIDs === 'undefined' ? 'missing' : dataIDs == null ? 'null' : Array.isArray(dataIDs) ? '[' + dataIDs.join(',') + ']' : dataIDs;
38
+ ids = RelayFeatureFlags.STRING_INTERN_LEVEL <= 1 ? ids : intern(ids, RelayFeatureFlags.MAX_DATA_ID_LENGTH);
39
+ return fragmentOwnerIdentifier + '/' + fragmentNode.name + '/' + (fragmentVariables == null || isEmptyObject(fragmentVariables) ? '{}' : JSON.stringify(stableCopy(fragmentVariables))) + '/' + ids;
35
40
  } else {
36
41
  var _JSON$stringify;
37
42
 
38
- return fragmentOwnerIdentifier + '/' + fragmentNode.name + '/' + JSON.stringify(stableCopy(fragmentVariables)) + '/' + ((_JSON$stringify = JSON.stringify(dataIDs)) !== null && _JSON$stringify !== void 0 ? _JSON$stringify : 'missing');
43
+ var _ids = (_JSON$stringify = JSON.stringify(dataIDs)) !== null && _JSON$stringify !== void 0 ? _JSON$stringify : 'missing';
44
+
45
+ _ids = RelayFeatureFlags.STRING_INTERN_LEVEL <= 1 ? _ids : intern(_ids, RelayFeatureFlags.MAX_DATA_ID_LENGTH);
46
+ return fragmentOwnerIdentifier + '/' + fragmentNode.name + '/' + JSON.stringify(stableCopy(fragmentVariables)) + '/' + _ids;
39
47
  }
40
48
  }
41
49
 
@@ -14,11 +14,12 @@
14
14
  var _require = require('./RelayConcreteNode'),
15
15
  REQUEST = _require.REQUEST,
16
16
  SPLIT_OPERATION = _require.SPLIT_OPERATION;
17
-
18
17
  /**
19
18
  * OperationLoaders can return either a NormalizationSplitOperation or
20
19
  * ConcreteRequest.
21
20
  */
21
+
22
+
22
23
  function getOperation(node) {
23
24
  switch (node.kind) {
24
25
  case REQUEST:
@@ -32,7 +32,7 @@ function getPaginationVariables(direction, count, cursor, baseVariables, extraVa
32
32
 
33
33
  !(backwardMetadata != null && backwardMetadata.count != null && backwardMetadata.cursor != null) ? process.env.NODE_ENV !== "production" ? invariant(false, 'Relay: Expected backward pagination metadata to be available. ' + "If you're seeing this, this is likely a bug in Relay.") : invariant(false) : void 0;
34
34
  process.env.NODE_ENV !== "production" ? warning(!extraVariables.hasOwnProperty(backwardMetadata.cursor), 'Relay: `UNSTABLE_extraVariables` provided by caller should not ' + 'contain cursor variable `%s`. This variable is automatically ' + 'determined by Relay.', backwardMetadata.cursor) : void 0;
35
- process.env.NODE_ENV !== "production" ? warning(!extraVariables.hasOwnProperty(backwardMetadata.count), 'Relay: `UNSTABLE_extraVariables` provided by caller should not ' + 'contain count variable `%s`. This variable is automatically ' + 'determined by Relay.', backwardMetadata.count) : void 0; // $FlowFixMe[cannot-spread-interface]
35
+ process.env.NODE_ENV !== "production" ? warning(!extraVariables.hasOwnProperty(backwardMetadata.count), 'Relay: `UNSTABLE_extraVariables` provided by caller should not ' + 'contain count variable `%s`. This variable is automatically ' + 'determined by Relay.', backwardMetadata.count) : void 0;
36
36
 
37
37
  var _paginationVariables = (0, _objectSpread4["default"])((0, _objectSpread4["default"])((0, _objectSpread4["default"])({}, baseVariables), extraVariables), {}, (_objectSpread2 = {}, (0, _defineProperty2["default"])(_objectSpread2, backwardMetadata.cursor, cursor), (0, _defineProperty2["default"])(_objectSpread2, backwardMetadata.count, count), _objectSpread2));
38
38
 
@@ -49,8 +49,7 @@ function getPaginationVariables(direction, count, cursor, baseVariables, extraVa
49
49
 
50
50
  !(forwardMetadata != null && forwardMetadata.count != null && forwardMetadata.cursor != null) ? process.env.NODE_ENV !== "production" ? invariant(false, 'Relay: Expected forward pagination metadata to be available. ' + "If you're seeing this, this is likely a bug in Relay.") : invariant(false) : void 0;
51
51
  process.env.NODE_ENV !== "production" ? warning(!extraVariables.hasOwnProperty(forwardMetadata.cursor), 'Relay: `UNSTABLE_extraVariables` provided by caller should not ' + 'contain cursor variable `%s`. This variable is automatically ' + 'determined by Relay.', forwardMetadata.cursor) : void 0;
52
- process.env.NODE_ENV !== "production" ? warning(!extraVariables.hasOwnProperty(forwardMetadata.count), 'Relay: `UNSTABLE_extraVariables` provided by caller should not ' + 'contain count variable `%s`. This variable is automatically ' + 'determined by Relay.', forwardMetadata.count) : void 0; // $FlowFixMe[cannot-spread-interface]
53
-
52
+ process.env.NODE_ENV !== "production" ? warning(!extraVariables.hasOwnProperty(forwardMetadata.count), 'Relay: `UNSTABLE_extraVariables` provided by caller should not ' + 'contain count variable `%s`. This variable is automatically ' + 'determined by Relay.', forwardMetadata.count) : void 0;
54
53
  var paginationVariables = (0, _objectSpread4["default"])((0, _objectSpread4["default"])((0, _objectSpread4["default"])({}, baseVariables), extraVariables), {}, (_objectSpread3 = {}, (0, _defineProperty2["default"])(_objectSpread3, forwardMetadata.cursor, cursor), (0, _defineProperty2["default"])(_objectSpread3, forwardMetadata.count, count), _objectSpread3));
55
54
 
56
55
  if (backwardMetadata && backwardMetadata.cursor) {
@@ -10,10 +10,10 @@
10
10
  // flowlint ambiguous-object-type:error
11
11
  'use strict';
12
12
 
13
- var invariant = require('invariant');
14
-
15
13
  var _require = require('./RelayDefaultHandleKey'),
16
14
  DEFAULT_HANDLE_KEY = _require.DEFAULT_HANDLE_KEY;
15
+
16
+ var invariant = require('invariant');
17
17
  /**
18
18
  * @internal
19
19
  *
@@ -10,10 +10,10 @@
10
10
  // flowlint ambiguous-object-type:error
11
11
  'use strict';
12
12
 
13
- var invariant = require('invariant');
14
-
15
13
  var stableCopy = require('./stableCopy');
16
14
 
15
+ var invariant = require('invariant');
16
+
17
17
  /**
18
18
  * Returns a stable identifier for the given pair of `RequestParameters` +
19
19
  * variables.
@@ -11,31 +11,25 @@
11
11
 
12
12
  'use strict';
13
13
 
14
- const RelayOperationTracker = require('../store/RelayOperationTracker');
15
- const RelayPublishQueue = require('../store/RelayPublishQueue');
16
-
17
- const defaultGetDataID = require('../store/defaultGetDataID');
18
- const registerEnvironmentWithDevTools = require('../util/registerEnvironmentWithDevTools');
19
- const wrapNetworkWithLogObserver = require('../network/wrapNetworkWithLogObserver');
20
-
21
14
  import type {HandlerProvider} from '../handlers/RelayDefaultHandlerProvider';
22
15
  import type {GraphQLResponse, PayloadData} from '../network/RelayNetworkTypes';
23
16
  import type {INetwork} from '../network/RelayNetworkTypes';
24
17
  import type RelayObservable from '../network/RelayObservable';
25
18
  import type {
19
+ ExecuteMutationConfig,
20
+ LogFunction,
21
+ MutationParameters,
22
+ OperationAvailability,
23
+ OperationDescriptor,
24
+ OperationTracker,
26
25
  OptimisticResponseConfig,
27
26
  OptimisticUpdateFunction,
28
- OperationDescriptor,
29
- OperationAvailability,
30
- Snapshot,
27
+ RequiredFieldLogger,
31
28
  SelectorStoreUpdater,
32
29
  SingularReaderSelector,
33
- StoreUpdater,
34
- RequiredFieldLogger,
35
- ExecuteMutationConfig,
36
- LogFunction,
30
+ Snapshot,
37
31
  Store,
38
- OperationTracker,
32
+ StoreUpdater,
39
33
  } from '../store/RelayStoreTypes';
40
34
  import type {Disposable, RenderPolicy} from '../util/RelayRuntimeTypes';
41
35
  import type {ActorIdentifier} from './ActorIdentifier';
@@ -44,6 +38,12 @@ import type {
44
38
  IMultiActorEnvironment,
45
39
  } from './MultiActorEnvironmentTypes';
46
40
 
41
+ const wrapNetworkWithLogObserver = require('../network/wrapNetworkWithLogObserver');
42
+ const defaultGetDataID = require('../store/defaultGetDataID');
43
+ const RelayOperationTracker = require('../store/RelayOperationTracker');
44
+ const RelayPublishQueue = require('../store/RelayPublishQueue');
45
+ const registerEnvironmentWithDevTools = require('../util/registerEnvironmentWithDevTools');
46
+
47
47
  export type ActorSpecificEnvironmentConfig = $ReadOnly<{
48
48
  actorIdentifier: ActorIdentifier,
49
49
  configName: ?string,
@@ -113,7 +113,9 @@ class ActorSpecificEnvironment implements IActorEnvironment {
113
113
  return this._defaultRenderPolicy;
114
114
  }
115
115
 
116
- applyMutation(optimisticConfig: OptimisticResponseConfig): Disposable {
116
+ applyMutation<TMutation: MutationParameters>(
117
+ optimisticConfig: OptimisticResponseConfig<TMutation>,
118
+ ): Disposable {
117
119
  return this.multiActorEnvironment.applyMutation(this, optimisticConfig);
118
120
  }
119
121
 
@@ -187,13 +189,19 @@ class ActorSpecificEnvironment implements IActorEnvironment {
187
189
 
188
190
  execute(config: {
189
191
  operation: OperationDescriptor,
190
- updater?: ?SelectorStoreUpdater,
191
192
  }): RelayObservable<GraphQLResponse> {
192
193
  return this.multiActorEnvironment.execute(this, config);
193
194
  }
194
195
 
195
- executeMutation(
196
- options: ExecuteMutationConfig,
196
+ executeSubscription<TMutation: MutationParameters>(config: {
197
+ operation: OperationDescriptor,
198
+ updater?: ?SelectorStoreUpdater<TMutation['response']>,
199
+ }): RelayObservable<GraphQLResponse> {
200
+ return this.multiActorEnvironment.executeSubscription(this, config);
201
+ }
202
+
203
+ executeMutation<TMutation: MutationParameters>(
204
+ options: ExecuteMutationConfig<TMutation>,
197
205
  ): RelayObservable<GraphQLResponse> {
198
206
  return this.multiActorEnvironment.executeMutation(this, options);
199
207
  }
@@ -13,10 +13,10 @@
13
13
 
14
14
  const ACTOR_IDENTIFIER_FIELD_NAME = 'actor_key';
15
15
 
16
- const {getActorIdentifier} = require('./ActorIdentifier');
17
-
18
16
  import type {ActorIdentifier} from './ActorIdentifier';
19
17
 
18
+ const {getActorIdentifier} = require('./ActorIdentifier');
19
+
20
20
  function getActorIdentifierFromPayload(payload: mixed): ?ActorIdentifier {
21
21
  if (
22
22
  payload != null &&