Skip to content

adjust/fe-hometask

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

30 Commits
 
 
 
 

Repository files navigation

React & Rockets

Description: Challenge for Adjust Frontend Developer

Owner: adjust

Contacts: frontend-hiring@adjust.com


Welcome to our little coding exercise! 👋

Here, you will have the opportunity to work with TypeScript and Rockets in the same project. We recommend setting aside 2-3 hours to complete it.

Please make sure to read this page entirely before starting the challenge. If you have any questions, feel free to open an issue as described at the bottom of this page.

Important: We want to give all candidates taking this test an equal opportunity to solve the exercise in their own way. Therefore, please do not fork or share this repo (nor your solution) with anyone 🙏🏻

Instructions

  1. Push your solution to a private repo in your personal GitHub account.
  2. When you're ready for us to review your work, please add adjust-frontend-hiring (GitHub user) as a collaborator.

General notes

  • The final solution must be a working React application.
    • It's up to you how to bootstrap a new React application.
  • You can use any third-party library if you see a good fit for it.
  • It's not necessary to heavily comment the code; please only leave comments where they are essential for code comprehension. However, we welcome notes and comments that reflect the higher-level decisions made during the challenge.
  • Aspects to be assessed:
    • Code Style – meaningful naming conventions, consistent code formatting, and emphasis on code readability and future extensibility.
    • Quality Assurance – the solution you upload should work as expected, conforming to the specifications of the tasks. A solution that produces a different result than specified will not be considered.
    • Introducing best practices, such as tests and linting, is appreciated.

Good luck and happy coding! 🚀


Exercise

TASK #1 - TypeScript

Implement the prepareData higher-order function, which takes an object of filter parameters {year, customerName} and returns a function that processes a list of missions, showing only those launched in the specified year and carrying a payload belonging to customerName.

Observations:

  • Missions should appear in inverse chronological order (sorted by the launch_date_utc field), except that those carrying more payloads should appear first.
  • Payloads are carried in the second stage of a rocket, and they can belong to multiple customers.
  • It doesn't matter to which customerName 'program' each payload belongs, as long as customerName is the customer.

Example:

Considering we have a response from the SpaceX API and the following filter parameters:

{
  year: 2018,
  customerName: "NASA"
}

The expected result should be:

[
  {
    flight_number: 62,
    mission_name: "Iridium NEXT Mission 6",
    payloads_count: 2,
  },
  {
    flight_number: 72,
    mission_name: "CRS-16",
    payloads_count: 1,
  },
  {
    flight_number: 64,
    mission_name: "CRS-15",
    payloads_count: 1,
  },
  {
    flight_number: 60,
    mission_name: "TESS",
    payloads_count: 1,
  },
  {
    flight_number: 59,
    mission_name: "CRS-14",
    payloads_count: 1,
  },
];

TASK #2 - React & Hooks

Implement the <RocketsList> component with the following specifications:

  • The component receives a filterParams object (with the shape described in task #1) as a prop.
  • The component obtains a list of 'missions' from a custom hook, which fetches the entire list of missions from the SpaceX API and processes them using the prepareData function (from task #1) and the filterParams prop.
    • The mission data should only be fetched once.
    • As part of this challenge, you are not allowed to use any of the filter parameters provided by the SpaceX API docs.
  • For each 'mission' obtained from the custom hook, the component renders a string using template literals in the following format: "#flight_number mission_name (payloads_count)".
  • While 'missions' are being fetched from the API, the component renders "Loading..." on the screen.
  • If no 'missions' are obtained from the custom hook, the component renders "No data" on the screen.

Expected outcome:

Please set the filterParams to match the example below:

<RocketsList
  filterParams={{
    year: 2018,
    customerName: "NASA",
  }}
/>

The expected render should match the following outcome:

We will be testing your solution with a small set of E2E tests. Please make sure your solution conforms to the specifications above. Our E2E tests rely on the following facts:

  • Your React application starts a development server by running the npm run start command.
  • The development server is hosted on localhost:3000.
  • filterParams are specified as { year: 2018, customerName: "NASA" }, as in the example above.
  • The markup is represented as an unordered list, composed of <ul> and <li> HTML elements. Please refer to the example below:
<ul>
  <li>#62 Iridium NEXT Mission 6 (2)</li>
  <li>#72 CRS-16 (1)</li>
  ...
</ul>

How to request help

If you have any questions or doubts, you can reach out to us by creating a GitHub issue in your private repo.

Describe your question(s) and mention adjust-frontend-hiring in your comments (don't forget to add the user as a collaborator). We will receive a notification and get back to you as soon as possible.

Helpful links

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published