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.
- package/handlers/RelayDefaultHandlerProvider.js.flow +2 -2
- package/handlers/connection/ConnectionHandler.js.flow +8 -17
- package/handlers/connection/MutationHandlers.js.flow +7 -11
- package/index.js +1 -1
- package/index.js.flow +40 -33
- package/lib/handlers/connection/ConnectionHandler.js +12 -18
- package/lib/handlers/connection/MutationHandlers.js +3 -6
- package/lib/index.js +45 -45
- package/lib/multi-actor-environment/ActorSpecificEnvironment.js +8 -4
- package/lib/multi-actor-environment/MultiActorEnvironment.js +35 -22
- package/lib/multi-actor-environment/index.js +2 -2
- package/lib/mutations/RelayDeclarativeMutationConfig.js +4 -1
- package/lib/mutations/RelayRecordProxy.js +3 -2
- package/lib/mutations/RelayRecordSourceMutator.js +3 -2
- package/lib/mutations/RelayRecordSourceProxy.js +12 -4
- package/lib/mutations/RelayRecordSourceSelectorProxy.js +12 -4
- package/lib/mutations/applyOptimisticMutation.js +6 -6
- package/lib/mutations/commitMutation.js +15 -14
- package/lib/mutations/readUpdatableQuery_EXPERIMENTAL.js +238 -0
- package/lib/mutations/validateMutation.js +6 -6
- package/lib/network/ConvertToExecuteFunction.js +2 -1
- package/lib/network/RelayNetwork.js +3 -2
- package/lib/network/RelayObservable.js +1 -3
- package/lib/network/RelayQueryResponseCache.js +2 -2
- package/lib/network/wrapNetworkWithLogObserver.js +2 -1
- package/lib/query/GraphQLTag.js +2 -1
- package/lib/query/fetchQuery.js +6 -5
- package/lib/query/fetchQuery_DEPRECATED.js +2 -1
- package/lib/store/ClientID.js +7 -1
- package/lib/store/DataChecker.js +16 -17
- package/lib/store/OperationExecutor.js +13 -13
- package/lib/store/RelayConcreteVariables.js +6 -9
- package/lib/store/RelayModernEnvironment.js +66 -42
- package/lib/store/RelayModernFragmentSpecResolver.js +8 -8
- package/lib/store/RelayModernOperationDescriptor.js +2 -1
- package/lib/store/RelayModernRecord.js +12 -11
- package/lib/store/RelayModernSelector.js +14 -8
- package/lib/store/RelayModernStore.js +14 -15
- package/lib/store/RelayPublishQueue.js +11 -5
- package/lib/store/RelayReader.js +130 -37
- package/lib/store/RelayReferenceMarker.js +10 -11
- package/lib/store/RelayResponseNormalizer.js +25 -22
- package/lib/store/RelayStoreReactFlightUtils.js +3 -3
- package/lib/store/RelayStoreSubscriptions.js +6 -4
- package/lib/store/RelayStoreUtils.js +5 -5
- package/lib/store/ResolverCache.js +6 -6
- package/lib/store/ResolverFragments.js +9 -5
- package/lib/store/cloneRelayHandleSourceField.js +5 -4
- package/lib/store/cloneRelayScalarHandleSourceField.js +5 -4
- package/lib/store/createRelayContext.js +3 -1
- package/lib/store/readInlineData.js +6 -2
- package/lib/subscription/requestSubscription.js +5 -5
- package/lib/util/RelayConcreteNode.js +1 -0
- package/lib/util/RelayFeatureFlags.js +7 -1
- package/lib/util/RelayRuntimeTypes.js +0 -6
- package/lib/util/StringInterner.js +71 -0
- package/lib/util/getFragmentIdentifier.js +15 -7
- package/lib/util/getOperation.js +2 -1
- package/lib/util/getPaginationVariables.js +2 -3
- package/lib/util/getRelayHandleKey.js +2 -2
- package/lib/util/getRequestIdentifier.js +2 -2
- package/multi-actor-environment/ActorSpecificEnvironment.js.flow +27 -19
- package/multi-actor-environment/ActorUtils.js.flow +2 -2
- package/multi-actor-environment/MultiActorEnvironment.js.flow +45 -24
- package/multi-actor-environment/MultiActorEnvironmentTypes.js.flow +27 -11
- package/multi-actor-environment/index.js.flow +1 -2
- package/mutations/RelayDeclarativeMutationConfig.js.flow +32 -26
- package/mutations/RelayRecordProxy.js.flow +4 -5
- package/mutations/RelayRecordSourceMutator.js.flow +4 -6
- package/mutations/RelayRecordSourceProxy.js.flow +19 -10
- package/mutations/RelayRecordSourceSelectorProxy.js.flow +15 -5
- package/mutations/applyOptimisticMutation.js.flow +13 -14
- package/mutations/commitLocalUpdate.js.flow +1 -1
- package/mutations/commitMutation.js.flow +35 -48
- package/mutations/readUpdatableQuery_EXPERIMENTAL.js.flow +309 -0
- package/mutations/validateMutation.js.flow +19 -17
- package/network/ConvertToExecuteFunction.js.flow +2 -2
- package/network/RelayNetwork.js.flow +4 -5
- package/network/RelayObservable.js.flow +1 -3
- package/network/RelayQueryResponseCache.js.flow +3 -3
- package/network/wrapNetworkWithLogObserver.js.flow +8 -7
- package/package.json +1 -1
- package/query/GraphQLTag.js.flow +9 -9
- package/query/PreloadableQueryRegistry.js.flow +2 -1
- package/query/fetchQuery.js.flow +11 -13
- package/query/fetchQueryInternal.js.flow +6 -9
- package/query/fetchQuery_DEPRECATED.js.flow +6 -6
- package/relay-runtime.js +2 -2
- package/relay-runtime.min.js +2 -2
- package/store/ClientID.js.flow +9 -2
- package/store/DataChecker.js.flow +20 -29
- package/store/OperationExecutor.js.flow +54 -62
- package/store/RelayConcreteVariables.js.flow +4 -10
- package/store/RelayModernEnvironment.js.flow +56 -27
- package/store/RelayModernFragmentSpecResolver.js.flow +17 -19
- package/store/RelayModernOperationDescriptor.js.flow +10 -11
- package/store/RelayModernRecord.js.flow +19 -12
- package/store/RelayModernSelector.js.flow +24 -14
- package/store/RelayModernStore.js.flow +21 -24
- package/store/RelayOperationTracker.js.flow +11 -17
- package/store/RelayOptimisticRecordSource.js.flow +2 -2
- package/store/RelayPublishQueue.js.flow +42 -23
- package/store/RelayReader.js.flow +180 -60
- package/store/RelayRecordSource.js.flow +2 -2
- package/store/RelayReferenceMarker.js.flow +12 -15
- package/store/RelayResponseNormalizer.js.flow +43 -41
- package/store/RelayStoreReactFlightUtils.js.flow +3 -4
- package/store/RelayStoreSubscriptions.js.flow +9 -8
- package/store/RelayStoreTypes.js.flow +72 -29
- package/store/RelayStoreUtils.js.flow +8 -9
- package/store/ResolverCache.js.flow +16 -14
- package/store/ResolverFragments.js.flow +15 -22
- package/store/StoreInspector.js.flow +2 -2
- package/store/TypeID.js.flow +1 -1
- package/store/ViewerPattern.js.flow +2 -2
- package/store/cloneRelayHandleSourceField.js.flow +5 -6
- package/store/cloneRelayScalarHandleSourceField.js.flow +5 -6
- package/store/createFragmentSpecResolver.js.flow +3 -4
- package/store/createRelayContext.js.flow +2 -2
- package/store/normalizeRelayPayload.js.flow +6 -7
- package/store/readInlineData.js.flow +7 -8
- package/subscription/requestSubscription.js.flow +16 -24
- package/util/ReaderNode.js.flow +9 -0
- package/util/RelayConcreteNode.js.flow +1 -0
- package/util/RelayFeatureFlags.js.flow +14 -2
- package/util/RelayReplaySubject.js.flow +2 -3
- package/util/RelayRuntimeTypes.js.flow +69 -2
- package/util/StringInterner.js.flow +69 -0
- package/util/createPayloadFor3DField.js.flow +3 -3
- package/util/getFragmentIdentifier.js.flow +27 -15
- package/util/getOperation.js.flow +2 -2
- package/util/getPaginationMetadata.js.flow +5 -7
- package/util/getPaginationVariables.js.flow +5 -9
- package/util/getPendingOperationsForFragment.js.flow +2 -2
- package/util/getRefetchMetadata.js.flow +6 -7
- package/util/getRelayHandleKey.js.flow +1 -2
- package/util/getRequestIdentifier.js.flow +3 -3
- 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
|
|
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;
|
|
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,
|
|
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,
|
|
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,
|
|
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.
|
|
51
|
+
var sub = environment.executeSubscription({
|
|
52
52
|
operation: operation,
|
|
53
53
|
updater: updater
|
|
54
54
|
}).subscribe({
|
|
@@ -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
|
|
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
|
|
21
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
|
package/lib/util/getOperation.js
CHANGED
|
@@ -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;
|
|
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;
|
|
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
|
-
|
|
29
|
-
OperationAvailability,
|
|
30
|
-
Snapshot,
|
|
27
|
+
RequiredFieldLogger,
|
|
31
28
|
SelectorStoreUpdater,
|
|
32
29
|
SingularReaderSelector,
|
|
33
|
-
|
|
34
|
-
RequiredFieldLogger,
|
|
35
|
-
ExecuteMutationConfig,
|
|
36
|
-
LogFunction,
|
|
30
|
+
Snapshot,
|
|
37
31
|
Store,
|
|
38
|
-
|
|
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
|
|
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
|
-
|
|
196
|
-
|
|
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 &&
|