relay-runtime 0.0.0-main-e0f88a3b → 0.0.0-main-2087b512
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 -3
- package/handlers/connection/ConnectionHandler.js.flow +8 -10
- package/handlers/connection/MutationHandlers.js.flow +7 -8
- package/index.js +1 -1
- package/index.js.flow +29 -31
- package/lib/handlers/connection/ConnectionHandler.js +7 -7
- package/lib/index.js +45 -45
- package/lib/multi-actor-environment/ActorSpecificEnvironment.js +4 -4
- package/lib/multi-actor-environment/MultiActorEnvironment.js +8 -8
- package/lib/multi-actor-environment/index.js +2 -2
- package/lib/mutations/RelayRecordProxy.js +3 -2
- package/lib/mutations/RelayRecordSourceMutator.js +3 -2
- package/lib/mutations/RelayRecordSourceProxy.js +5 -4
- package/lib/mutations/RelayRecordSourceSelectorProxy.js +5 -4
- package/lib/mutations/applyOptimisticMutation.js +6 -6
- package/lib/mutations/commitMutation.js +10 -10
- package/lib/mutations/validateMutation.js +6 -6
- package/lib/network/ConvertToExecuteFunction.js +2 -1
- package/lib/network/RelayNetwork.js +3 -2
- 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 +4 -4
- package/lib/store/DataChecker.js +15 -15
- package/lib/store/OperationExecutor.js +13 -13
- package/lib/store/RelayConcreteVariables.js +3 -2
- package/lib/store/RelayModernEnvironment.js +11 -11
- 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 +7 -6
- package/lib/store/RelayModernStore.js +13 -13
- package/lib/store/RelayPublishQueue.js +4 -4
- package/lib/store/RelayReader.js +12 -12
- package/lib/store/RelayReferenceMarker.js +9 -9
- package/lib/store/RelayResponseNormalizer.js +19 -19
- package/lib/store/RelayStoreReactFlightUtils.js +3 -3
- package/lib/store/RelayStoreSubscriptions.js +4 -4
- package/lib/store/RelayStoreUtils.js +3 -3
- package/lib/store/ResolverCache.js +6 -6
- package/lib/store/ResolverFragments.js +6 -2
- 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 +4 -4
- package/lib/util/RelayFeatureFlags.js +1 -0
- package/lib/util/StringInterner.js +57 -0
- package/lib/util/getFragmentIdentifier.js +10 -10
- package/lib/util/getOperation.js +2 -1
- package/lib/util/getRelayHandleKey.js +2 -2
- package/lib/util/getRequestIdentifier.js +2 -2
- package/multi-actor-environment/ActorSpecificEnvironment.js.flow +14 -15
- package/multi-actor-environment/ActorUtils.js.flow +2 -2
- package/multi-actor-environment/MultiActorEnvironment.js.flow +9 -10
- package/multi-actor-environment/MultiActorEnvironmentTypes.js.flow +4 -4
- package/multi-actor-environment/index.js.flow +1 -2
- package/mutations/RelayDeclarativeMutationConfig.js.flow +3 -4
- package/mutations/RelayRecordProxy.js.flow +4 -5
- package/mutations/RelayRecordSourceMutator.js.flow +4 -6
- package/mutations/RelayRecordSourceProxy.js.flow +7 -9
- package/mutations/RelayRecordSourceSelectorProxy.js.flow +3 -4
- package/mutations/applyOptimisticMutation.js.flow +8 -10
- package/mutations/commitLocalUpdate.js.flow +1 -1
- package/mutations/commitMutation.js.flow +12 -19
- package/mutations/validateMutation.js.flow +14 -16
- package/network/ConvertToExecuteFunction.js.flow +2 -2
- package/network/RelayNetwork.js.flow +4 -5
- package/network/RelayQueryResponseCache.js.flow +3 -3
- package/network/wrapNetworkWithLogObserver.js.flow +3 -3
- package/package.json +1 -1
- package/query/GraphQLTag.js.flow +6 -7
- package/query/fetchQuery.js.flow +9 -11
- package/query/fetchQueryInternal.js.flow +4 -5
- package/query/fetchQuery_DEPRECATED.js.flow +4 -4
- package/relay-runtime.js +2 -2
- package/relay-runtime.min.js +2 -2
- package/store/ClientID.js.flow +8 -6
- package/store/DataChecker.js.flow +16 -18
- package/store/OperationExecutor.js.flow +24 -26
- package/store/RelayConcreteVariables.js.flow +4 -5
- package/store/RelayModernEnvironment.js.flow +17 -19
- package/store/RelayModernFragmentSpecResolver.js.flow +16 -18
- package/store/RelayModernOperationDescriptor.js.flow +10 -11
- package/store/RelayModernRecord.js.flow +19 -12
- package/store/RelayModernSelector.js.flow +11 -12
- package/store/RelayModernStore.js.flow +21 -23
- package/store/RelayOperationTracker.js.flow +2 -2
- package/store/RelayOptimisticRecordSource.js.flow +2 -2
- package/store/RelayPublishQueue.js.flow +8 -9
- package/store/RelayReader.js.flow +33 -35
- package/store/RelayRecordSource.js.flow +2 -2
- package/store/RelayReferenceMarker.js.flow +12 -14
- package/store/RelayResponseNormalizer.js.flow +36 -38
- package/store/RelayStoreReactFlightUtils.js.flow +3 -4
- package/store/RelayStoreSubscriptions.js.flow +7 -8
- package/store/RelayStoreTypes.js.flow +9 -3
- package/store/RelayStoreUtils.js.flow +7 -8
- package/store/ResolverCache.js.flow +11 -13
- package/store/ResolverFragments.js.flow +4 -5
- 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 +3 -4
- package/subscription/requestSubscription.js.flow +9 -11
- package/util/RelayFeatureFlags.js.flow +2 -0
- package/util/RelayReplaySubject.js.flow +2 -3
- package/util/StringInterner.js.flow +57 -0
- package/util/createPayloadFor3DField.js.flow +3 -3
- package/util/getFragmentIdentifier.js.flow +14 -10
- package/util/getOperation.js.flow +2 -2
- package/util/getPaginationMetadata.js.flow +3 -3
- package/util/getPaginationVariables.js.flow +3 -3
- package/util/getPendingOperationsForFragment.js.flow +2 -2
- package/util/getRefetchMetadata.js.flow +2 -2
- package/util/getRelayHandleKey.js.flow +1 -2
- package/util/getRequestIdentifier.js.flow +3 -3
- package/lib/util/shortString.js +0 -63
- package/util/shortString.js.flow +0 -62
|
@@ -16,25 +16,15 @@ var _createForOfIteratorHelper2 = _interopRequireDefault(require("@babel/runtime
|
|
|
16
16
|
|
|
17
17
|
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
18
18
|
|
|
19
|
-
var RelayFeatureFlags = require('../util/RelayFeatureFlags');
|
|
20
|
-
|
|
21
|
-
var RelayModernRecord = require('./RelayModernRecord');
|
|
22
|
-
|
|
23
|
-
var areEqual = require("fbjs/lib/areEqual");
|
|
24
|
-
|
|
25
|
-
var invariant = require('invariant');
|
|
26
|
-
|
|
27
|
-
var warning = require("fbjs/lib/warning");
|
|
28
|
-
|
|
29
19
|
var _require = require('../multi-actor-environment/ActorUtils'),
|
|
30
20
|
ACTOR_IDENTIFIER_FIELD_NAME = _require.ACTOR_IDENTIFIER_FIELD_NAME,
|
|
31
21
|
getActorIdentifierFromPayload = _require.getActorIdentifierFromPayload;
|
|
32
22
|
|
|
33
23
|
var _require2 = require('../util/RelayConcreteNode'),
|
|
34
24
|
ACTOR_CHANGE = _require2.ACTOR_CHANGE,
|
|
35
|
-
CONDITION = _require2.CONDITION,
|
|
36
25
|
CLIENT_COMPONENT = _require2.CLIENT_COMPONENT,
|
|
37
26
|
CLIENT_EXTENSION = _require2.CLIENT_EXTENSION,
|
|
27
|
+
CONDITION = _require2.CONDITION,
|
|
38
28
|
DEFER = _require2.DEFER,
|
|
39
29
|
FLIGHT_FIELD = _require2.FLIGHT_FIELD,
|
|
40
30
|
FRAGMENT_SPREAD = _require2.FRAGMENT_SPREAD,
|
|
@@ -47,6 +37,8 @@ var _require2 = require('../util/RelayConcreteNode'),
|
|
|
47
37
|
STREAM = _require2.STREAM,
|
|
48
38
|
TYPE_DISCRIMINATOR = _require2.TYPE_DISCRIMINATOR;
|
|
49
39
|
|
|
40
|
+
var RelayFeatureFlags = require('../util/RelayFeatureFlags');
|
|
41
|
+
|
|
50
42
|
var _require3 = require('./ClientID'),
|
|
51
43
|
generateClientID = _require3.generateClientID,
|
|
52
44
|
isClientID = _require3.isClientID;
|
|
@@ -54,28 +46,36 @@ var _require3 = require('./ClientID'),
|
|
|
54
46
|
var _require4 = require('./RelayConcreteVariables'),
|
|
55
47
|
getLocalVariables = _require4.getLocalVariables;
|
|
56
48
|
|
|
49
|
+
var RelayModernRecord = require('./RelayModernRecord');
|
|
50
|
+
|
|
57
51
|
var _require5 = require('./RelayModernSelector'),
|
|
58
52
|
createNormalizationSelector = _require5.createNormalizationSelector;
|
|
59
53
|
|
|
60
54
|
var _require6 = require('./RelayStoreReactFlightUtils'),
|
|
61
|
-
refineToReactFlightPayloadData = _require6.refineToReactFlightPayloadData,
|
|
62
55
|
REACT_FLIGHT_EXECUTABLE_DEFINITIONS_STORAGE_KEY = _require6.REACT_FLIGHT_EXECUTABLE_DEFINITIONS_STORAGE_KEY,
|
|
63
56
|
REACT_FLIGHT_TREE_STORAGE_KEY = _require6.REACT_FLIGHT_TREE_STORAGE_KEY,
|
|
64
|
-
REACT_FLIGHT_TYPE_NAME = _require6.REACT_FLIGHT_TYPE_NAME
|
|
57
|
+
REACT_FLIGHT_TYPE_NAME = _require6.REACT_FLIGHT_TYPE_NAME,
|
|
58
|
+
refineToReactFlightPayloadData = _require6.refineToReactFlightPayloadData;
|
|
65
59
|
|
|
66
60
|
var _require7 = require('./RelayStoreUtils'),
|
|
61
|
+
ROOT_ID = _require7.ROOT_ID,
|
|
62
|
+
ROOT_TYPE = _require7.ROOT_TYPE,
|
|
63
|
+
TYPENAME_KEY = _require7.TYPENAME_KEY,
|
|
67
64
|
getArgumentValues = _require7.getArgumentValues,
|
|
68
65
|
getHandleStorageKey = _require7.getHandleStorageKey,
|
|
69
66
|
getModuleComponentKey = _require7.getModuleComponentKey,
|
|
70
67
|
getModuleOperationKey = _require7.getModuleOperationKey,
|
|
71
|
-
getStorageKey = _require7.getStorageKey
|
|
72
|
-
TYPENAME_KEY = _require7.TYPENAME_KEY,
|
|
73
|
-
ROOT_ID = _require7.ROOT_ID,
|
|
74
|
-
ROOT_TYPE = _require7.ROOT_TYPE;
|
|
68
|
+
getStorageKey = _require7.getStorageKey;
|
|
75
69
|
|
|
76
70
|
var _require8 = require('./TypeID'),
|
|
77
|
-
|
|
78
|
-
|
|
71
|
+
TYPE_SCHEMA_TYPE = _require8.TYPE_SCHEMA_TYPE,
|
|
72
|
+
generateTypeID = _require8.generateTypeID;
|
|
73
|
+
|
|
74
|
+
var areEqual = require("fbjs/lib/areEqual");
|
|
75
|
+
|
|
76
|
+
var invariant = require('invariant');
|
|
77
|
+
|
|
78
|
+
var warning = require("fbjs/lib/warning");
|
|
79
79
|
|
|
80
80
|
/**
|
|
81
81
|
* Normalizes the results of a query and standard GraphQL response, writing the
|
|
@@ -10,13 +10,13 @@
|
|
|
10
10
|
// flowlint ambiguous-object-type:error
|
|
11
11
|
'use strict';
|
|
12
12
|
|
|
13
|
-
var invariant = require('invariant');
|
|
14
|
-
|
|
15
13
|
var _require = require('./RelayModernRecord'),
|
|
16
14
|
getType = _require.getType;
|
|
17
15
|
|
|
18
|
-
// Reachable (client) executable definitions encountered while server component
|
|
16
|
+
var invariant = require('invariant'); // Reachable (client) executable definitions encountered while server component
|
|
19
17
|
// rendering
|
|
18
|
+
|
|
19
|
+
|
|
20
20
|
var REACT_FLIGHT_EXECUTABLE_DEFINITIONS_STORAGE_KEY = 'executableDefinitions';
|
|
21
21
|
var REACT_FLIGHT_TREE_STORAGE_KEY = 'tree';
|
|
22
22
|
var REACT_FLIGHT_TYPE_NAME = 'ReactFlightComponent';
|
|
@@ -10,15 +10,15 @@
|
|
|
10
10
|
// flowlint ambiguous-object-type:error
|
|
11
11
|
'use strict';
|
|
12
12
|
|
|
13
|
-
var
|
|
13
|
+
var deepFreeze = require('../util/deepFreeze');
|
|
14
14
|
|
|
15
|
-
var
|
|
15
|
+
var recycleNodesInto = require('../util/recycleNodesInto');
|
|
16
16
|
|
|
17
|
-
var
|
|
17
|
+
var RelayFeatureFlags = require('../util/RelayFeatureFlags');
|
|
18
18
|
|
|
19
19
|
var hasOverlappingIDs = require('./hasOverlappingIDs');
|
|
20
20
|
|
|
21
|
-
var
|
|
21
|
+
var RelayReader = require('./RelayReader');
|
|
22
22
|
|
|
23
23
|
var RelayStoreSubscriptions = /*#__PURE__*/function () {
|
|
24
24
|
function RelayStoreSubscriptions(log, resolverCache) {
|
|
@@ -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,
|
|
@@ -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) {
|
|
@@ -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
|
|
|
@@ -0,0 +1,57 @@
|
|
|
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
|
+
'use strict';
|
|
11
|
+
|
|
12
|
+
var internTable = new Map();
|
|
13
|
+
var nextIndex = 1;
|
|
14
|
+
var digits = new Set('0123456789'); // Character used as the prefix for interned strings. The specific character is
|
|
15
|
+
// chosen to reduce the likelihood that non-interned input strings need to be
|
|
16
|
+
// escaped (choosing eg a-Z would increase the likelihood we need to escape)
|
|
17
|
+
|
|
18
|
+
var INTERN_PREFIX = '\t'; // Character used as the prefix of escaped strings. As above, this is also
|
|
19
|
+
// chosen to be unlikely in normal input strings.
|
|
20
|
+
|
|
21
|
+
var ESCAPE_PREFIX = '\v'; // Escape a string so that it cannot conflict with an interned string
|
|
22
|
+
|
|
23
|
+
function escape(str) {
|
|
24
|
+
if ( // "\t<digit>..." -> "\v\t<digit>..."
|
|
25
|
+
str[0] === INTERN_PREFIX && digits.has(str[1]) || // "\v..." -> "\v\v..."
|
|
26
|
+
str[0] === ESCAPE_PREFIX) {
|
|
27
|
+
return ESCAPE_PREFIX + str;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
return str;
|
|
31
|
+
} // Interns the input string if its length equals or exceeds the given `limit`,
|
|
32
|
+
// returning a shorter replacement string that is uniquely associated with the
|
|
33
|
+
// input: multiple calls to intern() for the equivalent input strings (and limit)
|
|
34
|
+
// will always return the exact same string.
|
|
35
|
+
// Strings shorter than the limit are not interned but are escaped if they
|
|
36
|
+
// could conflict with interned strings.
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
function intern(str, limit) {
|
|
40
|
+
if (limit == null || str.length < limit) {
|
|
41
|
+
return escape(str);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
var internedString = internTable.get(str);
|
|
45
|
+
|
|
46
|
+
if (internedString != null) {
|
|
47
|
+
return internedString;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
internedString = INTERN_PREFIX + nextIndex++;
|
|
51
|
+
internTable.set(str, internedString);
|
|
52
|
+
return internedString;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
module.exports = {
|
|
56
|
+
intern: intern
|
|
57
|
+
};
|
|
@@ -11,19 +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
|
|
|
18
|
-
var
|
|
21
|
+
var RelayFeatureFlags = require('./RelayFeatureFlags');
|
|
19
22
|
|
|
20
|
-
var
|
|
21
|
-
getDataIDsFromFragment = _require.getDataIDsFromFragment,
|
|
22
|
-
getVariablesFromFragment = _require.getVariablesFromFragment,
|
|
23
|
-
getSelector = _require.getSelector;
|
|
23
|
+
var stableCopy = require('./stableCopy');
|
|
24
24
|
|
|
25
|
-
var _require2 = require('./
|
|
26
|
-
|
|
25
|
+
var _require2 = require('./StringInterner'),
|
|
26
|
+
intern = _require2.intern;
|
|
27
27
|
|
|
28
28
|
function getFragmentIdentifier(fragmentNode, fragmentRef) {
|
|
29
29
|
var selector = getSelector(fragmentNode, fragmentRef);
|
|
@@ -35,14 +35,14 @@ function getFragmentIdentifier(fragmentNode, fragmentRef) {
|
|
|
35
35
|
|
|
36
36
|
if (RelayFeatureFlags.ENABLE_GETFRAGMENTIDENTIFIER_OPTIMIZATION) {
|
|
37
37
|
var ids = typeof dataIDs === 'undefined' ? 'missing' : dataIDs == null ? 'null' : Array.isArray(dataIDs) ? '[' + dataIDs.join(',') + ']' : dataIDs;
|
|
38
|
-
ids = RelayFeatureFlags.STRING_INTERN_LEVEL <= 1 ? ids :
|
|
38
|
+
ids = RelayFeatureFlags.STRING_INTERN_LEVEL <= 1 ? ids : intern(ids, RelayFeatureFlags.MAX_DATA_ID_LENGTH);
|
|
39
39
|
return fragmentOwnerIdentifier + '/' + fragmentNode.name + '/' + (fragmentVariables == null || isEmptyObject(fragmentVariables) ? '{}' : JSON.stringify(stableCopy(fragmentVariables))) + '/' + ids;
|
|
40
40
|
} else {
|
|
41
41
|
var _JSON$stringify;
|
|
42
42
|
|
|
43
43
|
var _ids = (_JSON$stringify = JSON.stringify(dataIDs)) !== null && _JSON$stringify !== void 0 ? _JSON$stringify : 'missing';
|
|
44
44
|
|
|
45
|
-
_ids = RelayFeatureFlags.STRING_INTERN_LEVEL <= 1 ? _ids :
|
|
45
|
+
_ids = RelayFeatureFlags.STRING_INTERN_LEVEL <= 1 ? _ids : intern(_ids, RelayFeatureFlags.MAX_DATA_ID_LENGTH);
|
|
46
46
|
return fragmentOwnerIdentifier + '/' + fragmentNode.name + '/' + JSON.stringify(stableCopy(fragmentVariables)) + '/' + _ids;
|
|
47
47
|
}
|
|
48
48
|
}
|
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:
|
|
@@ -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,24 @@
|
|
|
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
|
+
OperationAvailability,
|
|
22
|
+
OperationDescriptor,
|
|
23
|
+
OperationTracker,
|
|
26
24
|
OptimisticResponseConfig,
|
|
27
25
|
OptimisticUpdateFunction,
|
|
28
|
-
|
|
29
|
-
OperationAvailability,
|
|
30
|
-
Snapshot,
|
|
26
|
+
RequiredFieldLogger,
|
|
31
27
|
SelectorStoreUpdater,
|
|
32
28
|
SingularReaderSelector,
|
|
33
|
-
|
|
34
|
-
RequiredFieldLogger,
|
|
35
|
-
ExecuteMutationConfig,
|
|
36
|
-
LogFunction,
|
|
29
|
+
Snapshot,
|
|
37
30
|
Store,
|
|
38
|
-
|
|
31
|
+
StoreUpdater,
|
|
39
32
|
} from '../store/RelayStoreTypes';
|
|
40
33
|
import type {Disposable, RenderPolicy} from '../util/RelayRuntimeTypes';
|
|
41
34
|
import type {ActorIdentifier} from './ActorIdentifier';
|
|
@@ -44,6 +37,12 @@ import type {
|
|
|
44
37
|
IMultiActorEnvironment,
|
|
45
38
|
} from './MultiActorEnvironmentTypes';
|
|
46
39
|
|
|
40
|
+
const wrapNetworkWithLogObserver = require('../network/wrapNetworkWithLogObserver');
|
|
41
|
+
const defaultGetDataID = require('../store/defaultGetDataID');
|
|
42
|
+
const RelayOperationTracker = require('../store/RelayOperationTracker');
|
|
43
|
+
const RelayPublishQueue = require('../store/RelayPublishQueue');
|
|
44
|
+
const registerEnvironmentWithDevTools = require('../util/registerEnvironmentWithDevTools');
|
|
45
|
+
|
|
47
46
|
export type ActorSpecificEnvironmentConfig = $ReadOnly<{
|
|
48
47
|
actorIdentifier: ActorIdentifier,
|
|
49
48
|
configName: ?string,
|
|
@@ -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 &&
|
|
@@ -11,16 +11,6 @@
|
|
|
11
11
|
|
|
12
12
|
'use strict';
|
|
13
13
|
|
|
14
|
-
const ActorSpecificEnvironment = require('./ActorSpecificEnvironment');
|
|
15
|
-
const OperationExecutor = require('../store/OperationExecutor');
|
|
16
|
-
const RelayDefaultHandlerProvider = require('../handlers/RelayDefaultHandlerProvider');
|
|
17
|
-
const RelayModernStore = require('../store/RelayModernStore');
|
|
18
|
-
const RelayObservable = require('../network/RelayObservable');
|
|
19
|
-
const RelayRecordSource = require('../store/RelayRecordSource');
|
|
20
|
-
|
|
21
|
-
const defaultGetDataID = require('../store/defaultGetDataID');
|
|
22
|
-
const defaultRequiredFieldLogger = require('../store/defaultRequiredFieldLogger');
|
|
23
|
-
|
|
24
14
|
import type {HandlerProvider} from '../handlers/RelayDefaultHandlerProvider';
|
|
25
15
|
import type {GraphQLResponse, PayloadData} from '../network/RelayNetworkTypes';
|
|
26
16
|
import type {INetwork} from '../network/RelayNetworkTypes';
|
|
@@ -54,6 +44,15 @@ import type {
|
|
|
54
44
|
MultiActorStoreUpdater,
|
|
55
45
|
} from './MultiActorEnvironmentTypes';
|
|
56
46
|
|
|
47
|
+
const RelayDefaultHandlerProvider = require('../handlers/RelayDefaultHandlerProvider');
|
|
48
|
+
const RelayObservable = require('../network/RelayObservable');
|
|
49
|
+
const defaultGetDataID = require('../store/defaultGetDataID');
|
|
50
|
+
const defaultRequiredFieldLogger = require('../store/defaultRequiredFieldLogger');
|
|
51
|
+
const OperationExecutor = require('../store/OperationExecutor');
|
|
52
|
+
const RelayModernStore = require('../store/RelayModernStore');
|
|
53
|
+
const RelayRecordSource = require('../store/RelayRecordSource');
|
|
54
|
+
const ActorSpecificEnvironment = require('./ActorSpecificEnvironment');
|
|
55
|
+
|
|
57
56
|
export type MultiActorEnvironmentConfig = $ReadOnly<{
|
|
58
57
|
createConfigNameForActor?: ?(actorIdentifier: ActorIdentifier) => string,
|
|
59
58
|
createNetworkForActor: (actorIdentifier: ActorIdentifier) => INetwork,
|
|
@@ -11,21 +11,21 @@
|
|
|
11
11
|
|
|
12
12
|
'use strict';
|
|
13
13
|
|
|
14
|
-
import type {
|
|
14
|
+
import type {GraphQLResponse, PayloadData} from '../network/RelayNetworkTypes';
|
|
15
15
|
import type RelayObservable from '../network/RelayObservable';
|
|
16
16
|
import type RelayPublishQueue from '../store/RelayPublishQueue';
|
|
17
17
|
import type {
|
|
18
|
+
ExecuteMutationConfig,
|
|
19
|
+
IEnvironment,
|
|
18
20
|
OperationAvailability,
|
|
19
21
|
OperationDescriptor,
|
|
20
22
|
OptimisticResponseConfig,
|
|
21
23
|
OptimisticUpdateFunction,
|
|
24
|
+
RecordSourceProxy,
|
|
22
25
|
SelectorStoreUpdater,
|
|
23
26
|
SingularReaderSelector,
|
|
24
27
|
Snapshot,
|
|
25
28
|
StoreUpdater,
|
|
26
|
-
IEnvironment,
|
|
27
|
-
ExecuteMutationConfig,
|
|
28
|
-
RecordSourceProxy,
|
|
29
29
|
} from '../store/RelayStoreTypes';
|
|
30
30
|
import type {Disposable} from '../util/RelayRuntimeTypes';
|
|
31
31
|
import type {ActorIdentifier} from './ActorIdentifier';
|
|
@@ -11,9 +11,8 @@
|
|
|
11
11
|
|
|
12
12
|
'use strict';
|
|
13
13
|
|
|
14
|
-
const MultiActorEnvironment = require('./MultiActorEnvironment');
|
|
15
|
-
|
|
16
14
|
const {getActorIdentifier} = require('./ActorIdentifier');
|
|
15
|
+
const MultiActorEnvironment = require('./MultiActorEnvironment');
|
|
17
16
|
|
|
18
17
|
export type {ActorIdentifier} from './ActorIdentifier';
|
|
19
18
|
export type {
|
|
@@ -12,10 +12,6 @@
|
|
|
12
12
|
|
|
13
13
|
'use strict';
|
|
14
14
|
|
|
15
|
-
const ConnectionHandler = require('../handlers/connection/ConnectionHandler');
|
|
16
|
-
|
|
17
|
-
const warning = require('warning');
|
|
18
|
-
|
|
19
15
|
import type {
|
|
20
16
|
RecordSourceSelectorProxy,
|
|
21
17
|
SelectorData,
|
|
@@ -24,6 +20,9 @@ import type {
|
|
|
24
20
|
import type {ConcreteRequest} from '../util/RelayConcreteNode';
|
|
25
21
|
import type {Variables} from '../util/RelayRuntimeTypes';
|
|
26
22
|
|
|
23
|
+
const ConnectionHandler = require('../handlers/connection/ConnectionHandler');
|
|
24
|
+
const warning = require('warning');
|
|
25
|
+
|
|
27
26
|
const MutationTypes = Object.freeze({
|
|
28
27
|
RANGE_ADD: 'RANGE_ADD',
|
|
29
28
|
RANGE_DELETE: 'RANGE_DELETE',
|
|
@@ -12,17 +12,16 @@
|
|
|
12
12
|
|
|
13
13
|
'use strict';
|
|
14
14
|
|
|
15
|
-
const invariant = require('invariant');
|
|
16
|
-
|
|
17
|
-
const {generateClientID} = require('../store/ClientID');
|
|
18
|
-
const {getStableStorageKey} = require('../store/RelayStoreUtils');
|
|
19
|
-
|
|
20
15
|
import type {RecordProxy} from '../store/RelayStoreTypes';
|
|
21
16
|
import type {Arguments} from '../store/RelayStoreUtils';
|
|
22
17
|
import type {DataID} from '../util/RelayRuntimeTypes';
|
|
23
18
|
import type RelayRecordSourceMutator from './RelayRecordSourceMutator';
|
|
24
19
|
import type RelayRecordSourceProxy from './RelayRecordSourceProxy';
|
|
25
20
|
|
|
21
|
+
const {generateClientID} = require('../store/ClientID');
|
|
22
|
+
const {getStableStorageKey} = require('../store/RelayStoreUtils');
|
|
23
|
+
const invariant = require('invariant');
|
|
24
|
+
|
|
26
25
|
/**
|
|
27
26
|
* @internal
|
|
28
27
|
*
|