A simple contact book created using Angular6 (frontend) and loopback (backend). By the end of this tutorial project you will have basic knowledge of below technologies:
- Loopback
- Testing APIs using Mocha, chai and chai-http
- Angular 6
- You must have at least node
v8.9
installed on your system.- Check here to see How to install nodejs on windows.
- Check here to see How to install nodejs on mac.
- You must have
angular-cli
installed on your system.npm install -g @angular/cli
Git clone the project into your local system,
Clone via ssh
git clone git@github.com:sukheja-varun/angular6-contact-book.git
OR
Clone via https
git clone https://github.com/sukheja-varun/angular6-contact-book.git
Check if the project is properly cloned by comparing at the project content on git https://github.com/sukheja-varun/angular6-contact-book
-
Install Loopback dependencies: Inside project root folder
/angular6-contact-book
, run below cmdnpm install
NOTE: It will take some time to download all the required dependencies, wait for it to finish. After this check project should contains folder
angular6-contact-book/node_modules
-
Install Angular dependencies : Inside Angular root folder
/angular6-contact-book/client
, run below cmdnpm install
NOTE: It will take some time to download all the required dependencies, wait for it to finish. After this check project should contains folder
/angular6-contact-book/client/node_modules
There are 2 modes for running the project.
- Development Mode
- Production Mode
Go to project root folder i.e. /angular6-contact-book
and Start loopback server using,
npm start
you will get to see below message when server is up,
Web server listening at: http://localhost:3000
Browse your REST API at http://localhost:3000/explorer
To run Loopback server just copy-paste below URL in your browser
http://localhost:3000/
But you won't be able to see anything as we are running development mode and there are angular static files as of now which loopback can serve.
To run Loopback API explorer just copy-paste below URL in your browser
http://localhost:3000/explorer
Go to project Angular folder i.e. /angular6-contact-book/client
and Start Angular server using,
npm start
you will get to see below message when server is up,
ℹ 「wdm」: Compiled successfully.
To run Angular app just copy-paste below URL in your browser
http://localhost:4200
To run project in prod mode i.e. make loopback server to serve angular app.
- Build your angular app to generate static content for loopback.
- Go to Angular folder i.e.
/angular6-contact-book/client
- Run build cmd
ng build
- Once build is done, you will get to see
angular6-contact-book/client/dist
is generated.
- Go to Angular folder i.e.
- Now simply run loopback server i.e. go to project root folder
angular6-contact-book
and run below cmd,npm start
you will get to see below message when server is up,
Web server listening at: http://localhost:3000
Browse your REST API at http://localhost:3000/explorer
To run Loopback server just copy-paste below URL in your browser
http://localhost:3000/
Now both Loopback and Angular runs at http://localhost:3000
Make sure you have downloaded all the needed dependencies, if not then go to project root folder angular6-contact-book
and run below cmd
npm install
Running Api test is very easy, as we have already setup npm script so all you need to do is just go to Project root
angular6-contact-book
and run below cmd
npm test
This project has been developed by keeping in mind to serve as Tutorial for new users to these technologies.
One can go through the each feature branch merged to develop, where it contains step wise code in commits along with readme file explaining each and every step.
Table of Content for DOCs in learning order :
- creating-loopback-app.md
- test-api-setup.md
- angular6-setup.md
- angular-material-setup.md
- creating-angular6-app.md
- integrate-loopback-angular.md
NOTE : All the above mentioned files are present in
/docs
folder under root folder.
-
Loopback (creating-loopback-app.md)
- How to setup loopback
- Creating loopback API server
- Creating new Data Source
- Creating new Model and generating REST API
- Running server
- Running API explorer
-
Backend Testing (test-api-setup.md)
- Setting up Mocha (the testing framework).
- Setting up Chai for assertions.
- Setting up Chai-http for testing HTTP API request
- Creating new Data Source for test
- Setting up test file
- Writing test
- Writing negative tests.
- Writing test for edge cases.
- Creating Database after running Test
- Running Test
- Running test via npm
-
Angular6 Setup (angular6-setup.md)
- Installing Angular CLI
- Creating new Angular6 App
- Running your Angular project
-
Angular Material Setup (angular-material-setup.md)
- Installing angular material
- Creating material module
- Adding material icons
- Adding material theme
-
Creating Contact Book Angular App (creating-angular6-app.md)
- Creating Thumbnail Component
- Creating Contact Class for strong typing
- Creating mock data file
- Creating contact service
- Creating thumbnail-list component
- Using thumbnail component as child component in thumbnail-list component.
- Using Service for CRUD
- Creating Add catalog Component.
- Creating edit catalog component
- Passing data from parent to child component.
- Passing data from child to parent component.
- Setting up router module.
- Created Not found component for invalid path routes.
-
Integrating Loopback-Angular app (integrate-loopback-angular.md)
- Setting up proxy in Angular to communicate at 3000 from 4200 port.
- Making Http get request in Angular to fetch data from backend using loopback API.
- Making Http post request in Angular to create data in backend using loopback API.
- Making Http put request in Angular to update data in backend using loopback API.
- Making Http delete request in Angular to delete data from backend using loopback API.
- Generate angular app build.
- Serving static angular app build from loopback server.
- Add grunt/gulp/webpack the task runner.
- Deploy project on Heroku.
- Angular6 Unit testing.
- Angular6 E2E testing.
- Creating list-view component.
- Frontend Validations.
- Backend custom validation like restrict duplicate phone entry.
- Writing Custom backend API.
- Add image uploader.