Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/abdulwahab0/map-application-log
A mini FullStack (React and Nodejs) Application which helps user to delete and see their Visited places on Map .
https://github.com/abdulwahab0/map-application-log
expressjs file-upload html-css javascript leaftlet mondodb node-js openstreetmap reactjs router
Last synced: 17 days ago
JSON representation
A mini FullStack (React and Nodejs) Application which helps user to delete and see their Visited places on Map .
- Host: GitHub
- URL: https://github.com/abdulwahab0/map-application-log
- Owner: AbdulWahab0
- Created: 2020-10-05T01:09:45.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2020-10-10T18:19:10.000Z (over 4 years ago)
- Last Synced: 2024-11-11T07:46:36.569Z (3 months ago)
- Topics: expressjs, file-upload, html-css, javascript, leaftlet, mondodb, node-js, openstreetmap, reactjs, router
- Language: JavaScript
- Homepage:
- Size: 47.1 MB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Simple-FullStack-Map-App 💵 📍 (See Mockup Below )
[![Hits](https://hits.seeyoufarm.com/api/count/incr/badge.svg?url=https%3A%2F%2Fgithub.com%2FAbdulWahab0%2FMap-Application-log&count_bg=%2379C83D&title_bg=%23555555&icon=expo.svg&icon_color=%23E7E7E7&title=HITCount&edge_flat=false)](https://hits.seeyoufarm.com)
This is a boilerplate to build a full stack web application using React, Node.js, Express and Webpack. It is also configured with webpack-dev-server, eslint, prettier and babel.
- [simple-react-full-stack](#simple-react-full-stack)
- [Introduction](#introduction)
- [Development mode](#development-mode)
- [Production mode](#production-mode)
- [Quick Start](#quick-start)
- [Documentation](#documentation)
- [Folder Structure](#folder-structure)
- [Babel](#babel)
- [ESLint](#eslint)
- [Webpack](#webpack)
- [Webpack dev server](#webpack-dev-server)
- [Nodemon](#nodemon)
- [Express](#express)
- [Concurrently](#concurrently)
- [VSCode + ESLint + Prettier](#vscode--eslint--prettier)
- [Installation guide](#installation-guide)## Introduction
This is simple Application which helps users to add makrker 📍 on the app and save the name of that place, When user vist the the map page again then user can see his makred place and user can also add new Maker 📍, eidt place name and also upload the image . This application is short porject which can be extended at higher level in future.
## Features ✨
* **Add a place marker** Clicking on the map add a place marker (stored in the backend)
* **Show Existing Marker** Clicking on an existing marker shows its properties in a popup window (name, image).
* **Edit a Marker (Place)** - Clicking on an existing marker show the popup window allows to edit name and image URL.
* **Delete a Marker** - Clicking on an existing marker show the popup window allows to delete the Marker.
* **Show all Existing Marker** - Reloading or HomePage show all the Markers.## Sections
✔️ Shows Existing Markers\
✔️ Shows pop up window \
✔️ Remove and edit Marker\## Technologies used 🛠️
- [React](https://reactjs.org/)
- [Node.js](https://redux.js.org/)
- [MongoDB](https://www.mongodb.com/)
- [LeadfLet js](https://leafletjs.com/)
- [Open Street Map](https://www.openstreetmap.org/)## Concepts Implemented
- HTML5 and CSS3,
- React: Components, Props, Events, Hooks, Router, Axios
- Node & Express: Web API, Body Parser, File Upload, JWT
- MongoDB: Mongoose, Aggregation
- Development: ESLint, Babel, Git, Github,
- Libararies: LeadfLet Js,Open Street Map## Sections
✔️ **Show Default Map No Marker**
✔️ **Now Add Marker**
✔️ **Show Popup Window Edit Place Name, Image**
✔️ **Show New Added Place**
✔️ **After Deleting Some Markers**
## Deployment 📦
Once you have done with your setup. You need to put your website online!
I highly recommend to use [heroku](https://devcenter.heroku.com/articles/nodejs-support/) to achieve this on the EASIEST WAY## Contributors ✨
## Development mode
In the development mode, we will have 2 servers running. The front end code will be served by the [webpack dev server](https://webpack.js.org/configuration/dev-server/) which helps with hot and live reloading. The server side Express code will be served by a node server using [nodemon](https://nodemon.io/) which helps in automatically restarting the server whenever server side code changes.
### Production mode
In the production mode, we will have only 1 server running. All the client side code will be bundled into static files using webpack and it will be served by the Node.js/Express application.
## Quick Start
```bash
# Clone the repository
git clone https://github.com/AbdulWahab0/Map-Application-log# Go inside the directory
cd Map-Application-log# Install dependencies
yarn (or npm install)# Start development server
yarn dev (or npm run dev)# Build for production
yarn build (or npm run build)# Start production server
yarn start (or npm start)# Start MonoDB
sudo mondod (for Mac --> Make sure that mongoDb is install and running on your system)
```## Documentation
### Folder Structure
All the source code will be inside **src** directory. Inside src, there is client and server directory. All the frontend code (react, css, js and any other assets) will be in client directory. Backend Node.js/Express code will be in the server directory.
### Babel
[Babel](https://babeljs.io/) helps us to write code in the latest version of JavaScript. If an environment does not support certain features natively, Babel will help us to compile those features down to a supported version. It also helps us to convert JSX to Javascript.
[.babelrc file](https://babeljs.io/docs/usage/babelrc/) is used describe the configurations required for Babel. Below is the .babelrc file which I am using.
```javascript
{
"presets": ["env", "react"]
}
```Babel requires plugins to do the transformation. Presets are the set of plugins defined by Babel. Preset **env** allows to use babel-preset-es2015, babel-preset-es2016, and babel-preset-es2017 and it will transform them to ES5. Preset **react** allows us to use JSX syntax and it will transform JSX to Javascript.
### ESLint
[ESLint](https://eslint.org/) is a pluggable and configurable linter tool for identifying and reporting on patterns in JavaScript.
[.eslintrc.json file](<(https://eslint.org/docs/user-guide/configuring)>) (alternatively configurations can we written in Javascript or YAML as well) is used describe the configurations required for ESLint. Below is the .eslintrc.json file which I am using.
```javascript
{
"extends": ["airbnb"],
"env": {
"browser": true,
"node": true
},
"rules": {
"no-console": "off",
"comma-dangle": "off",
"react/jsx-filename-extension": "off"
}
}
```[I am using Airbnb's Javascript Style Guide](https://github.com/airbnb/javascript) which is used by many JavaScript developers worldwide. Since we are going to write both client (browser) and server side (Node.js) code, I am setting the **env** to browser and node. Optionally, we can override the Airbnb's configurations to suit our needs. I have turned off [**no-console**](https://eslint.org/docs/rules/no-console), [**comma-dangle**](https://eslint.org/docs/rules/comma-dangle) and [**react/jsx-filename-extension**](https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/jsx-filename-extension.md) rules.
### Webpack
[Webpack](https://webpack.js.org/) is a module bundler. Its main purpose is to bundle JavaScript files for usage in a browser.
[webpack.config.js](https://webpack.js.org/configuration/) file is used to describe the configurations required for webpack. Below is the webpack.config.js file which I am using.
```javascript
const path = require("path");
const HtmlWebpackPlugin = require("html-webpack-plugin");
const CleanWebpackPlugin = require("clean-webpack-plugin");const outputDirectory = "dist";
module.exports = {
entry: ["babel-polyfill", "./src/client/index.js"],
output: {
path: path.join(__dirname, outputDirectory),
filename: "bundle.js"
},
module: {
rules: [
{
test: /\.js$/,
exclude: /node_modules/,
use: {
loader: "babel-loader"
}
},
{
test: /\.css$/,
use: ["style-loader", "css-loader"]
},
{
test: /\.(png|woff|woff2|eot|ttf|svg)$/,
loader: "url-loader?limit=100000"
}
]
},
devServer: {
port: 3000,
open: true,
proxy: {
"/api": "http://localhost:8080"
}
},
plugins: [
new CleanWebpackPlugin([outputDirectory]),
new HtmlWebpackPlugin({
template: "./public/index.html",
favicon: "./public/favicon.ico"
})
]
};
```1. **entry:** entry: ./src/client/index.js is where the application starts executing and webpack starts bundling.
Note: babel-polyfill is added to support async/await. Read more [here](https://babeljs.io/docs/en/babel-polyfill#usage-in-node-browserify-webpack).
2. **output path and filename:** the target directory and the filename for the bundled output
3. **module loaders:** Module loaders are transformations that are applied on the source code of a module. We pass all the js file through [babel-loader](https://github.com/babel/babel-loader) to transform JSX to Javascript. CSS files are passed through [css-loaders](https://github.com/webpack-contrib/css-loader) and [style-loaders](https://github.com/webpack-contrib/style-loader) to load and bundle CSS files. Fonts and images are loaded through url-loader.
4. **Dev Server:** Configurations for the webpack-dev-server which will be described in coming section.
5. **plugins:** [clean-webpack-plugin](https://github.com/johnagan/clean-webpack-plugin) is a webpack plugin to remove the build folder(s) before building. [html-webpack-plugin](https://github.com/jantimon/html-webpack-plugin) simplifies creation of HTML files to serve your webpack bundles. It loads the template (public/index.html) and injects the output bundle.### Webpack dev server
[Webpack dev server](https://webpack.js.org/configuration/dev-server/) is used along with webpack. It provides a development server that provides live reloading for the client side code. This should be used for development only.
The devServer section of webpack.config.js contains the configuration required to run webpack-dev-server which is given below.
```javascript
devServer: {
port: 3000,
open: true,
proxy: {
"/api": "http://localhost:8080"
}
}
```[**Port**](https://webpack.js.org/configuration/dev-server/#devserver-port) specifies the Webpack dev server to listen on this particular port (3000 in this case). When [**open**](https://webpack.js.org/configuration/dev-server/#devserver-open) is set to true, it will automatically open the home page on startup. [Proxying](https://webpack.js.org/configuration/dev-server/#devserver-proxy) URLs can be useful when we have a separate API backend development server and we want to send API requests on the same domain. In our case, we have a Node.js/Express backend where we want to send the API requests to.
### Nodemon
Nodemon is a utility that will monitor for any changes in the server source code and it automatically restart the server. This is used in development only.
nodemon.json file is used to describe the configurations for Nodemon. Below is the nodemon.json file which I am using.
```javascript
{
"watch": ["src/server/"]
}
```Here, we tell nodemon to watch the files in the directory src/server where out server side code resides. Nodemon will restart the node server whenever a file under src/server directory is modified.
### Express
Express is a web application framework for Node.js. It is used to build our backend API's.
src/server/index.js is the entry point to the server application. Below is the src/server/index.js file
```javascript
const express = require("express");
const os = require("os");const app = express();
app.use(express.static("dist"));
app.get("/api/getUsername", (req, res) =>
res.send({ username: os.userInfo().username })
);
app.listen(8080, () => console.log("Listening on port 8080!"));
```This starts a server and listens on port 8080 for connections. The app responds with `{username: }` for requests to the URL (/api/getUsername). It is also configured to serve the static files from **dist** directory.
### Concurrently
[Concurrently](https://github.com/kimmobrunfeldt/concurrently) is used to run multiple commands concurrently. I am using it to run the webpack dev server and the backend node server concurrently in the development environment. Below are the npm/yarn script commands used.
```javascript
"client": "webpack-dev-server --mode development --devtool inline-source-map --hot",
"server": "nodemon src/server/index.js",
"dev": "concurrently \"npm run server\" \"npm run client\""
```### VSCode + ESLint + Prettier
[VSCode](https://code.visualstudio.com/) is a lightweight but powerful source code editor. [ESLint](https://eslint.org/) takes care of the code-quality. [Prettier](https://prettier.io/) takes care of all the formatting.
#### Installation guide
1. Install [VSCode](https://code.visualstudio.com/)
2. Install [ESLint extension](https://marketplace.visualstudio.com/items?itemName=dbaeumer.vscode-eslint)
3. Install [Prettier extension](https://marketplace.visualstudio.com/items?itemName=esbenp.prettier-vscode)
4. Modify the VSCode user settings to add below configuration```javascript
"eslint.alwaysShowStatus": true,
"eslint.autoFixOnSave": true,
"editor.formatOnSave": true,
"prettier.eslintIntegration": true
```Above, we have modified editor configurations. Alternatively, this can be configured at the project level by following [this article](https://medium.com/@netczuk/your-last-eslint-config-9e35bace2f99).