animations
A simple to learn and use API for custom animations in HTML5; supporting Typescript, ES and UMD.
See 'installation' for obtaining the API.
See 'usage' for learning how to use the API.
installation
Simply install the repository using npm.
#Assuming you are in your project's directory
npm i @dyrektrypt/animations
And that's it! Now all you need to do is import desired custom animations.
Please note:
- For Typescript - the tsconfig property
moduleResolution: node
should be present in order to support npm imports. - For ES modules - code should be transpiled to UMD or similar variants by using either webpack, rollup or browserify.
usage
Custom animations work similar to the normal DOM Animation
object but add extra functionality; controlling how properties change - rather than just changing properties over a set interval.
Animations come with at least two methods:
- (async) play - start and run the animation, using the
playClassValue
. - (async) halt - stop and reset the animation, using the
haltClassValue
.
To use animations, create an instance of the desired custom animation, which follows the constructor:
constructor(elements: Array<HTMLElement>, animationConfig: AnimationConfig)
Noting AnimationConfig
being an object with properties:
playClassValue: string = ''
haltClassValue: string = ''
interval: number
The current custom animations are as follows:
- LoadAnimation:
- play - loads properties linearly, detaching the
haltClassValue
and attaching theplayClassValue
after a setinterval
. - halt - unloads elements linearly, detaching the
playClassValue
and attaching thehaltClassValue
.
- play - loads properties linearly, detaching the
- BlinkAnimation:
- play - makes properties blink, switching between the
playClassValue
and then thehaltClassValue
every setinterval
. - halt - stops the elements from blinking, detaching the
playClassValue
and attaching thehaltClassValue
.
- play - makes properties blink, switching between the
New custom animations are always welcome!
To enforce good coding conventions, animations change only the class
property on HTML elements. However animations are declarative, and will only change values defined in the constructor - preventing the need to hard code all class names in an instance.
An example of this:
HTML5
<input class="main-input hidden"/>
ES6
import { BlinkAnimation } from '@dyrektrypt/animations'
//Fetch all 'main-input' elements
let elements = document.getElementByClassName('main-input')
//Create a new blinking animation
let blinkAnimation = new BlinkAnimation(elements, {
haltClassValue: 'hidden', //The value for halting will be 'hidden'
interval: 100 //The animation will be called every 100ms
})
blinkAnimation.play()
This will cause the input field to start 'blinking', switching between being 'hidden'
and ''
.
Notice how only the 'hidden'
is declared in the constructor, this causes 'main-input'
to remain untouched.