Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mpalourdio/ng-http-loader
:dango: Smart angular HTTP interceptor - Intercepts automagically HTTP requests and shows a spinkit spinner / loader / progress bar
https://github.com/mpalourdio/ng-http-loader
angular angular2 http http-interceptor interceptor loader ng-http-loader progress-bar spinkit spinkit-components spinner
Last synced: 2 days ago
JSON representation
:dango: Smart angular HTTP interceptor - Intercepts automagically HTTP requests and shows a spinkit spinner / loader / progress bar
- Host: GitHub
- URL: https://github.com/mpalourdio/ng-http-loader
- Owner: mpalourdio
- License: mit
- Created: 2017-04-14T11:04:12.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2025-01-18T10:45:16.000Z (8 days ago)
- Last Synced: 2025-01-23T04:05:12.745Z (3 days ago)
- Topics: angular, angular2, http, http-interceptor, interceptor, loader, ng-http-loader, progress-bar, spinkit, spinkit-components, spinner
- Language: TypeScript
- Homepage:
- Size: 5.53 MB
- Stars: 351
- Watchers: 14
- Forks: 65
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- my-awesome-list - ng-http-loader - Intercepts automagically HTTP requests and shows a spinkit spinner / loader / progress bar | mpalourdio | 351 | (TypeScript)
- awesome-angular - ng-http-loader - Angular http interceptor - intercepts automatically all http requests and shows a spinkit spinner / loader / progress bar. (Uncategorized / Uncategorized)
- awesome-angular - ng-http-loader - Smart Angular HTTP interceptor - Intercepts automagically HTTP requests and shows a spinkit spinner / loader / progress bar. (Table of contents / Angular)
- fucking-awesome-angular - ng-http-loader - Smart Angular HTTP interceptor - Intercepts automagically HTTP requests and shows a spinkit spinner / loader / progress bar. (Table of contents / Angular)
- fucking-awesome-angular - ng-http-loader - Smart Angular HTTP interceptor - Intercepts automagically HTTP requests and shows a spinkit spinner / loader / progress bar. (Table of contents / Angular)
README
# ng-http-loader
[![CI](https://github.com/mpalourdio/ng-http-loader/actions/workflows/main.yml/badge.svg)](https://github.com/mpalourdio/ng-http-loader/actions/workflows/main.yml)
[![Coverage Status](https://coveralls.io/repos/github/mpalourdio/ng-http-loader/badge.svg?branch=master)](https://coveralls.io/github/mpalourdio/ng-http-loader?branch=master)
[![npm](https://img.shields.io/npm/v/ng-http-loader.svg)](https://www.npmjs.com/package/ng-http-loader)
[![npm](https://img.shields.io/npm/dm/ng-http-loader.svg)](https://www.npmjs.com/package/ng-http-loader)
[![npm](https://img.shields.io/npm/dt/ng-http-loader.svg)](https://www.npmjs.com/package/ng-http-loader)## Changelog
[Please read the changelog](CHANGELOG.md)
## Contributing
Use the fork, Luke. PR without tests will likely not be merged.
## Installation
To install this library, run:
```bash
$ npm install ng-http-loader --save / yarn add ng-http-loader
```## What does it do ?
This package provides an HTTP Interceptor, and some spinner components (All from [SpinKit](https://github.com/tobiasahlin/SpinKit) at the moment).
The HTTP interceptor listens to all HTTP requests and shows a spinner / loader indicator during pending HTTP requests.## Angular Compatibility
| ng-http-loader | Angular |
|----------------|---------|
| >=0.1.0 <0.4.0 | ^4.3.0 |
| >=0.4.0 <1.0.0 | ^5.0.0 |
| >=1.0.0 <3.2.0 | ^6.0.0 |
| >=3.2.0 <5.1.0 | ^7.0.0 |
| >=6.0.0 <7.0.0 | ^8.0.0 |
| >=7.0.0 <8.0.0 | ^9.0.0 |
| >=8.0.0 <9.0.0 | ^10.0.0 |
| >=9.0.0 | ^11.0.0 |
| >=10.0.0 | ^12.0.0 |
| >=11.0.0 | ^13.0.0 |
| >=12.0.0 | ^14.0.0 |
| >=13.0.0 | ^15.0.0 |
| >=14.0.0 | ^16.0.0 |
| >=15.0.0 | ^17.0.0 |
| >=16.0.0 | ^18.0.0 |
| >=17.0.0 | ^19.0.0 |If you experience errors like below, **please double-check the version you use.**
`ERROR in Error: Metadata version mismatch for module [...]/angular/node_modules/ng-http-loader/ng-http-loader.module.d.ts, found version x, expected y [...]`
## Requirements - HttpClient
Performing HTTP requests with the `HttpClient` API is **mandatory**. Otherwise, the spinner will not be fired **at all**.
## Usage
From your Angular root component (`app.component.ts` for example):
```typescript
@Component({
selector: 'app-root',
standalone: true,
templateUrl: './app.component.html',
styleUrls: ['./app.component.scss'],
imports: [NgHttpLoaderComponent] <====== import the component
})
```In your `app.component.html`, simply add:
```xml```
At last, configure your `ApplicationConfig` like following:```typescript
import { ApplicationConfig, importProvidersFrom } from '@angular/core';
import { provideRouter } from '@angular/router';
import { NgHttpLoaderModule } from 'ng-http-loader';
import { routes } from './app.routes';
import { provideHttpClient, withInterceptors } from '@angular/common/http';
import { pendingRequestsInterceptor$ } from 'ng-http-loader';export const appConfig: ApplicationConfig = {
providers: [
provideRouter(routes),
provideHttpClient(withInterceptors([pendingRequestsInterceptor$])),
],
};
```## Customizing the spinner
You can customize the following parameters:
- The spinner **backdrop** (visible by default).
- The **background-color** (ie. the color of the spinner itself).
- The **debounce delay** (ie. after how many milliseconds the spinner will be visible, if needed).
- The **extra duration** (ie. how many extra milliseconds should the spinner be visible).
- The **minimum duration** (ie. how many milliseconds should the spinner be visible at least).
- The spinner **opacity**.
- The backdrop **background-color** (ie. the color of the spinner backdrop, if enabled).
- The **spinner type**.```xml
```
**_To specify the spinner type this way, you must reference the `Spinkit` const as a public property in your app.component.ts_**:
```typescript
import { Component } from '@angular/core';
import { Spinkit } from 'ng-http-loader'; // <============@Component({
selector: 'app-root',
standalone: true,
templateUrl: './app.component.html',
styleUrls: ['./app.component.css'],
imports: [NgHttpLoaderComponent]
})
export class AppComponent {
public spinkit = Spinkit; // <============
}
```
The different spinners available are referenced in [this file](src/lib/spinkits.ts).**_Otherwise, you can reference the spinner type as a simple string_**:
```xml
```
## Defining your own spinner
You can define your own spinner component in place of the built-in ones. The needed steps are:
- Create your component
- Reference your component as a public property in your `app.component.ts`
- Reference the predefined property in the ng-http-loader `entryComponent` component selector like this:
```typescript
import { Component } from '@angular/core';
import { AwesomeComponent } from 'my.awesome.component';@Component({
selector: 'app-root',
standalone: true,
templateUrl: './app.component.html',
styleUrls: ['./app.component.css'],
imports: [NgHttpLoaderComponent]
})
export class AppComponent {
public awesomeComponent = AwesomeComponent;
}
```
```xml```
You can find some examples [here](https://gist.github.com/mpalourdio/2c0bec03d610b24ff49db649fbb69a48) and [here](https://gist.github.com/mpalourdio/e05b4495de2abeeecfcf92d70e4ef93e).
## Requests filtering by URL, HTTP method or HTTP headers
You can filter the HTTP requests that shouldn't be caught by the interceptor by providing **an array of regex patterns**:
```xml```
You can filter the HTTP requests by providing **an array of HTTP methods** (case insensitive):
```xml```
You can also filter the HTTP requests by providing **an array of HTTP headers** (case insensitive):
```xml```
## Manually show and hide the spinner
You can manually show and hide the spinner if needed. You must use the `SpinnerVisibilityService` for this purpose.
Sometimes, when manually showing the spinner, an HTTP request could be performed in background, and when finished, the spinner would automagically disappear.
**For this reason, when calling `SpinnerVisibilityService#show()`, it prevents the HTTP interceptor from being triggered unless you explicitly call `SpinnerVisibilityService#hide()`.**
```typescript
import { Component } from '@angular/core';
import { SpinnerVisibilityService } from 'ng-http-loader';@Component({
selector: 'my-component',
templateUrl: './my.component.html',
styleUrls: ['./my.component.css'],
})
export class MyComponent {constructor(private spinner: SpinnerVisibilityService) {
// show the spinner
spinner.show();
//////////////
// HTTP requests performed between show && hide won't have any side effect on the spinner.
/////////////
// hide the spinner
spinner.hide();
}
}
```## Internet explorer or Safari problem ?
Just use a [real browser](https://download.mozilla.org).
## Misc
Each Spinkit component defined in [SPINKIT_COMPONENTS](src/lib/spinkits.ts#L30) can be used individually.
## Credits
[Tobias Ahlin](https://github.com/tobiasahlin), the awesome creator of [SpinKit](https://github.com/tobiasahlin/SpinKit).
[David Herges](https://github.com/dherges), the awesome developer of [ng-packagr](https://github.com/dherges/ng-packagr).