Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jiayihu/ng-animate
🌙 A collection of cool, reusable and flexible animations for Angular 14+
https://github.com/jiayihu/ng-animate
angular animations
Last synced: 1 day ago
JSON representation
🌙 A collection of cool, reusable and flexible animations for Angular 14+
- Host: GitHub
- URL: https://github.com/jiayihu/ng-animate
- Owner: jiayihu
- License: mit
- Created: 2017-07-28T09:13:12.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2023-02-04T14:08:14.000Z (almost 2 years ago)
- Last Synced: 2025-01-17T09:04:16.568Z (9 days ago)
- Topics: angular, animations
- Language: TypeScript
- Homepage: https://jiayihu.github.io/ng-animate/
- Size: 5.12 MB
- Stars: 719
- Watchers: 17
- Forks: 73
- Open Issues: 17
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
- my-awesome-list - ng-animate
- awesome-angular-components - ng-animate - 🌙 A collection of cool, reusable and flexible animations for Angular 4.2+ (Uncategorized / Uncategorized)
- awesome-angular-components - ng-animate - 🌙 A collection of cool, reusable and flexible animations for Angular 4.2+ (Uncategorized / Uncategorized)
README
# 🌙 ng-animate
[![npm](https://img.shields.io/npm/v/ng-animate.svg)](https://www.npmjs.com/package/ng-animate)
`ng-animate` is a collection of cool, reusable and flexible animations for Angular. It implements all the animations in [animate.css](https://daneden.github.io/animate.css/), but with the power and flexibility of [Angular animations](https://angular.io/guide/animations) instead of CSS.
## Demo
The demo of the animations is available at [https://jiayihu.github.io/ng-animate/](https://jiayihu.github.io/ng-animate/).
## Usage
```
npm install ng-animate --save
```## Example
Import the animation from the package and pass it to your Angular component using [useAnimation](https://angular.io/api/animations/useAnimation):
```javascript
// my-component.component.ts
import { trigger, transition, useAnimation } from '@angular/animations';
import { bounce } from 'ng-animate';@Component({
selector: 'my-component',
templateUrl: 'my-component.component.html',
animations: [
trigger('bounce', [transition('* => *', useAnimation(bounce))])
],
})
export class MyComponent {
bounce: any;
}
``````html
```**Note**: Make sure to have included `BrowserAnimationsModule` in your `AppModule` and the [web-animation.js](https://github.com/web-animations/web-animations-js) polyfill.
It's also possible to import only a subset of the animations:
```javascript
import { bounce } from 'ng-animate/lib/bouncing';
```### Animation params
**All the animations** provided by `ng-animate` support at least two **optional** params `timing` and `delay` to specify the animation duration and delay. Default value for `timing` is usually `1`s and `0`s for `delay`.
You can pass the `params` object using the Javascript API or within the component template:```javascript
@Component({
selector: 'my-component',
templateUrl: 'my-component.component.html',
animations: [
trigger('bounce', [transition('* => *', useAnimation(bounce, {
// Set the duration to 5seconds and delay to 2seconds
params: { timing: 5, delay: 2 }
}))])
],
})
export class MyComponent {}
```Using a template can achieve the same result, but you'll have access to the component context:
```html
```## Animations
All the animations are organized by their group. Many of them have additional params other than `timing/delay`: refer to [Advanced Usage](#advanced-params) for more details. Nevertheless you can probably ignore them if you're happy with how they are by default.
### Attention seekers
- `bounce`
- `flash`
- `pulse`
- `rubberBand`
- `shakeX`
- `shakeY`
- `headShake`
- `swing`
- `tada`
- `wobble`
- `jello`
- `heartBeat`### Back
- `backInDown`
- `backInLeft`
- `backInRight`
- `backInUp`- `backOutDown`
- `backOutLeft`
- `backOutRight`
- `backOutUp`### Bouncing
- `bounceIn`
- `bounceOut`. Additional param: `scale`The following bouncing animations have additional params `a, b, c, d` for `translate`
- `bounceInDown`
- `bounceInLeft`
- `bounceInRight`
- `bounceInUp`- `bounceOutDown`
- `bounceOutLeft`
- `bounceOutRight`
- `bounceOutUp`### Fading
All fading animations have additional params `fromOpacity`, `toOpacity` for `opacity` transition and `a, b` for `translate`.
- `fadeIn`
- `fadeInDown`
- `fadeInLeft`
- `fadeInRight`
- `fadeInUp`- `fadeInDownBig`
- `fadeInLeftBig`
- `fadeInRightBig`
- `fadeInUpBig`- `fadeOut`
- `fadeOutDown`
- `fadeOutLeft`
- `fadeOutRight`
- `fadeOutUp`- `fadeOutDownBig`
- `fadeOutLeftBig`
- `fadeOutRightBig`
- `fadeOutUpBig`The following fading animations do not have `a, b` for `translate` but `fromX`,`fromY`,`toX`,`toY` instead.
- `fadeInTopLeft`
- `fadeInTopRight`
- `fadeInBottomLeft`
- `fadeInBottomRight`- `fadeOutTopLeft`
- `fadeOutTopRight`
- `fadeOutBottomLeft`
- `fadeOutBottomRight`### Sliding
Sliding animations are basically fading animations without a change of `opacity`. They can also receive the same params.
- `slideInDown`
- `slideInLeft`
- `slideInRight`
- `slideInUp`
- `slideOutDown`
- `slideOutLeft`
- `slideOutRight`
- `slideOutUp`### Flippers
- `flip`
- `flipInX`
- `flipInY`
- `flipOutX`
- `flipOutY`### LightSpeed
- `lightSpeedIn`
- `lightSpeedLeft`
- `lightSpeedIn`
- `lightSpeedOut`
- `lightSpeedOutRight` (same as `lightSpeedOut`)
- `lightSpeedOutLeft`### Rotating
All rotating animations have additional params `fromOpacity`, `toOpacity` for `opacity` transition, `origin` for `transform-origin` and `degrees` for `rotate3d`.
- `rotateIn`
- `rotateInDownLeft`
- `rotateInDownRight`
- `rotateInUpLeft`
- `rotateInUpRight`
- `rotateOut`
- `rotateOutDownLeft`
- `rotateOutDownRight`
- `rotateOutUpLeft`
- `rotateOutUpRight`### Specials
- `jackInTheBox`
- `hinge`
- `rollIn`
- `rollOut`### Zooming
- `zoomIn`
- `zoomOut`The following zooming animations have additional params `a, b` for `translate`
- `zoomInDown`
- `zoomInLeft`
- `zoomInRight`
- `zoomInUp`- `zoomOutDown`
- `zoomOutLeft`
- `zoomOutRight`
- `zoomOutUp`## Advanced params
Many of the animations support also other params like `scale`, `fromOpacity`, `toOpacity` and much more, allowing extremely flexible usage and customization if you're not happy with default values.
Single letters like `a, b, c, d` are used for the steps of some animations: `a` is the starting value, `d` is the ending.
The animated property they refer to depends on the animation and the direction: usually `translate` on axis Y from `-Down/-Up`, axis X for `-Left/-Right`.```javascript
useAnimation(bounceInDown, {
params: {
timing: 5,// Specify granular values for `translate` on axis Y during 'bounceInDown'
a: '-3000px',
b: '25px',
c: '-10px',
d: '5px',
}
})
```