This repository contains the Smartia frontend challenge.
In this repository you will find a vanilla Create React App project created using Yarn.
If you are unfamilar with Create React App and the tooling it provides, please see CRA_README.md
at the root of this repository.
This is intended as a starting point. To start the app, run...
yarn start
Having taken a keen interest in SpaceX launches recently 🚀, you've discovered a public API where you can query for launch, rocket, launchpad, landing pad data and more.
- SpaceX API README
- Example: Past launches
The API is REST and does not require any authenitcation.
past_launches.json
is provided at the root of this repository as a static example of the data
Armed with your newly discovered API you've tasked yourself with writing a simple application to list and query past launches.
You've decided the application must have the following features:
- List of past SpaceX launches displaying:
- Flight patch image (
links.patch.small
) - Name (
name
) - Launch date (
date_utc
ordate_local
) - Whether all the cores successfully landed (
cores.landing_success
)
- Flight patch image (
- Search allowing you to query for:
- Launch name (
name
)
- Launch name (
This is 💯 percent in your control!
Feel free to put as much energy into the UX as you are comfortable. If UX and a sleak design is where you feel you shine, feel free to focus here (as long as the application basically works of course).
Don't worry if UX isn't your thing, it's 💯% fine to use an off the shelf library or maybe even go for a super minimalistic look using plain HTML.
Note! Don't worry about responsiveness or mobile screens for this exercise.
We have provide you with a base template in a Create React App to get you started.
From this point onwards the codebase is 💯% in your control to take it in any direction you wish to complete the task.
This could include:
- Installing any library of your choice to help you complete the task
- Changing the directory structure
- Add TypeScript support (if you're more comfortable with TS)
- ...
Tip! Consider that others might work on this application in the future.
While the aim is for the basic application to work, keep in mind other possible functionality or features you added (or wish you had time to add).
For example:
- 💪 More powerful search
- 📃 Pagination
- 💫 Overall UX
- 🕵️ Debugging tools
- 🧪 Testing tools
- This list could go on forever...
Please don't spend more than 3-4 hours working on this task, it will not net you extra points, and we do not want you to spend enormous amounts of time on a throw-away test.
Our primary focus is to verify that you know how to code, and give thought to the huge array of considerations any engineer must take when writing front end code. You are not expected to have covered every scenario, the guide time limit is to focus you on what you feel is most worth the time and energy.
Everyone's approach to this task will be unique, we cannot wait to hear your thoughts on how to solve it! :D
Once you are ready, submit a pull-request with your solution and shoot me an email at [email protected]
with a link to your pull-request and copy of your up-to-date CV. We will then schedule a call with you as soon as we receive it to discuss your solution (this call usually lasts about 1-2 hours, as we want to get to know one another well). If you have submitted a PR with a solution to the task, you will be invited for the call as we believe that it’s only fair to put in the same amount of time as do the candidates.
We hope that you will have fun with it!