I'd like to namespace / nest query variables like this:
query ($params: {$id: ID!}) {
getUser(id: $params.id) {
email
username
}
}
with the variables:
{
"params": {
"id": "42"
}
}
but it's not a valid query.
However a query like:
query ($id: ID!) {
getUser(id: $id) {
email
username
}
}
with the variables:
{
"id": "42"
}
will work just fine.
The reason I want to do this is to automatically send in query options into the ApolloReact graphql
higher order component with the params
prop from that is applied to the wrapped component from react router. This question essentially has nothing to do with react router, apart from the fact that the params
prop is applied to the component by react router.
ApolloReact will try to use the props from the component to automatically build the variables object, and since id
is nested in props
it can't find it.
The alternative is to specifically define where to find id
, by defining an options
method that receives ownProps
and returns the variables object in graphql
but I would like to avoid it if possible.