This is the code challenge for applying to FWI's FE Developer Position.
- Getting Started and Challenge Information
- API Documentation
- Running both servers simultaneously
- Client Application
- Server Application
This challenge will test your ability to:
- work in an existing code base
- use React, CSS, and redux
- consume/create data from a RESTful API
To make things easier from the get-go, we have provided both a backend RESTful API as well as a starter front end app using create-react-app and some default "reasonable" styles.
This app will start with the ability to view every poker player in the database and list them within a table. Your job will be to update this app so that players can be added, modified, or deleted using the RESTful API backend we have provided. The app started with very simplistic styles, so feel free to import and use any of your favorite libraries or expand upon the current styles to your liking. If possible, ensure that the FWI branding colors are still used which can be found in client/src/_variables.scss.
Applicants should not fork this repository directly; rather, they should initialize their own repositories and pull this repository's content in:
username @ ~/
$ mkdir fwi-fe-code-challenge
$ cd fwi-fe-code-challenge
$ git init
$ git remote add origin https://github.com/USERNAME/fwi-fe-code-challenge
$ git remote add remote-origin https://github.com/fourwindsinteractive/fwi-fe-code-challenge
$ git pull remote-origin master
$ git push origin master
The steps above will create an empty git repo, set the origin to your GitHub code challenge location, then pull the latest code challenge into your repo, and push it to your GitHub. Once you have done all of this, you should be set to start the code challenge.
After you have cloned the repo, you will need to ensure that yarn has been
installed since this project uses yarn for dependency management and the
workspaces feature. Once yarn
has been installed, you can get up and running
with:
$ yarn
$ yarn start
The above commands will install all the dependencies in both the client
and
server
folders as well as start up both the client server and the API server
for you.
The client
app will be using create-react-app, so anything that is supported
by create-react-app can be used.
This project is using yarn workspaces to manage dependencies in both the
client
and server
folders so that the node_modules
folder can be a bit
smaller and a simple way to install dependencies in both directories. Instead of
having to cd
into both the client
and server
folders to install
dependencies, you can now just run yarn
in the root folder which will
automatically install all required dependencies.
If you would like to install a new dependency for this code challenge, you can
either cd
into the client
folder and run yarn add PACKAGE_NAME
like normal
or use the yarn workspace
prefix. Check out the example below for more
information and an example of adding the redux-devtools-extension to the
client
app.
username @ ~/fwi-fe-code-challenge
$ yarn workspace client add redux-devtools-extension
Or directly within the client
folder:
username @ ~/fwi-fe-code-challenge/client
$ yarn add redux-devtools-extension
So packages should still be installed in the client/package.json
instead of
the root package.json
.
Before submitting your code, make sure that there are no console errors within
your app and everything works as expected. We have also provided a very simple
checklist below for the main features that we are looking for, and you can mark
a task as completed by replacing the space with an x
:
- [ ] Create Player
+ [x] Create Player
When you are ready, please send an email to your FWI recruiter with a link to your GitHub repo and any additional instructions for running the project if you added any additional steps.
- Create Player
- Modify Player
- Delete Player
- Implement sorting (optional)
- Lazy loading/pagination (optional)
- Tests (optional)
The player entity will have the following structure:
import { COUNTRIES } from './constants';
type Guid = string;
type CountryCode = keyof COUNTRIES;
interface Player {
id: Guid;
name: string;
country: CountryCode;
winnings: number;
imageUrl: string;
}
You can get a list of all the players be sending a GET
request to /players
:
$ curl -H "Accept: application/json" \
http://localhost:3001/players
Response:
{
"players": [
{
"id": "314c5ab7-ba9b-4821-adba-b4f9d92009db",
"name": "Freddy Kruger",
"country": "US",
"winnings": 93024,
"imageUrl": "https://i.pravatar.cc/40?u=314c5ab7-ba9b-4821-adba-b4f9d92009db"
},
{
"id": "70629df2-571a-4899-b36a-8f36c909508a",
"name": "Bob Bobbity",
"country": "US",
"winnings": 93024,
"imageUrl": "https://i.pravatar.cc/40?u=70629df2-571a-4899-b36a-8f36c909508a"
}
// ... other players
]
}
This endpoint will also support pagination using the start
and size
query
parameters:
$ curl -H "Accept: application/json" \
http://localhost:3001/players?size=24
Response:
{
"from": 0,
"size": 24,
"total": 1000,
"players": [
{
"id": "314c5ab7-ba9b-4821-adba-b4f9d92009db",
"name": "Freddy Kruger",
"country": "US",
"winnings": 93024,
"imageUrl": "https://i.pravatar.cc/40?u=314c5ab7-ba9b-4821-adba-b4f9d92009db"
},
{
"id": "70629df2-571a-4899-b36a-8f36c909508a",
"name": "Bob Bobbity",
"country": "US",
"winnings": 93024,
"imageUrl": "https://i.pravatar.cc/40?u=70629df2-571a-4899-b36a-8f36c909508a"
}
// ... other players
]
}
So if you would like to get the next set of results, you can do:
$ curl -H "Accept: application/json" \
http://localhost:3001/players?size=24&from=24
Response:
{
"from": 24,
"size": 24,
"total": 1000,
"players": [
{
"id": "0ef94f22-e727-4888-91e3-088be5dbd896",
"name": "Scott Sterling",
"country": "UK",
"winnings": 93024,
"imageUrl": "https://i.pravatar.cc/40?u=0ef94f22-e727-4888-91e3-088be5dbd896"
},
{
"id": "4f3b5ce4-2072-47d4-beb8-d46a9a0a8c9f",
"name": "Stirling Archer",
"country": "US",
"winnings": 9302400,
"imageUrl": "https://i.pravatar.cc/40?u=4f3b5ce4-2072-47d4-beb8-d46a9a0a8c9f"
}
// ... other players
]
}
You can get a single player by sending a GET
request to /players/:guid
:
$ curl -H "Accept: application/json" \
http://localhost:3001/players/70629df2-571a-4899-b36a-8f36c909508a
Response:
{
"id": "70629df2-571a-4899-b36a-8f36c909508a",
"name": "Bob Bobbity",
"country": "US",
"winnings": 93024,
"imageUrl": "https://i.pravatar.cc/40?u=70629df2-571a-4899-b36a-8f36c909508a"
}
To create a player, you can send a POST
to /players
with the following data:
interface Player {
name: string;
country: string;
winnings: number;
imageUrl?: string;
}
The imageUrl
will be optional as the BE will automatically create a pravatar
url for you if omitted. After you create a player and it was successful, you
should get a 201
response as well as a Location
header pointing to the newly
created player:
$ curl -d '{ "name": "New Person", "country": "US", "winnings": 1000 }' \
-H "Content-Type: application/json" \
-X POST http://localhost:3001/players
Response:
201 Created
Location: http://localhost:3001/players/0ef94f22-e727-4888-91e3-088be5dbd896
To update a player, you can send a PATCH
to /players/:guid
with the updated
data:
$ curl -d '{ "name": "Example Name" }' \
-H "Content-Type: application/json" \
-X PATCH \
http://localhost:3001/players/314c5ab7-ba9b-4821-adba-b4f9d92009db
Finally, to delete a player, you can send a DELETE
to /players/:guid
:
$ curl -X DELETE \
http://localhost:3001/players/4f3b5ce4-2072-47d4-beb8-d46a9a0a8c9f
If you'd like to run the client
and server
apps in one command, you can
change into the root directory and just run:
$ yarn
$ yarn start
This will install dependencies in both folders as well as spin up both servers
using npm-run-all
$ cd client
$ yarn
$ yarn start
The app will be started and available at http://localhost:3000
$ cd server
$ yarn
$ yarn start
The API server will be started and available at http://localhost:3001