Submission by Nurin Fazil
Demo link can be found here
- Next.js
- TypeScript
- Tailwind
- Google Maps API
- AG Grid
- Chart.js
You are given a sample Climate Risk Rating dataset in order to solve the following problems.
Objective: Create an interactive map that displays the geographic locations from the provided dataset and highlights the relative risk levels using color-coded markers.
- Set up a Next.js boilerplate app with the following command under Node v16 environment
or
yarn create next-app risk-viz --ts --tailwind --eslint --src-dir --import-alias "@/*" --experimental-app
npx create-next-app@latest risk-viz --ts --tailwind --eslint --src-dir --import-alias "@/*" --experimental-app
- Load and parse the sample datasets.
- Integrate a mapping library (e.g., Mapbox, Leaflet, Google Maps).
- Implement a control for users to select different decades.
- Display the locations (Lat, Long) from the dataset as markers on the map of a given decade year.
- Color-code the markers based on their Risk Rating (climate risk score) derived from the dataset.
- Add interactivity to the map, such as zooming and panning, and display a tooltip with the Asset Name and Business Category on marker hover.
Objective: Display the climate risk data in a table format, allowing users to sort and filter the dataset.
- Create a data table component.
- Load and display the sample dataset with a given year selection (from Problem 1) in the table.
- Implement sorting functionality on reasonable columns.
- Implement filter functionality on reasonable columns, especially risk factors.
Objective: Create a line graph to visualize the changes in risk levels over time for a given location, Asset or Business Category.
- Set up a charting library (e.g., Chart.js, D3.js, Highcharts).
- Implement a line graph component that displays the Risk Rating over time (Year) for a selected location (Lat, Long), Asset, or Business Category.
- Add interactivity to the graph, such as tooltips displaying Asset Name, Risk Rating, Risk Factors, and Year.
- Implement controls for selecting different locations, Assets, or Business Categories to visualize their risk levels over time.
- You may need to perform some data aggregation in order to achieve this.
Objective: Combine the components from the previous problems into a cohesive web app, ensuring optimal performance and user experience.
- Design a user interface that integrates the map, data table, and line graph components.
- Implement state management to handle user interactions and data flow between components (e.g., selecting a location on the map updates the line graph and data table).
- Optimize the app's performance by implementing lazy loading for components and efficient data handling, such as pagination for the data table.
- (Bonus) Implement reasonable tests for utility functions, data flow hooks, and React components.
- You are encouraged to use any open source libraries to assist with the given problems.
- You can use AI assistants (such as ChatGPT or GitHub Copilot), but make sure to include the full interaction/chat log along with your solution.
- Attribute tutorials, Stackoverflow Q&As, and any other references along with your solution.
- You are encouraged to ask any questions you may have during the hiring process, including but not limited to questions related to the work sample itself.
- Keep in mind that both the amount and the dimension of the data we work with are much higher in reality, so try to demonstrate that your solutions can handle beyond the sample scale.
- Try to think of yourself as the user of the web app, who may want to have certain questions answered, such as:
- What are the top risk factors by ranking?
- What regions are at the most risk?
- What risk factors impact a particular category the most?
- Any others that you can think of...
- You are more than welcome to keep your solutions public as a part of your professional portfolio.
- Host your solution code in a open source repository (e.g. GitHub).
- Deploy your solutions through a suitable service (see below for recommended services, especially Glitch).
- Reply to the original work sample email with your solution source and deployment links.
Some recommended services for your deployments are:
This is a Next.js project bootstrapped with create-next-app
.
First, run the development server:
npm run dev
# or
yarn dev
# or
pnpm dev
Open http://localhost:3000 with your browser to see the result.
You can start editing the page by modifying app/page.tsx
. The page auto-updates as you edit the file.
http://localhost:3000/api/hello is an endpoint that uses Route Handlers. This endpoint can be edited in app/api/hello/route.ts
.
This project uses next/font
to automatically optimize and load Inter, a custom Google Font.
To learn more about Next.js, take a look at the following resources:
- Next.js Documentation - learn about Next.js features and API.
- Learn Next.js - an interactive Next.js tutorial.
You can check out the Next.js GitHub repository - your feedback and contributions are welcome!