back to all posts

React Tutorial - SpaceX fan site with Apollo Client -3

by Nabendu Biswas / January 6th, 2020

#javascript #react #graphql
Series: React-apollo-client

Welcome to part-3 of the series. Now, let’s send the data from our Launches.js file to a new component LaunchItem.js. We are just lopping through the data using map and then passing it to a new LaunchItem component.

Launches.jsLaunches.js

Next, we will create the LaunchItem.js file in the same components folder. We are just de-structuring the props and showing it through some use of bootstrap classes.

LaunchItem.jsLaunchItem.js

It will show all the launches in a nice list view in our web-page.

All LaunchesAll Launches

Next, we will install two packages in our client which will help us with showing different color for a failed or successful mission.

classnames and momentclassnames and moment

We also need to install one more package called react-moment, which i missed. So, npm install it in client folder.

react-momentreact-moment

Next, we will update our LaunchItem.js to use classNames and change the mission_name color to green or red, depending on whether launch_success is true or false.

LaunchItem.jsLaunchItem.js

Now, our web-app will show as below.

LaunchesLaunches

Now, the user show know what red and green means. So, we put a color description in Launches.js

Launches.jsLaunches.js

It will show these in our web-page.

Success or FailSuccess or Fail

From the above image the date seems a bit difficult to read, so we will use moment to show it in a good format.

Using MomentUsing Moment

It will now show the date format in our web-page.

Nice date formatNice date format

Now, when the user clicks on Launch Details it show open a different page, showing the details of the launch. We need to use react-router to navigate to different page. So, let’s npm install it in the client folder.

react-routerreact-router

Next, we will use routes in our App.js. We are first doing import of Router and the Launch component(yet to be created).

Then we are wrapping everything in Router and using two routes, one for Launches component an other for Launch component.

Routes in App.jsRoutes in App.js

Next, we will create Launch.js inside the components folder and put the basic code in it. We will change the content later.

import React from 'react'

const Launch = () => {
    return (
        <div>
            Launch Component
        </div>
    )
}

export default Launch

We also need to change the simple button in our LaunchItem.js to use Link from react-router-dom.

LaunchItem.jsLaunchItem.js

Now, once we click on the Launch Details link, it will show us the Launch Component. Also, notice the url as it got changed to the launch with flight_number.

Web-pageWeb-page

This completes the part-3 of the series. You can find the code for the same in my github repo here.

Nabendu Biswas