Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kuuurt13/ng-block-ui
Block UI Loader/Spinner for Angular
https://github.com/kuuurt13/ng-block-ui
angular block-ui blocking loader loading spinner
Last synced: 2 months ago
JSON representation
Block UI Loader/Spinner for Angular
- Host: GitHub
- URL: https://github.com/kuuurt13/ng-block-ui
- Owner: kuuurt13
- License: mit
- Created: 2017-02-21T02:06:51.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2023-12-01T02:47:26.000Z (about 1 year ago)
- Last Synced: 2024-04-14T07:47:58.344Z (9 months ago)
- Topics: angular, block-ui, blocking, loader, loading, spinner
- Language: TypeScript
- Homepage:
- Size: 2.55 MB
- Stars: 144
- Watchers: 4
- Forks: 24
- Open Issues: 17
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-angular - ng-block-ui - Block UI For Angular. (Uncategorized / Uncategorized)
- awesome-angular - ng-block-ui - Block UI Loader/Spinner for Angular. (Table of contents / Third Party Components)
- fucking-awesome-angular - ng-block-ui - Block UI Loader/Spinner for Angular. (Table of contents / Third Party Components)
- fucking-awesome-angular - ng-block-ui - Block UI Loader/Spinner for Angular. (Table of contents / Third Party Components)
README
# NG Block UI
A Block UI implementation for Angular
[![npm](https://img.shields.io/npm/v/ng-block-ui.svg)](https://www.npmjs.com/package/ng-block-ui)
[![npm](https://img.shields.io/npm/v/ng-block-ui/next)](https://www.npmjs.com/package/ng-block-ui/v/next)
[![npm](https://img.shields.io/npm/dm/ng-block-ui.svg)](https://www.npmjs.com/package/ng-block-ui)
[![Build Status](https://travis-ci.org/kuuurt13/ng-block-ui.svg?branch=master)](https://travis-ci.org/kuuurt13/ng-block-ui)## Installation
Add to your project via [npm](https://www.npmjs.com/package/ng-block-ui)
```bash
npm install ng-block-ui --save
```Include the `BlockUIModule` in your main app module.
```ts
// All other imports
import { BlockUIModule } from 'ng-block-ui';@NgModule({
imports: [
BlockUIModule.forRoot()
],
...
})
export class AppModule { }
```## Quick Start
Wrap your main components in your app root template with a `block-ui` component.
Import the `BlockUI` decorator into your component and declare a property with the decorator.
This decorator will auto wire this property to the main Block UI instance of your app.To start blocking your app, simply invoke the `start` method.
This method also can take a custom message to display while blocking.
Once finished call the `stop` method to stop blocking the app.```ts
import { Component } from '@angular/core';// Import BlockUI decorator & optional NgBlockUI type
import { BlockUI, NgBlockUI } from 'ng-block-ui';@Component({
selector: 'app-root',
template: `
`
})
export class AppComponent {
// Decorator wires up blockUI instance
@BlockUI() blockUI: NgBlockUI;constructor() {
this.blockUI.start('Loading...'); // Start blockingsetTimeout(() => {
this.blockUI.stop(); // Stop blocking
}, 2000);
}
```### Current Release
For more information and/or migrating to the newest version see [Releases](./RELEASES.md).
## Settings
Settings can be changed on the module level and component/directive level. Also, in some cases settings can be overwritten via the method level.
### Default Message
A default message can be configured to be shown instead of passing a message each time to the `start` method. The default message will be shown any time blocking is activated.
| Setting | Type | Description |
| --------- | -------- | ---------------------------------------------- |
| `message` | `string` | Custom message to be displayed while blocking. |#### Module Level
```ts
@NgModule({
imports: [
BlockUIModule.forRoot({
message: 'Default Message'
})
],
...
})
export class AppModule { }
```#### Component Level
```html
```
#### Method Level
```ts
@Component({
...,
template: `
`
})
export class Cmp {
@BlockUI() blockUI: NgBlockUI;defaultMessage() {
this.blockUI.start(); // "Default Message" will display
}customMessage() {
this.blockUI.start('Updating...'); // "Updating..." will display
}
}
```### Delay Start/Stop
When blocking with fast service calls the block overlay can flicker for a small amount of time.
To prevent this a `delayStart` and a `delayStop` can be configured to prevent this scenario.| Setting | Type | Description |
| ------------ | -------- | ----------------------------------------------------------------- |
| `delayStart` | `number` | Waits given amount of milliseconds before starting to block. |
| `delayStop` | `number` | Waits given amount of milliseconds before stopping current block. |#### Module Level
```ts
@NgModule({
imports: [
BlockUIModule.forRoot({
delayStart: 500,
delayStop: 500
})
],
...
})
export class AppModule { }
```#### Component Level
```html
```
### Custom Template
If you want to display other markup than the default spinner and message then you can provide a custom template.
Custom templates can be provided as a `Component` or `TemplateRef`. The template will then be used instead of the default template whenever blocking.| Setting | Type | Description |
| ---------- | ----------------------------------------- | ---------------------------------------- |
| `template` |Component | TemplateRef
| Custom template to be used when blocking |#### Component Custom Template
Create a component and declare it in your app module.
The component also will need to be added to the `entryComponents` property of the module._Example Component:_
_Note: When providing a `Component` as a template just add the `{{message}}`
interpolation to your template and it will display your default message or the message passed to the `start` method._```ts
// Template component
// Use block-ui-template class to center div if desired
@Component({
template: `
{{ message }}
`,
})
export class BlockTemplateCmp {}
```##### Module Level
```ts
@NgModule({
imports: [
BlockUIModule.forRoot({
template: BlockTemplateCmp
})
],
declarations: [
...,
BlockTemplateCmp // Declare template component
],
entryComponents: [ BlockTemplateCmp ]
})
export class AppModule { }
```##### Component Level
```ts
@Component({
selector: "app-root",
template: `
`,
})
export class AppComponent {
// Declare template component
blockTemplate: BlockTemplateCmp = BlockTemplateCmp;
}
```#### TemplateRef Custom Template
Add a `` with a template reference variable to the view. Then pass the template reference variable to the `blockUI` component using the `[template]` property.
_Note: TemplateRef templates can only be set on a Component level._
##### Component Level
```ts
@Component({
selector: "cmp",
template: `
`,
})
export class Cmp {}
```## Block UI Directive
Sometimes you want to only apply blocking to a certain element in your app.
The Block UI directive can be added to an element to apply blocking only to that specific element.Add the `*blockUI` structural directive to any element
and pass it an instance name `*blockUI="'contact-list'"`.Then in a component create a class property using the Block UI decorator with the instance name `@BlockUI('contact-list')`. This will then take care of wiring up that property to point to that specific instance in your app.
```ts
@Component({
selector: 'app-cmp',
template: `
`
})
export class AppComponent {
// Pass instance name to decorator
@BlockUI('contact-list') blockUIList: NgBlockUI;constructor() {
this.blockUIList.start('Loading...'); // Start blocking element only
this.blockUIList.stop(); // Stop blocking
}
```### Directive Settings
Angular has a specific syntax for passing properties to structural directives. Properties are passed in `key: value;` pair. To pass settings to a Block UI directive they must be passed as shown below.
```html
```## NgBlockUI Instance
### NgBlockUI Instance Properties
Below highlights all the properties that can be found on a BlockUI instance when a class property is decorated with the `@BlockUI()` decorator.
| Property | Description |
| ------------- | ------------------------------------------------------------------------------------------------------------------------------------ |
| `name` | Name of the targeted instance (defaults to main instance). |
| `isActive` | Indicates if the targeted instance is blocking. |
| `start` | Starts blocking for instance, can be passed an optional message. |
| `stop` | Stops blocking for instance. |
| `reset` | Stops blocking for all targeted instances regardless of the `delayStop` option. |
| `resetGlobal` | Stops blocking app wide for all instances regardless of the `delayStop` option. |
| `update` | Updates current instances blocking message with the passed message. |
| `unsubscribe` | Unsubscribe an instance so it no longer can be blocked. All BlockUI components/directives unsubscribe by default during `onDestroy`. |### NgBlockUI Instance Settings
Below are all the settings that can be passed as a second argument to the `@BlockUI()` decorator (`@BlockUI(, )`).
| Property | Description |
| ----------------- | -------------------------------------------------------------------------------------------------------------------------------- |
| `scopeToInstance` | When set to `true` a unique `name` will be given to the blockUI instance which will "scope" it to the parent component instance. |## BlockUIService
In some cases you may want to have more control over all the instances in you app.
Instead of declaring separate instances with the `@BlockUI()` decorator you can use the `BlockUIService`. This service allows you to easily target multiple instance across your app.| Method | Parameters | Description |
| ------------- | ---------------------------------------------------------- | ---------------------------------------------------------------------------------------- |
| `isActive` |target: string | string[]
| Indicates if the targeted instance(s) is blocking. |
| `start` |target: string | string[], message?: any
| Starts blocking for a single instance or multiple instances by passing instance name(s). |
| `stop` |target: string | string[]
| Stops blocking for a single instance or multiple instances by passing instance name(s). |
| `update` |target: string | string[], message: any
| Updates message for a single instance or multiple instances by passing instance name(s). |
| `reset` |target: string | string[]
| Resets blocking for a single instance or multiple instances by passing instance name(s). |
| `resetGlobal` |N/A
| Resets blocking app wide for all instances. |
| `unsubscribe` |target: string | string[]
| Unsubscribes a single instance or multiple instances by passing instance name(s). |## Other Modules
### [Http Module](docs/http-module.md) - Automatically block during http requests
### [Router Module](docs/router-module.md) - Prevent route changes while blocking
## Guides
### [SystemJS Config](docs/systemjs-config.md)
## Examples
### BlockUI Component - [Stackblitz](https://stackblitz.com/github/kuuurt13/ng-block-ui/tree/master/examples/default)
### BlockUI Component Default Message - [Stackblitz](https://stackblitz.com/github/kuuurt13/ng-block-ui/tree/master/examples/default-message)
### BlockUI Directive - [Stackblitz](https://stackblitz.com/github/kuuurt13/ng-block-ui/tree/master/examples/directive)
### BlockUI Custom Spinner Styles - [Stackblitz](https://stackblitz.com/github/kuuurt13/ng-block-ui/tree/master/examples/custom-spinner-styles)
### BlockUI Custom Template - [Stackblitz](https://stackblitz.com/github/kuuurt13/ng-block-ui/tree/master/examples/custom-template)