This web app display job posts to a user. The app has two routes:
-
All Jobs: Lists all jobs.
-
Job Details: Displays details about a certain job.
Each book in both pages has a selector for reclassifying that book.
To run and use the app:
-
install
json-server
globallyyarn global add json-server
-
clone the repo with
[email protected]:khaled-elakkad/job-listings.git
-
navigate into the project directory with
cd job-listings
-
install all project dependencies with
yarn
-
run locally in development mode
yarn dev
├── README.md - This file.
├── package.json # npm package manager file. It's unlikely that you'll need to modify this.
└── src
├── App.js # The root of the app. Encapsulates the app in the Redux Provider
├── actions # Redux actions
├── constants # Contains constants across the app.
├── helpers.js # Contains functions used by various components to provide different functionalities .
├── components # contains the child componets of the routes
| ├── ErrorMsg
| ├── Header
│ ├── JobDetails
| ├── JobItem
| ├── JobsContainer
| └── JobsSection
├── reducers # contains the redux state reducers
├── sagas # contains the redux sagas that does async state update
├── index.css # Global styles.
└── index.js # It is used for DOM rendering only.
To simplify your development process, we've provided a backend server for you to develop against. The provided api
contains the methods you will need to perform necessary operations on the backend:
Method Signature:
fetchJobs(page);
- page:
<String>
contains the page number of jobs list. - Returns a Promise which resolves to a JSON object containing a collection of 6 jobs for the page passed.
Method Signature:
fetchDetails(id);
- id:
<String>
containing theid
of the job fetch. - Returns a Promise which resolves to a JSON object containing the job details of the id passed.
Method Signature:
search(query);
- query:
<String>
- Returns a Promise which resolves to a JSON object containing a collection of a maximum of 20 book objects.
- These books do not know which shelf they are on. They are raw results only. You'll need to make sure that books have the correct state while on the search page.
- data item shape
{
"id": 9,
"title": "HR Specialist",
"description": "Experienced with HR policies and systems.",
"employment_type": "Full time",
"location": "Alexandria"
}
- fake API package is
json-server
This project was bootstrapped with Create React App. You can find more information on how to perform common tasks here.