recompose-relay-modern
v1.0.2
Published
Recompose helpers for Relay Modern.
Downloads
99
Readme
recompose-relay-modern
This is a HOC for relay modern to work with сomposable react components.
You probably want to use this when you work with smart and dumb components and you need to compose relay data fetching in your smart component and pass it down to dumb component.
Setup
npm install --save recompose-relay-modern
Set relay environment using setEnvironment
in your enty point. For example in client.js
:
import { setEnviroment } from 'recompose-relay-modern';
import relayEnv from './createRelayEnvironment'
setEnviroment(relayEnv);
And now you are ready to use it.
Examples
FragmentContainer
import {
graphql,
} from 'react-relay';
import { fragmentContainer } from 'recompose-relay-modern';
import Persons from './Persons';
export default compose(
fragmentContainer(graphql`
fragment PersonsContainerDesc on Person @relay(plural: true) {
id
title
}
`),
connect(mapProps, mapDispatch, mergeProps),
)(Persons);
Query renderer(root)
import {
graphql,
} from 'react-relay';
import { queryRenderer } from 'recompose-relay-modern';
import PersonsInfoPage from './PersonsInfoPage';
import { PersonsContainer } from '../Persons';
export default compose(
queryRenderer(graphql`
query PersonsInfoPageContainerQuery {
Person {
...PersonsContainerDesc
}
}
`),
mapProps(props => ({
persons: <PersonsContainer data={props.Person} />,
})),
)(PersonsInfoPage);
Mutations
import { createMutation } from 'recompose-relay-modern';
export default compose(
mapProps(props => ({
onSubmit: (data) => {
createMutation(graphql`
mutation MyComponentContainerMutation($input: MyInput!) {
createUser(input: $input) {
clientMutationId
}
}
`, { input: data }).then(res => console.log(res);
},
})),
reduxForm({
form: 'MyForm',
}),
)(MyForm);
RefetchContainer
import { queryRenderer, refetchContainer } from 'recompose-relay-modern';
export default compose(
queryRenderer(graphql`
query appQuery {
viewer {
...Test_viewer
}
}
`),
refetchContainer(
{
viewer: graphql.experimental`
fragment Test_viewer on User
@argumentDefinitions(
name: { type: String }
) {
id
firstName
lastName
}
`,
},
graphql.experimental`
query TestQuery($name: String!) {
viewer {
...Test_viewer @arguments(name: $name)
}
}
`,
),
)(Test);
PaginationContainer
import { queryRenderer, paginationContainer } from 'recompose-relay-modern';
export default compose(
queryRenderer(
query songsContainerQuery(
$count: Int!
$cursor: String
) {
...songsContainer
}
`),
paginationContainer(
fragment songsContainer on Query {
songs(
first: $count,
after: $cursor,
) @connection(key: "songsContainer_songs") {
edges {
node {
audioId,
name,
coverImageUrl,
artist,
likes,
dislikes,
}
}
}
}
`),
{
direction: 'forward',
query: graphql`
query songsContainerForwardQuery(
$count: Int!
$cursor: String
) {
...songsContainer,
}
`,
getVariables: (_, { count, cursor }) => ({
count,
cursor,
}),
}),
)(Test);