Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@exercism/active-background

Package Overview
Dependencies
Maintainers
3
Versions
7
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@exercism/active-background - npm Package Compare versions

Comparing version 0.2.0 to 0.3.0

LICENSE

20

dist/ActiveBackground.d.ts

@@ -1,3 +0,17 @@

import * as React from 'react';
import { IActiveBackground } from './index';
export declare const ActiveBackground: React.FC<IActiveBackground>;
import type { ReactNode } from 'react';
export declare type PatternOptions = Record<string, unknown>;
export interface PatternConstructor<TOptions> {
new (canvas: HTMLCanvasElement, options?: TOptions): ActiveBackgroundPattern;
}
export interface ActiveBackgroundPattern {
render(): void;
start(): void;
stop(): void;
}
export interface ActiveBackgroundProps<TPatternOptions = PatternOptions> {
Pattern: PatternConstructor<TPatternOptions>;
patternOptions?: TPatternOptions;
className?: string;
children: ReactNode;
}
export declare function ActiveBackground({ Pattern, patternOptions, className, children }: ActiveBackgroundProps): JSX.Element;

49

dist/ActiveBackground.js

@@ -8,5 +8,5 @@ "use strict";

});
exports.ActiveBackground = void 0;
exports.ActiveBackground = ActiveBackground;
var React = _interopRequireWildcard(require("react"));
var _react = _interopRequireWildcard(require("react"));

@@ -31,24 +31,23 @@ var _useResizeObserver = require("./hooks/useResizeObserver");

var ActiveBackground = function ActiveBackground(_ref) {
var pattern = _ref.pattern,
_ref$patternOptions = _ref.patternOptions,
patternOptions = _ref$patternOptions === void 0 ? {} : _ref$patternOptions,
function ActiveBackground(_ref) {
var Pattern = _ref.Pattern,
patternOptions = _ref.patternOptions,
className = _ref.className,
children = _ref.children;
var _React$useState = React.useState(null),
_React$useState2 = _slicedToArray(_React$useState, 2),
canvasRef = _React$useState2[0],
setRef = _React$useState2[1];
var _useState = (0, _react.useState)(null),
_useState2 = _slicedToArray(_useState, 2),
canvasRef = _useState2[0],
setRef = _useState2[1];
var onRefSet = React.useCallback(function (ref) {
var onRefSet = (0, _react.useCallback)(function (ref) {
return setRef(ref);
}, [setRef]);
var _React$useState3 = React.useState({}),
_React$useState4 = _slicedToArray(_React$useState3, 2),
update = _React$useState4[0],
setUpdate = _React$useState4[1];
var _useState3 = (0, _react.useState)({}),
_useState4 = _slicedToArray(_useState3, 2),
update = _useState4[0],
setUpdate = _useState4[1];
var updateCanvasSizeAndPosition = React.useCallback(function () {
var updateCanvasSizeAndPosition = (0, _react.useCallback)(function () {
var _canvasRef$parentElem, _canvasRef$parentElem2, _canvasRef$parentElem3, _canvasRef$parentElem4, _canvasRef$parentElem5, _canvasRef$parentElem6, _canvasRef$parentElem7, _canvasRef$parentElem8;

@@ -69,3 +68,3 @@

React.useEffect(updateCanvasSizeAndPosition, [updateCanvasSizeAndPosition]);
(0, _react.useEffect)(updateCanvasSizeAndPosition, [updateCanvasSizeAndPosition]);
(0, _useResizeObserver.useResizeObserver)({

@@ -75,3 +74,3 @@ target: canvasRef === null || canvasRef === void 0 ? void 0 : canvasRef.parentElement,

});
React.useEffect(function () {
(0, _react.useEffect)(function () {
if (!canvasRef) {

@@ -81,3 +80,3 @@ return;

var background = new pattern(canvasRef, patternOptions);
var background = new Pattern(canvasRef, patternOptions);
background.start();

@@ -87,6 +86,6 @@ return function () {

};
}, [canvasRef, pattern, patternOptions, update]);
}, [canvasRef, Pattern, patternOptions, update]);
var selfClassName = 'active-background-canvas';
className = className ? "".concat(className, " ").concat(selfClassName) : selfClassName;
return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("canvas", {
return /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, /*#__PURE__*/_react["default"].createElement("canvas", {
style: {

@@ -97,3 +96,3 @@ position: 'absolute'

ref: onRefSet
}), /*#__PURE__*/React.createElement("div", {
}), /*#__PURE__*/_react["default"].createElement("div", {
style: {

@@ -103,5 +102,3 @@ position: 'relative'

}, children));
};
exports.ActiveBackground = ActiveBackground;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9BY3RpdmVCYWNrZ3JvdW5kLnRzeCJdLCJuYW1lcyI6WyJBY3RpdmVCYWNrZ3JvdW5kIiwicGF0dGVybiIsInBhdHRlcm5PcHRpb25zIiwiY2xhc3NOYW1lIiwiY2hpbGRyZW4iLCJSZWFjdCIsInVzZVN0YXRlIiwiY2FudmFzUmVmIiwic2V0UmVmIiwib25SZWZTZXQiLCJ1c2VDYWxsYmFjayIsInJlZiIsInVwZGF0ZSIsInNldFVwZGF0ZSIsInVwZGF0ZUNhbnZhc1NpemVBbmRQb3NpdGlvbiIsInN0eWxlIiwiaGVpZ2h0IiwicGFyZW50RWxlbWVudCIsIm9mZnNldEhlaWdodCIsIndpZHRoIiwib2Zmc2V0V2lkdGgiLCJ0b3AiLCJvZmZzZXRUb3AiLCJsZWZ0Iiwib2Zmc2V0TGVmdCIsIndpbmRvdyIsImRldmljZVBpeGVsUmF0aW8iLCJ1c2VFZmZlY3QiLCJ0YXJnZXQiLCJjYWxsYmFjayIsImJhY2tncm91bmQiLCJzdGFydCIsInN0b3AiLCJzZWxmQ2xhc3NOYW1lIiwicG9zaXRpb24iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUFBOztBQUNBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFHTyxJQUFNQSxnQkFBNkMsR0FBRyxTQUFoREEsZ0JBQWdELE9BS3ZEO0FBQUEsTUFKSkMsT0FJSSxRQUpKQSxPQUlJO0FBQUEsaUNBSEpDLGNBR0k7QUFBQSxNQUhKQSxjQUdJLG9DQUhhLEVBR2I7QUFBQSxNQUZKQyxTQUVJLFFBRkpBLFNBRUk7QUFBQSxNQURKQyxRQUNJLFFBREpBLFFBQ0k7O0FBQUEsd0JBQ3dCQyxLQUFLLENBQUNDLFFBQU4sQ0FBeUMsSUFBekMsQ0FEeEI7QUFBQTtBQUFBLE1BQ0dDLFNBREg7QUFBQSxNQUNjQyxNQURkOztBQUVKLE1BQU1DLFFBQVEsR0FBR0osS0FBSyxDQUFDSyxXQUFOLENBQWtCLFVBQUNDLEdBQUQ7QUFBQSxXQUFTSCxNQUFNLENBQUNHLEdBQUQsQ0FBZjtBQUFBLEdBQWxCLEVBQXdDLENBQUNILE1BQUQsQ0FBeEMsQ0FBakI7O0FBRkkseUJBR3dCSCxLQUFLLENBQUNDLFFBQU4sQ0FBZSxFQUFmLENBSHhCO0FBQUE7QUFBQSxNQUdHTSxNQUhIO0FBQUEsTUFHV0MsU0FIWDs7QUFLSixNQUFNQywyQkFBMkIsR0FBR1QsS0FBSyxDQUFDSyxXQUFOLENBQWtCLFlBQU07QUFBQTs7QUFDMUQsUUFBSSxDQUFDSCxTQUFMLEVBQWdCO0FBQ2Q7QUFDRDs7QUFFREEsSUFBQUEsU0FBUyxDQUFDUSxLQUFWLENBQWdCQyxNQUFoQixzQ0FBNEJULFNBQVMsQ0FBQ1UsYUFBdEMsMERBQTRCLHNCQUF5QkMsWUFBckQ7QUFDQVgsSUFBQUEsU0FBUyxDQUFDUSxLQUFWLENBQWdCSSxLQUFoQix1Q0FBMkJaLFNBQVMsQ0FBQ1UsYUFBckMsMkRBQTJCLHVCQUF5QkcsV0FBcEQ7QUFDQWIsSUFBQUEsU0FBUyxDQUFDUSxLQUFWLENBQWdCTSxHQUFoQix1Q0FBeUJkLFNBQVMsQ0FBQ1UsYUFBbkMsMkRBQXlCLHVCQUF5QkssU0FBbEQ7QUFDQWYsSUFBQUEsU0FBUyxDQUFDUSxLQUFWLENBQWdCUSxJQUFoQix1Q0FBMEJoQixTQUFTLENBQUNVLGFBQXBDLDJEQUEwQix1QkFBeUJPLFVBQW5EO0FBQ0FqQixJQUFBQSxTQUFTLENBQUNTLE1BQVYsdURBQ0VULFNBQVMsQ0FBQ1UsYUFEWiwyREFDRSx1QkFBeUJDLFlBRDNCLDJFQUMyQyxJQUFJTyxNQUFNLENBQUNDLGdCQUR0RDtBQUVBbkIsSUFBQUEsU0FBUyxDQUFDWSxLQUFWLHVEQUNFWixTQUFTLENBQUNVLGFBRFosMkRBQ0UsdUJBQXlCRyxXQUQzQiwyRUFDMEMsSUFBSUssTUFBTSxDQUFDQyxnQkFEckQ7QUFHQWIsSUFBQUEsU0FBUyxDQUFDLEVBQUQsQ0FBVDtBQUNELEdBZm1DLEVBZWpDLENBQUNOLFNBQUQsRUFBWU0sU0FBWixDQWZpQyxDQUFwQyxDQUxJLENBc0JKOztBQUNBUixFQUFBQSxLQUFLLENBQUNzQixTQUFOLENBQWdCYiwyQkFBaEIsRUFBNkMsQ0FBQ0EsMkJBQUQsQ0FBN0M7QUFFQSw0Q0FBa0I7QUFDaEJjLElBQUFBLE1BQU0sRUFBRXJCLFNBQUYsYUFBRUEsU0FBRix1QkFBRUEsU0FBUyxDQUFFVSxhQURIO0FBRWhCWSxJQUFBQSxRQUFRLEVBQUVmO0FBRk0sR0FBbEI7QUFLQVQsRUFBQUEsS0FBSyxDQUFDc0IsU0FBTixDQUFnQixZQUFNO0FBQ3BCLFFBQUksQ0FBQ3BCLFNBQUwsRUFBZ0I7QUFDZDtBQUNEOztBQUVELFFBQU11QixVQUFvQyxHQUFHLElBQUk3QixPQUFKLENBQzNDTSxTQUQyQyxFQUUzQ0wsY0FGMkMsQ0FBN0M7QUFLQTRCLElBQUFBLFVBQVUsQ0FBQ0MsS0FBWDtBQUVBLFdBQU8sWUFBTTtBQUNYRCxNQUFBQSxVQUFVLENBQUNFLElBQVg7QUFDRCxLQUZEO0FBR0QsR0FmRCxFQWVHLENBQUN6QixTQUFELEVBQVlOLE9BQVosRUFBcUJDLGNBQXJCLEVBQXFDVSxNQUFyQyxDQWZIO0FBaUJBLE1BQU1xQixhQUFhLEdBQUcsMEJBQXRCO0FBQ0E5QixFQUFBQSxTQUFTLEdBQUdBLFNBQVMsYUFBTUEsU0FBTixjQUFtQjhCLGFBQW5CLElBQXFDQSxhQUExRDtBQUNBLHNCQUNFLHVEQUNFO0FBQ0UsSUFBQSxLQUFLLEVBQUU7QUFBRUMsTUFBQUEsUUFBUSxFQUFFO0FBQVosS0FEVDtBQUVFLElBQUEsU0FBUyxFQUFFL0IsU0FGYjtBQUdFLElBQUEsR0FBRyxFQUFFTTtBQUhQLElBREYsZUFNRTtBQUFLLElBQUEsS0FBSyxFQUFFO0FBQUV5QixNQUFBQSxRQUFRLEVBQUU7QUFBWjtBQUFaLEtBQXVDOUIsUUFBdkMsQ0FORixDQURGO0FBVUQsQ0FoRU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBSZWFjdCBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZVJlc2l6ZU9ic2VydmVyIH0gZnJvbSAnLi9ob29rcy91c2VSZXNpemVPYnNlcnZlcidcbmltcG9ydCB7IElBY3RpdmVCYWNrZ3JvdW5kLCBJQWN0aXZlQmFja2dyb3VuZFBhdHRlcm4gfSBmcm9tICcuL2luZGV4J1xuXG5leHBvcnQgY29uc3QgQWN0aXZlQmFja2dyb3VuZDogUmVhY3QuRkM8SUFjdGl2ZUJhY2tncm91bmQ+ID0gKHtcbiAgcGF0dGVybixcbiAgcGF0dGVybk9wdGlvbnMgPSB7fSxcbiAgY2xhc3NOYW1lLFxuICBjaGlsZHJlbixcbn0pID0+IHtcbiAgY29uc3QgW2NhbnZhc1JlZiwgc2V0UmVmXSA9IFJlYWN0LnVzZVN0YXRlPEhUTUxDYW52YXNFbGVtZW50IHwgbnVsbD4obnVsbClcbiAgY29uc3Qgb25SZWZTZXQgPSBSZWFjdC51c2VDYWxsYmFjaygocmVmKSA9PiBzZXRSZWYocmVmKSwgW3NldFJlZl0pXG4gIGNvbnN0IFt1cGRhdGUsIHNldFVwZGF0ZV0gPSBSZWFjdC51c2VTdGF0ZSh7fSlcblxuICBjb25zdCB1cGRhdGVDYW52YXNTaXplQW5kUG9zaXRpb24gPSBSZWFjdC51c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgaWYgKCFjYW52YXNSZWYpIHtcbiAgICAgIHJldHVyblxuICAgIH1cblxuICAgIGNhbnZhc1JlZi5zdHlsZS5oZWlnaHQgPSBgJHtjYW52YXNSZWYucGFyZW50RWxlbWVudD8ub2Zmc2V0SGVpZ2h0fXB4YFxuICAgIGNhbnZhc1JlZi5zdHlsZS53aWR0aCA9IGAke2NhbnZhc1JlZi5wYXJlbnRFbGVtZW50Py5vZmZzZXRXaWR0aH1weGBcbiAgICBjYW52YXNSZWYuc3R5bGUudG9wID0gYCR7Y2FudmFzUmVmLnBhcmVudEVsZW1lbnQ/Lm9mZnNldFRvcH1weGBcbiAgICBjYW52YXNSZWYuc3R5bGUubGVmdCA9IGAke2NhbnZhc1JlZi5wYXJlbnRFbGVtZW50Py5vZmZzZXRMZWZ0fXB4YFxuICAgIGNhbnZhc1JlZi5oZWlnaHQgPVxuICAgICAgY2FudmFzUmVmLnBhcmVudEVsZW1lbnQ/Lm9mZnNldEhlaWdodCA/PyAwICogd2luZG93LmRldmljZVBpeGVsUmF0aW9cbiAgICBjYW52YXNSZWYud2lkdGggPVxuICAgICAgY2FudmFzUmVmLnBhcmVudEVsZW1lbnQ/Lm9mZnNldFdpZHRoID8/IDAgKiB3aW5kb3cuZGV2aWNlUGl4ZWxSYXRpb1xuXG4gICAgc2V0VXBkYXRlKHt9KVxuICB9LCBbY2FudmFzUmVmLCBzZXRVcGRhdGVdKVxuXG4gIC8vIFNldCBjYW52YXMgdG8gc2l6ZSBhbmQgcG9zaXRpb24gb2YgcGFyZW50IGVsZW1lbnRcbiAgUmVhY3QudXNlRWZmZWN0KHVwZGF0ZUNhbnZhc1NpemVBbmRQb3NpdGlvbiwgW3VwZGF0ZUNhbnZhc1NpemVBbmRQb3NpdGlvbl0pXG5cbiAgdXNlUmVzaXplT2JzZXJ2ZXIoe1xuICAgIHRhcmdldDogY2FudmFzUmVmPy5wYXJlbnRFbGVtZW50LFxuICAgIGNhbGxiYWNrOiB1cGRhdGVDYW52YXNTaXplQW5kUG9zaXRpb24sXG4gIH0pXG5cbiAgUmVhY3QudXNlRWZmZWN0KCgpID0+IHtcbiAgICBpZiAoIWNhbnZhc1JlZikge1xuICAgICAgcmV0dXJuXG4gICAgfVxuXG4gICAgY29uc3QgYmFja2dyb3VuZDogSUFjdGl2ZUJhY2tncm91bmRQYXR0ZXJuID0gbmV3IHBhdHRlcm4oXG4gICAgICBjYW52YXNSZWYsXG4gICAgICBwYXR0ZXJuT3B0aW9uc1xuICAgIClcblxuICAgIGJhY2tncm91bmQuc3RhcnQoKVxuXG4gICAgcmV0dXJuICgpID0+IHtcbiAgICAgIGJhY2tncm91bmQuc3RvcCgpXG4gICAgfVxuICB9LCBbY2FudmFzUmVmLCBwYXR0ZXJuLCBwYXR0ZXJuT3B0aW9ucywgdXBkYXRlXSlcblxuICBjb25zdCBzZWxmQ2xhc3NOYW1lID0gJ2FjdGl2ZS1iYWNrZ3JvdW5kLWNhbnZhcydcbiAgY2xhc3NOYW1lID0gY2xhc3NOYW1lID8gYCR7Y2xhc3NOYW1lfSAke3NlbGZDbGFzc05hbWV9YCA6IHNlbGZDbGFzc05hbWVcbiAgcmV0dXJuIChcbiAgICA8PlxuICAgICAgPGNhbnZhc1xuICAgICAgICBzdHlsZT17eyBwb3NpdGlvbjogJ2Fic29sdXRlJyB9fVxuICAgICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgICAgcmVmPXtvblJlZlNldH1cbiAgICAgIC8+XG4gICAgICA8ZGl2IHN0eWxlPXt7IHBvc2l0aW9uOiAncmVsYXRpdmUnIH19PntjaGlsZHJlbn08L2Rpdj5cbiAgICA8Lz5cbiAgKVxufVxuIl19
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9BY3RpdmVCYWNrZ3JvdW5kLnRzeCJdLCJuYW1lcyI6WyJBY3RpdmVCYWNrZ3JvdW5kIiwiUGF0dGVybiIsInBhdHRlcm5PcHRpb25zIiwiY2xhc3NOYW1lIiwiY2hpbGRyZW4iLCJjYW52YXNSZWYiLCJzZXRSZWYiLCJvblJlZlNldCIsInJlZiIsInVwZGF0ZSIsInNldFVwZGF0ZSIsInVwZGF0ZUNhbnZhc1NpemVBbmRQb3NpdGlvbiIsInN0eWxlIiwiaGVpZ2h0IiwicGFyZW50RWxlbWVudCIsIm9mZnNldEhlaWdodCIsIndpZHRoIiwib2Zmc2V0V2lkdGgiLCJ0b3AiLCJvZmZzZXRUb3AiLCJsZWZ0Iiwib2Zmc2V0TGVmdCIsIndpbmRvdyIsImRldmljZVBpeGVsUmF0aW8iLCJ0YXJnZXQiLCJjYWxsYmFjayIsImJhY2tncm91bmQiLCJzdGFydCIsInN0b3AiLCJzZWxmQ2xhc3NOYW1lIiwicG9zaXRpb24iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUNBOztBQUNBOzs7Ozs7Ozs7Ozs7Ozs7Ozs7QUF1Qk8sU0FBU0EsZ0JBQVQsT0FBZ0g7QUFBQSxNQUFwRkMsT0FBb0YsUUFBcEZBLE9BQW9GO0FBQUEsTUFBM0VDLGNBQTJFLFFBQTNFQSxjQUEyRTtBQUFBLE1BQTNEQyxTQUEyRCxRQUEzREEsU0FBMkQ7QUFBQSxNQUFoREMsUUFBZ0QsUUFBaERBLFFBQWdEOztBQUFBLGtCQUN6RixxQkFBbUMsSUFBbkMsQ0FEeUY7QUFBQTtBQUFBLE1BQzlHQyxTQUQ4RztBQUFBLE1BQ25HQyxNQURtRzs7QUFFckgsTUFBTUMsUUFBUSxHQUFHLHdCQUFZLFVBQUNDLEdBQUQ7QUFBQSxXQUFTRixNQUFNLENBQUNFLEdBQUQsQ0FBZjtBQUFBLEdBQVosRUFBa0MsQ0FBQ0YsTUFBRCxDQUFsQyxDQUFqQjs7QUFGcUgsbUJBR3pGLHFCQUFTLEVBQVQsQ0FIeUY7QUFBQTtBQUFBLE1BRzlHRyxNQUg4RztBQUFBLE1BR3RHQyxTQUhzRzs7QUFLckgsTUFBTUMsMkJBQTJCLEdBQUcsd0JBQVksWUFBTTtBQUFBOztBQUNwRCxRQUFJLENBQUNOLFNBQUwsRUFBZ0I7QUFDZDtBQUNEOztBQUVEQSxJQUFBQSxTQUFTLENBQUNPLEtBQVYsQ0FBZ0JDLE1BQWhCLHNDQUE0QlIsU0FBUyxDQUFDUyxhQUF0QywwREFBNEIsc0JBQXlCQyxZQUFyRDtBQUNBVixJQUFBQSxTQUFTLENBQUNPLEtBQVYsQ0FBZ0JJLEtBQWhCLHVDQUEyQlgsU0FBUyxDQUFDUyxhQUFyQywyREFBMkIsdUJBQXlCRyxXQUFwRDtBQUNBWixJQUFBQSxTQUFTLENBQUNPLEtBQVYsQ0FBZ0JNLEdBQWhCLHVDQUF5QmIsU0FBUyxDQUFDUyxhQUFuQywyREFBeUIsdUJBQXlCSyxTQUFsRDtBQUNBZCxJQUFBQSxTQUFTLENBQUNPLEtBQVYsQ0FBZ0JRLElBQWhCLHVDQUEwQmYsU0FBUyxDQUFDUyxhQUFwQywyREFBMEIsdUJBQXlCTyxVQUFuRDtBQUNBaEIsSUFBQUEsU0FBUyxDQUFDUSxNQUFWLHVEQUNFUixTQUFTLENBQUNTLGFBRFosMkRBQ0UsdUJBQXlCQyxZQUQzQiwyRUFDMkMsSUFBSU8sTUFBTSxDQUFDQyxnQkFEdEQ7QUFFQWxCLElBQUFBLFNBQVMsQ0FBQ1csS0FBVix1REFDRVgsU0FBUyxDQUFDUyxhQURaLDJEQUNFLHVCQUF5QkcsV0FEM0IsMkVBQzBDLElBQUlLLE1BQU0sQ0FBQ0MsZ0JBRHJEO0FBR0FiLElBQUFBLFNBQVMsQ0FBQyxFQUFELENBQVQ7QUFDRCxHQWZtQyxFQWVqQyxDQUFDTCxTQUFELEVBQVlLLFNBQVosQ0FmaUMsQ0FBcEMsQ0FMcUgsQ0FzQnJIOztBQUNBLHdCQUFVQywyQkFBVixFQUF1QyxDQUFDQSwyQkFBRCxDQUF2QztBQUVBLDRDQUFrQjtBQUNoQmEsSUFBQUEsTUFBTSxFQUFFbkIsU0FBRixhQUFFQSxTQUFGLHVCQUFFQSxTQUFTLENBQUVTLGFBREg7QUFFaEJXLElBQUFBLFFBQVEsRUFBRWQ7QUFGTSxHQUFsQjtBQUtBLHdCQUFVLFlBQU07QUFDZCxRQUFJLENBQUNOLFNBQUwsRUFBZ0I7QUFDZDtBQUNEOztBQUVELFFBQU1xQixVQUFVLEdBQUcsSUFBSXpCLE9BQUosQ0FDakJJLFNBRGlCLEVBRWpCSCxjQUZpQixDQUFuQjtBQUtBd0IsSUFBQUEsVUFBVSxDQUFDQyxLQUFYO0FBRUEsV0FBTyxZQUFNO0FBQ1hELE1BQUFBLFVBQVUsQ0FBQ0UsSUFBWDtBQUNELEtBRkQ7QUFHRCxHQWZELEVBZUcsQ0FBQ3ZCLFNBQUQsRUFBWUosT0FBWixFQUFxQkMsY0FBckIsRUFBcUNPLE1BQXJDLENBZkg7QUFpQkEsTUFBTW9CLGFBQWEsR0FBRywwQkFBdEI7QUFDQTFCLEVBQUFBLFNBQVMsR0FBR0EsU0FBUyxhQUFNQSxTQUFOLGNBQW1CMEIsYUFBbkIsSUFBcUNBLGFBQTFEO0FBQ0Esc0JBQ0UsK0VBQ0U7QUFDRSxJQUFBLEtBQUssRUFBRTtBQUFFQyxNQUFBQSxRQUFRLEVBQUU7QUFBWixLQURUO0FBRUUsSUFBQSxTQUFTLEVBQUUzQixTQUZiO0FBR0UsSUFBQSxHQUFHLEVBQUVJO0FBSFAsSUFERixlQU1FO0FBQUssSUFBQSxLQUFLLEVBQUU7QUFBRXVCLE1BQUFBLFFBQVEsRUFBRTtBQUFaO0FBQVosS0FBdUMxQixRQUF2QyxDQU5GLENBREY7QUFVRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgUmVhY3QsIHsgdXNlQ2FsbGJhY2ssIHVzZUVmZmVjdCwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZVJlc2l6ZU9ic2VydmVyIH0gZnJvbSAnLi9ob29rcy91c2VSZXNpemVPYnNlcnZlcidcblxuZXhwb3J0IHR5cGUgUGF0dGVybk9wdGlvbnMgPSBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPlxuZXhwb3J0IGludGVyZmFjZSBQYXR0ZXJuQ29uc3RydWN0b3I8VE9wdGlvbnM+IHtcbiAgbmV3IChcbiAgICBjYW52YXM6IEhUTUxDYW52YXNFbGVtZW50LFxuICAgIG9wdGlvbnM/OiBUT3B0aW9uc1xuICApOiBBY3RpdmVCYWNrZ3JvdW5kUGF0dGVyblxufVxuZXhwb3J0IGludGVyZmFjZSBBY3RpdmVCYWNrZ3JvdW5kUGF0dGVybiB7XG4gIHJlbmRlcigpOiB2b2lkXG4gIHN0YXJ0KCk6IHZvaWRcbiAgc3RvcCgpOiB2b2lkXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQWN0aXZlQmFja2dyb3VuZFByb3BzPFRQYXR0ZXJuT3B0aW9ucyA9IFBhdHRlcm5PcHRpb25zPiB7XG4gIFBhdHRlcm46IFBhdHRlcm5Db25zdHJ1Y3RvcjxUUGF0dGVybk9wdGlvbnM+XG4gIHBhdHRlcm5PcHRpb25zPzogVFBhdHRlcm5PcHRpb25zXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICBjaGlsZHJlbjogUmVhY3ROb2RlXG59XG5cblxuZXhwb3J0IGZ1bmN0aW9uIEFjdGl2ZUJhY2tncm91bmQoeyBQYXR0ZXJuLCBwYXR0ZXJuT3B0aW9ucywgY2xhc3NOYW1lLCBjaGlsZHJlbiB9OiBBY3RpdmVCYWNrZ3JvdW5kUHJvcHMpOiBKU1guRWxlbWVudCB7XG4gIGNvbnN0IFtjYW52YXNSZWYsIHNldFJlZl0gPSB1c2VTdGF0ZTxIVE1MQ2FudmFzRWxlbWVudCB8IG51bGw+KG51bGwpXG4gIGNvbnN0IG9uUmVmU2V0ID0gdXNlQ2FsbGJhY2soKHJlZikgPT4gc2V0UmVmKHJlZiksIFtzZXRSZWZdKVxuICBjb25zdCBbdXBkYXRlLCBzZXRVcGRhdGVdID0gdXNlU3RhdGUoe30pXG5cbiAgY29uc3QgdXBkYXRlQ2FudmFzU2l6ZUFuZFBvc2l0aW9uID0gdXNlQ2FsbGJhY2soKCkgPT4ge1xuICAgIGlmICghY2FudmFzUmVmKSB7XG4gICAgICByZXR1cm5cbiAgICB9XG5cbiAgICBjYW52YXNSZWYuc3R5bGUuaGVpZ2h0ID0gYCR7Y2FudmFzUmVmLnBhcmVudEVsZW1lbnQ/Lm9mZnNldEhlaWdodH1weGBcbiAgICBjYW52YXNSZWYuc3R5bGUud2lkdGggPSBgJHtjYW52YXNSZWYucGFyZW50RWxlbWVudD8ub2Zmc2V0V2lkdGh9cHhgXG4gICAgY2FudmFzUmVmLnN0eWxlLnRvcCA9IGAke2NhbnZhc1JlZi5wYXJlbnRFbGVtZW50Py5vZmZzZXRUb3B9cHhgXG4gICAgY2FudmFzUmVmLnN0eWxlLmxlZnQgPSBgJHtjYW52YXNSZWYucGFyZW50RWxlbWVudD8ub2Zmc2V0TGVmdH1weGBcbiAgICBjYW52YXNSZWYuaGVpZ2h0ID1cbiAgICAgIGNhbnZhc1JlZi5wYXJlbnRFbGVtZW50Py5vZmZzZXRIZWlnaHQgPz8gMCAqIHdpbmRvdy5kZXZpY2VQaXhlbFJhdGlvXG4gICAgY2FudmFzUmVmLndpZHRoID1cbiAgICAgIGNhbnZhc1JlZi5wYXJlbnRFbGVtZW50Py5vZmZzZXRXaWR0aCA/PyAwICogd2luZG93LmRldmljZVBpeGVsUmF0aW9cblxuICAgIHNldFVwZGF0ZSh7fSlcbiAgfSwgW2NhbnZhc1JlZiwgc2V0VXBkYXRlXSlcblxuICAvLyBTZXQgY2FudmFzIHRvIHNpemUgYW5kIHBvc2l0aW9uIG9mIHBhcmVudCBlbGVtZW50XG4gIHVzZUVmZmVjdCh1cGRhdGVDYW52YXNTaXplQW5kUG9zaXRpb24sIFt1cGRhdGVDYW52YXNTaXplQW5kUG9zaXRpb25dKVxuXG4gIHVzZVJlc2l6ZU9ic2VydmVyKHtcbiAgICB0YXJnZXQ6IGNhbnZhc1JlZj8ucGFyZW50RWxlbWVudCxcbiAgICBjYWxsYmFjazogdXBkYXRlQ2FudmFzU2l6ZUFuZFBvc2l0aW9uLFxuICB9KVxuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKCFjYW52YXNSZWYpIHtcbiAgICAgIHJldHVyblxuICAgIH1cblxuICAgIGNvbnN0IGJhY2tncm91bmQgPSBuZXcgUGF0dGVybihcbiAgICAgIGNhbnZhc1JlZixcbiAgICAgIHBhdHRlcm5PcHRpb25zXG4gICAgKVxuXG4gICAgYmFja2dyb3VuZC5zdGFydCgpXG5cbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgYmFja2dyb3VuZC5zdG9wKClcbiAgICB9XG4gIH0sIFtjYW52YXNSZWYsIFBhdHRlcm4sIHBhdHRlcm5PcHRpb25zLCB1cGRhdGVdKVxuXG4gIGNvbnN0IHNlbGZDbGFzc05hbWUgPSAnYWN0aXZlLWJhY2tncm91bmQtY2FudmFzJ1xuICBjbGFzc05hbWUgPSBjbGFzc05hbWUgPyBgJHtjbGFzc05hbWV9ICR7c2VsZkNsYXNzTmFtZX1gIDogc2VsZkNsYXNzTmFtZVxuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICA8Y2FudmFzXG4gICAgICAgIHN0eWxlPXt7IHBvc2l0aW9uOiAnYWJzb2x1dGUnIH19XG4gICAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgICByZWY9e29uUmVmU2V0fVxuICAgICAgLz5cbiAgICAgIDxkaXYgc3R5bGU9e3sgcG9zaXRpb246ICdyZWxhdGl2ZScgfX0+e2NoaWxkcmVufTwvZGl2PlxuICAgIDwvPlxuICApXG59XG4iXX0=

@@ -1,5 +0,3 @@

import { IActiveBackgroundPattern, ActiveBackgroundPatternOptions } from '../index';
import { ConfettiPaper } from './Confetti/ConfettiPaper';
import { ConfettiRibbon } from './Confetti/ConfettiRibbon';
interface ConfettiOptions extends ActiveBackgroundPatternOptions {
import type { ActiveBackgroundPattern, PatternOptions } from '../ActiveBackground';
export interface ConfettiOptions extends PatternOptions {
speed?: number;

@@ -11,13 +9,13 @@ duration?: number;

}
declare class Confetti implements IActiveBackgroundPattern {
canvas: HTMLCanvasElement;
context: CanvasRenderingContext2D | null;
ratio: number;
width: number;
height: number;
speed: number;
duration: number;
confettiPapers: ConfettiPaper[];
confettiRibbons: ConfettiRibbon[];
animationFrameRequestId: number | null;
export declare class Confetti implements ActiveBackgroundPattern {
private readonly canvas;
private readonly context;
private readonly ratio;
readonly width: number;
readonly height: number;
private readonly speed;
private readonly duration;
private readonly confettiPapers;
private readonly confettiRibbons;
private animationFrameRequestId;
constructor(canvas: HTMLCanvasElement, options?: ConfettiOptions);

@@ -28,2 +26,1 @@ start(): void;

}
export { Confetti };

@@ -67,3 +67,3 @@ "use strict";

parent: _this,
fetchColors: fetchRandomColor
fetchColors: getRandomColors
});

@@ -75,3 +75,3 @@ });

parent: _this,
fetchColors: fetchRandomColor
fetchColors: getRandomColors
});

@@ -142,10 +142,7 @@ });

function getRandomColors(colors) {
function getRandomColors() {
var colors = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : COLORS;
var randomIndex = Math.round(Math.random() * (colors.length - 1));
return colors[randomIndex];
}
function fetchRandomColor() {
return getRandomColors(COLORS);
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/ActiveBackground/Confetti.ts"],"names":["SPEED","DEFAULT_CONFETTI_PAPERS","DEFAULT_CONFETTI_RIBBONS","DEFAULT_SCALE_CONFETTI_COUNT","COLORS","Confetti","canvas","options","context","getContext","speed","duration","ratio","window","devicePixelRatio","width","offsetWidth","height","offsetHeight","confettiPaperCount","scaleConfettiCount","Math","round","confettiPapers","Array","map","ConfettiPaper","parent","fetchColors","fetchRandomColor","confettiRibbonCount","confettiRibbons","ConfettiRibbon","animationFrameRequestId","requestAnimationFrame","render","bind","cancelAnimationFrame","clearRect","confettiPaper","update","draw","confettiRibbon","getRandomColors","colors","randomIndex","random","length"],"mappings":"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","sourcesContent":["import {\n  IActiveBackgroundPattern,\n  ActiveBackgroundPatternOptions,\n} from '../index'\nimport { ConfettiPaper } from './Confetti/ConfettiPaper'\nimport { ConfettiRibbon } from './Confetti/ConfettiRibbon'\n\ninterface ConfettiOptions extends ActiveBackgroundPatternOptions {\n  speed?: number\n  duration?: number\n  confettiPaperCount?: number\n  scaleConfettiCount?: boolean\n  confettiRibbonCount?: number\n}\n\nconst SPEED = 50\nconst DEFAULT_CONFETTI_PAPERS = 50\nconst DEFAULT_CONFETTI_RIBBONS = 10\nconst DEFAULT_SCALE_CONFETTI_COUNT = true\n\nconst COLORS = [\n  ['#df0049', '#660671'],\n  ['#00e857', '#005291'],\n  ['#2bebbc', '#05798a'],\n  ['#ffd200', '#b06c00'],\n]\n\nclass Confetti implements IActiveBackgroundPattern {\n  canvas: HTMLCanvasElement\n  context: CanvasRenderingContext2D | null\n\n  ratio: number\n  width: number\n  height: number\n\n  speed: number\n  duration: number\n  confettiPapers: ConfettiPaper[]\n  confettiRibbons: ConfettiRibbon[]\n\n  animationFrameRequestId: number | null\n\n  constructor(canvas: HTMLCanvasElement, options: ConfettiOptions = {}) {\n    this.canvas = canvas\n    this.context = canvas.getContext('2d')\n\n    this.speed = options?.speed ?? SPEED\n    this.duration = options?.duration ?? 1.0 / this.speed\n\n    this.ratio = window.devicePixelRatio\n    this.width = canvas.offsetWidth * this.ratio\n    this.height = canvas.offsetHeight * this.ratio\n\n    let confettiPaperCount =\n      options?.confettiPaperCount ?? DEFAULT_CONFETTI_PAPERS\n\n    if (options?.scaleConfettiCount ?? DEFAULT_SCALE_CONFETTI_COUNT) {\n      confettiPaperCount = Math.round(confettiPaperCount / this.ratio)\n    }\n\n    this.confettiPapers = [...new Array(confettiPaperCount)].map(() => {\n      return new ConfettiPaper({\n        parent: this,\n        fetchColors: fetchRandomColor,\n      })\n    })\n\n    let confettiRibbonCount =\n      options?.confettiRibbonCount ?? DEFAULT_CONFETTI_RIBBONS\n\n    this.confettiRibbons = [...new Array(confettiRibbonCount)].map(() => {\n      return new ConfettiRibbon({\n        parent: this,\n        fetchColors: fetchRandomColor,\n      })\n    })\n\n    this.animationFrameRequestId = null\n  }\n\n  start() {\n    this.animationFrameRequestId = requestAnimationFrame(this.render.bind(this))\n  }\n\n  stop() {\n    if (this.animationFrameRequestId) {\n      cancelAnimationFrame(this.animationFrameRequestId)\n    }\n  }\n\n  render() {\n    if (!this.context) {\n      return\n    }\n\n    this.context.clearRect(0, 0, this.canvas.width, this.canvas.height)\n\n    for (const confettiPaper of this.confettiPapers) {\n      confettiPaper.update(this.duration)\n      confettiPaper.draw(this.context)\n    }\n\n    for (const confettiRibbon of this.confettiRibbons) {\n      confettiRibbon.update(this.duration)\n      confettiRibbon.draw(this.context)\n    }\n\n    this.animationFrameRequestId = requestAnimationFrame(this.render.bind(this))\n  }\n}\n\nfunction getRandomColors(colors: string[][]) {\n  const randomIndex = Math.round(Math.random() * (colors.length - 1))\n  return colors[randomIndex]\n}\n\nfunction fetchRandomColor() {\n  return getRandomColors(COLORS)\n}\n\nexport { Confetti }\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/ActiveBackground/Confetti.ts"],"names":["SPEED","DEFAULT_CONFETTI_PAPERS","DEFAULT_CONFETTI_RIBBONS","DEFAULT_SCALE_CONFETTI_COUNT","COLORS","Confetti","canvas","options","context","getContext","speed","duration","ratio","window","devicePixelRatio","width","offsetWidth","height","offsetHeight","confettiPaperCount","scaleConfettiCount","Math","round","confettiPapers","Array","map","ConfettiPaper","parent","fetchColors","getRandomColors","confettiRibbonCount","confettiRibbons","ConfettiRibbon","animationFrameRequestId","requestAnimationFrame","render","bind","cancelAnimationFrame","clearRect","confettiPaper","update","draw","confettiRibbon","colors","randomIndex","random","length"],"mappings":"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","sourcesContent":["import type { ActiveBackgroundPattern, PatternOptions } from '../ActiveBackground'\nimport { ConfettiPaper } from './Confetti/ConfettiPaper'\nimport { ConfettiRibbon } from './Confetti/ConfettiRibbon'\n\nexport interface ConfettiOptions extends PatternOptions {\n  speed?: number\n  duration?: number\n  confettiPaperCount?: number\n  scaleConfettiCount?: boolean\n  confettiRibbonCount?: number\n}\n\nconst SPEED = 50\nconst DEFAULT_CONFETTI_PAPERS = 50\nconst DEFAULT_CONFETTI_RIBBONS = 10\nconst DEFAULT_SCALE_CONFETTI_COUNT = true\n\nconst COLORS = [\n  ['#df0049', '#660671'],\n  ['#00e857', '#005291'],\n  ['#2bebbc', '#05798a'],\n  ['#ffd200', '#b06c00'],\n]\n\nexport class Confetti implements ActiveBackgroundPattern {\n  private readonly canvas: HTMLCanvasElement\n  private readonly context: CanvasRenderingContext2D | null\n\n  private readonly ratio: number\n  public readonly width: number\n  public readonly height: number\n\n  private readonly speed: number\n  private readonly duration: number\n  private readonly confettiPapers: ConfettiPaper[]\n  private readonly confettiRibbons: ConfettiRibbon[]\n\n  private animationFrameRequestId: number | null\n\n  constructor(canvas: HTMLCanvasElement, options: ConfettiOptions = {}) {\n    this.canvas = canvas\n    this.context = canvas.getContext('2d')\n\n    this.speed = options?.speed ?? SPEED\n    this.duration = options?.duration ?? 1.0 / this.speed\n\n    this.ratio = window.devicePixelRatio\n    this.width = canvas.offsetWidth * this.ratio\n    this.height = canvas.offsetHeight * this.ratio\n\n    let confettiPaperCount =\n      options?.confettiPaperCount ?? DEFAULT_CONFETTI_PAPERS\n\n    if (options?.scaleConfettiCount ?? DEFAULT_SCALE_CONFETTI_COUNT) {\n      confettiPaperCount = Math.round(confettiPaperCount / this.ratio)\n    }\n\n    this.confettiPapers = [...new Array(confettiPaperCount)].map(() => {\n      return new ConfettiPaper({\n        parent: this,\n        fetchColors: getRandomColors,\n      })\n    })\n\n    let confettiRibbonCount =\n      options?.confettiRibbonCount ?? DEFAULT_CONFETTI_RIBBONS\n\n    this.confettiRibbons = [...new Array(confettiRibbonCount)].map(() => {\n      return new ConfettiRibbon({\n        parent: this,\n        fetchColors: getRandomColors,\n      })\n    })\n\n    this.animationFrameRequestId = null\n  }\n\n  public start(): void {\n    this.animationFrameRequestId = requestAnimationFrame(this.render.bind(this))\n  }\n\n  public stop(): void {\n    if (this.animationFrameRequestId) {\n      cancelAnimationFrame(this.animationFrameRequestId)\n    }\n  }\n\n  public render(): void {\n    if (!this.context) {\n      return\n    }\n\n    this.context.clearRect(0, 0, this.canvas.width, this.canvas.height)\n\n    for (const confettiPaper of this.confettiPapers) {\n      confettiPaper.update(this.duration)\n      confettiPaper.draw(this.context)\n    }\n\n    for (const confettiRibbon of this.confettiRibbons) {\n      confettiRibbon.update(this.duration)\n      confettiRibbon.draw(this.context)\n    }\n\n    this.animationFrameRequestId = requestAnimationFrame(this.render.bind(this))\n  }\n}\n\nfunction getRandomColors(colors: string[][] = COLORS): string[] {\n  const randomIndex = Math.round(Math.random() * (colors.length - 1))\n  return colors[randomIndex]\n}\n"]}
import { Confetti } from '../Confetti';
import { Vector2D } from './Vector';
declare type ConfettiPaperConfig = {

@@ -7,26 +6,23 @@ parent: Confetti;

};
declare class ConfettiPaper {
position: Vector2D;
rotationSpeed: number;
angle: number;
cosRotation: number;
rotation: number;
size: number;
oscillationSpeed: number;
xVelocity: number;
yVelocity: number;
corners: Vector2D[];
time: number;
frontColor: string;
backColor: string;
parent: Confetti;
fetchColors: () => string[];
export declare class ConfettiPaper {
private readonly position;
private readonly rotationSpeed;
private readonly angle;
private cosRotation;
private rotation;
private readonly size;
private readonly oscillationSpeed;
private readonly xVelocity;
private readonly yVelocity;
private readonly corners;
private time;
private readonly frontColor;
private readonly backColor;
private readonly parent;
private readonly fetchColors;
constructor(config: ConfettiPaperConfig);
update(dt: number): void;
draw(context: CanvasRenderingContext2D): void;
computeCornerDrawPositions(): {
x: number;
y: number;
}[];
private computeCornerDrawPositions;
}
export { ConfettiPaper };
export {};

@@ -138,2 +138,2 @@ "use strict";

}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/ActiveBackground/Confetti/ConfettiPaper.ts"],"names":["DEG_360_IN_RAD","Math","PI","DEG_90_IN_RAD","DEG_45_IN_RAD","ROTATION_SPEED_VARIANCE","ROTATION_SPEED_MINIMUM","OSCILLATION_SPEED_VARIANCE","OSCILLATION_SPEED_MINIMUM","X_VELOCITY","Y_VELOCITY_VARIANCE","Y_VELOCITY_MINIMUM","ConfettiPaper","config","parent","fetchColors","position","Vector2D","random","width","height","cosRotation","angle","rotation","rotationSpeed","oscillationSpeed","xVelocity","yVelocity","time","corners","computeCorners","frontColor","backColor","size","dt","cos","x","y","context","fillStyle","computeCornerDrawPositions","firstCorner","remainingCorners","beginPath","moveTo","forEach","lineTo","closePath","fill","map","i","dx","dy","sin"],"mappings":"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","sourcesContent":["import { Confetti } from '../Confetti'\nimport { Vector2D } from './Vector'\n\ntype ConfettiPaperConfig = {\n  parent: Confetti\n  fetchColors: () => string[]\n}\n\nconst DEG_360_IN_RAD = 2 * Math.PI\nconst DEG_90_IN_RAD = Math.PI / 2\nconst DEG_45_IN_RAD = Math.PI / 4\n\nconst ROTATION_SPEED_VARIANCE = 600\nconst ROTATION_SPEED_MINIMUM = 800\nconst OSCILLATION_SPEED_VARIANCE = 1.5\nconst OSCILLATION_SPEED_MINIMUM = 0.5\nconst X_VELOCITY = 40\nconst Y_VELOCITY_VARIANCE = 60\nconst Y_VELOCITY_MINIMUM = 50\n\nclass ConfettiPaper {\n  position: Vector2D\n  rotationSpeed: number\n  angle: number\n  cosRotation: number\n  rotation: number\n  size: number\n  oscillationSpeed: number\n  xVelocity: number\n  yVelocity: number\n  corners: Vector2D[]\n  time: number\n  frontColor: string\n  backColor: string\n\n  parent: Confetti\n  fetchColors: () => string[]\n\n  constructor(config: ConfettiPaperConfig) {\n    this.parent = config.parent\n    this.fetchColors = config.fetchColors\n\n    this.position = new Vector2D(\n      Math.random() * this.parent.width,\n      Math.random() * this.parent.height\n    )\n\n    this.cosRotation = 1.0\n    this.angle = Math.random() * DEG_360_IN_RAD\n    this.rotation = Math.random() * DEG_360_IN_RAD\n    this.rotationSpeed =\n      Math.random() * ROTATION_SPEED_VARIANCE + ROTATION_SPEED_MINIMUM\n\n    this.oscillationSpeed =\n      Math.random() * OSCILLATION_SPEED_VARIANCE + OSCILLATION_SPEED_MINIMUM\n\n    this.xVelocity = X_VELOCITY\n    this.yVelocity = Math.random() * Y_VELOCITY_VARIANCE + Y_VELOCITY_MINIMUM\n    this.time = Math.random()\n\n    this.corners = computeCorners(this.angle)\n\n    const [frontColor, backColor] = this.fetchColors()\n    this.frontColor = frontColor\n    this.backColor = backColor\n    this.size = 5.0\n  }\n\n  update(dt: number) {\n    this.time += dt\n    this.rotation += this.rotationSpeed * dt\n    this.cosRotation = Math.cos((this.rotation * Math.PI) / 180)\n\n    this.position.x +=\n      Math.cos(this.time * this.oscillationSpeed) * this.xVelocity * dt\n    this.position.y += this.yVelocity * dt\n\n    // Reset paper to the top of the screen\n    if (this.position.y > this.parent.height) {\n      this.position.x = Math.random() * this.parent.width\n      this.position.y = 0\n    }\n  }\n\n  draw(context: CanvasRenderingContext2D) {\n    if (this.cosRotation > 0) {\n      context.fillStyle = this.frontColor\n    } else {\n      context.fillStyle = this.backColor\n    }\n\n    const [firstCorner, ...remainingCorners] = this.computeCornerDrawPositions()\n    context.beginPath()\n    context.moveTo(firstCorner.x, firstCorner.y)\n    remainingCorners.forEach(({ x, y }) => context.lineTo(x, y))\n    context.closePath()\n    context.fill()\n  }\n\n  computeCornerDrawPositions() {\n    return this.corners.map(({ x, y }, i) => {\n      x = this.position.x + x * this.size\n      y = this.position.y + y * this.size * this.cosRotation\n\n      return { x, y }\n    })\n  }\n}\n\nfunction computeCorners(angle: number) {\n  return [0, 1, 2, 3].map((i) => {\n    const dx = Math.cos(angle + (i * DEG_90_IN_RAD + DEG_45_IN_RAD))\n    const dy = Math.sin(angle + (i * DEG_90_IN_RAD + DEG_45_IN_RAD))\n    return new Vector2D(dx, dy)\n  })\n}\n\nexport { ConfettiPaper }\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/ActiveBackground/Confetti/ConfettiPaper.ts"],"names":["DEG_360_IN_RAD","Math","PI","DEG_90_IN_RAD","DEG_45_IN_RAD","ROTATION_SPEED_VARIANCE","ROTATION_SPEED_MINIMUM","OSCILLATION_SPEED_VARIANCE","OSCILLATION_SPEED_MINIMUM","X_VELOCITY","Y_VELOCITY_VARIANCE","Y_VELOCITY_MINIMUM","ConfettiPaper","config","parent","fetchColors","position","Vector2D","random","width","height","cosRotation","angle","rotation","rotationSpeed","oscillationSpeed","xVelocity","yVelocity","time","corners","computeCorners","frontColor","backColor","size","dt","cos","x","y","context","fillStyle","computeCornerDrawPositions","firstCorner","remainingCorners","beginPath","moveTo","forEach","lineTo","closePath","fill","map","i","dx","dy","sin"],"mappings":"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","sourcesContent":["import { Confetti } from '../Confetti'\nimport { Vector2D } from './Vector'\n\ntype ConfettiPaperConfig = {\n  parent: Confetti\n  fetchColors: () => string[]\n}\n\nconst DEG_360_IN_RAD = 2 * Math.PI\nconst DEG_90_IN_RAD = Math.PI / 2\nconst DEG_45_IN_RAD = Math.PI / 4\n\nconst ROTATION_SPEED_VARIANCE = 600\nconst ROTATION_SPEED_MINIMUM = 800\nconst OSCILLATION_SPEED_VARIANCE = 1.5\nconst OSCILLATION_SPEED_MINIMUM = 0.5\nconst X_VELOCITY = 40\nconst Y_VELOCITY_VARIANCE = 60\nconst Y_VELOCITY_MINIMUM = 50\n\ntype Position = { x: number, y: number }\ntype Positions = readonly Position[]\n\nexport class ConfettiPaper {\n  private readonly position: Vector2D\n  private readonly rotationSpeed: number\n  private readonly angle: number\n  private cosRotation: number\n  private rotation: number\n  private readonly size: number\n  private readonly oscillationSpeed: number\n  private readonly xVelocity: number\n  private readonly yVelocity: number\n  private readonly corners: Vector2D[]\n  private time: number\n  private readonly frontColor: string\n  private readonly backColor: string\n\n  private readonly parent: Confetti\n  private readonly fetchColors: () => string[]\n\n  constructor(config: ConfettiPaperConfig) {\n    this.parent = config.parent\n    this.fetchColors = config.fetchColors\n\n    this.position = new Vector2D(\n      Math.random() * this.parent.width,\n      Math.random() * this.parent.height\n    )\n\n    this.cosRotation = 1.0\n    this.angle = Math.random() * DEG_360_IN_RAD\n    this.rotation = Math.random() * DEG_360_IN_RAD\n    this.rotationSpeed =\n      Math.random() * ROTATION_SPEED_VARIANCE + ROTATION_SPEED_MINIMUM\n\n    this.oscillationSpeed =\n      Math.random() * OSCILLATION_SPEED_VARIANCE + OSCILLATION_SPEED_MINIMUM\n\n    this.xVelocity = X_VELOCITY\n    this.yVelocity = Math.random() * Y_VELOCITY_VARIANCE + Y_VELOCITY_MINIMUM\n    this.time = Math.random()\n\n    this.corners = computeCorners(this.angle)\n\n    const [frontColor, backColor] = this.fetchColors()\n    this.frontColor = frontColor\n    this.backColor = backColor\n    this.size = 5.0\n  }\n\n  public update(dt: number): void {\n    this.time += dt\n    this.rotation += this.rotationSpeed * dt\n    this.cosRotation = Math.cos((this.rotation * Math.PI) / 180)\n\n    this.position.x +=\n      Math.cos(this.time * this.oscillationSpeed) * this.xVelocity * dt\n    this.position.y += this.yVelocity * dt\n\n    // Reset paper to the top of the screen\n    if (this.position.y > this.parent.height) {\n      this.position.x = Math.random() * this.parent.width\n      this.position.y = 0\n    }\n  }\n\n  public draw(context: CanvasRenderingContext2D): void {\n    if (this.cosRotation > 0) {\n      context.fillStyle = this.frontColor\n    } else {\n      context.fillStyle = this.backColor\n    }\n\n    const [firstCorner, ...remainingCorners] = this.computeCornerDrawPositions()\n    context.beginPath()\n    context.moveTo(firstCorner.x, firstCorner.y)\n    remainingCorners.forEach(({ x, y }) => context.lineTo(x, y))\n    context.closePath()\n    context.fill()\n  }\n\n  private computeCornerDrawPositions(): Positions {\n    return this.corners.map(({ x, y }, i) => {\n      x = this.position.x + x * this.size\n      y = this.position.y + y * this.size * this.cosRotation\n\n      return { x, y }\n    })\n  }\n}\n\nfunction computeCorners(angle: number) {\n  return [0, 1, 2, 3].map((i) => {\n    const dx = Math.cos(angle + (i * DEG_90_IN_RAD + DEG_45_IN_RAD))\n    const dy = Math.sin(angle + (i * DEG_90_IN_RAD + DEG_45_IN_RAD))\n    return new Vector2D(dx, dy)\n  })\n}\n\n"]}
import { Confetti } from '../Confetti';
import { EulerMass } from './EulerMass';
import { Vector2D } from './Vector';
declare type ConfettiRibbonConfig = {

@@ -14,31 +12,31 @@ particleCount?: number;

};
declare class ConfettiRibbon {
parent: Confetti;
fetchColors: () => string[];
currPosition: Vector2D;
prevPosition: Vector2D;
particleCount: number;
particleMass: number;
particleDrag: number;
particleDistance: number;
thickness: number;
angle: number;
xOff: number;
yOff: number;
frontColor: string;
backColor: string;
time: number;
velocityInherit: number;
oscillationSpeed: number;
oscillationDistance: number;
yVelocity: number;
particles: EulerMass[];
export declare class ConfettiRibbon {
private readonly parent;
private readonly fetchColors;
private currPosition;
private prevPosition;
private readonly particleCount;
private readonly particleMass;
private readonly particleDrag;
private readonly particleDistance;
private readonly thickness;
private readonly angle;
private readonly xOff;
private readonly yOff;
private frontColor;
private backColor;
private time;
private velocityInherit;
private oscillationSpeed;
private oscillationDistance;
private yVelocity;
private particles;
constructor({ particleCount, particleMass, particleDrag, particleDistance, thickness, angle, parent, fetchColors, }: ConfettiRibbonConfig);
reset(): void;
private reset;
update(dt: number): void;
draw(context: CanvasRenderingContext2D): void;
drawFirstParticle(context: CanvasRenderingContext2D, particle: EulerMass, nextParticle: EulerMass, p0: Vector2D, p1: Vector2D): void;
drawMiddleParticle(context: CanvasRenderingContext2D, particle: EulerMass, nextParticle: EulerMass, p0: Vector2D, p1: Vector2D): void;
drawLastParticle(context: CanvasRenderingContext2D, particle: EulerMass, nextParticle: EulerMass, p0: Vector2D, p1: Vector2D): void;
private drawFirstParticle;
private drawMiddleParticle;
private drawLastParticle;
}
export { ConfettiRibbon };
export {};

@@ -233,2 +233,2 @@ "use strict";

}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/ActiveBackground/Confetti/ConfettiRibbon.ts"],"names":["VELOCITY_INHERIT_INITIAL_MAX","TIME_INITIAL_MAX","OSCILLATION_SPEED_VARIANCE","OSCILLATION_SPEED_MINIMUM","OSCILLATION_DISTANCE_VARIANCE","OSCILLATION_DISTANCE_MINIMUM","Y_VELOCITY_VARIANCE","Y_VELOCITY_MINIMUM","ConfettiRibbon","particleCount","particleMass","particleDrag","particleDistance","thickness","angle","Math","PI","parent","fetchColors","xOff","cos","yOff","sin","reset","x","random","width","y","height","currPosition","Vector2D","prevPosition","clone","frontColor","backColor","time","oscillationSpeed","oscillationDistance","velocityInherit","yVelocity","particles","Array","map","_","i","EulerMass","dt","dx","dy","dDistance","sqrt","position","index","length","directionForce","sub","normalize","multiply","addForce","integrate","rp2","subtract","add","context","particle","nextParticle","offsetVector","p0","p1","sideFacing","fillStyle","strokeStyle","drawFirstParticle","drawMiddleParticle","drawLastParticle","beginPath","moveTo","lineTo","closePath","stroke","fill","x1","y1","x2","y2","x3","y3"],"mappings":"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","sourcesContent":["import { Confetti } from '../Confetti'\nimport { EulerMass } from './EulerMass'\nimport { Vector2D } from './Vector'\n\ntype ConfettiRibbonConfig = {\n  particleCount?: number\n  particleMass?: number\n  particleDrag?: number\n  particleDistance?: number\n  thickness?: number\n  angle?: number\n  parent: Confetti\n  fetchColors: () => string[]\n}\n\nconst VELOCITY_INHERIT_INITIAL_MAX = 2\nconst TIME_INITIAL_MAX = 10\nconst OSCILLATION_SPEED_VARIANCE = 2\nconst OSCILLATION_SPEED_MINIMUM = 1.5\nconst OSCILLATION_DISTANCE_VARIANCE = 40\nconst OSCILLATION_DISTANCE_MINIMUM = 40\nconst Y_VELOCITY_VARIANCE = 40\nconst Y_VELOCITY_MINIMUM = 80\n\nclass ConfettiRibbon {\n  parent: Confetti\n  fetchColors: () => string[]\n\n  currPosition!: Vector2D\n  prevPosition!: Vector2D\n\n  particleCount: number\n  particleMass: number\n  particleDrag: number\n  particleDistance: number\n  thickness: number\n  angle: number\n\n  xOff: number\n  yOff: number\n\n  frontColor!: string\n  backColor!: string\n\n  time!: number\n  velocityInherit!: number\n  oscillationSpeed!: number\n  oscillationDistance!: number\n  yVelocity!: number\n\n  particles!: EulerMass[]\n\n  constructor({\n    particleCount = 30,\n    particleMass = 1,\n    particleDrag = 0.05,\n    particleDistance = 8.0,\n    thickness = 8.0,\n    angle = Math.PI / 4,\n    parent,\n    fetchColors,\n  }: ConfettiRibbonConfig) {\n    this.parent = parent\n    this.fetchColors = fetchColors\n\n    this.particleCount = particleCount\n    this.particleMass = particleMass\n    this.particleDrag = particleDrag\n    this.particleDistance = particleDistance\n    this.thickness = thickness\n    this.angle = angle\n\n    this.xOff = Math.cos(this.angle) * this.thickness\n    this.yOff = Math.sin(this.angle) * this.thickness\n\n    this.reset()\n  }\n\n  reset() {\n    const x = Math.random() * this.parent.width\n    const y = -1 * Math.random() * this.parent.height * 2\n\n    this.currPosition = new Vector2D(x, y)\n    this.prevPosition = this.currPosition.clone()\n\n    const [frontColor, backColor] = this.fetchColors()\n    this.frontColor = frontColor\n    this.backColor = backColor\n\n    this.time = Math.random() * TIME_INITIAL_MAX\n\n    this.oscillationSpeed =\n      Math.random() * OSCILLATION_SPEED_VARIANCE + OSCILLATION_SPEED_MINIMUM\n    this.oscillationDistance =\n      Math.random() * OSCILLATION_DISTANCE_VARIANCE +\n      OSCILLATION_DISTANCE_MINIMUM\n\n    this.velocityInherit = Math.random() * VELOCITY_INHERIT_INITIAL_MAX\n    this.yVelocity = Math.random() * Y_VELOCITY_VARIANCE + Y_VELOCITY_MINIMUM\n\n    this.particles = [...new Array(this.particleCount)].map(\n      (_, i) =>\n        new EulerMass(\n          x,\n          y - i * this.particleDistance,\n          this.particleMass,\n          this.particleDrag\n        )\n    )\n  }\n\n  update(dt: number) {\n    this.time += dt * this.oscillationSpeed\n    this.currPosition.x += Math.cos(this.time) * this.oscillationDistance * dt\n    this.currPosition.y += this.yVelocity * dt\n\n    const dx = this.prevPosition.x - this.currPosition.x\n    const dy = this.prevPosition.y - this.currPosition.y\n    const dDistance = Math.sqrt(dx * dx + dy * dy)\n\n    this.prevPosition = this.currPosition.clone()\n\n    // Update each particle's position\n    this.particles[0].position = this.currPosition\n    for (let index = 1; index < this.particles.length; index += 1) {\n      const directionForce = Vector2D.sub(\n        this.particles[index - 1].position,\n        this.particles[index].position\n      )\n        .normalize()\n        .multiply((dDistance / dt) * this.velocityInherit)\n\n      this.particles[index].addForce(directionForce)\n    }\n\n    // integrate the forces\n    for (let index = 1; index < this.particles.length; index += 1) {\n      this.particles[index].integrate(dt)\n    }\n\n    // calculate final position\n    for (let index = 1; index < this.particles.length; index += 1) {\n      const rp2 = this.particles[index].position\n        .subtract(this.particles[index - 1].position)\n        .normalize()\n        .multiply(this.particleDistance)\n        .add(this.particles[index - 1].position)\n      this.particles[index].position = rp2\n    }\n\n    if (\n      this.currPosition.y >\n      this.parent.height + this.particleDistance * this.particleCount\n    ) {\n      this.reset()\n    }\n  }\n\n  draw(context: CanvasRenderingContext2D) {\n    for (let index = 0; index < this.particles.length - 1; index += 1) {\n      const particle = this.particles[index]\n      const nextParticle = this.particles[index + 1]\n\n      const offsetVector = new Vector2D(this.xOff, this.yOff)\n      const p0 = particle.position.add(offsetVector)\n      const p1 = nextParticle.position.add(offsetVector)\n\n      if (sideFacing(particle, nextParticle, p1) < 0) {\n        context.fillStyle = this.frontColor\n        context.strokeStyle = this.frontColor\n      } else {\n        context.fillStyle = this.backColor\n        context.strokeStyle = this.backColor\n      }\n\n      if (index === 0) {\n        this.drawFirstParticle(context, particle, nextParticle, p0, p1)\n      } else if (index === this.particles.length - 2) {\n        this.drawMiddleParticle(context, particle, nextParticle, p0, p1)\n      } else {\n        this.drawLastParticle(context, particle, nextParticle, p0, p1)\n      }\n    }\n  }\n\n  drawFirstParticle(\n    context: CanvasRenderingContext2D,\n    particle: EulerMass,\n    nextParticle: EulerMass,\n    p0: Vector2D,\n    p1: Vector2D\n  ) {\n    context.beginPath()\n    context.moveTo(particle.position.x, particle.position.y)\n    context.lineTo(nextParticle.position.x, nextParticle.position.y)\n    context.lineTo(\n      (nextParticle.position.x + p1.x) * 0.5,\n      (nextParticle.position.y + p1.y) * 0.5\n    )\n    context.closePath()\n    context.stroke()\n    context.fill()\n    context.beginPath()\n    context.moveTo(p1.x, p1.y)\n    context.lineTo(p0.x, p0.y)\n    context.lineTo(\n      (nextParticle.position.x + p1.x) * 0.5,\n      (nextParticle.position.y + p1.y) * 0.5\n    )\n    context.closePath()\n    context.stroke()\n    context.fill()\n  }\n\n  drawMiddleParticle(\n    context: CanvasRenderingContext2D,\n    particle: EulerMass,\n    nextParticle: EulerMass,\n    p0: Vector2D,\n    p1: Vector2D\n  ) {\n    context.beginPath()\n    context.moveTo(particle.position.x, particle.position.y)\n    context.lineTo(nextParticle.position.x, nextParticle.position.y)\n    context.lineTo(\n      (particle.position.x + p0.x) * 0.5,\n      (particle.position.y + p0.y) * 0.5\n    )\n    context.closePath()\n    context.stroke()\n    context.fill()\n    context.beginPath()\n    context.moveTo(p1.x, p1.y)\n    context.lineTo(p0.x, p0.y)\n    context.lineTo(\n      (particle.position.x + p0.x) * 0.5,\n      (particle.position.y + p0.y) * 0.5\n    )\n    context.closePath()\n    context.stroke()\n    context.fill()\n  }\n\n  drawLastParticle(\n    context: CanvasRenderingContext2D,\n    particle: EulerMass,\n    nextParticle: EulerMass,\n    p0: Vector2D,\n    p1: Vector2D\n  ) {\n    context.beginPath()\n    context.moveTo(particle.position.x, particle.position.y)\n    context.lineTo(nextParticle.position.x, nextParticle.position.y)\n    context.lineTo(p1.x, p1.y)\n    context.lineTo(p0.x, p0.y)\n    context.closePath()\n    context.stroke()\n    context.fill()\n  }\n}\n\nfunction sideFacing(\n  { position: { x: x1, y: y1 } }: EulerMass,\n  { position: { x: x2, y: y2 } }: EulerMass,\n  { x: x3, y: y3 }: Vector2D\n) {\n  return (x1 - x2) * (y3 - y2) - (y1 - y2) * (x3 - x2)\n}\n\nexport { ConfettiRibbon }\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/ActiveBackground/Confetti/ConfettiRibbon.ts"],"names":["VELOCITY_INHERIT_INITIAL_MAX","TIME_INITIAL_MAX","OSCILLATION_SPEED_VARIANCE","OSCILLATION_SPEED_MINIMUM","OSCILLATION_DISTANCE_VARIANCE","OSCILLATION_DISTANCE_MINIMUM","Y_VELOCITY_VARIANCE","Y_VELOCITY_MINIMUM","ConfettiRibbon","particleCount","particleMass","particleDrag","particleDistance","thickness","angle","Math","PI","parent","fetchColors","xOff","cos","yOff","sin","reset","x","random","width","y","height","currPosition","Vector2D","prevPosition","clone","frontColor","backColor","time","oscillationSpeed","oscillationDistance","velocityInherit","yVelocity","particles","Array","map","_","i","EulerMass","dt","dx","dy","dDistance","sqrt","position","index","length","directionForce","sub","normalize","multiply","addForce","integrate","rp2","subtract","add","context","particle","nextParticle","offsetVector","p0","p1","sideFacing","fillStyle","strokeStyle","drawFirstParticle","drawMiddleParticle","drawLastParticle","beginPath","moveTo","lineTo","closePath","stroke","fill","x1","y1","x2","y2","x3","y3"],"mappings":"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","sourcesContent":["import { Confetti } from '../Confetti'\nimport { EulerMass } from './EulerMass'\nimport { Vector2D } from './Vector'\n\ntype ConfettiRibbonConfig = {\n  particleCount?: number\n  particleMass?: number\n  particleDrag?: number\n  particleDistance?: number\n  thickness?: number\n  angle?: number\n  parent: Confetti\n  fetchColors: () => string[]\n}\n\nconst VELOCITY_INHERIT_INITIAL_MAX = 2\nconst TIME_INITIAL_MAX = 10\nconst OSCILLATION_SPEED_VARIANCE = 2\nconst OSCILLATION_SPEED_MINIMUM = 1.5\nconst OSCILLATION_DISTANCE_VARIANCE = 40\nconst OSCILLATION_DISTANCE_MINIMUM = 40\nconst Y_VELOCITY_VARIANCE = 40\nconst Y_VELOCITY_MINIMUM = 80\n\nexport class ConfettiRibbon {\n  private readonly parent: Confetti\n  private readonly fetchColors: () => string[]\n\n  private currPosition!: Vector2D\n  private prevPosition!: Vector2D\n\n  private readonly particleCount: number\n  private readonly particleMass: number\n  private readonly particleDrag: number\n  private readonly particleDistance: number\n  private readonly thickness: number\n  private readonly angle: number\n\n  private readonly xOff: number\n  private readonly yOff: number\n\n  private frontColor!: string\n  private backColor!: string\n\n  private time!: number\n  private velocityInherit!: number\n  private oscillationSpeed!: number\n  private oscillationDistance!: number\n  private yVelocity!: number\n\n  private particles!: EulerMass[]\n\n  constructor({\n    particleCount = 30,\n    particleMass = 1,\n    particleDrag = 0.05,\n    particleDistance = 8.0,\n    thickness = 8.0,\n    angle = Math.PI / 4,\n    parent,\n    fetchColors,\n  }: ConfettiRibbonConfig) {\n    this.parent = parent\n    this.fetchColors = fetchColors\n\n    this.particleCount = particleCount\n    this.particleMass = particleMass\n    this.particleDrag = particleDrag\n    this.particleDistance = particleDistance\n    this.thickness = thickness\n    this.angle = angle\n\n    this.xOff = Math.cos(this.angle) * this.thickness\n    this.yOff = Math.sin(this.angle) * this.thickness\n\n    this.reset()\n  }\n\n  private reset(): void {\n    const x = Math.random() * this.parent.width\n    const y = -1 * Math.random() * this.parent.height * 2\n\n    this.currPosition = new Vector2D(x, y)\n    this.prevPosition = this.currPosition.clone()\n\n    const [frontColor, backColor] = this.fetchColors()\n    this.frontColor = frontColor\n    this.backColor = backColor\n\n    this.time = Math.random() * TIME_INITIAL_MAX\n\n    this.oscillationSpeed =\n      Math.random() * OSCILLATION_SPEED_VARIANCE + OSCILLATION_SPEED_MINIMUM\n    this.oscillationDistance =\n      Math.random() * OSCILLATION_DISTANCE_VARIANCE +\n      OSCILLATION_DISTANCE_MINIMUM\n\n    this.velocityInherit = Math.random() * VELOCITY_INHERIT_INITIAL_MAX\n    this.yVelocity = Math.random() * Y_VELOCITY_VARIANCE + Y_VELOCITY_MINIMUM\n\n    this.particles = [...new Array(this.particleCount)].map(\n      (_, i) =>\n        new EulerMass(\n          x,\n          y - i * this.particleDistance,\n          this.particleMass,\n          this.particleDrag\n        )\n    )\n  }\n\n  public update(dt: number): void {\n    this.time += dt * this.oscillationSpeed\n    this.currPosition.x += Math.cos(this.time) * this.oscillationDistance * dt\n    this.currPosition.y += this.yVelocity * dt\n\n    const dx = this.prevPosition.x - this.currPosition.x\n    const dy = this.prevPosition.y - this.currPosition.y\n    const dDistance = Math.sqrt(dx * dx + dy * dy)\n\n    this.prevPosition = this.currPosition.clone()\n\n    // Update each particle's position\n    this.particles[0].position = this.currPosition\n    for (let index = 1; index < this.particles.length; index += 1) {\n      const directionForce = Vector2D.sub(\n        this.particles[index - 1].position,\n        this.particles[index].position\n      )\n        .normalize()\n        .multiply((dDistance / dt) * this.velocityInherit)\n\n      this.particles[index].addForce(directionForce)\n    }\n\n    // integrate the forces\n    for (let index = 1; index < this.particles.length; index += 1) {\n      this.particles[index].integrate(dt)\n    }\n\n    // calculate final position\n    for (let index = 1; index < this.particles.length; index += 1) {\n      const rp2 = this.particles[index].position\n        .subtract(this.particles[index - 1].position)\n        .normalize()\n        .multiply(this.particleDistance)\n        .add(this.particles[index - 1].position)\n      this.particles[index].position = rp2\n    }\n\n    if (\n      this.currPosition.y >\n      this.parent.height + this.particleDistance * this.particleCount\n    ) {\n      this.reset()\n    }\n  }\n\n  public draw(context: CanvasRenderingContext2D): void {\n    for (let index = 0; index < this.particles.length - 1; index += 1) {\n      const particle = this.particles[index]\n      const nextParticle = this.particles[index + 1]\n\n      const offsetVector = new Vector2D(this.xOff, this.yOff)\n      const p0 = particle.position.add(offsetVector)\n      const p1 = nextParticle.position.add(offsetVector)\n\n      if (sideFacing(particle, nextParticle, p1) < 0) {\n        context.fillStyle = this.frontColor\n        context.strokeStyle = this.frontColor\n      } else {\n        context.fillStyle = this.backColor\n        context.strokeStyle = this.backColor\n      }\n\n      if (index === 0) {\n        this.drawFirstParticle(context, particle, nextParticle, p0, p1)\n      } else if (index === this.particles.length - 2) {\n        this.drawMiddleParticle(context, particle, nextParticle, p0, p1)\n      } else {\n        this.drawLastParticle(context, particle, nextParticle, p0, p1)\n      }\n    }\n  }\n\n  private drawFirstParticle(\n    context: CanvasRenderingContext2D,\n    particle: EulerMass,\n    nextParticle: EulerMass,\n    p0: Vector2D,\n    p1: Vector2D\n  ): void {\n    context.beginPath()\n    context.moveTo(particle.position.x, particle.position.y)\n    context.lineTo(nextParticle.position.x, nextParticle.position.y)\n    context.lineTo(\n      (nextParticle.position.x + p1.x) * 0.5,\n      (nextParticle.position.y + p1.y) * 0.5\n    )\n    context.closePath()\n    context.stroke()\n    context.fill()\n    context.beginPath()\n    context.moveTo(p1.x, p1.y)\n    context.lineTo(p0.x, p0.y)\n    context.lineTo(\n      (nextParticle.position.x + p1.x) * 0.5,\n      (nextParticle.position.y + p1.y) * 0.5\n    )\n    context.closePath()\n    context.stroke()\n    context.fill()\n  }\n\n  private drawMiddleParticle(\n    context: CanvasRenderingContext2D,\n    particle: EulerMass,\n    nextParticle: EulerMass,\n    p0: Vector2D,\n    p1: Vector2D\n  ): void {\n    context.beginPath()\n    context.moveTo(particle.position.x, particle.position.y)\n    context.lineTo(nextParticle.position.x, nextParticle.position.y)\n    context.lineTo(\n      (particle.position.x + p0.x) * 0.5,\n      (particle.position.y + p0.y) * 0.5\n    )\n    context.closePath()\n    context.stroke()\n    context.fill()\n    context.beginPath()\n    context.moveTo(p1.x, p1.y)\n    context.lineTo(p0.x, p0.y)\n    context.lineTo(\n      (particle.position.x + p0.x) * 0.5,\n      (particle.position.y + p0.y) * 0.5\n    )\n    context.closePath()\n    context.stroke()\n    context.fill()\n  }\n\n  private drawLastParticle(\n    context: CanvasRenderingContext2D,\n    particle: EulerMass,\n    nextParticle: EulerMass,\n    p0: Vector2D,\n    p1: Vector2D\n  ): void {\n    context.beginPath()\n    context.moveTo(particle.position.x, particle.position.y)\n    context.lineTo(nextParticle.position.x, nextParticle.position.y)\n    context.lineTo(p1.x, p1.y)\n    context.lineTo(p0.x, p0.y)\n    context.closePath()\n    context.stroke()\n    context.fill()\n  }\n}\n\nfunction sideFacing(\n  { position: { x: x1, y: y1 } }: EulerMass,\n  { position: { x: x2, y: y2 } }: EulerMass,\n  { x: x3, y: y3 }: Vector2D\n) {\n  return (x1 - x2) * (y3 - y2) - (y1 - y2) * (x3 - x2)\n}\n"]}
import { Vector2D } from './Vector';
declare class EulerMass {
export declare class EulerMass {
private readonly mass;
private readonly drag;
position: Vector2D;
mass: number;
drag: number;
force: Vector2D;
velocity: Vector2D;
private force;
private velocity;
constructor(x: number, y: number, mass: number, drag: number);
get currentForce(): Vector2D;
addForce(v: Vector2D): void;
currentForce(): Vector2D;
integrate(dt: number): void;
}
export { EulerMass };

@@ -20,5 +20,5 @@ "use strict";

this.position = new _Vector.Vector2D(x, y);
this.mass = mass;
this.drag = drag;
this.position = new _Vector.Vector2D(x, y);
this.force = new _Vector.Vector2D(0, 0);

@@ -29,9 +29,4 @@ this.velocity = new _Vector.Vector2D(0, 0);

_createClass(EulerMass, [{
key: "addForce",
value: function addForce(v) {
this.force = this.force.add(v);
}
}, {
key: "currentForce",
value: function currentForce() {
get: function get() {
var speed = this.velocity.length;

@@ -42,5 +37,10 @@ var dragVelocity = this.velocity.multiply(this.drag * this.mass * speed);

}, {
key: "addForce",
value: function addForce(v) {
this.force = this.force.add(v);
}
}, {
key: "integrate",
value: function integrate(dt) {
var acceleration = this.currentForce().divide(this.mass).multiply(dt);
var acceleration = this.currentForce.divide(this.mass).multiply(dt);
var deltaPosition = this.velocity.multiply(dt);

@@ -57,2 +57,2 @@ this.position = this.position.add(deltaPosition);

exports.EulerMass = EulerMass;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9BY3RpdmVCYWNrZ3JvdW5kL0NvbmZldHRpL0V1bGVyTWFzcy50cyJdLCJuYW1lcyI6WyJFdWxlck1hc3MiLCJ4IiwieSIsIm1hc3MiLCJkcmFnIiwicG9zaXRpb24iLCJWZWN0b3IyRCIsImZvcmNlIiwidmVsb2NpdHkiLCJ2IiwiYWRkIiwic3BlZWQiLCJsZW5ndGgiLCJkcmFnVmVsb2NpdHkiLCJtdWx0aXBseSIsInN1YnRyYWN0IiwiZHQiLCJhY2NlbGVyYXRpb24iLCJjdXJyZW50Rm9yY2UiLCJkaXZpZGUiLCJkZWx0YVBvc2l0aW9uIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7Ozs7Ozs7O0lBRU1BLFM7QUFPSixxQkFBWUMsQ0FBWixFQUF1QkMsQ0FBdkIsRUFBa0NDLElBQWxDLEVBQWdEQyxJQUFoRCxFQUE4RDtBQUFBOztBQUM1RCxTQUFLQyxRQUFMLEdBQWdCLElBQUlDLGdCQUFKLENBQWFMLENBQWIsRUFBZ0JDLENBQWhCLENBQWhCO0FBQ0EsU0FBS0MsSUFBTCxHQUFZQSxJQUFaO0FBQ0EsU0FBS0MsSUFBTCxHQUFZQSxJQUFaO0FBQ0EsU0FBS0csS0FBTCxHQUFhLElBQUlELGdCQUFKLENBQWEsQ0FBYixFQUFnQixDQUFoQixDQUFiO0FBQ0EsU0FBS0UsUUFBTCxHQUFnQixJQUFJRixnQkFBSixDQUFhLENBQWIsRUFBZ0IsQ0FBaEIsQ0FBaEI7QUFDRDs7OztXQUVELGtCQUFTRyxDQUFULEVBQXNCO0FBQ3BCLFdBQUtGLEtBQUwsR0FBYSxLQUFLQSxLQUFMLENBQVdHLEdBQVgsQ0FBZUQsQ0FBZixDQUFiO0FBQ0Q7OztXQUVELHdCQUFlO0FBQ2IsVUFBTUUsS0FBSyxHQUFHLEtBQUtILFFBQUwsQ0FBY0ksTUFBNUI7QUFDQSxVQUFNQyxZQUFZLEdBQUcsS0FBS0wsUUFBTCxDQUFjTSxRQUFkLENBQXVCLEtBQUtWLElBQUwsR0FBWSxLQUFLRCxJQUFqQixHQUF3QlEsS0FBL0MsQ0FBckI7QUFDQSxhQUFPLEtBQUtKLEtBQUwsQ0FBV1EsUUFBWCxDQUFvQkYsWUFBcEIsQ0FBUDtBQUNEOzs7V0FFRCxtQkFBVUcsRUFBVixFQUFzQjtBQUNwQixVQUFNQyxZQUFZLEdBQUcsS0FBS0MsWUFBTCxHQUFvQkMsTUFBcEIsQ0FBMkIsS0FBS2hCLElBQWhDLEVBQXNDVyxRQUF0QyxDQUErQ0UsRUFBL0MsQ0FBckI7QUFDQSxVQUFNSSxhQUFhLEdBQUcsS0FBS1osUUFBTCxDQUFjTSxRQUFkLENBQXVCRSxFQUF2QixDQUF0QjtBQUNBLFdBQUtYLFFBQUwsR0FBZ0IsS0FBS0EsUUFBTCxDQUFjSyxHQUFkLENBQWtCVSxhQUFsQixDQUFoQjtBQUNBLFdBQUtaLFFBQUwsR0FBZ0IsS0FBS0EsUUFBTCxDQUFjRSxHQUFkLENBQWtCTyxZQUFsQixDQUFoQjtBQUNBLFdBQUtWLEtBQUwsR0FBYSxJQUFJRCxnQkFBSixDQUFhLENBQWIsRUFBZ0IsQ0FBaEIsQ0FBYjtBQUNEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVmVjdG9yMkQgfSBmcm9tICcuL1ZlY3RvcidcblxuY2xhc3MgRXVsZXJNYXNzIHtcbiAgcG9zaXRpb246IFZlY3RvcjJEXG4gIG1hc3M6IG51bWJlclxuICBkcmFnOiBudW1iZXJcbiAgZm9yY2U6IFZlY3RvcjJEXG4gIHZlbG9jaXR5OiBWZWN0b3IyRFxuXG4gIGNvbnN0cnVjdG9yKHg6IG51bWJlciwgeTogbnVtYmVyLCBtYXNzOiBudW1iZXIsIGRyYWc6IG51bWJlcikge1xuICAgIHRoaXMucG9zaXRpb24gPSBuZXcgVmVjdG9yMkQoeCwgeSlcbiAgICB0aGlzLm1hc3MgPSBtYXNzXG4gICAgdGhpcy5kcmFnID0gZHJhZ1xuICAgIHRoaXMuZm9yY2UgPSBuZXcgVmVjdG9yMkQoMCwgMClcbiAgICB0aGlzLnZlbG9jaXR5ID0gbmV3IFZlY3RvcjJEKDAsIDApXG4gIH1cblxuICBhZGRGb3JjZSh2OiBWZWN0b3IyRCkge1xuICAgIHRoaXMuZm9yY2UgPSB0aGlzLmZvcmNlLmFkZCh2KVxuICB9XG5cbiAgY3VycmVudEZvcmNlKCkge1xuICAgIGNvbnN0IHNwZWVkID0gdGhpcy52ZWxvY2l0eS5sZW5ndGhcbiAgICBjb25zdCBkcmFnVmVsb2NpdHkgPSB0aGlzLnZlbG9jaXR5Lm11bHRpcGx5KHRoaXMuZHJhZyAqIHRoaXMubWFzcyAqIHNwZWVkKVxuICAgIHJldHVybiB0aGlzLmZvcmNlLnN1YnRyYWN0KGRyYWdWZWxvY2l0eSlcbiAgfVxuXG4gIGludGVncmF0ZShkdDogbnVtYmVyKSB7XG4gICAgY29uc3QgYWNjZWxlcmF0aW9uID0gdGhpcy5jdXJyZW50Rm9yY2UoKS5kaXZpZGUodGhpcy5tYXNzKS5tdWx0aXBseShkdClcbiAgICBjb25zdCBkZWx0YVBvc2l0aW9uID0gdGhpcy52ZWxvY2l0eS5tdWx0aXBseShkdClcbiAgICB0aGlzLnBvc2l0aW9uID0gdGhpcy5wb3NpdGlvbi5hZGQoZGVsdGFQb3NpdGlvbilcbiAgICB0aGlzLnZlbG9jaXR5ID0gdGhpcy52ZWxvY2l0eS5hZGQoYWNjZWxlcmF0aW9uKVxuICAgIHRoaXMuZm9yY2UgPSBuZXcgVmVjdG9yMkQoMCwgMClcbiAgfVxufVxuXG5leHBvcnQgeyBFdWxlck1hc3MgfVxuIl19
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9BY3RpdmVCYWNrZ3JvdW5kL0NvbmZldHRpL0V1bGVyTWFzcy50cyJdLCJuYW1lcyI6WyJFdWxlck1hc3MiLCJ4IiwieSIsIm1hc3MiLCJkcmFnIiwicG9zaXRpb24iLCJWZWN0b3IyRCIsImZvcmNlIiwidmVsb2NpdHkiLCJzcGVlZCIsImxlbmd0aCIsImRyYWdWZWxvY2l0eSIsIm11bHRpcGx5Iiwic3VidHJhY3QiLCJ2IiwiYWRkIiwiZHQiLCJhY2NlbGVyYXRpb24iLCJjdXJyZW50Rm9yY2UiLCJkaXZpZGUiLCJkZWx0YVBvc2l0aW9uIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7Ozs7Ozs7O0lBRWFBLFM7QUFLWCxxQkFBWUMsQ0FBWixFQUF1QkMsQ0FBdkIsRUFBbURDLElBQW5ELEVBQW1GQyxJQUFuRixFQUFpRztBQUFBOztBQUFBLFNBQTlDRCxJQUE4QyxHQUE5Q0EsSUFBOEM7QUFBQSxTQUFkQyxJQUFjLEdBQWRBLElBQWM7QUFDL0YsU0FBS0MsUUFBTCxHQUFnQixJQUFJQyxnQkFBSixDQUFhTCxDQUFiLEVBQWdCQyxDQUFoQixDQUFoQjtBQUNBLFNBQUtLLEtBQUwsR0FBYSxJQUFJRCxnQkFBSixDQUFhLENBQWIsRUFBZ0IsQ0FBaEIsQ0FBYjtBQUNBLFNBQUtFLFFBQUwsR0FBZ0IsSUFBSUYsZ0JBQUosQ0FBYSxDQUFiLEVBQWdCLENBQWhCLENBQWhCO0FBQ0Q7Ozs7U0FFRCxlQUFtQjtBQUNqQixVQUFNRyxLQUFLLEdBQUcsS0FBS0QsUUFBTCxDQUFjRSxNQUE1QjtBQUNBLFVBQU1DLFlBQVksR0FBRyxLQUFLSCxRQUFMLENBQWNJLFFBQWQsQ0FBdUIsS0FBS1IsSUFBTCxHQUFZLEtBQUtELElBQWpCLEdBQXdCTSxLQUEvQyxDQUFyQjtBQUNBLGFBQU8sS0FBS0YsS0FBTCxDQUFXTSxRQUFYLENBQW9CRixZQUFwQixDQUFQO0FBQ0Q7OztXQUVELGtCQUFnQkcsQ0FBaEIsRUFBbUM7QUFDakMsV0FBS1AsS0FBTCxHQUFhLEtBQUtBLEtBQUwsQ0FBV1EsR0FBWCxDQUFlRCxDQUFmLENBQWI7QUFDRDs7O1dBRUQsbUJBQWlCRSxFQUFqQixFQUFtQztBQUNqQyxVQUFNQyxZQUFZLEdBQUcsS0FBS0MsWUFBTCxDQUFrQkMsTUFBbEIsQ0FBeUIsS0FBS2hCLElBQTlCLEVBQW9DUyxRQUFwQyxDQUE2Q0ksRUFBN0MsQ0FBckI7QUFDQSxVQUFNSSxhQUFhLEdBQUcsS0FBS1osUUFBTCxDQUFjSSxRQUFkLENBQXVCSSxFQUF2QixDQUF0QjtBQUNBLFdBQUtYLFFBQUwsR0FBZ0IsS0FBS0EsUUFBTCxDQUFjVSxHQUFkLENBQWtCSyxhQUFsQixDQUFoQjtBQUNBLFdBQUtaLFFBQUwsR0FBZ0IsS0FBS0EsUUFBTCxDQUFjTyxHQUFkLENBQWtCRSxZQUFsQixDQUFoQjtBQUNBLFdBQUtWLEtBQUwsR0FBYSxJQUFJRCxnQkFBSixDQUFhLENBQWIsRUFBZ0IsQ0FBaEIsQ0FBYjtBQUNEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVmVjdG9yMkQgfSBmcm9tICcuL1ZlY3RvcidcblxuZXhwb3J0IGNsYXNzIEV1bGVyTWFzcyB7XG4gIHB1YmxpYyBwb3NpdGlvbjogVmVjdG9yMkRcbiAgcHJpdmF0ZSBmb3JjZTogVmVjdG9yMkRcbiAgcHJpdmF0ZSB2ZWxvY2l0eTogVmVjdG9yMkRcblxuICBjb25zdHJ1Y3Rvcih4OiBudW1iZXIsIHk6IG51bWJlciwgcHJpdmF0ZSByZWFkb25seSBtYXNzOiBudW1iZXIsIHByaXZhdGUgcmVhZG9ubHkgIGRyYWc6IG51bWJlcikge1xuICAgIHRoaXMucG9zaXRpb24gPSBuZXcgVmVjdG9yMkQoeCwgeSlcbiAgICB0aGlzLmZvcmNlID0gbmV3IFZlY3RvcjJEKDAsIDApXG4gICAgdGhpcy52ZWxvY2l0eSA9IG5ldyBWZWN0b3IyRCgwLCAwKVxuICB9XG5cbiAgZ2V0IGN1cnJlbnRGb3JjZSgpIHtcbiAgICBjb25zdCBzcGVlZCA9IHRoaXMudmVsb2NpdHkubGVuZ3RoXG4gICAgY29uc3QgZHJhZ1ZlbG9jaXR5ID0gdGhpcy52ZWxvY2l0eS5tdWx0aXBseSh0aGlzLmRyYWcgKiB0aGlzLm1hc3MgKiBzcGVlZClcbiAgICByZXR1cm4gdGhpcy5mb3JjZS5zdWJ0cmFjdChkcmFnVmVsb2NpdHkpXG4gIH1cblxuICBwdWJsaWMgYWRkRm9yY2UodjogVmVjdG9yMkQpOiB2b2lkIHtcbiAgICB0aGlzLmZvcmNlID0gdGhpcy5mb3JjZS5hZGQodilcbiAgfVxuXG4gIHB1YmxpYyBpbnRlZ3JhdGUoZHQ6IG51bWJlcik6IHZvaWQge1xuICAgIGNvbnN0IGFjY2VsZXJhdGlvbiA9IHRoaXMuY3VycmVudEZvcmNlLmRpdmlkZSh0aGlzLm1hc3MpLm11bHRpcGx5KGR0KVxuICAgIGNvbnN0IGRlbHRhUG9zaXRpb24gPSB0aGlzLnZlbG9jaXR5Lm11bHRpcGx5KGR0KVxuICAgIHRoaXMucG9zaXRpb24gPSB0aGlzLnBvc2l0aW9uLmFkZChkZWx0YVBvc2l0aW9uKVxuICAgIHRoaXMudmVsb2NpdHkgPSB0aGlzLnZlbG9jaXR5LmFkZChhY2NlbGVyYXRpb24pXG4gICAgdGhpcy5mb3JjZSA9IG5ldyBWZWN0b3IyRCgwLCAwKVxuICB9XG59XG4iXX0=

@@ -1,2 +0,2 @@

declare class Vector2D {
export declare class Vector2D {
x: number;

@@ -11,8 +11,5 @@ y: number;

static sub(v0: Vector2D, v1: Vector2D): Vector2D;
/**
* Instance methods
*/
clone(): Vector2D;
get length(): number;
get squareLength(): number;
clone(): Vector2D;
add(vector: Vector2D): Vector2D;

@@ -24,2 +21,1 @@ subtract(vector: Vector2D): Vector2D;

}
export { Vector2D };

@@ -27,11 +27,2 @@ "use strict";

_createClass(Vector2D, [{
key: "clone",
value:
/**
* Instance methods
*/
function clone() {
return new Vector2D(this.x, this.y);
}
}, {
key: "length",

@@ -47,8 +38,10 @@ get: function get() {

}, {
key: "clone",
value: function clone() {
return new Vector2D(this.x, this.y);
}
}, {
key: "add",
value: function add(vector) {
var clone = this.clone();
clone.x += vector.x;
clone.y += vector.y;
return clone;
return new Vector2D(this.x + vector.x, this.y + vector.y);
}

@@ -58,6 +51,3 @@ }, {

value: function subtract(vector) {
var clone = this.clone();
clone.x -= vector.x;
clone.y -= vector.y;
return clone;
return new Vector2D(this.x - vector.x, this.y - vector.y);
}

@@ -67,6 +57,3 @@ }, {

value: function multiply(factor) {
var clone = this.clone();
clone.x *= factor;
clone.y *= factor;
return clone;
return new Vector2D(this.x * factor, this.y * factor);
}

@@ -76,6 +63,3 @@ }, {

value: function divide(factor) {
var clone = this.clone();
clone.x /= factor;
clone.y /= factor;
return clone;
return new Vector2D(this.x / factor, this.y / factor);
}

@@ -85,11 +69,8 @@ }, {

value: function normalize() {
var clone = this.clone();
var squareLength = clone.squareLength;
if (squareLength === 0) {
return clone;
if (this.squareLength === 0) {
return this.clone();
}
var factor = 1.0 / Math.sqrt(squareLength);
return clone.multiply(factor);
var factor = 1.0 / Math.sqrt(this.squareLength);
return this.multiply(factor);
}

@@ -119,2 +100,2 @@ }], [{

exports.Vector2D = Vector2D;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9BY3RpdmVCYWNrZ3JvdW5kL0NvbmZldHRpL1ZlY3Rvci50cyJdLCJuYW1lcyI6WyJWZWN0b3IyRCIsIngiLCJ5IiwiTWF0aCIsInNxcnQiLCJzcXVhcmVMZW5ndGgiLCJ2ZWN0b3IiLCJjbG9uZSIsImZhY3RvciIsIm11bHRpcGx5IiwidjAiLCJ2MSIsInNxdWFyZURpc3RhbmNlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7O0lBQU1BLFE7QUFJSixvQkFBWUMsQ0FBWixFQUF1QkMsQ0FBdkIsRUFBa0M7QUFBQTs7QUFDaEMsU0FBS0QsQ0FBTCxHQUFTQSxDQUFUO0FBQ0EsU0FBS0MsQ0FBTCxHQUFTQSxDQUFUO0FBQ0Q7QUFFRDtBQUNGO0FBQ0E7Ozs7OztBQWdCRTtBQUNGO0FBQ0E7QUFFRSxxQkFBUTtBQUNOLGFBQU8sSUFBSUYsUUFBSixDQUFhLEtBQUtDLENBQWxCLEVBQXFCLEtBQUtDLENBQTFCLENBQVA7QUFDRDs7O1NBRUQsZUFBYTtBQUNYLGFBQU9DLElBQUksQ0FBQ0MsSUFBTCxDQUFVLEtBQUtDLFlBQWYsQ0FBUDtBQUNEOzs7U0FFRCxlQUFtQjtBQUNqQixhQUFPLEtBQUtKLENBQUwsR0FBUyxLQUFLQSxDQUFkLEdBQWtCLEtBQUtDLENBQUwsR0FBUyxLQUFLQSxDQUF2QztBQUNEOzs7V0FFRCxhQUFJSSxNQUFKLEVBQXNCO0FBQ3BCLFVBQU1DLEtBQUssR0FBRyxLQUFLQSxLQUFMLEVBQWQ7QUFDQUEsTUFBQUEsS0FBSyxDQUFDTixDQUFOLElBQVdLLE1BQU0sQ0FBQ0wsQ0FBbEI7QUFDQU0sTUFBQUEsS0FBSyxDQUFDTCxDQUFOLElBQVdJLE1BQU0sQ0FBQ0osQ0FBbEI7QUFFQSxhQUFPSyxLQUFQO0FBQ0Q7OztXQUVELGtCQUFTRCxNQUFULEVBQTJCO0FBQ3pCLFVBQU1DLEtBQUssR0FBRyxLQUFLQSxLQUFMLEVBQWQ7QUFDQUEsTUFBQUEsS0FBSyxDQUFDTixDQUFOLElBQVdLLE1BQU0sQ0FBQ0wsQ0FBbEI7QUFDQU0sTUFBQUEsS0FBSyxDQUFDTCxDQUFOLElBQVdJLE1BQU0sQ0FBQ0osQ0FBbEI7QUFFQSxhQUFPSyxLQUFQO0FBQ0Q7OztXQUVELGtCQUFTQyxNQUFULEVBQXlCO0FBQ3ZCLFVBQU1ELEtBQUssR0FBRyxLQUFLQSxLQUFMLEVBQWQ7QUFDQUEsTUFBQUEsS0FBSyxDQUFDTixDQUFOLElBQVdPLE1BQVg7QUFDQUQsTUFBQUEsS0FBSyxDQUFDTCxDQUFOLElBQVdNLE1BQVg7QUFFQSxhQUFPRCxLQUFQO0FBQ0Q7OztXQUVELGdCQUFPQyxNQUFQLEVBQXVCO0FBQ3JCLFVBQU1ELEtBQUssR0FBRyxLQUFLQSxLQUFMLEVBQWQ7QUFDQUEsTUFBQUEsS0FBSyxDQUFDTixDQUFOLElBQVdPLE1BQVg7QUFDQUQsTUFBQUEsS0FBSyxDQUFDTCxDQUFOLElBQVdNLE1BQVg7QUFFQSxhQUFPRCxLQUFQO0FBQ0Q7OztXQUVELHFCQUFZO0FBQ1YsVUFBTUEsS0FBSyxHQUFHLEtBQUtBLEtBQUwsRUFBZDtBQUNBLFVBQU1GLFlBQVksR0FBR0UsS0FBSyxDQUFDRixZQUEzQjs7QUFFQSxVQUFJQSxZQUFZLEtBQUssQ0FBckIsRUFBd0I7QUFDdEIsZUFBT0UsS0FBUDtBQUNEOztBQUVELFVBQU1DLE1BQU0sR0FBRyxNQUFNTCxJQUFJLENBQUNDLElBQUwsQ0FBVUMsWUFBVixDQUFyQjtBQUNBLGFBQU9FLEtBQUssQ0FBQ0UsUUFBTixDQUFlRCxNQUFmLENBQVA7QUFDRDs7O1dBeEVELGtCQUFnQkUsRUFBaEIsRUFBOEJDLEVBQTlCLEVBQTRDO0FBQzFDLGFBQU9SLElBQUksQ0FBQ0MsSUFBTCxDQUFVSixRQUFRLENBQUNZLGNBQVQsQ0FBd0JGLEVBQXhCLEVBQTRCQyxFQUE1QixDQUFWLENBQVA7QUFDRDs7O1dBRUQsd0JBQXNCRCxFQUF0QixFQUFvQ0MsRUFBcEMsRUFBa0Q7QUFDaEQsVUFBTVYsQ0FBQyxHQUFHUyxFQUFFLENBQUNULENBQUgsR0FBT1UsRUFBRSxDQUFDVixDQUFwQjtBQUNBLFVBQU1DLENBQUMsR0FBR1EsRUFBRSxDQUFDUixDQUFILEdBQU9TLEVBQUUsQ0FBQ1QsQ0FBcEI7QUFDQSxhQUFPRCxDQUFDLEdBQUdBLENBQUosR0FBUUMsQ0FBQyxHQUFHQSxDQUFuQjtBQUNEOzs7V0FFRCxhQUFXUSxFQUFYLEVBQXlCQyxFQUF6QixFQUF1QztBQUNyQyxhQUFPLElBQUlYLFFBQUosQ0FBYVUsRUFBRSxDQUFDVCxDQUFILEdBQU9VLEVBQUUsQ0FBQ1YsQ0FBdkIsRUFBMEJTLEVBQUUsQ0FBQ1IsQ0FBSCxHQUFPUyxFQUFFLENBQUNULENBQXBDLENBQVA7QUFDRCIsInNvdXJjZXNDb250ZW50IjpbImNsYXNzIFZlY3RvcjJEIHtcbiAgeDogbnVtYmVyXG4gIHk6IG51bWJlclxuXG4gIGNvbnN0cnVjdG9yKHg6IG51bWJlciwgeTogbnVtYmVyKSB7XG4gICAgdGhpcy54ID0geFxuICAgIHRoaXMueSA9IHlcbiAgfVxuXG4gIC8qKlxuICAgKiBTdGF0aWMgbWV0aG9kc1xuICAgKi9cblxuICBzdGF0aWMgZGlzdGFuY2UodjA6IFZlY3RvcjJELCB2MTogVmVjdG9yMkQpIHtcbiAgICByZXR1cm4gTWF0aC5zcXJ0KFZlY3RvcjJELnNxdWFyZURpc3RhbmNlKHYwLCB2MSkpXG4gIH1cblxuICBzdGF0aWMgc3F1YXJlRGlzdGFuY2UodjA6IFZlY3RvcjJELCB2MTogVmVjdG9yMkQpIHtcbiAgICBjb25zdCB4ID0gdjAueCAtIHYxLnhcbiAgICBjb25zdCB5ID0gdjAueSAtIHYxLnlcbiAgICByZXR1cm4geCAqIHggKyB5ICogeVxuICB9XG5cbiAgc3RhdGljIHN1Yih2MDogVmVjdG9yMkQsIHYxOiBWZWN0b3IyRCkge1xuICAgIHJldHVybiBuZXcgVmVjdG9yMkQodjAueCAtIHYxLngsIHYwLnkgLSB2MS55KVxuICB9XG5cbiAgLyoqXG4gICAqIEluc3RhbmNlIG1ldGhvZHNcbiAgICovXG5cbiAgY2xvbmUoKSB7XG4gICAgcmV0dXJuIG5ldyBWZWN0b3IyRCh0aGlzLngsIHRoaXMueSlcbiAgfVxuXG4gIGdldCBsZW5ndGgoKSB7XG4gICAgcmV0dXJuIE1hdGguc3FydCh0aGlzLnNxdWFyZUxlbmd0aClcbiAgfVxuXG4gIGdldCBzcXVhcmVMZW5ndGgoKSB7XG4gICAgcmV0dXJuIHRoaXMueCAqIHRoaXMueCArIHRoaXMueSAqIHRoaXMueVxuICB9XG5cbiAgYWRkKHZlY3RvcjogVmVjdG9yMkQpIHtcbiAgICBjb25zdCBjbG9uZSA9IHRoaXMuY2xvbmUoKVxuICAgIGNsb25lLnggKz0gdmVjdG9yLnhcbiAgICBjbG9uZS55ICs9IHZlY3Rvci55XG5cbiAgICByZXR1cm4gY2xvbmVcbiAgfVxuXG4gIHN1YnRyYWN0KHZlY3RvcjogVmVjdG9yMkQpIHtcbiAgICBjb25zdCBjbG9uZSA9IHRoaXMuY2xvbmUoKVxuICAgIGNsb25lLnggLT0gdmVjdG9yLnhcbiAgICBjbG9uZS55IC09IHZlY3Rvci55XG5cbiAgICByZXR1cm4gY2xvbmVcbiAgfVxuXG4gIG11bHRpcGx5KGZhY3RvcjogbnVtYmVyKSB7XG4gICAgY29uc3QgY2xvbmUgPSB0aGlzLmNsb25lKClcbiAgICBjbG9uZS54ICo9IGZhY3RvclxuICAgIGNsb25lLnkgKj0gZmFjdG9yXG5cbiAgICByZXR1cm4gY2xvbmVcbiAgfVxuXG4gIGRpdmlkZShmYWN0b3I6IG51bWJlcikge1xuICAgIGNvbnN0IGNsb25lID0gdGhpcy5jbG9uZSgpXG4gICAgY2xvbmUueCAvPSBmYWN0b3JcbiAgICBjbG9uZS55IC89IGZhY3RvclxuXG4gICAgcmV0dXJuIGNsb25lXG4gIH1cblxuICBub3JtYWxpemUoKSB7XG4gICAgY29uc3QgY2xvbmUgPSB0aGlzLmNsb25lKClcbiAgICBjb25zdCBzcXVhcmVMZW5ndGggPSBjbG9uZS5zcXVhcmVMZW5ndGhcblxuICAgIGlmIChzcXVhcmVMZW5ndGggPT09IDApIHtcbiAgICAgIHJldHVybiBjbG9uZVxuICAgIH1cblxuICAgIGNvbnN0IGZhY3RvciA9IDEuMCAvIE1hdGguc3FydChzcXVhcmVMZW5ndGgpXG4gICAgcmV0dXJuIGNsb25lLm11bHRpcGx5KGZhY3RvcilcbiAgfVxufVxuXG5leHBvcnQgeyBWZWN0b3IyRCB9XG4iXX0=
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9BY3RpdmVCYWNrZ3JvdW5kL0NvbmZldHRpL1ZlY3Rvci50cyJdLCJuYW1lcyI6WyJWZWN0b3IyRCIsIngiLCJ5IiwiTWF0aCIsInNxcnQiLCJzcXVhcmVMZW5ndGgiLCJ2ZWN0b3IiLCJmYWN0b3IiLCJjbG9uZSIsIm11bHRpcGx5IiwidjAiLCJ2MSIsInNxdWFyZURpc3RhbmNlIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7O0lBQWFBLFE7QUFFWCxvQkFBbUJDLENBQW5CLEVBQXFDQyxDQUFyQyxFQUFnRDtBQUFBOztBQUFBLFNBQTdCRCxDQUE2QixHQUE3QkEsQ0FBNkI7QUFBQSxTQUFYQyxDQUFXLEdBQVhBLENBQVc7QUFDL0M7QUFFRDtBQUNGO0FBQ0E7Ozs7O1NBZ0JFLGVBQTRCO0FBQzFCLGFBQU9DLElBQUksQ0FBQ0MsSUFBTCxDQUFVLEtBQUtDLFlBQWYsQ0FBUDtBQUNEOzs7U0FFRCxlQUFrQztBQUNoQyxhQUFPLEtBQUtKLENBQUwsR0FBUyxLQUFLQSxDQUFkLEdBQWtCLEtBQUtDLENBQUwsR0FBUyxLQUFLQSxDQUF2QztBQUNEOzs7V0FFRCxpQkFBeUI7QUFDdkIsYUFBTyxJQUFJRixRQUFKLENBQWEsS0FBS0MsQ0FBbEIsRUFBcUIsS0FBS0MsQ0FBMUIsQ0FBUDtBQUNEOzs7V0FFRCxhQUFXSSxNQUFYLEVBQXVDO0FBQ3JDLGFBQU8sSUFBSU4sUUFBSixDQUFhLEtBQUtDLENBQUwsR0FBU0ssTUFBTSxDQUFDTCxDQUE3QixFQUFnQyxLQUFLQyxDQUFMLEdBQVNJLE1BQU0sQ0FBQ0osQ0FBaEQsQ0FBUDtBQUNEOzs7V0FFRCxrQkFBZ0JJLE1BQWhCLEVBQTRDO0FBQzFDLGFBQU8sSUFBSU4sUUFBSixDQUFhLEtBQUtDLENBQUwsR0FBU0ssTUFBTSxDQUFDTCxDQUE3QixFQUFnQyxLQUFLQyxDQUFMLEdBQVFJLE1BQU0sQ0FBQ0osQ0FBL0MsQ0FBUDtBQUNEOzs7V0FFRCxrQkFBZ0JLLE1BQWhCLEVBQTBDO0FBQ3hDLGFBQU8sSUFBSVAsUUFBSixDQUFhLEtBQUtDLENBQUwsR0FBU00sTUFBdEIsRUFBOEIsS0FBS0wsQ0FBTCxHQUFTSyxNQUF2QyxDQUFQO0FBQ0Q7OztXQUVELGdCQUFjQSxNQUFkLEVBQXdDO0FBQ3RDLGFBQU8sSUFBSVAsUUFBSixDQUFhLEtBQUtDLENBQUwsR0FBU00sTUFBdEIsRUFBOEIsS0FBS0wsQ0FBTCxHQUFTSyxNQUF2QyxDQUFQO0FBQ0Q7OztXQUVELHFCQUE2QjtBQUMzQixVQUFJLEtBQUtGLFlBQUwsS0FBc0IsQ0FBMUIsRUFBNkI7QUFDM0IsZUFBTyxLQUFLRyxLQUFMLEVBQVA7QUFDRDs7QUFFRCxVQUFNRCxNQUFNLEdBQUcsTUFBTUosSUFBSSxDQUFDQyxJQUFMLENBQVUsS0FBS0MsWUFBZixDQUFyQjtBQUNBLGFBQU8sS0FBS0ksUUFBTCxDQUFjRixNQUFkLENBQVA7QUFDRDs7O1dBakRELGtCQUFnQkcsRUFBaEIsRUFBOEJDLEVBQTlCLEVBQTRDO0FBQzFDLGFBQU9SLElBQUksQ0FBQ0MsSUFBTCxDQUFVSixRQUFRLENBQUNZLGNBQVQsQ0FBd0JGLEVBQXhCLEVBQTRCQyxFQUE1QixDQUFWLENBQVA7QUFDRDs7O1dBRUQsd0JBQXNCRCxFQUF0QixFQUFvQ0MsRUFBcEMsRUFBa0Q7QUFDaEQsVUFBTVYsQ0FBQyxHQUFHUyxFQUFFLENBQUNULENBQUgsR0FBT1UsRUFBRSxDQUFDVixDQUFwQjtBQUNBLFVBQU1DLENBQUMsR0FBR1EsRUFBRSxDQUFDUixDQUFILEdBQU9TLEVBQUUsQ0FBQ1QsQ0FBcEI7QUFDQSxhQUFPRCxDQUFDLEdBQUdBLENBQUosR0FBUUMsQ0FBQyxHQUFHQSxDQUFuQjtBQUNEOzs7V0FFRCxhQUFXUSxFQUFYLEVBQXlCQyxFQUF6QixFQUF1QztBQUNyQyxhQUFPLElBQUlYLFFBQUosQ0FBYVUsRUFBRSxDQUFDVCxDQUFILEdBQU9VLEVBQUUsQ0FBQ1YsQ0FBdkIsRUFBMEJTLEVBQUUsQ0FBQ1IsQ0FBSCxHQUFPUyxFQUFFLENBQUNULENBQXBDLENBQVA7QUFDRCIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBWZWN0b3IyRCB7XG5cbiAgY29uc3RydWN0b3IocHVibGljIHg6IG51bWJlciwgcHVibGljIHk6IG51bWJlcikge1xuICB9XG5cbiAgLyoqXG4gICAqIFN0YXRpYyBtZXRob2RzXG4gICAqL1xuXG4gIHN0YXRpYyBkaXN0YW5jZSh2MDogVmVjdG9yMkQsIHYxOiBWZWN0b3IyRCkge1xuICAgIHJldHVybiBNYXRoLnNxcnQoVmVjdG9yMkQuc3F1YXJlRGlzdGFuY2UodjAsIHYxKSlcbiAgfVxuXG4gIHN0YXRpYyBzcXVhcmVEaXN0YW5jZSh2MDogVmVjdG9yMkQsIHYxOiBWZWN0b3IyRCkge1xuICAgIGNvbnN0IHggPSB2MC54IC0gdjEueFxuICAgIGNvbnN0IHkgPSB2MC55IC0gdjEueVxuICAgIHJldHVybiB4ICogeCArIHkgKiB5XG4gIH1cblxuICBzdGF0aWMgc3ViKHYwOiBWZWN0b3IyRCwgdjE6IFZlY3RvcjJEKSB7XG4gICAgcmV0dXJuIG5ldyBWZWN0b3IyRCh2MC54IC0gdjEueCwgdjAueSAtIHYxLnkpXG4gIH1cblxuICBwdWJsaWMgZ2V0IGxlbmd0aCgpOiBudW1iZXIge1xuICAgIHJldHVybiBNYXRoLnNxcnQodGhpcy5zcXVhcmVMZW5ndGgpXG4gIH1cblxuICBwdWJsaWMgZ2V0IHNxdWFyZUxlbmd0aCgpOiBudW1iZXIge1xuICAgIHJldHVybiB0aGlzLnggKiB0aGlzLnggKyB0aGlzLnkgKiB0aGlzLnlcbiAgfVxuXG4gIHB1YmxpYyBjbG9uZSgpOiBWZWN0b3IyRCB7XG4gICAgcmV0dXJuIG5ldyBWZWN0b3IyRCh0aGlzLngsIHRoaXMueSlcbiAgfVxuXG4gIHB1YmxpYyBhZGQodmVjdG9yOiBWZWN0b3IyRCk6IFZlY3RvcjJEIHtcbiAgICByZXR1cm4gbmV3IFZlY3RvcjJEKHRoaXMueCArIHZlY3Rvci54LCB0aGlzLnkgKyB2ZWN0b3IueSlcbiAgfVxuXG4gIHB1YmxpYyBzdWJ0cmFjdCh2ZWN0b3I6IFZlY3RvcjJEKTogVmVjdG9yMkQge1xuICAgIHJldHVybiBuZXcgVmVjdG9yMkQodGhpcy54IC0gdmVjdG9yLngsIHRoaXMueS0gdmVjdG9yLnkpXG4gIH1cblxuICBwdWJsaWMgbXVsdGlwbHkoZmFjdG9yOiBudW1iZXIpOiBWZWN0b3IyRCB7XG4gICAgcmV0dXJuIG5ldyBWZWN0b3IyRCh0aGlzLnggKiBmYWN0b3IsIHRoaXMueSAqIGZhY3RvcilcbiAgfVxuXG4gIHB1YmxpYyBkaXZpZGUoZmFjdG9yOiBudW1iZXIpOiBWZWN0b3IyRCB7XG4gICAgcmV0dXJuIG5ldyBWZWN0b3IyRCh0aGlzLnggLyBmYWN0b3IsIHRoaXMueSAvIGZhY3RvcilcbiAgfVxuXG4gIHB1YmxpYyBub3JtYWxpemUoKTogVmVjdG9yMkQge1xuICAgIGlmICh0aGlzLnNxdWFyZUxlbmd0aCA9PT0gMCkge1xuICAgICAgcmV0dXJuIHRoaXMuY2xvbmUoKVxuICAgIH1cblxuICAgIGNvbnN0IGZhY3RvciA9IDEuMCAvIE1hdGguc3FydCh0aGlzLnNxdWFyZUxlbmd0aClcbiAgICByZXR1cm4gdGhpcy5tdWx0aXBseShmYWN0b3IpXG4gIH1cbn1cbiJdfQ==

@@ -1,9 +0,9 @@

declare class ZoomCircle {
canvas: HTMLCanvasElement;
context: CanvasRenderingContext2D | null;
ratio: number;
width: number;
height: number;
time: number;
animationFrameRequestId: number | null;
export declare class ZoomCircle {
private readonly canvas;
private readonly context;
private readonly ratio;
private readonly width;
private readonly height;
private time;
private animationFrameRequestId;
constructor(canvas: HTMLCanvasElement);

@@ -14,2 +14,1 @@ start(): void;

}
export { ZoomCircle };

@@ -59,2 +59,2 @@ "use strict";

exports.ZoomCircle = ZoomCircle;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9BY3RpdmVCYWNrZ3JvdW5kL1pvb21DaXJjbGUudHMiXSwibmFtZXMiOlsiWm9vbUNpcmNsZSIsImNhbnZhcyIsImNvbnRleHQiLCJnZXRDb250ZXh0IiwicmF0aW8iLCJ3aW5kb3ciLCJkZXZpY2VQaXhlbFJhdGlvIiwid2lkdGgiLCJvZmZzZXRXaWR0aCIsImhlaWdodCIsIm9mZnNldEhlaWdodCIsInRpbWUiLCJhbmltYXRpb25GcmFtZVJlcXVlc3RJZCIsInJlcXVlc3RBbmltYXRpb25GcmFtZSIsInJlbmRlciIsImJpbmQiLCJjYW5jZWxBbmltYXRpb25GcmFtZSIsImNsZWFyUmVjdCIsImJlZ2luUGF0aCIsImFyYyIsIk1hdGgiLCJhYnMiLCJjb3MiLCJQSSIsImZpbGwiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7SUFBTUEsVTtBQVlKLHNCQUFZQyxNQUFaLEVBQXVDO0FBQUE7O0FBQ3JDLFNBQUtBLE1BQUwsR0FBY0EsTUFBZDtBQUNBLFNBQUtDLE9BQUwsR0FBZUQsTUFBTSxDQUFDRSxVQUFQLENBQWtCLElBQWxCLENBQWY7QUFFQSxTQUFLQyxLQUFMLEdBQWFDLE1BQU0sQ0FBQ0MsZ0JBQXBCO0FBQ0EsU0FBS0MsS0FBTCxHQUFhTixNQUFNLENBQUNPLFdBQXBCO0FBQ0EsU0FBS0MsTUFBTCxHQUFjUixNQUFNLENBQUNTLFlBQXJCO0FBRUEsU0FBS0MsSUFBTCxHQUFZLENBQVo7QUFFQSxTQUFLQyx1QkFBTCxHQUErQixJQUEvQjtBQUNEOzs7O1dBRUQsaUJBQVE7QUFDTixXQUFLQSx1QkFBTCxHQUErQkMscUJBQXFCLENBQUMsS0FBS0MsTUFBTCxDQUFZQyxJQUFaLENBQWlCLElBQWpCLENBQUQsQ0FBcEQ7QUFDRDs7O1dBRUQsZ0JBQU87QUFDTCxVQUFJLEtBQUtILHVCQUFULEVBQWtDO0FBQ2hDSSxRQUFBQSxvQkFBb0IsQ0FBQyxLQUFLSix1QkFBTixDQUFwQjtBQUNEO0FBQ0Y7OztXQUVELGtCQUFTO0FBQ1AsVUFBSSxDQUFDLEtBQUtWLE9BQVYsRUFBbUI7QUFDakI7QUFDRDs7QUFFRCxXQUFLQSxPQUFMLENBQWFlLFNBQWIsQ0FBdUIsQ0FBdkIsRUFBMEIsQ0FBMUIsRUFBNkIsS0FBS2hCLE1BQUwsQ0FBWU0sS0FBekMsRUFBZ0QsS0FBS04sTUFBTCxDQUFZUSxNQUE1RDtBQUNBLFdBQUtQLE9BQUwsQ0FBYWdCLFNBQWI7QUFDQSxXQUFLaEIsT0FBTCxDQUFhaUIsR0FBYixDQUNFLEtBQUtsQixNQUFMLENBQVlNLEtBQVosR0FBb0IsQ0FEdEIsRUFFRSxLQUFLTixNQUFMLENBQVlRLE1BQVosR0FBcUIsQ0FGdkIsRUFHRyxLQUFLUixNQUFMLENBQVlNLEtBQVosR0FBb0IsQ0FBckIsR0FBMEJhLElBQUksQ0FBQ0MsR0FBTCxDQUFTRCxJQUFJLENBQUNFLEdBQUwsQ0FBUyxLQUFLWCxJQUFkLENBQVQsQ0FINUIsRUFJRSxDQUpGLEVBS0UsSUFBSVMsSUFBSSxDQUFDRyxFQUxYO0FBT0EsV0FBS3JCLE9BQUwsQ0FBYXNCLElBQWI7QUFDQSxXQUFLYixJQUFMLElBQWEsSUFBYjtBQUVBLFdBQUtDLHVCQUFMLEdBQStCQyxxQkFBcUIsQ0FBQyxLQUFLQyxNQUFMLENBQVlDLElBQVosQ0FBaUIsSUFBakIsQ0FBRCxDQUFwRDtBQUNEIiwic291cmNlc0NvbnRlbnQiOlsiY2xhc3MgWm9vbUNpcmNsZSB7XG4gIGNhbnZhczogSFRNTENhbnZhc0VsZW1lbnRcbiAgY29udGV4dDogQ2FudmFzUmVuZGVyaW5nQ29udGV4dDJEIHwgbnVsbFxuXG4gIHJhdGlvOiBudW1iZXJcbiAgd2lkdGg6IG51bWJlclxuICBoZWlnaHQ6IG51bWJlclxuXG4gIHRpbWU6IG51bWJlclxuXG4gIGFuaW1hdGlvbkZyYW1lUmVxdWVzdElkOiBudW1iZXIgfCBudWxsXG5cbiAgY29uc3RydWN0b3IoY2FudmFzOiBIVE1MQ2FudmFzRWxlbWVudCkge1xuICAgIHRoaXMuY2FudmFzID0gY2FudmFzXG4gICAgdGhpcy5jb250ZXh0ID0gY2FudmFzLmdldENvbnRleHQoJzJkJylcblxuICAgIHRoaXMucmF0aW8gPSB3aW5kb3cuZGV2aWNlUGl4ZWxSYXRpb1xuICAgIHRoaXMud2lkdGggPSBjYW52YXMub2Zmc2V0V2lkdGhcbiAgICB0aGlzLmhlaWdodCA9IGNhbnZhcy5vZmZzZXRIZWlnaHRcblxuICAgIHRoaXMudGltZSA9IDBcblxuICAgIHRoaXMuYW5pbWF0aW9uRnJhbWVSZXF1ZXN0SWQgPSBudWxsXG4gIH1cblxuICBzdGFydCgpIHtcbiAgICB0aGlzLmFuaW1hdGlvbkZyYW1lUmVxdWVzdElkID0gcmVxdWVzdEFuaW1hdGlvbkZyYW1lKHRoaXMucmVuZGVyLmJpbmQodGhpcykpXG4gIH1cblxuICBzdG9wKCkge1xuICAgIGlmICh0aGlzLmFuaW1hdGlvbkZyYW1lUmVxdWVzdElkKSB7XG4gICAgICBjYW5jZWxBbmltYXRpb25GcmFtZSh0aGlzLmFuaW1hdGlvbkZyYW1lUmVxdWVzdElkKVxuICAgIH1cbiAgfVxuXG4gIHJlbmRlcigpIHtcbiAgICBpZiAoIXRoaXMuY29udGV4dCkge1xuICAgICAgcmV0dXJuXG4gICAgfVxuXG4gICAgdGhpcy5jb250ZXh0LmNsZWFyUmVjdCgwLCAwLCB0aGlzLmNhbnZhcy53aWR0aCwgdGhpcy5jYW52YXMuaGVpZ2h0KVxuICAgIHRoaXMuY29udGV4dC5iZWdpblBhdGgoKVxuICAgIHRoaXMuY29udGV4dC5hcmMoXG4gICAgICB0aGlzLmNhbnZhcy53aWR0aCAvIDIsXG4gICAgICB0aGlzLmNhbnZhcy5oZWlnaHQgLyAyLFxuICAgICAgKHRoaXMuY2FudmFzLndpZHRoIC8gMikgKiBNYXRoLmFicyhNYXRoLmNvcyh0aGlzLnRpbWUpKSxcbiAgICAgIDAsXG4gICAgICAyICogTWF0aC5QSVxuICAgIClcbiAgICB0aGlzLmNvbnRleHQuZmlsbCgpXG4gICAgdGhpcy50aW1lICs9IDAuMDVcblxuICAgIHRoaXMuYW5pbWF0aW9uRnJhbWVSZXF1ZXN0SWQgPSByZXF1ZXN0QW5pbWF0aW9uRnJhbWUodGhpcy5yZW5kZXIuYmluZCh0aGlzKSlcbiAgfVxufVxuXG5leHBvcnQgeyBab29tQ2lyY2xlIH1cbiJdfQ==
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9BY3RpdmVCYWNrZ3JvdW5kL1pvb21DaXJjbGUudHMiXSwibmFtZXMiOlsiWm9vbUNpcmNsZSIsImNhbnZhcyIsImNvbnRleHQiLCJnZXRDb250ZXh0IiwicmF0aW8iLCJ3aW5kb3ciLCJkZXZpY2VQaXhlbFJhdGlvIiwid2lkdGgiLCJvZmZzZXRXaWR0aCIsImhlaWdodCIsIm9mZnNldEhlaWdodCIsInRpbWUiLCJhbmltYXRpb25GcmFtZVJlcXVlc3RJZCIsInJlcXVlc3RBbmltYXRpb25GcmFtZSIsInJlbmRlciIsImJpbmQiLCJjYW5jZWxBbmltYXRpb25GcmFtZSIsImNsZWFyUmVjdCIsImJlZ2luUGF0aCIsImFyYyIsIk1hdGgiLCJhYnMiLCJjb3MiLCJQSSIsImZpbGwiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7SUFBYUEsVTtBQVlYLHNCQUFZQyxNQUFaLEVBQXVDO0FBQUE7O0FBQ3JDLFNBQUtBLE1BQUwsR0FBY0EsTUFBZDtBQUNBLFNBQUtDLE9BQUwsR0FBZUQsTUFBTSxDQUFDRSxVQUFQLENBQWtCLElBQWxCLENBQWY7QUFFQSxTQUFLQyxLQUFMLEdBQWFDLE1BQU0sQ0FBQ0MsZ0JBQXBCO0FBQ0EsU0FBS0MsS0FBTCxHQUFhTixNQUFNLENBQUNPLFdBQXBCO0FBQ0EsU0FBS0MsTUFBTCxHQUFjUixNQUFNLENBQUNTLFlBQXJCO0FBRUEsU0FBS0MsSUFBTCxHQUFZLENBQVo7QUFFQSxTQUFLQyx1QkFBTCxHQUErQixJQUEvQjtBQUNEOzs7O1dBRUQsaUJBQXFCO0FBQ25CLFdBQUtBLHVCQUFMLEdBQStCQyxxQkFBcUIsQ0FBQyxLQUFLQyxNQUFMLENBQVlDLElBQVosQ0FBaUIsSUFBakIsQ0FBRCxDQUFwRDtBQUNEOzs7V0FFRCxnQkFBb0I7QUFDbEIsVUFBSSxLQUFLSCx1QkFBVCxFQUFrQztBQUNoQ0ksUUFBQUEsb0JBQW9CLENBQUMsS0FBS0osdUJBQU4sQ0FBcEI7QUFDRDtBQUNGOzs7V0FFRCxrQkFBc0I7QUFDcEIsVUFBSSxDQUFDLEtBQUtWLE9BQVYsRUFBbUI7QUFDakI7QUFDRDs7QUFFRCxXQUFLQSxPQUFMLENBQWFlLFNBQWIsQ0FBdUIsQ0FBdkIsRUFBMEIsQ0FBMUIsRUFBNkIsS0FBS2hCLE1BQUwsQ0FBWU0sS0FBekMsRUFBZ0QsS0FBS04sTUFBTCxDQUFZUSxNQUE1RDtBQUNBLFdBQUtQLE9BQUwsQ0FBYWdCLFNBQWI7QUFDQSxXQUFLaEIsT0FBTCxDQUFhaUIsR0FBYixDQUNFLEtBQUtsQixNQUFMLENBQVlNLEtBQVosR0FBb0IsQ0FEdEIsRUFFRSxLQUFLTixNQUFMLENBQVlRLE1BQVosR0FBcUIsQ0FGdkIsRUFHRyxLQUFLUixNQUFMLENBQVlNLEtBQVosR0FBb0IsQ0FBckIsR0FBMEJhLElBQUksQ0FBQ0MsR0FBTCxDQUFTRCxJQUFJLENBQUNFLEdBQUwsQ0FBUyxLQUFLWCxJQUFkLENBQVQsQ0FINUIsRUFJRSxDQUpGLEVBS0UsSUFBSVMsSUFBSSxDQUFDRyxFQUxYO0FBT0EsV0FBS3JCLE9BQUwsQ0FBYXNCLElBQWI7QUFDQSxXQUFLYixJQUFMLElBQWEsSUFBYjtBQUVBLFdBQUtDLHVCQUFMLEdBQStCQyxxQkFBcUIsQ0FBQyxLQUFLQyxNQUFMLENBQVlDLElBQVosQ0FBaUIsSUFBakIsQ0FBRCxDQUFwRDtBQUNEIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNsYXNzIFpvb21DaXJjbGUge1xuICBwcml2YXRlIHJlYWRvbmx5IGNhbnZhczogSFRNTENhbnZhc0VsZW1lbnRcbiAgcHJpdmF0ZSByZWFkb25seSBjb250ZXh0OiBDYW52YXNSZW5kZXJpbmdDb250ZXh0MkQgfCBudWxsXG5cbiAgcHJpdmF0ZSByZWFkb25seSByYXRpbzogbnVtYmVyXG4gIHByaXZhdGUgcmVhZG9ubHkgd2lkdGg6IG51bWJlclxuICBwcml2YXRlIHJlYWRvbmx5IGhlaWdodDogbnVtYmVyXG5cbiAgcHJpdmF0ZSB0aW1lOiBudW1iZXJcblxuICBwcml2YXRlIGFuaW1hdGlvbkZyYW1lUmVxdWVzdElkOiBudW1iZXIgfCBudWxsXG5cbiAgY29uc3RydWN0b3IoY2FudmFzOiBIVE1MQ2FudmFzRWxlbWVudCkge1xuICAgIHRoaXMuY2FudmFzID0gY2FudmFzXG4gICAgdGhpcy5jb250ZXh0ID0gY2FudmFzLmdldENvbnRleHQoJzJkJylcblxuICAgIHRoaXMucmF0aW8gPSB3aW5kb3cuZGV2aWNlUGl4ZWxSYXRpb1xuICAgIHRoaXMud2lkdGggPSBjYW52YXMub2Zmc2V0V2lkdGhcbiAgICB0aGlzLmhlaWdodCA9IGNhbnZhcy5vZmZzZXRIZWlnaHRcblxuICAgIHRoaXMudGltZSA9IDBcblxuICAgIHRoaXMuYW5pbWF0aW9uRnJhbWVSZXF1ZXN0SWQgPSBudWxsXG4gIH1cblxuICBwdWJsaWMgc3RhcnQoKTogdm9pZCB7XG4gICAgdGhpcy5hbmltYXRpb25GcmFtZVJlcXVlc3RJZCA9IHJlcXVlc3RBbmltYXRpb25GcmFtZSh0aGlzLnJlbmRlci5iaW5kKHRoaXMpKVxuICB9XG5cbiAgcHVibGljIHN0b3AoKTogdm9pZCB7XG4gICAgaWYgKHRoaXMuYW5pbWF0aW9uRnJhbWVSZXF1ZXN0SWQpIHtcbiAgICAgIGNhbmNlbEFuaW1hdGlvbkZyYW1lKHRoaXMuYW5pbWF0aW9uRnJhbWVSZXF1ZXN0SWQpXG4gICAgfVxuICB9XG5cbiAgcHVibGljIHJlbmRlcigpOiB2b2lkIHtcbiAgICBpZiAoIXRoaXMuY29udGV4dCkge1xuICAgICAgcmV0dXJuXG4gICAgfVxuXG4gICAgdGhpcy5jb250ZXh0LmNsZWFyUmVjdCgwLCAwLCB0aGlzLmNhbnZhcy53aWR0aCwgdGhpcy5jYW52YXMuaGVpZ2h0KVxuICAgIHRoaXMuY29udGV4dC5iZWdpblBhdGgoKVxuICAgIHRoaXMuY29udGV4dC5hcmMoXG4gICAgICB0aGlzLmNhbnZhcy53aWR0aCAvIDIsXG4gICAgICB0aGlzLmNhbnZhcy5oZWlnaHQgLyAyLFxuICAgICAgKHRoaXMuY2FudmFzLndpZHRoIC8gMikgKiBNYXRoLmFicyhNYXRoLmNvcyh0aGlzLnRpbWUpKSxcbiAgICAgIDAsXG4gICAgICAyICogTWF0aC5QSVxuICAgIClcbiAgICB0aGlzLmNvbnRleHQuZmlsbCgpXG4gICAgdGhpcy50aW1lICs9IDAuMDVcblxuICAgIHRoaXMuYW5pbWF0aW9uRnJhbWVSZXF1ZXN0SWQgPSByZXF1ZXN0QW5pbWF0aW9uRnJhbWUodGhpcy5yZW5kZXIuYmluZCh0aGlzKSlcbiAgfVxufVxuIl19
export { ActiveBackground } from './ActiveBackground';
export { Confetti } from './ActiveBackground/Confetti';
export { ZoomCircle } from './ActiveBackground/ZoomCircle';
export declare type ActiveBackgroundPatternOptions = Record<string, any>;
export interface IActiveBackgroundPatternConstructor {
new (canvas: HTMLCanvasElement, options: ActiveBackgroundPatternOptions): IActiveBackgroundPattern;
}
export interface IActiveBackgroundPattern {
render(): void;
start(): void;
stop(): void;
}
export interface IActiveBackground {
pattern: IActiveBackgroundPatternConstructor;
patternOptions?: {
[key: string]: any;
};
className?: string;
}
export type { PatternConstructor, PatternOptions, ActiveBackgroundProps } from './ActiveBackground';

@@ -30,2 +30,2 @@ "use strict";

var _ZoomCircle = require("./ActiveBackground/ZoomCircle");
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IEFjdGl2ZUJhY2tncm91bmQgfSBmcm9tICcuL0FjdGl2ZUJhY2tncm91bmQnXG5leHBvcnQgeyBDb25mZXR0aSB9IGZyb20gJy4vQWN0aXZlQmFja2dyb3VuZC9Db25mZXR0aSdcbmV4cG9ydCB7IFpvb21DaXJjbGUgfSBmcm9tICcuL0FjdGl2ZUJhY2tncm91bmQvWm9vbUNpcmNsZSdcblxuZXhwb3J0IHR5cGUgQWN0aXZlQmFja2dyb3VuZFBhdHRlcm5PcHRpb25zID0gUmVjb3JkPHN0cmluZywgYW55PlxuXG5leHBvcnQgaW50ZXJmYWNlIElBY3RpdmVCYWNrZ3JvdW5kUGF0dGVybkNvbnN0cnVjdG9yIHtcbiAgbmV3IChcbiAgICBjYW52YXM6IEhUTUxDYW52YXNFbGVtZW50LFxuICAgIG9wdGlvbnM6IEFjdGl2ZUJhY2tncm91bmRQYXR0ZXJuT3B0aW9uc1xuICApOiBJQWN0aXZlQmFja2dyb3VuZFBhdHRlcm5cbn1cblxuZXhwb3J0IGludGVyZmFjZSBJQWN0aXZlQmFja2dyb3VuZFBhdHRlcm4ge1xuICByZW5kZXIoKTogdm9pZFxuICBzdGFydCgpOiB2b2lkXG4gIHN0b3AoKTogdm9pZFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIElBY3RpdmVCYWNrZ3JvdW5kIHtcbiAgcGF0dGVybjogSUFjdGl2ZUJhY2tncm91bmRQYXR0ZXJuQ29uc3RydWN0b3JcbiAgcGF0dGVybk9wdGlvbnM/OiB7IFtrZXk6IHN0cmluZ106IGFueSB9XG4gIGNsYXNzTmFtZT86IHN0cmluZ1xufVxuIl19
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IEFjdGl2ZUJhY2tncm91bmQgfSBmcm9tICcuL0FjdGl2ZUJhY2tncm91bmQnXG5leHBvcnQgeyBDb25mZXR0aSB9IGZyb20gJy4vQWN0aXZlQmFja2dyb3VuZC9Db25mZXR0aSdcbmV4cG9ydCB7IFpvb21DaXJjbGUgfSBmcm9tICcuL0FjdGl2ZUJhY2tncm91bmQvWm9vbUNpcmNsZSdcblxuZXhwb3J0IHR5cGUgeyBQYXR0ZXJuQ29uc3RydWN0b3IsIFBhdHRlcm5PcHRpb25zLCBBY3RpdmVCYWNrZ3JvdW5kUHJvcHMgfSBmcm9tICcuL0FjdGl2ZUJhY2tncm91bmQnIl19
{
"name": "@exercism/active-background",
"version": "0.2.0",
"version": "0.3.0",
"description": "Give your elements an animated canvas background!",
"main": "dist/index.js",
"types": "dist/index.d.ts",
"scripts": {
"prepare": "npm run build",
"type-check": "tsc --noEmit",
"type-check:watch": "npm run type-check -- --watch",
"build": "npm run build:js && npm run build:types",
"clean": "rimraf dist",
"build": "npm run clean && npm run build:js && npm run build:types",
"build:types": "tsc --emitDeclarationOnly",
"build:js": "babel src --out-dir dist --extensions \".ts,.tsx\" --source-maps inline"
"build:js": "babel src --out-dir dist --extensions \".ts,.tsx\" --source-maps inline",
"prepare": "npm run build",
"prepublishOnly": "npm run type-check"
},

@@ -19,3 +22,6 @@ "keywords": [

],
"author": "Tim Austin",
"author": "Tim Austin <tim@neenjaw.com> (https://neenjaw.com)",
"contributors": [
"Derk-Jan Karrenbeld <derk-jan+git@karrenbeld.info> (https://derk-jan.com)"
],
"license": "MIT",

@@ -30,4 +36,8 @@ "devDependencies": {

"@types/react-dom": "^17.0.3",
"rimraf": "^3.0.2",
"typescript": "^4.2.4"
},
"files": [
"dist"
],
"peerDependencies": {

@@ -34,0 +44,0 @@ "react": ">=16.13.1",

@@ -17,3 +17,3 @@ # react-active-background

import { ActiveBackground, Confetti } from '@exercism/react-active-background'
import { ActiveBackground, Confetti } from '@exercism/active-background'

@@ -24,18 +24,16 @@ function App() {

<header className="App-header">
/*
* Active Background must be the first child in a react container component
*/
<ActiveBackground pattern={Confetti} />
<img src={logo} className="App-logo" alt="logo" />
<p>
Edit <code>src/App.tsx</code> and save to reload.
</p>
<a
className="App-link"
href="https://reactjs.org"
target="_blank"
rel="noopener noreferrer"
>
Learn React
</a>
<ActiveBackground pattern={Confetti}>
<img src={logo} className="App-logo" alt="logo" />
<p>
Edit <code>src/App.tsx</code> and save to reload.
</p>
<a
className="App-link"
href="https://reactjs.org"
target="_blank"
rel="noopener noreferrer"
>
Learn React
</a>
</ActiveBackground>
</header>

@@ -67,1 +65,5 @@ </div>

```
## Authors
This library was originally created by @neenjaw. It is maintained by @neenjaw, @sleeplessbyte and the Exercism team. See the [GitHub contributors graph](https://github.com/exercism/react-active-background/graphs/contributors) for a full list of contributors.
SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc