A library for loading spinner for Angular 4/5/6/7.
Branch: master
Clone or download
Latest commit 469e820 Jan 24, 2019



A library for loading spinner specifically for Angular 4/5/6/7. (https://napster2210.github.io/ngx-spinner/)

ng5 Support Support Support License devDependency Status

What's New

  • Latest update for Angular 7 🎉🎉🥳🥳
  • Fullscreen Mode(Enable/Disable)

The version 1.x supports Angular 4. UPDATE: Now works with Angular 4(v1.2.0)

Angular 4 Angular 5 Angular 6/7
>= v1.2.0 >= v2.0.0 >= v7.0.0

Table of contents

Browser Support

Chrome Firefox IE Safari Opera
Latest ✔ Latest ✔ 10+ ✔ Latest ✔ Latest ✔


Working Demo


ngx-spinner is available via npm and yarn

Using npm:

$ npm install ngx-spinner --save

Using yarn:

$ yarn add ngx-spinner


Import NgxSpinnerModule in in the root module(AppModule):

// Import library module
import { NgxSpinnerModule } from 'ngx-spinner';

  imports: [
    // ...
export class AppModule { }

Add NgxSpinnerService service wherever you want to use the ngx-spinner.

import { NgxSpinnerService } from 'ngx-spinner';

class AppComponent implements OnInit {
  constructor(private spinner: NgxSpinnerService) { }

  ngOnInit() {
    /** spinner starts on init */

    setTimeout(() => {
        /** spinner ends after 5 seconds */
    }, 5000);

Now use in your template


See Demo

NgxSpinner Service

  • NgxSpinnerService.show() Shows the spinner
  • NgxSpinnerService.hide() Hides the spinner

NgxSpinner Component

 <p style="font-size: 20px; color: white">Loading...</p>
  • [bdColor]: RGBA color format. To set background-color for backdrop, default rgba(51,51,51,0.8) where aplha value(0.8) is opacity of backdrop
  • [size]: Anyone from small, default, medium, large. To set size of spinner, default large
  • [color]: Any css color format. To set color of spinner, default #fff
  • [type]: Choose any animation spinner from Load Awesome. To set type of spinner, default ball-scale-multiple
  • [fullScreen]: true or false To enable/disable fullscreen mode(overlay), default true
  • Note: You can pass HTML code as loading text now, instead of input parameter(loadingText). Check above code for reference.

How to use type?

  • Go to the Load Awesome.
  • Select any animation, copy name of animation, replace all spaces with hyphen(-) and all letters should be lowercase.
    • Let's say if I select "Ball 8bits" animation then type will be ball-8bits.
    • For more information you can check it out Demo


ngx-spinner will be maintained under the Semantic Versioning guidelines. Releases will be numbered with the following format:


For more information on SemVer, please visit http://semver.org.


Yuvraj Chauhan

Future Plan

  • Interceptor Implementation (Coming soon)
  • Multiple Spinner Support
  • Configurable option using service


Inspired by Load Awesome by Daniel Cardoso.


The MIT License (MIT)