- Relay is now built with Babel 6.
- Upgraded the Babel Relay plugin to
graphql-js
0.6.0. Developers interested in upgrading tographql-js
0.6.0 might have to make some changes to their existing GraphQL schemas. Read the migration guide for more information: https://gist.github.com/steveluscher/ffc1dfefbb10ad280c8a4c520a5c201c - Debug information detailing every step of a Relay mutation is now printed to
the console when
DEV
is true, andconsole.groupCollapsed
andconsole.groupEnd
are available. - The
this.props.relay
prop passed into components byRelay.Container
now exposesapplyUpdate
andcommitUpdate
methods for dispatching mutations in the context of the currentRelay.Environment
. RANGE_DELETE
mutations can now remove multiple nodes from a connection, becausedeletedIDFieldName
can now point to a plural field.- You can now define
rangeBehaviors
as a function that receives the connection arguments and returns one ofGraphQLMutatorConstants.RANGE_OPERATIONS
. RelayNetworkDebug#init
now lets you pass in aRelayEnvironment
against which you would like to debug. This does not yet allow you to debug more than one environment at a time, but at least you can make the choice of which one.RelayReadyState
now contains anevents
array; a stream of events that can be accessed from aRelayReadyStateCallback
. You can reduce over this list of events to implement any kind of custom rendering logic you like.this.props.variables
now reflects the variables after being processed withprepareVariables
. The fact that variables were the un-prepared values was a source of confusion for many.- Fixed a bug where
prepareVariables
could be called twice, breaking components with non-idempotentprepareVariables
functions. - Relay now warns when you try to set a variable using
setVariables
, or produce one throughprepareVariables
, that you have not declared ininitialVariables
upfront. - It's now possible for the
stale
prop of areadyState
to change even if there was previously anerror
present. - Fixed a bug formatting error messages when the error being pointed to starts at column 0.
- A container definition can now optionally include a
shouldComponentUpdate: () => boolean
function. If specified, this function always overrides the default implementation (ie. there is no fall-through to the default).
RelayNetworkDebug
now logs query variables.RelayNetworkDebug
is now added as a subscriber instead of replacing any existing network layers. It also no longer replaces the globalfetch
.Relay.Environment#injectNetworkLayer
(and, by extensionRelay#injectNetworkLayer
) will now warn if injecting would overwrite a previously injected layer.- Added experimental low-level
RelayGraphQLMutation
API (still being finalized and not yet documented, so use at your own risk).
- Added a React Native / Relay TodoMVC example app.
- You can now render multiple Relay apps at once, each with their own store.
The following APIs are early versions and are as of yet undocumented so please
use them with caution.
- Added
Relay.Environment
.Relay.Store
is now simply a global instance ofRelayEnvironment
. To create your own isolated store and network subsystem, create anew RelayEnvironment()
and make use of it whereverenvironment
is required. - Use
Relay.Environment#injectNetworkLayer
to inject a custom network layer for use within the context of a particularRelay.Environment
instance. - Added
Relay.ReadyStateRenderer
. This component takes in an instance ofRelay.Environment
, aqueryConfig
that conforms to theRelayQueryConfigInterface
, and a Relaycontainer
. It renders synchronously based on the suppliedreadyState
. This primitive enables you to create alternatives toRelay.Renderer
that fetch and handle data in a custom way (eg. for server rendered applications). - Added
Relay.Renderer
– a replacement forRelay.RootContainer
that composes aRelay.ReadyStateRenderer
and performs data fetching.Relay.RootContainer
is now a wrapper aroundRelay.Renderer
that substitutesRelay.Store
forenvironment
.
- Added
- Renamed the Flow type
RelayRendererRenderCallback
toRelayRenderCallback
. - Renamed the Flow type
RelayQueryConfigSpec
toRelayQueryConfigInterface
. RelayContainer.setVariables
will no longer check if the variables are changed before re-running the variables. To prevent extra work, check the current variables before callingsetVariables
.- You can now roll back mutations in the
COMMIT_QUEUED
state usingRelayMutationTransaction#rollback
. - When specifying a
NODE_DELETE
orRANGE_DELETE
mutation config, you can omitparentID
if your parent, in fact, does not have an ID. - In cases where you query for a field, but that field is unset in the response,
Relay will now write
null
into the store for that field. This allows you to return smaller payloads over the wire by simply omitting a key in the JSON response, rather than to write an explicitfieldName: null
. - If the
relay
prop does not change between renders, we now recycle the same object. This should enable you to make an efficientthis.props.relay === nextProps.relay
comparison inshouldComponentUpdate
. - You can now craft a connection query having invalid combinations of connection
arguments (first/last/after/before) so long as the values of those arguments
are variables and not concrete values (eg.
friends(first: $first, last: $last)
will no longer cause the Relay Babel plugin to throw). - Added runtime validation to mutation configs to help developers to debug their
Relay.Mutation
. - Added
RelayNetworkDebug
. Invokerequire('RelayNetworkDebug').init(Relay.DefaultNetworkLayer)
to enjoy simple to read logs of your network requests and responses on the console. Substitute your own network layer if you use one. - Added two new
rangeBehaviors
:IGNORE
means the range should not be refetched at all.REFETCH
will refetch the entire connection.
- Connection diff optimization: Enables a mode where Relay skips diffing
information about edges that have already been fetched. This can be enabled by
adding
@relay(variables: ['variableNames'])
to a connection fragment.
- The instance of Babel that the babel-relay-plugin receives will now be used when making assertions about version numbers.
- Identifying arguments on root fields can now be of any type - boolean, number, string, or array/object of the the same.
- Fixes a bug when we read connections or fragments without allocating a record until we encounter a child field that is not null. We now ensure that we allocate the record for connections and fragments (if it exists) regardless.
- Made babelAdapter compatible with Babel 6.6
npm run build
now works on Windows- Tests now pass when using Node 5 / NPM 3
- Passing an empty array as a prop corresponding to a plural fragment no longer warns about mock data. The empty array is now passed through to the component as-is.
- Removed
uri
fromRelayQueryConfigSpec
. Theuri
property was part ofRelayRoute
, but neverRelayQueryConfig
. This revision simply cleans up the Flow shape inRelayContainer
. - RelayRenderer now runs queries after mount to make sure
RelayRenderer
does not run queries during synchronous server-side rendering.
- Having fixed a bug, now you can actually interpolate an array of fragments
into a
Relay.QL
query. eg.${containers.map(c => c.getFragment('foo'))}
- Eliminated a race condition that would cause
RelayGarbageCollector
to fatal when, in the middle of areadRelayDiskCache
traversal, a container attempts to subscribe to a record not yet registered with the garbage collector. - The garbage collector now strictly increments references to all subscribed nodes, and strictly decrements references to all previously subscribed nodes, eliminating a class of race condition by ensuring an exact 1:1 correspondence of increment/decrement calls for a given node.
- Replaced
GraphQLStoreDataHandler
withRelayRecord
, and added theRelayRecord#isRecord
method. - Introduced
RelayQueryIndexPath
which tracks fragment indexes to the nearest parent field during query traversal. This replaces the existing logic used to generate field serialization keys. - Added
RelayContext
, a step toward making all Relay state contextual. - Improved query printing performance via short circuiting and inlining.
- Moved record writing functions out of
RelayRecordStore
and into a newRelayRecordWriter
class. - The Babel plugin now prints
canHaveSubselections
metadata on object-like fields that can contain child fields, making it possible to determine if a given field in a query is a true leaf node, or an object-type field having no subselections. This replacesRelayQueryNode#isScalar
withRelayQueryNode#canHaveSubselections
. RANGE_DELETE
mutation configs now allow you to specify an array path to a deleted node, rather than just adeletedIDFieldName
.- Renamed
Records
toRecordMap
. - Record reads from cache managers are now abortable. If the network request finishes before the cache read, for instance, the cache read can be cancelled.
- Added USERS.md; a catalog of products and developers that use Relay.
- You can now interpolate an array of fragments into a
Relay.QL
query. eg.${containers.map(c => c.getFragment('foo'))}
- Fixed a bug where invalid queries could be printed due to different variables having the same value; duplicates are now avoided.
- Renamed
RelayStore#update
toRelayStore#commitUpdate
.RelayStore#commit
will be removed in v0.8.0. For an automated codemod that you can use to update your Relay app, visit https://github.com/relayjs/relay-codemod - Replaced
RelayTestUtils.unmockRelay();
withrequire('configureForRelayOSS');
in tests. - Fragment names in printed queries are now less verbose.
- Fixed a bug that caused queries to be printed incorrectly.
- Eliminated concrete fragment hashes.
- Connections now handle repeated edges more gracefully.
- Created a new
RelayTaskQueue
class. Used it to backRelayTaskScheduler
. - Reduced memory by only storing paths to container root nodes.
- Renamed
RelayTaskScheduler#await
toRelayTaskScheduler#enqueue
. - Fixed a series of memory leaks with a new GC implementation.
- Tests now run with Jasmine 2.
- Bump the
babel-relay-plugin
version to v0.6.0 (now Babel 6 compatible). - The keys in
rangeBehaviors
are now compared against the sorted filter arguments of a field. For the fieldfoo(first: 10, b:true, a:false)
the matching range behavior key will be'a(false).b(true)'
. - Relay will now throw an invariant if range behavior keys are unsorted.
- Fragments are now supported in mutation fat queries.
- Added
Relay.Store#applyUpdate
method to create a transaction optimistically without committing it. Returns a transaction object that you can use tocommit()
orrollback()
. - Added
RelayStoreData#clearCacheManager
method. - Renamed
RelayQuery#getHash
toRelayQuery#getConcreteFragmentHash
- Removed
RelayQueryPath#toJSON
andRelayQueryPath#fromJSON
- Bump the
babel-relay-plugin
version to v0.4.1.- Added validation of arguments for connections with
edges
orpageInfo
.- Connections without arguments in fat queries can add the new fragment
directive
@relay(pattern: true)
.
- Connections without arguments in fat queries can add the new fragment
directive
- Fixed validation of fields within inline fragments in connections.
- Print queries using a plain-object representation (instead of
GraphQL
objects).
- Added validation of arguments for connections with
RelayQueryField#getStorageKey
will now produce the same key regardless of the order of a field's arguments.- Range behavior keys in mutation configs are now guaranteed to be sorted.
- Added the
Relay.createQuery()
function which returns aRelayQuery.Root
(that can be used withRelay.Store
methods). - Optimistic response keys now use GraphQL OSS syntax. (Usage of old, call-like syntax is now deprecated and will warn.)
- Fix a bug where optimistic queries could cause the error "Could not find a type name for record ...".
- Bump the
babel-relay-plugin
version to v0.3.0.- Fixed the metadata for fields on abstract types.
- Directives are now validated against the schema.
- Mutations field arguments are now validated.
- Non-root
node(id: ...)
fields are now invalid. - Added support for
RelayQL
template tag. - Improvements to validation and error messages.
- The
__typename
of abstract types are now fetched and stored locally. - Fixed
hasOptimisticUpdate
returning true after mutation succeeds (#86). - Fixed printing mutations with generated
id
fields (#414). - Fixed updating views when removing the last element in a plural field (#401).
- Fixed sending mutations via classes without invalid GraphQL characters (#448).
- Added a
__DEV__
-only warning when data is passed down via the wrong prop.
- Bump the
babel-relay-plugin
version to v0.2.5.- Queries now preserve directives.
- Output is now generated by babel.
- Fix refragmenting diff queries (#305).
- Directives are now printed.
- Rebuild to replace faulty NPM package (no code changes).
- Fix query variable printing for non-null and list types (#203).
- Bumped React dependency to v0.14.0-rc.
- Switched to using
ReactDOM
rather thanReact
for performing batched updates (viaunstable_batchedUpdates
). - Updated the babel-relay-plugin to v0.2.3:
- Added support for compiling queries containing introspection fields such as
__schema
,__typename
and such. - Use of
field(before: ..., first: ...)
orfield(after: ..., last: ...)
is now an error.
- Added support for compiling queries containing introspection fields such as
- Various improvements to documentation, warnings and error messages.
- Support simplified route query definitions (previous API still supported).
- Upgraded jest to 0.5 and switched Relay to use iojs v2+ only.
- Changed
Relay.DefaultNetworkLayer
constructor to take aninit
object instead offetchTimeout
andretryDelays
. - Scalars other than strings are now allowed as cursors, so long as they serialize to strings.
- Added
npm run update-schema
to update the test schema.
- The 'main' entrypoint can now be used in non-ES6 projects (now built w/ Babel).
- Instance methods of
Relay.DefaultNetworkLayer
are bound to the instance, facilitating reuse. - Renamed
GraphQL_EXPERIMENTAL
toGraphQL
(internal change). - Update copyright headers.
- Remove invariant in
RelayQueryField.getCallType()
when argument is unknown. GraphQLRange
returns diff calls with numeric values instead of strings.- Example apps now include an ES6 polyfill.
- Moved React to peer dependencies; projects should depend on React directly.
- Variables in the default network layer are no longer double-JSON encoded.
- The default network layer now passed cookies along to the server.
- Initial public release.