Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/davebitter/example_app
https://github.com/davebitter/example_app
Last synced: 19 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/davebitter/example_app
- Owner: DaveBitter
- Created: 2018-01-14T12:58:20.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2023-01-01T09:15:03.000Z (about 2 years ago)
- Last Synced: 2024-10-27T16:19:25.552Z (2 months ago)
- Language: JavaScript
- Size: 3.34 MB
- Stars: 0
- Watchers: 3
- Forks: 0
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# World Population Dashboard (example app)
![World Population Dashboard](mockup.png)
This repository holds an example app in the form of a dashboard. You can view information on the population in all countries in the world. This dashboard provides some insights, but that is not the main goal of this project. The main goal is to show how I would create a dashboard like this and what techniques I would use.
## Getting Started
First, fork the repository at:
`HTTPS://github.com/davebitter/example_app`
Then open up your terminal and clone the forked repository
`git clone HTTPS://github.com/[YOUR_USERNAME]/example_app.git`
Enter the directory
`cd assignment`
Install all the dependencies
`npm I`
Run the project
`npm start`
Finally, open up your browser at
http://localhost:3000## Demo
Do you want gain some insights in the world's population? Cool, you can view the demo at [https://world.davebitter.com](https://world.davebitter.com).
## Folder structure
The folder structure of this project is pretty straight forward. In `src/index.js` you will find the mounting point of the app. In `src/js/components` you will find all the components that are used. Note that I used the [Atomic Design](http://bradfrost.com/blog/post/atomic-web-design/) principal by the amazing Brad Forst. Although this project has a small amount of components, following this principal will result in well structured folders that make it easy to find each component for fellow developers to work on.
## Techniques and Packages
### Create React App
I used Create React App to quickly setup this project. It ensures that I don't have to spend time setting up the project which allowed me to spend all my time on creating the actual dashboard.
### Fetch
I used the fetch API to request data from the open API endpoint [REST Countries](HTTPS://restcountries.eu) to get some data to build a dashboard with. Fetch provides all the functionality I will need and prevents the need of using a NPM package like Request.js.
### Async/Await
I used Async/Await in order to make the API object in `src/js/lib/API.js`. By doing this I was able to make my API call asynchronous. This is a neater way than using callbacks. Async/Await again prevents the need of using a NPM package like Async.js.
### Config based rendering
In order to keep the code as DRY as possible and make the low-level components as dumb as possible I used a config to render all the components from. With the config, that you can find in `src/config.js`, the app renders all the components and subcomponents without having to hard code anything. The config contains titles, types, datapoints and subcomponents. This allows for easy updating of the application and user specific applications. You can imagine that you can save an altered config for a user that you can use when they login to offer a personalized dashboard.
### ES6 all the way
This project is coded in ES6. This allows me to use the various functionalities that it offers. This, again, prevents the need of using packages. It also helps with more readable code in the form of ternaries, arrow functions, concatting, array manipulation, Object assign, spreading and more.
### CSS
I decided to use regular CSS instead of using SASS or LESS. This project needed minimal styling. Setting up SASS or LESS for just a few lines of styles was not necessary. CSS is powerful enough for what I needed this project.
### Flexbox
I used flexbox to handle everything regarding layout. This allows for easily creating a layout and having everything perfectly aligned.
### Leaflet
I used Leaflet to build the map component. Leaflet is an amazing package where you have full control over each layer and marker. Together with a nice dark tilelayer this made for an eye-catching map component.
### C3.js
I used C3.js to build the charts. C3.js builds D3.js code for you from a config object that I can then hook up to the config for all the components. If you need to build specific functionality you can always use D3.js to alter the charts. I used this because it offered everything I needed and was faster an easier to setup in this short project.
### Numeral.js
I used Numeral.js to format all the numeric values. I did this because this was the fastest and easiest way to ensure that the numbers would be perfectly formatted how big or small they may be.