I am building a demo Indian Restaurant Billing App , after completing Advanced React course by Wes Bos.
In my first article i changed the menu to hamburger menu from the normal menu. In the second article i had given details to upload images through cloudinary. In the third, we learnt to send transactional email using gmail.
In the app, we are using Apollo Client in the frontend, to get data from the Prisma database. So, we are using Mutation and Query components. In one of the component, we faced the deadly “Render prop callback hell”, with three level of callback.
You can find the starting code for Bill.js here.
The three level of render props
Here User is a generic Query component.
User component
To solve this problem, we use a third-party tool known as react-adopt.
So, let’s npm install react-adopt and use it in our component. Here, we will create a Composed component and use the adopt.
In it we write the three different keys in our Object and the value will be equal to the Mutation/Query we are going to replace.
Composed
We will now see the benefit of react-adopt. First we will replace the User component with the Compose component and also change the top level render prop to use all the keys from adopt.
Replacing User component
Now, time to delete the toggle cart Mutation. Go ahead and delete both starting and ending of it.
Mutation deleted
Next, it’s time to delete the Query component.
Query component deleted
Now, if we go back to our frontend and check we will find everything works fine. But if we open the console, we will find three warnings.
Warning spoiler
To fix it we have to make child component in Composed component for every value.
Our updated Composed
This will solve our warning problem and we get a minimal and readable code, with upper level render-prop.
You can find the updated code for Bill.js here.