From 1f6a84bd8b8878a37701bd64d3c69bc2acfe154b Mon Sep 17 00:00:00 2001 From: Aaron Carlino Date: Thu, 11 Oct 2018 14:41:16 +1300 Subject: [PATCH 1/2] Add docs for new args/fields API --- .../07_ReactJS_Redux_and_GraphQL.md | 60 ++++++++++++++++++- 1 file changed, 57 insertions(+), 3 deletions(-) diff --git a/docs/en/02_Developer_Guides/15_Customising_the_Admin_Interface/07_ReactJS_Redux_and_GraphQL.md b/docs/en/02_Developer_Guides/15_Customising_the_Admin_Interface/07_ReactJS_Redux_and_GraphQL.md index d83d3da0d22..9efe5773281 100644 --- a/docs/en/02_Developer_Guides/15_Customising_the_Admin_Interface/07_ReactJS_Redux_and_GraphQL.md +++ b/docs/en/02_Developer_Guides/15_Customising_the_Admin_Interface/07_ReactJS_Redux_and_GraphQL.md @@ -1080,13 +1080,67 @@ Now, let's update the query to fetch our new field. *my-other-app/client/transformReadNotes.js* ```js const transformReadNotes = (manager) => { - manager.addField('Priority'); + manager.addField('root', 'Priority'); }; export default transformReadNotes; ``` -Simple! The transformation passes us a `ApolloGraphQLManager` instance that provides a fluent API for updating a query definition the same way the `FormStateManager` allows us to update Redux form state. In this case, our need is really straightforward. We'l just add a new field and be done with it. +Simple! The transformation passes us a `ApolloGraphQLManager` instance that provides a fluent API for updating a query definition the same way the `FormStateManager` allows us to update Redux form state. + +#### Adding fields + +In the above example, we added a single field to a query. Here's how that works: + + +```js +manager.addField(fieldPath, fieldName) +``` + +The `fieldPath` argument tells the manager at what level to add the field. In this case, since the `Priority` field is going on the root query (`readNotes`), we'll use `root` as the path. But suppose we had a more complex query like this: + +``` +query readMembers { + FirstName + Surname + Friends { + Email + Company { + Name + } + } +} +``` + +If we wanted to add a field to the nested `Company` query on `Friends`, we would use a path syntax. + +```js +manager.addField('root/Friends/Company', 'Tagline'); +``` + +#### Adding field arguments + +Let's suppose we had the following query: + +``` +query ReadMembers($ImageSize: String!) { + readMembers { + FirstName + Avatar(Size: $ImageSize) + Company { + Name + } + } +} +``` + +Maybe the `Company` type has a `Logo`, and we want to apply the `ImageSize` parameter as an argument to that field. + +```js +manager.addArg('root/Company/Logo', 'Size', 'ImageSize'); +``` + +Where `root/Company/Logo` is the path to the field, `Size` is the name of the argument on that field, and `ImageSize` is the name of the variable. #### Applying the transforms @@ -1260,7 +1314,7 @@ We've extended the `onAdd` callback to take two parameters -- one for the note c *my-other-app/client/transformCreateNote.js* ```js const transformCreateNote = (manager) => { - manager.addField('Priority'); + manager.addField('root', 'Priority'); manager.transformApolloConfig('props', ({ mutate }) => (prevProps) => { const onAdd = (content, priority) => { mutate({ From 3fcbeaddefad71dc782f639dae1fa5bb76e6662d Mon Sep 17 00:00:00 2001 From: Aaron Carlino Date: Thu, 18 Oct 2018 11:22:29 +1300 Subject: [PATCH 2/2] Reverse argument signature of pathed query properties --- .../07_ReactJS_Redux_and_GraphQL.md | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/docs/en/02_Developer_Guides/15_Customising_the_Admin_Interface/07_ReactJS_Redux_and_GraphQL.md b/docs/en/02_Developer_Guides/15_Customising_the_Admin_Interface/07_ReactJS_Redux_and_GraphQL.md index 9efe5773281..2c34a482e0a 100644 --- a/docs/en/02_Developer_Guides/15_Customising_the_Admin_Interface/07_ReactJS_Redux_and_GraphQL.md +++ b/docs/en/02_Developer_Guides/15_Customising_the_Admin_Interface/07_ReactJS_Redux_and_GraphQL.md @@ -1080,7 +1080,7 @@ Now, let's update the query to fetch our new field. *my-other-app/client/transformReadNotes.js* ```js const transformReadNotes = (manager) => { - manager.addField('root', 'Priority'); + manager.addField('Priority'); }; export default transformReadNotes; @@ -1094,7 +1094,7 @@ In the above example, we added a single field to a query. Here's how that works: ```js -manager.addField(fieldPath, fieldName) +manager.addField(fieldName, fieldPath = 'root') ``` The `fieldPath` argument tells the manager at what level to add the field. In this case, since the `Priority` field is going on the root query (`readNotes`), we'll use `root` as the path. But suppose we had a more complex query like this: @@ -1115,7 +1115,7 @@ query readMembers { If we wanted to add a field to the nested `Company` query on `Friends`, we would use a path syntax. ```js -manager.addField('root/Friends/Company', 'Tagline'); +manager.addField('Tagline', 'root/Friends/Company'); ``` #### Adding field arguments @@ -1137,7 +1137,7 @@ query ReadMembers($ImageSize: String!) { Maybe the `Company` type has a `Logo`, and we want to apply the `ImageSize` parameter as an argument to that field. ```js -manager.addArg('root/Company/Logo', 'Size', 'ImageSize'); +manager.addArg('Size', 'ImageSize', 'root/Company/Logo'); ``` Where `root/Company/Logo` is the path to the field, `Size` is the name of the argument on that field, and `ImageSize` is the name of the variable. @@ -1314,7 +1314,7 @@ We've extended the `onAdd` callback to take two parameters -- one for the note c *my-other-app/client/transformCreateNote.js* ```js const transformCreateNote = (manager) => { - manager.addField('root', 'Priority'); + manager.addField('Priority'); manager.transformApolloConfig('props', ({ mutate }) => (prevProps) => { const onAdd = (content, priority) => { mutate({