Mission Control Dashboard - Initial implementation
This commit is contained in:
40
node_modules/motion-dom/dist/es/animation/waapi/start-waapi-animation.mjs
generated
vendored
Normal file
40
node_modules/motion-dom/dist/es/animation/waapi/start-waapi-animation.mjs
generated
vendored
Normal file
@@ -0,0 +1,40 @@
|
||||
import { activeAnimations } from '../../stats/animation-count.mjs';
|
||||
import { statsBuffer } from '../../stats/buffer.mjs';
|
||||
import { mapEasingToNativeEasing } from './easing/map-easing.mjs';
|
||||
|
||||
function startWaapiAnimation(element, valueName, keyframes, { delay = 0, duration = 300, repeat = 0, repeatType = "loop", ease = "easeOut", times, } = {}, pseudoElement = undefined) {
|
||||
const keyframeOptions = {
|
||||
[valueName]: keyframes,
|
||||
};
|
||||
if (times)
|
||||
keyframeOptions.offset = times;
|
||||
const easing = mapEasingToNativeEasing(ease, duration);
|
||||
/**
|
||||
* If this is an easing array, apply to keyframes, not animation as a whole
|
||||
*/
|
||||
if (Array.isArray(easing))
|
||||
keyframeOptions.easing = easing;
|
||||
if (statsBuffer.value) {
|
||||
activeAnimations.waapi++;
|
||||
}
|
||||
const options = {
|
||||
delay,
|
||||
duration,
|
||||
easing: !Array.isArray(easing) ? easing : "linear",
|
||||
fill: "both",
|
||||
iterations: repeat + 1,
|
||||
direction: repeatType === "reverse" ? "alternate" : "normal",
|
||||
};
|
||||
if (pseudoElement)
|
||||
options.pseudoElement = pseudoElement;
|
||||
const animation = element.animate(keyframeOptions, options);
|
||||
if (statsBuffer.value) {
|
||||
animation.finished.finally(() => {
|
||||
activeAnimations.waapi--;
|
||||
});
|
||||
}
|
||||
return animation;
|
||||
}
|
||||
|
||||
export { startWaapiAnimation };
|
||||
//# sourceMappingURL=start-waapi-animation.mjs.map
|
||||
Reference in New Issue
Block a user