angular-particle-effect-button
Advanced tools
Comparing version 0.0.42 to 0.0.43
(function (global, factory) { | ||
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('animejs'), require('@angular/core')) : | ||
typeof define === 'function' && define.amd ? define('angular-particle-effect-button', ['exports', 'animejs', '@angular/core'], factory) : | ||
(factory((global['angular-particle-effect-button'] = {}),global.anime,global.ng.core)); | ||
}(this, (function (exports,anime,core) { 'use strict'; | ||
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('animejs')) : | ||
typeof define === 'function' && define.amd ? define('angular-particle-effect-button', ['exports', '@angular/core', 'animejs'], factory) : | ||
(global = global || self, factory(global['angular-particle-effect-button'] = {}, global.ng.core, global.animejs)); | ||
}(this, function (exports, core, anime) { 'use strict'; | ||
anime = anime && anime.hasOwnProperty('default') ? anime['default'] : anime; | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** @type {?} */ | ||
var is = { | ||
arr: function (a) { return Array.isArray(a); }, | ||
str: function (a) { return typeof a === 'string'; }, | ||
fnc: function (a) { return typeof a === 'function'; } | ||
}; | ||
/** @type {?} */ | ||
var stringToHyphens = function (str) { | ||
return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase(); | ||
}; | ||
/** @type {?} */ | ||
var getCSSValue = function (el, prop) { | ||
if (prop in el.style) { | ||
return getComputedStyle(el).getPropertyValue(stringToHyphens(prop)) || '0'; | ||
} | ||
}; | ||
/** @type {?} */ | ||
var t = 'transform'; | ||
/** @type {?} */ | ||
var transformString = getCSSValue(document.body, t) ? t : '-webkit-' + t; | ||
/** @type {?} */ | ||
var rand = function (value) { | ||
return Math.random() * value - value / 2; | ||
}; | ||
/*! ***************************************************************************** | ||
@@ -52,9 +23,22 @@ Copyright (c) Microsoft Corporation. All rights reserved. | ||
***************************************************************************** */ | ||
var __assign = function () { | ||
/* global Reflect, Promise */ | ||
var extendStatics = function(d, b) { | ||
extendStatics = Object.setPrototypeOf || | ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || | ||
function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; | ||
return extendStatics(d, b); | ||
}; | ||
function __extends(d, b) { | ||
extendStatics(d, b); | ||
function __() { this.constructor = d; } | ||
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); | ||
} | ||
var __assign = function() { | ||
__assign = Object.assign || function __assign(t) { | ||
for (var s, i = 1, n = arguments.length; i < n; i++) { | ||
s = arguments[i]; | ||
for (var p in s) | ||
if (Object.prototype.hasOwnProperty.call(s, p)) | ||
t[p] = s[p]; | ||
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; | ||
} | ||
@@ -66,6 +50,262 @@ return t; | ||
function __rest(s, e) { | ||
var t = {}; | ||
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) | ||
t[p] = s[p]; | ||
if (s != null && typeof Object.getOwnPropertySymbols === "function") | ||
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { | ||
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) | ||
t[p[i]] = s[p[i]]; | ||
} | ||
return t; | ||
} | ||
function __decorate(decorators, target, key, desc) { | ||
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; | ||
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); | ||
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; | ||
return c > 3 && r && Object.defineProperty(target, key, r), r; | ||
} | ||
function __param(paramIndex, decorator) { | ||
return function (target, key) { decorator(target, key, paramIndex); } | ||
} | ||
function __metadata(metadataKey, metadataValue) { | ||
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue); | ||
} | ||
function __awaiter(thisArg, _arguments, P, generator) { | ||
return new (P || (P = Promise))(function (resolve, reject) { | ||
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } | ||
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } | ||
function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } | ||
step((generator = generator.apply(thisArg, _arguments || [])).next()); | ||
}); | ||
} | ||
function __generator(thisArg, body) { | ||
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; | ||
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; | ||
function verb(n) { return function (v) { return step([n, v]); }; } | ||
function step(op) { | ||
if (f) throw new TypeError("Generator is already executing."); | ||
while (_) try { | ||
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; | ||
if (y = 0, t) op = [op[0] & 2, t.value]; | ||
switch (op[0]) { | ||
case 0: case 1: t = op; break; | ||
case 4: _.label++; return { value: op[1], done: false }; | ||
case 5: _.label++; y = op[1]; op = [0]; continue; | ||
case 7: op = _.ops.pop(); _.trys.pop(); continue; | ||
default: | ||
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } | ||
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } | ||
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } | ||
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } | ||
if (t[2]) _.ops.pop(); | ||
_.trys.pop(); continue; | ||
} | ||
op = body.call(thisArg, _); | ||
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } | ||
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; | ||
} | ||
} | ||
function __exportStar(m, exports) { | ||
for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p]; | ||
} | ||
function __values(o) { | ||
var m = typeof Symbol === "function" && o[Symbol.iterator], i = 0; | ||
if (m) return m.call(o); | ||
return { | ||
next: function () { | ||
if (o && i >= o.length) o = void 0; | ||
return { value: o && o[i++], done: !o }; | ||
} | ||
}; | ||
} | ||
function __read(o, n) { | ||
var m = typeof Symbol === "function" && o[Symbol.iterator]; | ||
if (!m) return o; | ||
var i = m.call(o), r, ar = [], e; | ||
try { | ||
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); | ||
} | ||
catch (error) { e = { error: error }; } | ||
finally { | ||
try { | ||
if (r && !r.done && (m = i["return"])) m.call(i); | ||
} | ||
finally { if (e) throw e.error; } | ||
} | ||
return ar; | ||
} | ||
function __spread() { | ||
for (var ar = [], i = 0; i < arguments.length; i++) | ||
ar = ar.concat(__read(arguments[i])); | ||
return ar; | ||
} | ||
function __spreadArrays() { | ||
for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length; | ||
for (var r = Array(s), k = 0, i = 0; i < il; i++) | ||
for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) | ||
r[k] = a[j]; | ||
return r; | ||
}; | ||
function __await(v) { | ||
return this instanceof __await ? (this.v = v, this) : new __await(v); | ||
} | ||
function __asyncGenerator(thisArg, _arguments, generator) { | ||
if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); | ||
var g = generator.apply(thisArg, _arguments || []), i, q = []; | ||
return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i; | ||
function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; } | ||
function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } } | ||
function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); } | ||
function fulfill(value) { resume("next", value); } | ||
function reject(value) { resume("throw", value); } | ||
function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); } | ||
} | ||
function __asyncDelegator(o) { | ||
var i, p; | ||
return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i; | ||
function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === "return" } : f ? f(v) : v; } : f; } | ||
} | ||
function __asyncValues(o) { | ||
if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); | ||
var m = o[Symbol.asyncIterator], i; | ||
return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i); | ||
function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; } | ||
function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); } | ||
} | ||
function __makeTemplateObject(cooked, raw) { | ||
if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; } | ||
return cooked; | ||
}; | ||
function __importStar(mod) { | ||
if (mod && mod.__esModule) return mod; | ||
var result = {}; | ||
if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k]; | ||
result.default = mod; | ||
return result; | ||
} | ||
function __importDefault(mod) { | ||
return (mod && mod.__esModule) ? mod : { default: mod }; | ||
} | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
var ɵ0 = /** | ||
* @param {?} a | ||
* @return {?} | ||
*/ | ||
function (a) { return Array.isArray(a); }, ɵ1 = /** | ||
* @param {?} a | ||
* @return {?} | ||
*/ | ||
function (a) { return typeof a === 'string'; }, ɵ2 = /** | ||
* @param {?} a | ||
* @return {?} | ||
*/ | ||
function (a) { return typeof a === 'function'; }; | ||
/** @type {?} */ | ||
var is = { | ||
arr: (ɵ0), | ||
str: (ɵ1), | ||
fnc: (ɵ2) | ||
}; | ||
/** @type {?} */ | ||
var stringToHyphens = (/** | ||
* @param {?} str | ||
* @return {?} | ||
*/ | ||
function (str) { | ||
return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase(); | ||
}); | ||
/** @type {?} */ | ||
var getCSSValue = (/** | ||
* @param {?} el | ||
* @param {?} prop | ||
* @return {?} | ||
*/ | ||
function (el, prop) { | ||
if (prop in el.style) { | ||
return getComputedStyle(el).getPropertyValue(stringToHyphens(prop)) || '0'; | ||
} | ||
}); | ||
/** @type {?} */ | ||
var t = 'transform'; | ||
/** @type {?} */ | ||
var transformString = getCSSValue(document.body, t) ? t : '-webkit-' + t; | ||
/** @type {?} */ | ||
var rand = (/** | ||
* @param {?} value | ||
* @return {?} | ||
*/ | ||
function (value) { | ||
return Math.random() * value - value / 2; | ||
}); | ||
/** @type {?} */ | ||
var getElement = (/** | ||
* @param {?} element | ||
* @return {?} | ||
*/ | ||
function (element) { | ||
return is.str(element) ? document.querySelector(element) : element; | ||
}); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @record | ||
*/ | ||
function IOption() { } | ||
if (false) { | ||
/** @type {?|undefined} */ | ||
IOption.prototype.color; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.type; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.style; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.canvasPadding; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.duration; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.easing; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.direction; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.size; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.speed; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.particlesAmountCoefficient; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.oscillationCoefficient; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.begin; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.width; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.height; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.complete; | ||
} | ||
var Particles = /** @class */ (function () { | ||
@@ -87,24 +327,24 @@ function Particles(el, options, renderer) { | ||
*/ | ||
function () { | ||
this.canvas = this.renderer.createElement('canvas'); | ||
this.ctx = this.canvas.getContext('2d'); | ||
this.renderer.setStyle(this.canvas, 'position', 'absolute'); | ||
this.renderer.setStyle(this.canvas, 'pointerEvents', 'none'); | ||
this.renderer.setStyle(this.canvas, 'top', '50%'); | ||
this.renderer.setStyle(this.canvas, 'left', '50%'); | ||
this.renderer.setStyle(this.canvas, 'transform', 'translate3d(-50%, -50%, 0)'); | ||
this.renderer.setStyle(this.canvas, 'display', 'none'); | ||
this.wrapper = this.renderer.createElement('div'); | ||
this.renderer.setStyle(this.wrapper, 'position', 'relative'); | ||
this.renderer.setStyle(this.wrapper, 'display', 'inline-block'); | ||
this.renderer.setStyle(this.wrapper, 'overflow', 'hidden'); | ||
this.renderer.insertBefore(this.el.parentNode, this.wrapper, this.el); | ||
this.renderer.appendChild(this.wrapper, this.el); | ||
this.parentWrapper = this.renderer.createElement('div'); | ||
this.renderer.setStyle(this.parentWrapper, 'position', 'relative'); | ||
this.renderer.setStyle(this.parentWrapper, 'display', 'inline-block'); | ||
this.renderer.insertBefore(this.wrapper.parentNode, this.parentWrapper, this.wrapper); | ||
this.renderer.appendChild(this.parentWrapper, this.wrapper); | ||
this.renderer.appendChild(this.parentWrapper, this.canvas); | ||
}; | ||
function () { | ||
this.canvas = this.renderer.createElement('canvas'); | ||
this.ctx = this.canvas.getContext('2d'); | ||
this.renderer.setStyle(this.canvas, 'position', 'absolute'); | ||
this.renderer.setStyle(this.canvas, 'pointerEvents', 'none'); | ||
this.renderer.setStyle(this.canvas, 'top', '50%'); | ||
this.renderer.setStyle(this.canvas, 'left', '50%'); | ||
this.renderer.setStyle(this.canvas, 'transform', 'translate3d(-50%, -50%, 0)'); | ||
this.renderer.setStyle(this.canvas, 'display', 'none'); | ||
this.wrapper = this.renderer.createElement('div'); | ||
this.renderer.setStyle(this.wrapper, 'position', 'relative'); | ||
this.renderer.setStyle(this.wrapper, 'display', 'inline-block'); | ||
this.renderer.setStyle(this.wrapper, 'overflow', 'hidden'); | ||
this.renderer.insertBefore(this.el.parentNode, this.wrapper, this.el); | ||
this.renderer.appendChild(this.wrapper, this.el); | ||
this.parentWrapper = this.renderer.createElement('div'); | ||
this.renderer.setStyle(this.parentWrapper, 'position', 'relative'); | ||
this.renderer.setStyle(this.parentWrapper, 'display', 'inline-block'); | ||
this.renderer.insertBefore(this.wrapper.parentNode, this.parentWrapper, this.wrapper); | ||
this.renderer.appendChild(this.parentWrapper, this.wrapper); | ||
this.renderer.appendChild(this.parentWrapper, this.canvas); | ||
}; | ||
/** | ||
@@ -118,5 +358,5 @@ * @param {?} options | ||
*/ | ||
function (options) { | ||
this.options = __assign({}, this.options, options); | ||
}; | ||
function (options) { | ||
this.options = __assign({}, this.options, options); | ||
}; | ||
/** | ||
@@ -128,9 +368,9 @@ * @return {?} | ||
*/ | ||
function () { | ||
this.updateParticles(); | ||
this.renderParticles(); | ||
if (this.isAnimating()) { | ||
this.frame = requestAnimationFrame(this.loop.bind(this)); | ||
} | ||
}; | ||
function () { | ||
this.updateParticles(); | ||
this.renderParticles(); | ||
if (this.isAnimating()) { | ||
this.frame = requestAnimationFrame(this.loop.bind(this)); | ||
} | ||
}; | ||
/** | ||
@@ -142,25 +382,25 @@ * @return {?} | ||
*/ | ||
function () { | ||
/** @type {?} */ | ||
var p; | ||
for (var i = 0; i < this.particles.length; i++) { | ||
p = this.particles[i]; | ||
if (p.life > p.death) { | ||
this.particles.splice(i, 1); | ||
} | ||
else { | ||
p.x += p.speed; | ||
p.y = this.o.oscillationCoefficient * Math.sin(p.counter * p.increase); | ||
p.life++; | ||
p.counter += this.disintegrating ? 1 : -1; | ||
} | ||
function () { | ||
/** @type {?} */ | ||
var p; | ||
for (var i = 0; i < this.particles.length; i++) { | ||
p = this.particles[i]; | ||
if (p.life > p.death) { | ||
this.particles.splice(i, 1); | ||
} | ||
if (!this.particles.length) { | ||
this.pause(); | ||
this.renderer.setStyle(this.canvas, 'display', 'none'); | ||
if (is.fnc(this.o.complete)) { | ||
this.o.complete(); | ||
} | ||
else { | ||
p.x += p.speed; | ||
p.y = this.o.oscillationCoefficient * Math.sin(p.counter * p.increase); | ||
p.life++; | ||
p.counter += this.disintegrating ? 1 : -1; | ||
} | ||
}; | ||
} | ||
if (!this.particles.length) { | ||
this.pause(); | ||
this.renderer.setStyle(this.canvas, 'display', 'none'); | ||
if (is.fnc(this.o.complete)) { | ||
this.o.complete(); | ||
} | ||
} | ||
}; | ||
/** | ||
@@ -172,40 +412,40 @@ * @return {?} | ||
*/ | ||
function () { | ||
this.ctx.clearRect(0, 0, this.width, this.height); | ||
/** @type {?} */ | ||
var p; | ||
for (var i = 0; i < this.particles.length; i++) { | ||
p = this.particles[i]; | ||
if (p.life < p.death) { | ||
this.ctx.translate(p.startX, p.startY); | ||
this.ctx.rotate(p.angle * Math.PI / 180); | ||
this.ctx.globalAlpha = this.disintegrating | ||
? 1 - p.life / p.death | ||
: p.life / p.death; | ||
this.ctx.fillStyle = this.ctx.strokeStyle = this.o.color; | ||
this.ctx.beginPath(); | ||
if (this.o.type === 'circle') { | ||
this.ctx.arc(p.x, p.y, p.size, 0, 2 * Math.PI); | ||
} | ||
else if (this.o.type === 'triangle') { | ||
this.ctx.moveTo(p.x, p.y); | ||
this.ctx.lineTo(p.x + p.size, p.y + p.size); | ||
this.ctx.lineTo(p.x + p.size, p.y - p.size); | ||
} | ||
else if (this.o.type === 'rectangle') { | ||
this.ctx.rect(p.x, p.y, p.size, p.size); | ||
} | ||
if (this.o.style === 'fill') { | ||
this.ctx.fill(); | ||
} | ||
else if (this.o.style === 'stroke') { | ||
this.ctx.closePath(); | ||
this.ctx.stroke(); | ||
} | ||
this.ctx.globalAlpha = 1; | ||
this.ctx.rotate(-p.angle * Math.PI / 180); | ||
this.ctx.translate(-p.startX, -p.startY); | ||
function () { | ||
this.ctx.clearRect(0, 0, this.width, this.height); | ||
/** @type {?} */ | ||
var p; | ||
for (var i = 0; i < this.particles.length; i++) { | ||
p = this.particles[i]; | ||
if (p.life < p.death) { | ||
this.ctx.translate(p.startX, p.startY); | ||
this.ctx.rotate(p.angle * Math.PI / 180); | ||
this.ctx.globalAlpha = this.disintegrating | ||
? 1 - p.life / p.death | ||
: p.life / p.death; | ||
this.ctx.fillStyle = this.ctx.strokeStyle = this.o.color; | ||
this.ctx.beginPath(); | ||
if (this.o.type === 'circle') { | ||
this.ctx.arc(p.x, p.y, p.size, 0, 2 * Math.PI); | ||
} | ||
else if (this.o.type === 'triangle') { | ||
this.ctx.moveTo(p.x, p.y); | ||
this.ctx.lineTo(p.x + p.size, p.y + p.size); | ||
this.ctx.lineTo(p.x + p.size, p.y - p.size); | ||
} | ||
else if (this.o.type === 'rectangle') { | ||
this.ctx.rect(p.x, p.y, p.size, p.size); | ||
} | ||
if (this.o.style === 'fill') { | ||
this.ctx.fill(); | ||
} | ||
else if (this.o.style === 'stroke') { | ||
this.ctx.closePath(); | ||
this.ctx.stroke(); | ||
} | ||
this.ctx.globalAlpha = 1; | ||
this.ctx.rotate(-p.angle * Math.PI / 180); | ||
this.ctx.translate(-p.startX, -p.startY); | ||
} | ||
}; | ||
} | ||
}; | ||
/** | ||
@@ -217,5 +457,5 @@ * @return {?} | ||
*/ | ||
function () { | ||
this.frame = requestAnimationFrame(this.loop.bind(this)); | ||
}; | ||
function () { | ||
this.frame = requestAnimationFrame(this.loop.bind(this)); | ||
}; | ||
/** | ||
@@ -227,6 +467,6 @@ * @return {?} | ||
*/ | ||
function () { | ||
cancelAnimationFrame(this.frame); | ||
this.frame = null; | ||
}; | ||
function () { | ||
cancelAnimationFrame(this.frame); | ||
this.frame = null; | ||
}; | ||
/** | ||
@@ -240,23 +480,23 @@ * @param {?} options | ||
*/ | ||
function (options) { | ||
/** @type {?} */ | ||
var frames = this.o.duration * 60 / 1000; | ||
/** @type {?} */ | ||
var speed = ( /** @type {?} */((is.fnc(this.o.speed) | ||
? this.o.speed() | ||
: this.o.speed))); | ||
this.particles.push({ | ||
startX: options.x, | ||
startY: options.y, | ||
x: this.disintegrating ? 0 : speed * -frames, | ||
y: 0, | ||
angle: rand(360), | ||
counter: this.disintegrating ? 0 : frames, | ||
increase: Math.PI * 2 / 100, | ||
life: 0, | ||
death: this.disintegrating ? frames - 20 + Math.random() * 40 : frames, | ||
speed: speed, | ||
size: is.fnc(this.o.size) ? this.o.size() : this.o.size | ||
}); | ||
}; | ||
function (options) { | ||
/** @type {?} */ | ||
var frames = this.o.duration * 60 / 1000; | ||
/** @type {?} */ | ||
var speed = (/** @type {?} */ ((is.fnc(this.o.speed) | ||
? this.o.speed() | ||
: this.o.speed))); | ||
this.particles.push({ | ||
startX: options.x, | ||
startY: options.y, | ||
x: this.disintegrating ? 0 : speed * -frames, | ||
y: 0, | ||
angle: rand(360), | ||
counter: this.disintegrating ? 0 : frames, | ||
increase: Math.PI * 2 / 100, | ||
life: 0, | ||
death: this.disintegrating ? frames - 20 + Math.random() * 40 : frames, | ||
speed: speed, | ||
size: is.fnc(this.o.size) ? this.o.size() : this.o.size | ||
}); | ||
}; | ||
/** | ||
@@ -272,42 +512,42 @@ * @param {?} rect | ||
*/ | ||
function (rect, progress) { | ||
/** @type {?} */ | ||
var progressDiff = this.disintegrating | ||
? progress - this.lastProgress | ||
: this.lastProgress - progress; | ||
this.lastProgress = progress; | ||
/** @type {?} */ | ||
var x = this.options.canvasPadding; | ||
/** @type {?} */ | ||
var y = this.options.canvasPadding; | ||
/** @type {?} */ | ||
var progressValue = (this.isHorizontal() ? rect.width : rect.height) * progress + | ||
progressDiff * (this.disintegrating ? 100 : 220); | ||
if (this.isHorizontal()) { | ||
x += | ||
this.o.direction === 'left' | ||
? progressValue | ||
: rect.width - progressValue; | ||
function (rect, progress) { | ||
/** @type {?} */ | ||
var progressDiff = this.disintegrating | ||
? progress - this.lastProgress | ||
: this.lastProgress - progress; | ||
this.lastProgress = progress; | ||
/** @type {?} */ | ||
var x = this.options.canvasPadding; | ||
/** @type {?} */ | ||
var y = this.options.canvasPadding; | ||
/** @type {?} */ | ||
var progressValue = (this.isHorizontal() ? rect.width : rect.height) * progress + | ||
progressDiff * (this.disintegrating ? 100 : 220); | ||
if (this.isHorizontal()) { | ||
x += | ||
this.o.direction === 'left' | ||
? progressValue | ||
: rect.width - progressValue; | ||
} | ||
else { | ||
y += | ||
this.o.direction === 'top' | ||
? progressValue | ||
: rect.height - progressValue; | ||
} | ||
/** @type {?} */ | ||
var i = Math.floor(this.o.particlesAmountCoefficient * (progressDiff * 100 + 1)); | ||
if (i > 0) { | ||
while (i--) { | ||
this.addParticle({ | ||
x: x + (this.isHorizontal() ? 0 : rect.width * Math.random()), | ||
y: y + (this.isHorizontal() ? rect.height * Math.random() : 0) | ||
}); | ||
} | ||
else { | ||
y += | ||
this.o.direction === 'top' | ||
? progressValue | ||
: rect.height - progressValue; | ||
} | ||
/** @type {?} */ | ||
var i = Math.floor(this.o.particlesAmountCoefficient * (progressDiff * 100 + 1)); | ||
if (i > 0) { | ||
while (i--) { | ||
this.addParticle({ | ||
x: x + (this.isHorizontal() ? 0 : rect.width * Math.random()), | ||
y: y + (this.isHorizontal() ? rect.height * Math.random() : 0) | ||
}); | ||
} | ||
} | ||
if (!this.isAnimating()) { | ||
this.renderer.setStyle(this.canvas, 'display', 'block'); | ||
this.play(); | ||
} | ||
}; | ||
} | ||
if (!this.isAnimating()) { | ||
this.renderer.setStyle(this.canvas, 'display', 'block'); | ||
this.play(); | ||
} | ||
}; | ||
/** | ||
@@ -321,12 +561,12 @@ * @param {?} value | ||
*/ | ||
function (value) { | ||
/** @type {?} */ | ||
var translateProperty = this.isHorizontal() ? 'translateX' : 'translateY'; | ||
/** @type {?} */ | ||
var translateValue = this.o.direction === 'left' || this.o.direction === 'top' | ||
? value | ||
: -value; | ||
this.renderer.setStyle(this.wrapper, transformString, translateProperty + "(" + translateValue + "%)"); | ||
this.renderer.setStyle(this.el, transformString, translateProperty + "(" + -translateValue + "%)"); | ||
}; | ||
function (value) { | ||
/** @type {?} */ | ||
var translateProperty = this.isHorizontal() ? 'translateX' : 'translateY'; | ||
/** @type {?} */ | ||
var translateValue = this.o.direction === 'left' || this.o.direction === 'top' | ||
? value | ||
: -value; | ||
this.renderer.setStyle(this.wrapper, transformString, translateProperty + "(" + translateValue + "%)"); | ||
this.renderer.setStyle(this.el, transformString, translateProperty + "(" + -translateValue + "%)"); | ||
}; | ||
/** | ||
@@ -340,22 +580,24 @@ * @param {?=} options | ||
*/ | ||
function (options) { | ||
if (options === void 0) { | ||
options = {}; | ||
} | ||
if (!this.isAnimating()) { | ||
this.disintegrating = true; | ||
this.lastProgress = 0; | ||
this.setup(options); | ||
function (options) { | ||
if (options === void 0) { options = {}; } | ||
if (!this.isAnimating()) { | ||
this.disintegrating = true; | ||
this.lastProgress = 0; | ||
this.setup(options); | ||
/** @type {?} */ | ||
var _1 = this; | ||
this.animate((/** | ||
* @param {?} anim | ||
* @return {?} | ||
*/ | ||
function (anim) { | ||
/** @type {?} */ | ||
var _1 = this; | ||
this.animate(function (anim) { | ||
/** @type {?} */ | ||
var value = anim.animatables[0].target.value; | ||
_1.addTransforms(value); | ||
if (_1.o.duration) { | ||
_1.addParticles(_1.rect, value / 100); | ||
} | ||
}); | ||
} | ||
}; | ||
var value = anim.animatables[0].target.value; | ||
_1.addTransforms(value); | ||
if (_1.o.duration) { | ||
_1.addParticles(_1.rect, value / 100); | ||
} | ||
})); | ||
} | ||
}; | ||
/** | ||
@@ -369,24 +611,29 @@ * @param {?=} options | ||
*/ | ||
function (options) { | ||
if (options === void 0) { | ||
options = {}; | ||
} | ||
if (!this.isAnimating()) { | ||
this.disintegrating = false; | ||
this.lastProgress = 1; | ||
this.setup(options); | ||
function (options) { | ||
if (options === void 0) { options = {}; } | ||
if (!this.isAnimating()) { | ||
this.disintegrating = false; | ||
this.lastProgress = 1; | ||
this.setup(options); | ||
/** @type {?} */ | ||
var _2 = this; | ||
this.animate((/** | ||
* @param {?} anim | ||
* @return {?} | ||
*/ | ||
function (anim) { | ||
/** @type {?} */ | ||
var _2 = this; | ||
this.animate(function (anim) { | ||
/** @type {?} */ | ||
var value = anim.animatables[0].target.value; | ||
setTimeout(function () { | ||
_2.addTransforms(value); | ||
}, _2.o.duration); | ||
if (_2.o.duration) { | ||
_2.addParticles(_2.rect, value / 100); | ||
} | ||
}); | ||
} | ||
}; | ||
var value = anim.animatables[0].target.value; | ||
setTimeout((/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
_2.addTransforms(value); | ||
}), _2.o.duration); | ||
if (_2.o.duration) { | ||
_2.addParticles(_2.rect, value / 100); | ||
} | ||
})); | ||
} | ||
}; | ||
/** | ||
@@ -400,13 +647,13 @@ * @param {?} options | ||
*/ | ||
function (options) { | ||
this.o = __assign({}, this.options, options); | ||
this.renderer.setStyle(this.wrapper, 'visibility', 'visible'); | ||
if (this.o.duration) { | ||
this.rect = this.el.getBoundingClientRect(); | ||
this.width = this.canvas.width = | ||
this.o.width || this.rect.width + this.o.canvasPadding * 2; | ||
this.height = this.canvas.height = | ||
this.o.height || this.rect.height + this.o.canvasPadding * 2; | ||
} | ||
}; | ||
function (options) { | ||
this.o = __assign({}, this.options, options); | ||
this.renderer.setStyle(this.wrapper, 'visibility', 'visible'); | ||
if (this.o.duration) { | ||
this.rect = this.el.getBoundingClientRect(); | ||
this.width = this.canvas.width = | ||
this.o.width || this.rect.width + this.o.canvasPadding * 2; | ||
this.height = this.canvas.height = | ||
this.o.height || this.rect.height + this.o.canvasPadding * 2; | ||
} | ||
}; | ||
/** | ||
@@ -418,5 +665,5 @@ * @return {?} | ||
*/ | ||
function () { | ||
return this.disintegrating; | ||
}; | ||
function () { | ||
return this.disintegrating; | ||
}; | ||
/** | ||
@@ -430,20 +677,23 @@ * @param {?} update | ||
*/ | ||
function (update) { | ||
var _this = this; | ||
/** @type {?} */ | ||
var _ = this; | ||
anime({ | ||
targets: { value: _.disintegrating ? 0 : 100 }, | ||
value: _.disintegrating ? 100 : 0, | ||
duration: _.o.duration, | ||
easing: _.o.easing, | ||
begin: _.o.begin, | ||
update: update, | ||
complete: function () { | ||
if (_.disintegrating) { | ||
_this.renderer.setStyle(_.wrapper, 'visibility', 'hidden'); | ||
} | ||
function (update) { | ||
var _this = this; | ||
/** @type {?} */ | ||
var _ = this; | ||
anime({ | ||
targets: { value: _.disintegrating ? 0 : 100 }, | ||
value: _.disintegrating ? 100 : 0, | ||
duration: _.o.duration, | ||
easing: _.o.easing, | ||
begin: _.o.begin, | ||
update: update, | ||
complete: (/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
if (_.disintegrating) { | ||
_this.renderer.setStyle(_.wrapper, 'visibility', 'hidden'); | ||
} | ||
}); | ||
}; | ||
}) | ||
}); | ||
}; | ||
/** | ||
@@ -455,5 +705,5 @@ * @return {?} | ||
*/ | ||
function () { | ||
return !!this.frame; | ||
}; | ||
function () { | ||
return !!this.frame; | ||
}; | ||
/** | ||
@@ -465,11 +715,52 @@ * @return {?} | ||
*/ | ||
function () { | ||
return this.o.direction === 'left' || this.o.direction === 'right'; | ||
}; | ||
function () { | ||
return this.o.direction === 'left' || this.o.direction === 'right'; | ||
}; | ||
return Particles; | ||
}()); | ||
if (false) { | ||
/** @type {?} */ | ||
Particles.prototype.particles; | ||
/** @type {?} */ | ||
Particles.prototype.frame; | ||
/** @type {?} */ | ||
Particles.prototype.canvas; | ||
/** @type {?} */ | ||
Particles.prototype.ctx; | ||
/** @type {?} */ | ||
Particles.prototype.wrapper; | ||
/** @type {?} */ | ||
Particles.prototype.parentWrapper; | ||
/** @type {?} */ | ||
Particles.prototype.o; | ||
/** @type {?} */ | ||
Particles.prototype.disintegrating; | ||
/** @type {?} */ | ||
Particles.prototype.width; | ||
/** @type {?} */ | ||
Particles.prototype.height; | ||
/** @type {?} */ | ||
Particles.prototype.lastProgress; | ||
/** @type {?} */ | ||
Particles.prototype.rect; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
Particles.prototype.el; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
Particles.prototype.options; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
Particles.prototype.renderer; | ||
} | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -492,4 +783,10 @@ var ParticleEffectButtonDirective = /** @class */ (function () { | ||
this.pComplete = new core.EventEmitter(); | ||
this.pSize = function () { return Math.floor((Math.random() * 3) + 1); }; | ||
this.pSpeed = function () { return rand(4); }; | ||
this.pSize = (/** | ||
* @return {?} | ||
*/ | ||
function () { return Math.floor((Math.random() * 3) + 1); }); | ||
this.pSpeed = (/** | ||
* @return {?} | ||
*/ | ||
function () { return rand(4); }); | ||
} | ||
@@ -499,3 +796,4 @@ Object.defineProperty(ParticleEffectButtonDirective.prototype, "pHidden", { | ||
* @return {?} | ||
*/ function () { | ||
*/ | ||
function () { | ||
return this._pHidden; | ||
@@ -506,3 +804,4 @@ }, | ||
* @return {?} | ||
*/ function (value) { | ||
*/ | ||
function (value) { | ||
this._pHidden = value; | ||
@@ -527,8 +826,8 @@ if (this._particles) { | ||
*/ | ||
function () { | ||
this._particles = new Particles(this.el.nativeElement, this.getFormattedOptions(), this.renderer); | ||
if (this._pHidden) { | ||
this._particles.disintegrate({ duration: 0 }); | ||
} | ||
}; | ||
function () { | ||
this._particles = new Particles(this.el.nativeElement, this.getFormattedOptions(), this.renderer); | ||
if (this._pHidden) { | ||
this._particles.disintegrate({ duration: 0 }); | ||
} | ||
}; | ||
/** | ||
@@ -542,28 +841,35 @@ * @private | ||
*/ | ||
function () { | ||
var _this = this; | ||
return { | ||
color: this.pColor, | ||
type: this.pType, | ||
style: this.pStyle, | ||
canvasPadding: this.pCanvasPadding, | ||
duration: this.pDuration, | ||
easing: this.pEasing, | ||
direction: this.pDirection, | ||
size: this.pSize, | ||
speed: this.pSpeed, | ||
particlesAmountCoefficient: this.pParticlesAmountCoefficient, | ||
oscillationCoefficient: this.pOscillationCoefficient, | ||
begin: function () { | ||
_this.pBegin.emit(); | ||
}, | ||
complete: function () { | ||
_this.pComplete.emit(); | ||
} | ||
}; | ||
function () { | ||
var _this = this; | ||
return { | ||
color: this.pColor, | ||
type: this.pType, | ||
style: this.pStyle, | ||
canvasPadding: this.pCanvasPadding, | ||
duration: this.pDuration, | ||
easing: this.pEasing, | ||
direction: this.pDirection, | ||
size: this.pSize, | ||
speed: this.pSpeed, | ||
particlesAmountCoefficient: this.pParticlesAmountCoefficient, | ||
oscillationCoefficient: this.pOscillationCoefficient, | ||
begin: (/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
_this.pBegin.emit(); | ||
}), | ||
complete: (/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
_this.pComplete.emit(); | ||
}) | ||
}; | ||
}; | ||
Object.defineProperty(ParticleEffectButtonDirective.prototype, "pOptions", { | ||
get: /** | ||
* @return {?} | ||
*/ function () { | ||
*/ | ||
function () { | ||
return { | ||
@@ -588,11 +894,16 @@ pColor: this.pColor, | ||
* @return {?} | ||
*/ function (options) { | ||
*/ | ||
function (options) { | ||
var _this = this; | ||
/** @type {?} */ | ||
var allowedProps = this.pOptions; | ||
Object.keys(options).map(function (key) { | ||
Object.keys(options).map((/** | ||
* @param {?} key | ||
* @return {?} | ||
*/ | ||
function (key) { | ||
if (allowedProps[key]) { | ||
_this[key] = options[key]; | ||
} | ||
}); | ||
})); | ||
}, | ||
@@ -608,8 +919,6 @@ enumerable: true, | ||
/** @nocollapse */ | ||
ParticleEffectButtonDirective.ctorParameters = function () { | ||
return [ | ||
{ type: core.Renderer2 }, | ||
{ type: core.ElementRef } | ||
]; | ||
}; | ||
ParticleEffectButtonDirective.ctorParameters = function () { return [ | ||
{ type: core.Renderer2 }, | ||
{ type: core.ElementRef } | ||
]; }; | ||
ParticleEffectButtonDirective.propDecorators = { | ||
@@ -633,6 +942,54 @@ pColor: [{ type: core.Input }], | ||
}()); | ||
if (false) { | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
ParticleEffectButtonDirective.prototype._particles; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
ParticleEffectButtonDirective.prototype._pHidden; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pColor; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pDuration; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pEasing; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pType; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pStyle; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pDirection; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pCanvasPadding; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pOscillationCoefficient; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pParticlesAmountCoefficient; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pBegin; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pComplete; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pSize; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pSpeed; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
ParticleEffectButtonDirective.prototype.renderer; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
ParticleEffectButtonDirective.prototype.el; | ||
} | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -651,12 +1008,2 @@ var ParticleEffectButtonModule = /** @class */ (function () { | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
exports.ParticleEffectButtonDirective = ParticleEffectButtonDirective; | ||
@@ -667,4 +1014,3 @@ exports.ParticleEffectButtonModule = ParticleEffectButtonModule; | ||
}))); | ||
//# sourceMappingURL=angular-particle-effect-button.umd.js.map | ||
})); | ||
//# sourceMappingURL=angular-particle-effect-button.umd.js.map |
@@ -1,2 +0,2 @@ | ||
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("animejs"),require("@angular/core")):"function"==typeof define&&define.amd?define("angular-particle-effect-button",["exports","animejs","@angular/core"],e):e(t["angular-particle-effect-button"]={},t.anime,t.ng.core)}(this,function(t,s,i){"use strict";s=s&&s.hasOwnProperty("default")?s["default"]:s;var n=function(t){return"function"==typeof t},e="transform",r=function(t,e){if(e in t.style)return getComputedStyle(t).getPropertyValue(function(t){return t.replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase()}(e))||"0"}(document.body,e)?e:"-webkit-"+e,a=function(t){return Math.random()*t-t/2},o=function(){return(o=Object.assign||function(t){for(var e,i=1,s=arguments.length;i<s;i++)for(var n in e=arguments[i])Object.prototype.hasOwnProperty.call(e,n)&&(t[n]=e[n]);return t}).apply(this,arguments)},p=function(){function t(t,e,i){this.el=t,this.options=e,this.renderer=i,this.particles=[],this.frame=null,this.options=o({},e),this.init()}return t.prototype.init=function(){this.canvas=this.renderer.createElement("canvas"),this.ctx=this.canvas.getContext("2d"),this.renderer.setStyle(this.canvas,"position","absolute"),this.renderer.setStyle(this.canvas,"pointerEvents","none"),this.renderer.setStyle(this.canvas,"top","50%"),this.renderer.setStyle(this.canvas,"left","50%"),this.renderer.setStyle(this.canvas,"transform","translate3d(-50%, -50%, 0)"),this.renderer.setStyle(this.canvas,"display","none"),this.wrapper=this.renderer.createElement("div"),this.renderer.setStyle(this.wrapper,"position","relative"),this.renderer.setStyle(this.wrapper,"display","inline-block"),this.renderer.setStyle(this.wrapper,"overflow","hidden"),this.renderer.insertBefore(this.el.parentNode,this.wrapper,this.el),this.renderer.appendChild(this.wrapper,this.el),this.parentWrapper=this.renderer.createElement("div"),this.renderer.setStyle(this.parentWrapper,"position","relative"),this.renderer.setStyle(this.parentWrapper,"display","inline-block"),this.renderer.insertBefore(this.wrapper.parentNode,this.parentWrapper,this.wrapper),this.renderer.appendChild(this.parentWrapper,this.wrapper),this.renderer.appendChild(this.parentWrapper,this.canvas)},t.prototype.setOptions=function(t){this.options=o({},this.options,t)},t.prototype.loop=function(){this.updateParticles(),this.renderParticles(),this.isAnimating()&&(this.frame=requestAnimationFrame(this.loop.bind(this)))},t.prototype.updateParticles=function(){for(var t,e=0;e<this.particles.length;e++)(t=this.particles[e]).life>t.death?this.particles.splice(e,1):(t.x+=t.speed,t.y=this.o.oscillationCoefficient*Math.sin(t.counter*t.increase),t.life++,t.counter+=this.disintegrating?1:-1);this.particles.length||(this.pause(),this.renderer.setStyle(this.canvas,"display","none"),n(this.o.complete)&&this.o.complete())},t.prototype.renderParticles=function(){var t;this.ctx.clearRect(0,0,this.width,this.height);for(var e=0;e<this.particles.length;e++)(t=this.particles[e]).life<t.death&&(this.ctx.translate(t.startX,t.startY),this.ctx.rotate(t.angle*Math.PI/180),this.ctx.globalAlpha=this.disintegrating?1-t.life/t.death:t.life/t.death,this.ctx.fillStyle=this.ctx.strokeStyle=this.o.color,this.ctx.beginPath(),"circle"===this.o.type?this.ctx.arc(t.x,t.y,t.size,0,2*Math.PI):"triangle"===this.o.type?(this.ctx.moveTo(t.x,t.y),this.ctx.lineTo(t.x+t.size,t.y+t.size),this.ctx.lineTo(t.x+t.size,t.y-t.size)):"rectangle"===this.o.type&&this.ctx.rect(t.x,t.y,t.size,t.size),"fill"===this.o.style?this.ctx.fill():"stroke"===this.o.style&&(this.ctx.closePath(),this.ctx.stroke()),this.ctx.globalAlpha=1,this.ctx.rotate(-t.angle*Math.PI/180),this.ctx.translate(-t.startX,-t.startY))},t.prototype.play=function(){this.frame=requestAnimationFrame(this.loop.bind(this))},t.prototype.pause=function(){cancelAnimationFrame(this.frame),this.frame=null},t.prototype.addParticle=function(t){var e=60*this.o.duration/1e3,i=n(this.o.speed)?this.o.speed():this.o.speed;this.particles.push({startX:t.x,startY:t.y,x:this.disintegrating?0:i*-e,y:0,angle:a(360),counter:this.disintegrating?0:e,increase:2*Math.PI/100,life:0,death:this.disintegrating?e-20+40*Math.random():e,speed:i,size:n(this.o.size)?this.o.size():this.o.size})},t.prototype.addParticles=function(t,e){var i=this.disintegrating?e-this.lastProgress:this.lastProgress-e;this.lastProgress=e;var s=this.options.canvasPadding,n=this.options.canvasPadding,r=(this.isHorizontal()?t.width:t.height)*e+i*(this.disintegrating?100:220);this.isHorizontal()?s+="left"===this.o.direction?r:t.width-r:n+="top"===this.o.direction?r:t.height-r;var a=Math.floor(this.o.particlesAmountCoefficient*(100*i+1));if(0<a)for(;a--;)this.addParticle({x:s+(this.isHorizontal()?0:t.width*Math.random()),y:n+(this.isHorizontal()?t.height*Math.random():0)});this.isAnimating()||(this.renderer.setStyle(this.canvas,"display","block"),this.play())},t.prototype.addTransforms=function(t){var e=this.isHorizontal()?"translateX":"translateY",i="left"===this.o.direction||"top"===this.o.direction?t:-t;this.renderer.setStyle(this.wrapper,r,e+"("+i+"%)"),this.renderer.setStyle(this.el,r,e+"("+-i+"%)")},t.prototype.disintegrate=function(t){if(void 0===t&&(t={}),!this.isAnimating()){this.disintegrating=!0,this.lastProgress=0,this.setup(t);var i=this;this.animate(function(t){var e=t.animatables[0].target.value;i.addTransforms(e),i.o.duration&&i.addParticles(i.rect,e/100)})}},t.prototype.integrate=function(t){if(void 0===t&&(t={}),!this.isAnimating()){this.disintegrating=!1,this.lastProgress=1,this.setup(t);var i=this;this.animate(function(t){var e=t.animatables[0].target.value;setTimeout(function(){i.addTransforms(e)},i.o.duration),i.o.duration&&i.addParticles(i.rect,e/100)})}},t.prototype.setup=function(t){this.o=o({},this.options,t),this.renderer.setStyle(this.wrapper,"visibility","visible"),this.o.duration&&(this.rect=this.el.getBoundingClientRect(),this.width=this.canvas.width=this.o.width||this.rect.width+2*this.o.canvasPadding,this.height=this.canvas.height=this.o.height||this.rect.height+2*this.o.canvasPadding)},t.prototype.isDisintegrated=function(){return this.disintegrating},t.prototype.animate=function(t){var e=this,i=this;s({targets:{value:i.disintegrating?0:100},value:i.disintegrating?100:0,duration:i.o.duration,easing:i.o.easing,begin:i.o.begin,update:t,complete:function(){i.disintegrating&&e.renderer.setStyle(i.wrapper,"visibility","hidden")}})},t.prototype.isAnimating=function(){return!!this.frame},t.prototype.isHorizontal=function(){return"left"===this.o.direction||"right"===this.o.direction},t}(),h=function(){function t(t,e){this.renderer=t,this.el=e,this._pHidden=!1,this.pColor="#000",this.pDuration=1e3,this.pEasing="easeInOutCubic",this.pType="circle",this.pStyle="fill",this.pDirection="left",this.pCanvasPadding=150,this.pOscillationCoefficient=30,this.pParticlesAmountCoefficient=3,this.pBegin=new i.EventEmitter,this.pComplete=new i.EventEmitter,this.pSize=function(){return Math.floor(3*Math.random()+1)},this.pSpeed=function(){return a(4)}}return Object.defineProperty(t.prototype,"pHidden",{get:function(){return this._pHidden},set:function(t){this._pHidden=t,this._particles&&(t&&!this._particles.isDisintegrated()?this._particles.disintegrate(this.getFormattedOptions()):!t&&this._particles.isDisintegrated()&&this._particles.integrate(this.getFormattedOptions()))},enumerable:!0,configurable:!0}),t.prototype.ngAfterContentInit=function(){this._particles=new p(this.el.nativeElement,this.getFormattedOptions(),this.renderer),this._pHidden&&this._particles.disintegrate({duration:0})},t.prototype.getFormattedOptions=function(){var t=this;return{color:this.pColor,type:this.pType,style:this.pStyle,canvasPadding:this.pCanvasPadding,duration:this.pDuration,easing:this.pEasing,direction:this.pDirection,size:this.pSize,speed:this.pSpeed,particlesAmountCoefficient:this.pParticlesAmountCoefficient,oscillationCoefficient:this.pOscillationCoefficient,begin:function(){t.pBegin.emit()},complete:function(){t.pComplete.emit()}}},Object.defineProperty(t.prototype,"pOptions",{get:function(){return{pColor:this.pColor,pType:this.pType,pStyle:this.pStyle,pCanvasPadding:this.pCanvasPadding,pDuration:this.pDuration,pEasing:this.pEasing,pDirection:this.pDirection,pSize:this.pSize,pSpeed:this.pSpeed,pParticlesAmountCoefficient:this.pParticlesAmountCoefficient,pOscillationCoefficient:this.pOscillationCoefficient,pBegin:this.pBegin,pComplete:this.pComplete}},set:function(e){var i=this,s=this.pOptions;Object.keys(e).map(function(t){s[t]&&(i[t]=e[t])})},enumerable:!0,configurable:!0}),t.decorators=[{type:i.Directive,args:[{selector:"[libParticleEffectButton]"}]}],t.ctorParameters=function(){return[{type:i.Renderer2},{type:i.ElementRef}]},t.propDecorators={pColor:[{type:i.Input}],pDuration:[{type:i.Input}],pEasing:[{type:i.Input}],pType:[{type:i.Input}],pStyle:[{type:i.Input}],pDirection:[{type:i.Input}],pCanvasPadding:[{type:i.Input}],pOscillationCoefficient:[{type:i.Input}],pParticlesAmountCoefficient:[{type:i.Input}],pBegin:[{type:i.Output}],pComplete:[{type:i.Output}],pSize:[{type:i.Input}],pSpeed:[{type:i.Input}],pHidden:[{type:i.Input,args:["pHidden"]}]},t}(),l=function(){function t(){}return t.decorators=[{type:i.NgModule,args:[{declarations:[h],exports:[h]}]}],t}();t.ParticleEffectButtonDirective=h,t.ParticleEffectButtonModule=l,Object.defineProperty(t,"__esModule",{value:!0})}); | ||
!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?e(exports,require("@angular/core"),require("animejs")):"function"==typeof define&&define.amd?define("angular-particle-effect-button",["exports","@angular/core","animejs"],e):e((t=t||self)["angular-particle-effect-button"]={},t.ng.core,t.animejs)}(this,function(t,e,i){"use strict";i=i&&i.hasOwnProperty("default")?i.default:i;var s=function(){return(s=Object.assign||function(t){for(var e,i=1,s=arguments.length;i<s;i++)for(var n in e=arguments[i])Object.prototype.hasOwnProperty.call(e,n)&&(t[n]=e[n]);return t}).apply(this,arguments)};var n=function(t){return"function"==typeof t},r="transform",a=function(t,e){if(e in t.style)return getComputedStyle(t).getPropertyValue(e.replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase())||"0"}(document.body,r)?r:"-webkit-"+r,o=function(t){return Math.random()*t-t/2};var p=function(){function t(t,e,i){this.el=t,this.options=e,this.renderer=i,this.particles=[],this.frame=null,this.options=s({},e),this.init()}return t.prototype.init=function(){this.canvas=this.renderer.createElement("canvas"),this.ctx=this.canvas.getContext("2d"),this.renderer.setStyle(this.canvas,"position","absolute"),this.renderer.setStyle(this.canvas,"pointerEvents","none"),this.renderer.setStyle(this.canvas,"top","50%"),this.renderer.setStyle(this.canvas,"left","50%"),this.renderer.setStyle(this.canvas,"transform","translate3d(-50%, -50%, 0)"),this.renderer.setStyle(this.canvas,"display","none"),this.wrapper=this.renderer.createElement("div"),this.renderer.setStyle(this.wrapper,"position","relative"),this.renderer.setStyle(this.wrapper,"display","inline-block"),this.renderer.setStyle(this.wrapper,"overflow","hidden"),this.renderer.insertBefore(this.el.parentNode,this.wrapper,this.el),this.renderer.appendChild(this.wrapper,this.el),this.parentWrapper=this.renderer.createElement("div"),this.renderer.setStyle(this.parentWrapper,"position","relative"),this.renderer.setStyle(this.parentWrapper,"display","inline-block"),this.renderer.insertBefore(this.wrapper.parentNode,this.parentWrapper,this.wrapper),this.renderer.appendChild(this.parentWrapper,this.wrapper),this.renderer.appendChild(this.parentWrapper,this.canvas)},t.prototype.setOptions=function(t){this.options=s({},this.options,t)},t.prototype.loop=function(){this.updateParticles(),this.renderParticles(),this.isAnimating()&&(this.frame=requestAnimationFrame(this.loop.bind(this)))},t.prototype.updateParticles=function(){for(var t,e=0;e<this.particles.length;e++)(t=this.particles[e]).life>t.death?this.particles.splice(e,1):(t.x+=t.speed,t.y=this.o.oscillationCoefficient*Math.sin(t.counter*t.increase),t.life++,t.counter+=this.disintegrating?1:-1);this.particles.length||(this.pause(),this.renderer.setStyle(this.canvas,"display","none"),n(this.o.complete)&&this.o.complete())},t.prototype.renderParticles=function(){var t;this.ctx.clearRect(0,0,this.width,this.height);for(var e=0;e<this.particles.length;e++)(t=this.particles[e]).life<t.death&&(this.ctx.translate(t.startX,t.startY),this.ctx.rotate(t.angle*Math.PI/180),this.ctx.globalAlpha=this.disintegrating?1-t.life/t.death:t.life/t.death,this.ctx.fillStyle=this.ctx.strokeStyle=this.o.color,this.ctx.beginPath(),"circle"===this.o.type?this.ctx.arc(t.x,t.y,t.size,0,2*Math.PI):"triangle"===this.o.type?(this.ctx.moveTo(t.x,t.y),this.ctx.lineTo(t.x+t.size,t.y+t.size),this.ctx.lineTo(t.x+t.size,t.y-t.size)):"rectangle"===this.o.type&&this.ctx.rect(t.x,t.y,t.size,t.size),"fill"===this.o.style?this.ctx.fill():"stroke"===this.o.style&&(this.ctx.closePath(),this.ctx.stroke()),this.ctx.globalAlpha=1,this.ctx.rotate(-t.angle*Math.PI/180),this.ctx.translate(-t.startX,-t.startY))},t.prototype.play=function(){this.frame=requestAnimationFrame(this.loop.bind(this))},t.prototype.pause=function(){cancelAnimationFrame(this.frame),this.frame=null},t.prototype.addParticle=function(t){var e=60*this.o.duration/1e3,i=n(this.o.speed)?this.o.speed():this.o.speed;this.particles.push({startX:t.x,startY:t.y,x:this.disintegrating?0:i*-e,y:0,angle:o(360),counter:this.disintegrating?0:e,increase:2*Math.PI/100,life:0,death:this.disintegrating?e-20+40*Math.random():e,speed:i,size:n(this.o.size)?this.o.size():this.o.size})},t.prototype.addParticles=function(t,e){var i=this.disintegrating?e-this.lastProgress:this.lastProgress-e;this.lastProgress=e;var s=this.options.canvasPadding,n=this.options.canvasPadding,r=(this.isHorizontal()?t.width:t.height)*e+i*(this.disintegrating?100:220);this.isHorizontal()?s+="left"===this.o.direction?r:t.width-r:n+="top"===this.o.direction?r:t.height-r;var a=Math.floor(this.o.particlesAmountCoefficient*(100*i+1));if(a>0)for(;a--;)this.addParticle({x:s+(this.isHorizontal()?0:t.width*Math.random()),y:n+(this.isHorizontal()?t.height*Math.random():0)});this.isAnimating()||(this.renderer.setStyle(this.canvas,"display","block"),this.play())},t.prototype.addTransforms=function(t){var e=this.isHorizontal()?"translateX":"translateY",i="left"===this.o.direction||"top"===this.o.direction?t:-t;this.renderer.setStyle(this.wrapper,a,e+"("+i+"%)"),this.renderer.setStyle(this.el,a,e+"("+-i+"%)")},t.prototype.disintegrate=function(t){if(void 0===t&&(t={}),!this.isAnimating()){this.disintegrating=!0,this.lastProgress=0,this.setup(t);var e=this;this.animate(function(t){var i=t.animatables[0].target.value;e.addTransforms(i),e.o.duration&&e.addParticles(e.rect,i/100)})}},t.prototype.integrate=function(t){if(void 0===t&&(t={}),!this.isAnimating()){this.disintegrating=!1,this.lastProgress=1,this.setup(t);var e=this;this.animate(function(t){var i=t.animatables[0].target.value;setTimeout(function(){e.addTransforms(i)},e.o.duration),e.o.duration&&e.addParticles(e.rect,i/100)})}},t.prototype.setup=function(t){this.o=s({},this.options,t),this.renderer.setStyle(this.wrapper,"visibility","visible"),this.o.duration&&(this.rect=this.el.getBoundingClientRect(),this.width=this.canvas.width=this.o.width||this.rect.width+2*this.o.canvasPadding,this.height=this.canvas.height=this.o.height||this.rect.height+2*this.o.canvasPadding)},t.prototype.isDisintegrated=function(){return this.disintegrating},t.prototype.animate=function(t){var e=this,s=this;i({targets:{value:s.disintegrating?0:100},value:s.disintegrating?100:0,duration:s.o.duration,easing:s.o.easing,begin:s.o.begin,update:t,complete:function(){s.disintegrating&&e.renderer.setStyle(s.wrapper,"visibility","hidden")}})},t.prototype.isAnimating=function(){return!!this.frame},t.prototype.isHorizontal=function(){return"left"===this.o.direction||"right"===this.o.direction},t}();var h=function(){function t(t,i){this.renderer=t,this.el=i,this._pHidden=!1,this.pColor="#000",this.pDuration=1e3,this.pEasing="easeInOutCubic",this.pType="circle",this.pStyle="fill",this.pDirection="left",this.pCanvasPadding=150,this.pOscillationCoefficient=30,this.pParticlesAmountCoefficient=3,this.pBegin=new e.EventEmitter,this.pComplete=new e.EventEmitter,this.pSize=function(){return Math.floor(3*Math.random()+1)},this.pSpeed=function(){return o(4)}}return Object.defineProperty(t.prototype,"pHidden",{get:function(){return this._pHidden},set:function(t){this._pHidden=t,this._particles&&(t&&!this._particles.isDisintegrated()?this._particles.disintegrate(this.getFormattedOptions()):!t&&this._particles.isDisintegrated()&&this._particles.integrate(this.getFormattedOptions()))},enumerable:!0,configurable:!0}),t.prototype.ngAfterContentInit=function(){this._particles=new p(this.el.nativeElement,this.getFormattedOptions(),this.renderer),this._pHidden&&this._particles.disintegrate({duration:0})},t.prototype.getFormattedOptions=function(){var t=this;return{color:this.pColor,type:this.pType,style:this.pStyle,canvasPadding:this.pCanvasPadding,duration:this.pDuration,easing:this.pEasing,direction:this.pDirection,size:this.pSize,speed:this.pSpeed,particlesAmountCoefficient:this.pParticlesAmountCoefficient,oscillationCoefficient:this.pOscillationCoefficient,begin:function(){t.pBegin.emit()},complete:function(){t.pComplete.emit()}}},Object.defineProperty(t.prototype,"pOptions",{get:function(){return{pColor:this.pColor,pType:this.pType,pStyle:this.pStyle,pCanvasPadding:this.pCanvasPadding,pDuration:this.pDuration,pEasing:this.pEasing,pDirection:this.pDirection,pSize:this.pSize,pSpeed:this.pSpeed,pParticlesAmountCoefficient:this.pParticlesAmountCoefficient,pOscillationCoefficient:this.pOscillationCoefficient,pBegin:this.pBegin,pComplete:this.pComplete}},set:function(t){var e=this,i=this.pOptions;Object.keys(t).map(function(s){i[s]&&(e[s]=t[s])})},enumerable:!0,configurable:!0}),t.decorators=[{type:e.Directive,args:[{selector:"[libParticleEffectButton]"}]}],t.ctorParameters=function(){return[{type:e.Renderer2},{type:e.ElementRef}]},t.propDecorators={pColor:[{type:e.Input}],pDuration:[{type:e.Input}],pEasing:[{type:e.Input}],pType:[{type:e.Input}],pStyle:[{type:e.Input}],pDirection:[{type:e.Input}],pCanvasPadding:[{type:e.Input}],pOscillationCoefficient:[{type:e.Input}],pParticlesAmountCoefficient:[{type:e.Input}],pBegin:[{type:e.Output}],pComplete:[{type:e.Output}],pSize:[{type:e.Input}],pSpeed:[{type:e.Input}],pHidden:[{type:e.Input,args:["pHidden"]}]},t}();var l=function(){function t(){}return t.decorators=[{type:e.NgModule,args:[{declarations:[h],exports:[h]}]}],t}();t.ParticleEffectButtonDirective=h,t.ParticleEffectButtonModule=l,Object.defineProperty(t,"__esModule",{value:!0})}); | ||
//# sourceMappingURL=angular-particle-effect-button.umd.min.js.map |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -5,0 +5,0 @@ /** |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -28,4 +28,10 @@ import { ElementRef, Input, Directive, EventEmitter, Output, Renderer2 } from '@angular/core'; | ||
this.pComplete = new EventEmitter(); | ||
this.pSize = () => Math.floor((Math.random() * 3) + 1); | ||
this.pSpeed = () => rand(4); | ||
this.pSize = (/** | ||
* @return {?} | ||
*/ | ||
() => Math.floor((Math.random() * 3) + 1)); | ||
this.pSpeed = (/** | ||
* @return {?} | ||
*/ | ||
() => rand(4)); | ||
} | ||
@@ -79,8 +85,14 @@ /** | ||
oscillationCoefficient: this.pOscillationCoefficient, | ||
begin: () => { | ||
begin: (/** | ||
* @return {?} | ||
*/ | ||
() => { | ||
this.pBegin.emit(); | ||
}, | ||
complete: () => { | ||
}), | ||
complete: (/** | ||
* @return {?} | ||
*/ | ||
() => { | ||
this.pComplete.emit(); | ||
} | ||
}) | ||
}; | ||
@@ -115,7 +127,11 @@ } | ||
const allowedProps = this.pOptions; | ||
Object.keys(options).map(key => { | ||
Object.keys(options).map((/** | ||
* @param {?} key | ||
* @return {?} | ||
*/ | ||
key => { | ||
if (allowedProps[key]) { | ||
this[key] = options[key]; | ||
} | ||
}); | ||
})); | ||
} | ||
@@ -197,2 +213,2 @@ } | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-particle-effect-button.directive.js","sourceRoot":"ng://angular-particle-effect-button/","sources":["lib/angular-particle-effect-button.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ElementRef,\n  Input,\n  Directive,\n  EventEmitter,\n  Output,\n  Renderer2,\n  AfterContentInit,\n  OnDestroy,\n  OnInit\n} from '@angular/core';\nimport { rand } from './utils';\nimport { Particles, IOption } from './particles';\n\n@Directive({\n  selector: '[libParticleEffectButton]'\n})\nexport class ParticleEffectButtonDirective implements AfterContentInit {\n  private _particles: Particles;\n  private _pHidden = false;\n  @Input() pColor = '#000';\n  @Input() pDuration = 1000;\n  @Input() pEasing = 'easeInOutCubic';\n  @Input() pType = 'circle';\n  @Input() pStyle = 'fill';\n  @Input() pDirection = 'left';\n  @Input() pCanvasPadding = 150;\n  @Input() pOscillationCoefficient = 30;\n  @Input() pParticlesAmountCoefficient = 3;\n  @Output() pBegin = new EventEmitter<void>();\n  @Output() pComplete = new EventEmitter<void>();\n  @Input() pSize: () => number | number = () => Math.floor((Math.random() * 3) + 1);\n  @Input() pSpeed: () => number | number = () => rand(4);\n\n  @Input('pHidden')\n  set pHidden(value: boolean) {\n    this._pHidden = value;\n    if (this._particles) {\n      if (value && !this._particles.isDisintegrated()) {\n         this._particles.disintegrate(this.getFormattedOptions());\n      } else if (!value && this._particles.isDisintegrated()) {\n         this._particles.integrate(this.getFormattedOptions());\n      }\n    }\n  }\n  get pHidden(): boolean {\n    return this._pHidden;\n  }\n\n  constructor(private renderer: Renderer2, private el: ElementRef) {}\n\n  ngAfterContentInit() {\n    this._particles = new Particles(\n      this.el.nativeElement,\n      this.getFormattedOptions(),\n      this.renderer\n    );\n\n      if (this._pHidden) {\n          this._particles.disintegrate({duration: 0});\n      }\n  }\n  private getFormattedOptions(): IOption {\n     return {\n        color: this.pColor,\n        type: this.pType,\n        style: this.pStyle,\n        canvasPadding: this.pCanvasPadding,\n        duration: this.pDuration,\n        easing: this.pEasing,\n        direction: this.pDirection,\n        size: this.pSize,\n        speed: this.pSpeed,\n        particlesAmountCoefficient: this.pParticlesAmountCoefficient,\n        oscillationCoefficient: this.pOscillationCoefficient,\n        begin: () => {\n          this.pBegin.emit();\n        },\n        complete: () => {\n          this.pComplete.emit();\n        }\n    };\n  }\n  public get pOptions(): any {\n    return {\n        pColor: this.pColor,\n        pType: this.pType,\n        pStyle: this.pStyle,\n        pCanvasPadding: this.pCanvasPadding,\n        pDuration: this.pDuration,\n        pEasing: this.pEasing,\n        pDirection: this.pDirection,\n        pSize: this.pSize,\n        pSpeed: this.pSpeed,\n        pParticlesAmountCoefficient: this.pParticlesAmountCoefficient,\n        pOscillationCoefficient: this.pOscillationCoefficient,\n        pBegin: this.pBegin,\n        pComplete: this.pComplete\n    };\n  }\n  public set pOptions(options: any) {\n    const allowedProps = this.pOptions;\n    Object.keys(options).map( key => {\n      if (allowedProps[key]) {\n        this[key] = options[key];\n      }\n    });\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-particle-effect-button.directive.js","sourceRoot":"ng://angular-particle-effect-button/","sources":["lib/angular-particle-effect-button.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ElementRef,\n  Input,\n  Directive,\n  EventEmitter,\n  Output,\n  Renderer2,\n  AfterContentInit,\n  OnDestroy,\n  OnInit\n} from '@angular/core';\nimport { rand } from './utils';\nimport { Particles, IOption } from './particles';\n\n@Directive({\n  selector: '[libParticleEffectButton]'\n})\nexport class ParticleEffectButtonDirective implements AfterContentInit {\n  private _particles: Particles;\n  private _pHidden = false;\n  @Input() pColor = '#000';\n  @Input() pDuration = 1000;\n  @Input() pEasing = 'easeInOutCubic';\n  @Input() pType = 'circle';\n  @Input() pStyle = 'fill';\n  @Input() pDirection = 'left';\n  @Input() pCanvasPadding = 150;\n  @Input() pOscillationCoefficient = 30;\n  @Input() pParticlesAmountCoefficient = 3;\n  @Output() pBegin = new EventEmitter<void>();\n  @Output() pComplete = new EventEmitter<void>();\n  @Input() pSize: () => number | number = () => Math.floor((Math.random() * 3) + 1);\n  @Input() pSpeed: () => number | number = () => rand(4);\n\n  @Input('pHidden')\n  set pHidden(value: boolean) {\n    this._pHidden = value;\n    if (this._particles) {\n      if (value && !this._particles.isDisintegrated()) {\n         this._particles.disintegrate(this.getFormattedOptions());\n      } else if (!value && this._particles.isDisintegrated()) {\n         this._particles.integrate(this.getFormattedOptions());\n      }\n    }\n  }\n  get pHidden(): boolean {\n    return this._pHidden;\n  }\n\n  constructor(private renderer: Renderer2, private el: ElementRef) {}\n\n  ngAfterContentInit() {\n    this._particles = new Particles(\n      this.el.nativeElement,\n      this.getFormattedOptions(),\n      this.renderer\n    );\n\n      if (this._pHidden) {\n          this._particles.disintegrate({duration: 0});\n      }\n  }\n  private getFormattedOptions(): IOption {\n     return {\n        color: this.pColor,\n        type: this.pType,\n        style: this.pStyle,\n        canvasPadding: this.pCanvasPadding,\n        duration: this.pDuration,\n        easing: this.pEasing,\n        direction: this.pDirection,\n        size: this.pSize,\n        speed: this.pSpeed,\n        particlesAmountCoefficient: this.pParticlesAmountCoefficient,\n        oscillationCoefficient: this.pOscillationCoefficient,\n        begin: () => {\n          this.pBegin.emit();\n        },\n        complete: () => {\n          this.pComplete.emit();\n        }\n    };\n  }\n  public get pOptions(): any {\n    return {\n        pColor: this.pColor,\n        pType: this.pType,\n        pStyle: this.pStyle,\n        pCanvasPadding: this.pCanvasPadding,\n        pDuration: this.pDuration,\n        pEasing: this.pEasing,\n        pDirection: this.pDirection,\n        pSize: this.pSize,\n        pSpeed: this.pSpeed,\n        pParticlesAmountCoefficient: this.pParticlesAmountCoefficient,\n        pOscillationCoefficient: this.pOscillationCoefficient,\n        pBegin: this.pBegin,\n        pComplete: this.pComplete\n    };\n  }\n  public set pOptions(options: any) {\n    const allowedProps = this.pOptions;\n    Object.keys(options).map( key => {\n      if (allowedProps[key]) {\n        this[key] = options[key];\n      }\n    });\n  }\n}\n"]} |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -5,0 +5,0 @@ import { NgModule } from '@angular/core'; |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -275,3 +275,7 @@ import anime from 'animejs'; // tslint:disable-line | ||
const _ = this; | ||
this.animate(anim => { | ||
this.animate((/** | ||
* @param {?} anim | ||
* @return {?} | ||
*/ | ||
anim => { | ||
/** @type {?} */ | ||
@@ -283,3 +287,3 @@ const value = anim.animatables[0].target.value; | ||
} | ||
}); | ||
})); | ||
} | ||
@@ -298,12 +302,19 @@ } | ||
const _ = this; | ||
this.animate(anim => { | ||
this.animate((/** | ||
* @param {?} anim | ||
* @return {?} | ||
*/ | ||
anim => { | ||
/** @type {?} */ | ||
const value = anim.animatables[0].target.value; | ||
setTimeout(() => { | ||
setTimeout((/** | ||
* @return {?} | ||
*/ | ||
() => { | ||
_.addTransforms(value); | ||
}, _.o.duration); | ||
}), _.o.duration); | ||
if (_.o.duration) { | ||
_.addParticles(_.rect, value / 100); | ||
} | ||
}); | ||
})); | ||
} | ||
@@ -346,7 +357,10 @@ } | ||
update: update, | ||
complete: () => { | ||
complete: (/** | ||
* @return {?} | ||
*/ | ||
() => { | ||
if (_.disintegrating) { | ||
this.renderer.setStyle(_.wrapper, 'visibility', 'hidden'); | ||
} | ||
} | ||
}) | ||
}); | ||
@@ -408,2 +422,2 @@ } | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"particles.js","sourceRoot":"ng://angular-particle-effect-button/","sources":["lib/particles.ts"],"names":[],"mappings":"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","sourcesContent":["import anime from 'animejs'; // tslint:disable-line\n\nimport { ElementRef, Renderer2 } from '@angular/core';\nimport { rand, is, stringToHyphens, getCSSValue, transformString, getElement } from './utils';\n\nexport interface IOption {\n  color?: string;\n  type?: string;\n  style?: string;\n  canvasPadding?: number;\n  duration?: number;\n  easing?: Array<number> | string;\n  direction?: string;\n  size?: () => number | number;\n  speed?: () => number | number;\n  particlesAmountCoefficient?: number;\n  oscillationCoefficient?: number;\n  begin?: () => void;\n  width?: number;\n  height?: number;\n  complete?: () => void;\n}\n\nexport class Particles {\n  particles = [];\n  frame = null;\n  canvas: HTMLCanvasElement;\n  ctx: CanvasRenderingContext2D;\n  wrapper: HTMLDivElement;\n  parentWrapper: HTMLDivElement;\n  o: IOption;\n  disintegrating: boolean;\n  width: number;\n  height: number;\n  lastProgress: number;\n  rect: HTMLCanvasElement;\n  constructor(\n    private el: any,\n    private options: IOption,\n    private renderer: Renderer2\n  ) {\n    this.options = { ...options };\n    this.init();\n  }\n\n  init(): void {\n   this.canvas = this.renderer.createElement('canvas');\n    this.ctx = this.canvas.getContext('2d');\n    this.renderer.setStyle(this.canvas, 'position', 'absolute');\n    this.renderer.setStyle(this.canvas, 'pointerEvents', 'none');\n    this.renderer.setStyle(this.canvas, 'top', '50%');\n    this.renderer.setStyle(this.canvas, 'left', '50%');\n    this.renderer.setStyle(this.canvas, 'transform', 'translate3d(-50%, -50%, 0)');\n    this.renderer.setStyle(this.canvas, 'display', 'none');\n    this.wrapper = this.renderer.createElement('div');\n    this.renderer.setStyle(this.wrapper, 'position', 'relative');\n    this.renderer.setStyle(this.wrapper, 'display', 'inline-block');\n    this.renderer.setStyle(this.wrapper, 'overflow', 'hidden');\n    this.renderer.insertBefore(this.el.parentNode, this.wrapper, this.el);\n    this.renderer.appendChild(this.wrapper, this.el);\n    this.parentWrapper = this.renderer.createElement('div');\n    this.renderer.setStyle(this.parentWrapper, 'position', 'relative');\n    this.renderer.setStyle(this.parentWrapper, 'display', 'inline-block');\n    this.renderer.insertBefore(\n      this.wrapper.parentNode,\n      this.parentWrapper,\n      this.wrapper\n    );\n    this.renderer.appendChild(this.parentWrapper, this.wrapper);\n    this.renderer.appendChild(this.parentWrapper, this.canvas);\n  }\n\n  setOptions(options) {\n    this.options = { ...this.options, ...options };\n  }\n  loop() {\n    this.updateParticles();\n    this.renderParticles();\n    if (this.isAnimating()) {\n      this.frame = requestAnimationFrame(this.loop.bind(this));\n    }\n  }\n  updateParticles() {\n    let p;\n    for (let i = 0; i < this.particles.length; i++) {\n      p = this.particles[i];\n      if (p.life > p.death) {\n        this.particles.splice(i, 1);\n      } else {\n        p.x += p.speed;\n        p.y = this.o.oscillationCoefficient * Math.sin(p.counter * p.increase);\n        p.life++;\n        p.counter += this.disintegrating ? 1 : -1;\n      }\n    }\n    if (!this.particles.length) {\n      this.pause();\n      this.renderer.setStyle(this.canvas, 'display', 'none');\n      if (is.fnc(this.o.complete)) {\n        this.o.complete();\n      }\n    }\n  }\n  renderParticles() {\n    this.ctx.clearRect(0, 0, this.width, this.height);\n    let p;\n    for (let i = 0; i < this.particles.length; i++) {\n      p = this.particles[i];\n      if (p.life < p.death) {\n        this.ctx.translate(p.startX, p.startY);\n        this.ctx.rotate(p.angle * Math.PI / 180);\n        this.ctx.globalAlpha = this.disintegrating\n          ? 1 - p.life / p.death\n          : p.life / p.death;\n        this.ctx.fillStyle = this.ctx.strokeStyle = this.o.color;\n        this.ctx.beginPath();\n\n        if (this.o.type === 'circle') {\n          this.ctx.arc(p.x, p.y, p.size, 0, 2 * Math.PI);\n        } else if (this.o.type === 'triangle') {\n          this.ctx.moveTo(p.x, p.y);\n          this.ctx.lineTo(p.x + p.size, p.y + p.size);\n          this.ctx.lineTo(p.x + p.size, p.y - p.size);\n        } else if (this.o.type === 'rectangle') {\n          this.ctx.rect(p.x, p.y, p.size, p.size);\n        }\n\n        if (this.o.style === 'fill') {\n          this.ctx.fill();\n        } else if (this.o.style === 'stroke') {\n          this.ctx.closePath();\n          this.ctx.stroke();\n        }\n\n        this.ctx.globalAlpha = 1;\n        this.ctx.rotate(-p.angle * Math.PI / 180);\n        this.ctx.translate(-p.startX, -p.startY);\n      }\n    }\n  }\n  play() {\n    this.frame = requestAnimationFrame(this.loop.bind(this));\n  }\n  pause() {\n    cancelAnimationFrame(this.frame);\n    this.frame = null;\n  }\n  addParticle(options) {\n    const frames = this.o.duration * 60 / 1000;\n    const speed: number = (is.fnc(this.o.speed)\n      ? this.o.speed()\n      : this.o.speed) as number;\n    this.particles.push({\n      startX: options.x,\n      startY: options.y,\n      x: this.disintegrating ? 0 : speed * -frames,\n      y: 0,\n      angle: rand(360),\n      counter: this.disintegrating ? 0 : frames,\n      increase: Math.PI * 2 / 100,\n      life: 0,\n      death: this.disintegrating ? frames - 20 + Math.random() * 40 : frames,\n      speed: speed,\n      size: is.fnc(this.o.size) ? this.o.size() : this.o.size\n    });\n  }\n  addParticles(rect: any, progress) {\n    const progressDiff = this.disintegrating\n      ? progress - this.lastProgress\n      : this.lastProgress - progress;\n    this.lastProgress = progress;\n    let x = this.options.canvasPadding;\n    let y = this.options.canvasPadding;\n    const progressValue =\n      (this.isHorizontal() ? rect.width : rect.height) * progress +\n      progressDiff * (this.disintegrating ? 100 : 220);\n    if (this.isHorizontal()) {\n      x +=\n        this.o.direction === 'left'\n          ? progressValue\n          : rect.width - progressValue;\n    } else {\n      y +=\n        this.o.direction === 'top'\n          ? progressValue\n          : rect.height - progressValue;\n    }\n    let i = Math.floor(\n      this.o.particlesAmountCoefficient * (progressDiff * 100 + 1)\n    );\n    if (i > 0) {\n      while (i--) {\n        this.addParticle({\n          x: x + (this.isHorizontal() ? 0 : rect.width * Math.random()),\n          y: y + (this.isHorizontal() ? rect.height * Math.random() : 0)\n        });\n      }\n    }\n    if (!this.isAnimating()) {\n      this.renderer.setStyle(this.canvas, 'display', 'block');\n      this.play();\n    }\n  }\n  addTransforms(value) {\n    const translateProperty = this.isHorizontal() ? 'translateX' : 'translateY';\n    const translateValue =\n      this.o.direction === 'left' || this.o.direction === 'top'\n        ? value\n        : -value;\n    this.renderer.setStyle(this.wrapper, transformString, `${translateProperty}(${translateValue}%)`);\n    this.renderer.setStyle(this.el, transformString, `${translateProperty}(${-translateValue}%)`);\n  }\n  disintegrate(options: IOption = {}) {\n    if (!this.isAnimating()) {\n      this.disintegrating = true;\n      this.lastProgress = 0;\n      this.setup(options);\n      const _ = this;\n      this.animate(anim => {\n        const value = anim.animatables[0].target.value;\n        _.addTransforms(value);\n        if (_.o.duration) {\n          _.addParticles(_.rect, value / 100);\n        }\n      });\n    }\n  }\n  integrate(options: IOption = {}) {\n    if (!this.isAnimating()) {\n      this.disintegrating = false;\n      this.lastProgress = 1;\n      this.setup(options);\n      const _ = this;\n      this.animate(anim => {\n        const value = anim.animatables[0].target.value;\n        setTimeout(() => {\n          _.addTransforms(value);\n        }, _.o.duration);\n        if (_.o.duration) {\n          _.addParticles(_.rect, value / 100);\n        }\n      });\n    }\n  }\n  setup(options) {\n    this.o = { ...this.options, ...options };\n    this.renderer.setStyle(this.wrapper, 'visibility', 'visible');\n    if (this.o.duration) {\n      this.rect = this.el.getBoundingClientRect();\n      this.width = this.canvas.width =\n        this.o.width || this.rect.width + this.o.canvasPadding * 2;\n      this.height = this.canvas.height =\n        this.o.height || this.rect.height + this.o.canvasPadding * 2;\n    }\n  }\n\n  public isDisintegrated() {\n    return this.disintegrating;\n  }\n  animate(update) {\n    const _ = this;\n    anime({\n      targets: { value: _.disintegrating ? 0 : 100 },\n      value: _.disintegrating ? 100 : 0,\n      duration: _.o.duration,\n      easing: _.o.easing,\n      begin: _.o.begin,\n      update: update,\n      complete: () => {\n        if (_.disintegrating) {\n          this.renderer.setStyle(_.wrapper, 'visibility', 'hidden');\n        }\n      }\n    });\n  }\n  isAnimating() {\n    return !!this.frame;\n  }\n  isHorizontal() {\n    return this.o.direction === 'left' || this.o.direction === 'right';\n  }\n}\n\n\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"particles.js","sourceRoot":"ng://angular-particle-effect-button/","sources":["lib/particles.ts"],"names":[],"mappings":";;;;AAAA,OAAO,KAAK,MAAM,SAAS,CAAC,CAAC,sBAAsB;AAGnD,OAAO,EAAE,IAAI,EAAE,EAAE,EAAgC,eAAe,EAAc,MAAM,SAAS,CAAC;;;;AAE9F,6BAgBC;;;IAfC,wBAAe;;IACf,uBAAc;;IACd,wBAAe;;IACf,gCAAuB;;IACvB,2BAAkB;;IAClB,yBAAgC;;IAChC,4BAAmB;;IACnB,uBAA6B;;IAC7B,wBAA8B;;IAC9B,6CAAoC;;IACpC,yCAAgC;;IAChC,wBAAmB;;IACnB,wBAAe;;IACf,yBAAgB;;IAChB,2BAAsB;;AAGxB,MAAM,OAAO,SAAS;;;;;;IAapB,YACU,EAAO,EACP,OAAgB,EAChB,QAAmB;QAFnB,OAAE,GAAF,EAAE,CAAK;QACP,YAAO,GAAP,OAAO,CAAS;QAChB,aAAQ,GAAR,QAAQ,CAAW;QAf7B,cAAS,GAAG,EAAE,CAAC;QACf,UAAK,GAAG,IAAI,CAAC;QAgBX,IAAI,CAAC,OAAO,qBAAQ,OAAO,CAAE,CAAC;QAC9B,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;;;;IAED,IAAI;QACH,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QACnD,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QACxC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;QAC5D,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,eAAe,EAAE,MAAM,CAAC,CAAC;QAC7D,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;QAClD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;QACnD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,WAAW,EAAE,4BAA4B,CAAC,CAAC;QAC/E,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;QACvD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAClD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;QAC7D,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,EAAE,cAAc,CAAC,CAAC;QAChE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;QAC3D,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,CAAC,UAAU,EAAE,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;QACtE,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;QACjD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACxD,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;QACnE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,EAAE,SAAS,EAAE,cAAc,CAAC,CAAC;QACtE,IAAI,CAAC,QAAQ,CAAC,YAAY,CACxB,IAAI,CAAC,OAAO,CAAC,UAAU,EACvB,IAAI,CAAC,aAAa,EAClB,IAAI,CAAC,OAAO,CACb,CAAC;QACF,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QAC5D,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IAC7D,CAAC;;;;;IAED,UAAU,CAAC,OAAO;QAChB,IAAI,CAAC,OAAO,qBAAQ,IAAI,CAAC,OAAO,EAAK,OAAO,CAAE,CAAC;IACjD,CAAC;;;;IACD,IAAI;QACF,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,IAAI,CAAC,WAAW,EAAE,EAAE;YACtB,IAAI,CAAC,KAAK,GAAG,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;SAC1D;IACH,CAAC;;;;IACD,eAAe;;YACT,CAAC;QACL,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAC9C,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;YACtB,IAAI,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,KAAK,EAAE;gBACpB,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;aAC7B;iBAAM;gBACL,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC;gBACf,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,sBAAsB,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,OAAO,GAAG,CAAC,CAAC,QAAQ,CAAC,CAAC;gBACvE,CAAC,CAAC,IAAI,EAAE,CAAC;gBACT,CAAC,CAAC,OAAO,IAAI,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;aAC3C;SACF;QACD,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE;YAC1B,IAAI,CAAC,KAAK,EAAE,CAAC;YACb,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;YACvD,IAAI,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE;gBAC3B,IAAI,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;aACnB;SACF;IACH,CAAC;;;;IACD,eAAe;QACb,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;;YAC9C,CAAC;QACL,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAC9C,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;YACtB,IAAI,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,KAAK,EAAE;gBACpB,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC;gBACvC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC;gBACzC,IAAI,CAAC,GAAG,CAAC,WAAW,GAAG,IAAI,CAAC,cAAc;oBACxC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,KAAK;oBACtB,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,KAAK,CAAC;gBACrB,IAAI,CAAC,GAAG,CAAC,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,WAAW,GAAG,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;gBACzD,IAAI,CAAC,GAAG,CAAC,SAAS,EAAE,CAAC;gBAErB,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,EAAE;oBAC5B,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC;iBAChD;qBAAM,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,KAAK,UAAU,EAAE;oBACrC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;oBAC1B,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC;oBAC5C,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC;iBAC7C;qBAAM,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,KAAK,WAAW,EAAE;oBACtC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC;iBACzC;gBAED,IAAI,IAAI,CAAC,CAAC,CAAC,KAAK,KAAK,MAAM,EAAE;oBAC3B,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC;iBACjB;qBAAM,IAAI,IAAI,CAAC,CAAC,CAAC,KAAK,KAAK,QAAQ,EAAE;oBACpC,IAAI,CAAC,GAAG,CAAC,SAAS,EAAE,CAAC;oBACrB,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC;iBACnB;gBAED,IAAI,CAAC,GAAG,CAAC,WAAW,GAAG,CAAC,CAAC;gBACzB,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,IAAI,CAAC,EAAE,GAAG,GAAG,CAAC,CAAC;gBAC1C,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;aAC1C;SACF;IACH,CAAC;;;;IACD,IAAI;QACF,IAAI,CAAC,KAAK,GAAG,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IAC3D,CAAC;;;;IACD,KAAK;QACH,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACjC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACpB,CAAC;;;;;IACD,WAAW,CAAC,OAAO;;cACX,MAAM,GAAG,IAAI,CAAC,CAAC,CAAC,QAAQ,GAAG,EAAE,GAAG,IAAI;;cACpC,KAAK,GAAW,mBAAA,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;YACzC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,EAAE;YAChB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,EAAU;QAC3B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;YAClB,MAAM,EAAE,OAAO,CAAC,CAAC;YACjB,MAAM,EAAE,OAAO,CAAC,CAAC;YACjB,CAAC,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,MAAM;YAC5C,CAAC,EAAE,CAAC;YACJ,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC;YAChB,OAAO,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM;YACzC,QAAQ,EAAE,IAAI,CAAC,EAAE,GAAG,CAAC,GAAG,GAAG;YAC3B,IAAI,EAAE,CAAC;YACP,KAAK,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,MAAM,GAAG,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,MAAM;YACtE,KAAK,EAAE,KAAK;YACZ,IAAI,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI;SACxD,CAAC,CAAC;IACL,CAAC;;;;;;IACD,YAAY,CAAC,IAAS,EAAE,QAAQ;;cACxB,YAAY,GAAG,IAAI,CAAC,cAAc;YACtC,CAAC,CAAC,QAAQ,GAAG,IAAI,CAAC,YAAY;YAC9B,CAAC,CAAC,IAAI,CAAC,YAAY,GAAG,QAAQ;QAChC,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC;;YACzB,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa;;YAC9B,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa;;cAC5B,aAAa,GACjB,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,QAAQ;YAC3D,YAAY,GAAG,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;QAClD,IAAI,IAAI,CAAC,YAAY,EAAE,EAAE;YACvB,CAAC;gBACC,IAAI,CAAC,CAAC,CAAC,SAAS,KAAK,MAAM;oBACzB,CAAC,CAAC,aAAa;oBACf,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG,aAAa,CAAC;SAClC;aAAM;YACL,CAAC;gBACC,IAAI,CAAC,CAAC,CAAC,SAAS,KAAK,KAAK;oBACxB,CAAC,CAAC,aAAa;oBACf,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,aAAa,CAAC;SACnC;;YACG,CAAC,GAAG,IAAI,CAAC,KAAK,CAChB,IAAI,CAAC,CAAC,CAAC,0BAA0B,GAAG,CAAC,YAAY,GAAG,GAAG,GAAG,CAAC,CAAC,CAC7D;QACD,IAAI,CAAC,GAAG,CAAC,EAAE;YACT,OAAO,CAAC,EAAE,EAAE;gBACV,IAAI,CAAC,WAAW,CAAC;oBACf,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;oBAC7D,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;iBAC/D,CAAC,CAAC;aACJ;SACF;QACD,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE;YACvB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;YACxD,IAAI,CAAC,IAAI,EAAE,CAAC;SACb;IACH,CAAC;;;;;IACD,aAAa,CAAC,KAAK;;cACX,iBAAiB,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,YAAY;;cACrE,cAAc,GAClB,IAAI,CAAC,CAAC,CAAC,SAAS,KAAK,MAAM,IAAI,IAAI,CAAC,CAAC,CAAC,SAAS,KAAK,KAAK;YACvD,CAAC,CAAC,KAAK;YACP,CAAC,CAAC,CAAC,KAAK;QACZ,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,eAAe,EAAE,GAAG,iBAAiB,IAAI,cAAc,IAAI,CAAC,CAAC;QAClG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,EAAE,eAAe,EAAE,GAAG,iBAAiB,IAAI,CAAC,cAAc,IAAI,CAAC,CAAC;IAChG,CAAC;;;;;IACD,YAAY,CAAC,UAAmB,EAAE;QAChC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE;YACvB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;YAC3B,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;YACtB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;;kBACd,CAAC,GAAG,IAAI;YACd,IAAI,CAAC,OAAO;;;;YAAC,IAAI,CAAC,EAAE;;sBACZ,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK;gBAC9C,CAAC,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;gBACvB,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE;oBAChB,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,GAAG,GAAG,CAAC,CAAC;iBACrC;YACH,CAAC,EAAC,CAAC;SACJ;IACH,CAAC;;;;;IACD,SAAS,CAAC,UAAmB,EAAE;QAC7B,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE;YACvB,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;YAC5B,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;YACtB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;;kBACd,CAAC,GAAG,IAAI;YACd,IAAI,CAAC,OAAO;;;;YAAC,IAAI,CAAC,EAAE;;sBACZ,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK;gBAC9C,UAAU;;;gBAAC,GAAG,EAAE;oBACd,CAAC,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;gBACzB,CAAC,GAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;gBACjB,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE;oBAChB,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,GAAG,GAAG,CAAC,CAAC;iBACrC;YACH,CAAC,EAAC,CAAC;SACJ;IACH,CAAC;;;;;IACD,KAAK,CAAC,OAAO;QACX,IAAI,CAAC,CAAC,qBAAQ,IAAI,CAAC,OAAO,EAAK,OAAO,CAAE,CAAC;QACzC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,YAAY,EAAE,SAAS,CAAC,CAAC;QAC9D,IAAI,IAAI,CAAC,CAAC,CAAC,QAAQ,EAAE;YACnB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,qBAAqB,EAAE,CAAC;YAC5C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK;gBAC5B,IAAI,CAAC,CAAC,CAAC,KAAK,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,aAAa,GAAG,CAAC,CAAC;YAC7D,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM;gBAC9B,IAAI,CAAC,CAAC,CAAC,MAAM,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC,CAAC,aAAa,GAAG,CAAC,CAAC;SAChE;IACH,CAAC;;;;IAEM,eAAe;QACpB,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;;;;;IACD,OAAO,CAAC,MAAM;;cACN,CAAC,GAAG,IAAI;QACd,KAAK,CAAC;YACJ,OAAO,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE;YAC9C,KAAK,EAAE,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YACjC,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ;YACtB,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC,MAAM;YAClB,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK;YAChB,MAAM,EAAE,MAAM;YACd,QAAQ;;;YAAE,GAAG,EAAE;gBACb,IAAI,CAAC,CAAC,cAAc,EAAE;oBACpB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,EAAE,YAAY,EAAE,QAAQ,CAAC,CAAC;iBAC3D;YACH,CAAC,CAAA;SACF,CAAC,CAAC;IACL,CAAC;;;;IACD,WAAW;QACT,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC;IACtB,CAAC;;;;IACD,YAAY;QACV,OAAO,IAAI,CAAC,CAAC,CAAC,SAAS,KAAK,MAAM,IAAI,IAAI,CAAC,CAAC,CAAC,SAAS,KAAK,OAAO,CAAC;IACrE,CAAC;CACF;;;IAjQC,8BAAe;;IACf,0BAAa;;IACb,2BAA0B;;IAC1B,wBAA8B;;IAC9B,4BAAwB;;IACxB,kCAA8B;;IAC9B,sBAAW;;IACX,mCAAwB;;IACxB,0BAAc;;IACd,2BAAe;;IACf,iCAAqB;;IACrB,yBAAwB;;;;;IAEtB,uBAAe;;;;;IACf,4BAAwB;;;;;IACxB,6BAA2B","sourcesContent":["import anime from 'animejs'; // tslint:disable-line\n\nimport { ElementRef, Renderer2 } from '@angular/core';\nimport { rand, is, stringToHyphens, getCSSValue, transformString, getElement } from './utils';\n\nexport interface IOption {\n  color?: string;\n  type?: string;\n  style?: string;\n  canvasPadding?: number;\n  duration?: number;\n  easing?: Array<number> | string;\n  direction?: string;\n  size?: () => number | number;\n  speed?: () => number | number;\n  particlesAmountCoefficient?: number;\n  oscillationCoefficient?: number;\n  begin?: () => void;\n  width?: number;\n  height?: number;\n  complete?: () => void;\n}\n\nexport class Particles {\n  particles = [];\n  frame = null;\n  canvas: HTMLCanvasElement;\n  ctx: CanvasRenderingContext2D;\n  wrapper: HTMLDivElement;\n  parentWrapper: HTMLDivElement;\n  o: IOption;\n  disintegrating: boolean;\n  width: number;\n  height: number;\n  lastProgress: number;\n  rect: HTMLCanvasElement;\n  constructor(\n    private el: any,\n    private options: IOption,\n    private renderer: Renderer2\n  ) {\n    this.options = { ...options };\n    this.init();\n  }\n\n  init(): void {\n   this.canvas = this.renderer.createElement('canvas');\n    this.ctx = this.canvas.getContext('2d');\n    this.renderer.setStyle(this.canvas, 'position', 'absolute');\n    this.renderer.setStyle(this.canvas, 'pointerEvents', 'none');\n    this.renderer.setStyle(this.canvas, 'top', '50%');\n    this.renderer.setStyle(this.canvas, 'left', '50%');\n    this.renderer.setStyle(this.canvas, 'transform', 'translate3d(-50%, -50%, 0)');\n    this.renderer.setStyle(this.canvas, 'display', 'none');\n    this.wrapper = this.renderer.createElement('div');\n    this.renderer.setStyle(this.wrapper, 'position', 'relative');\n    this.renderer.setStyle(this.wrapper, 'display', 'inline-block');\n    this.renderer.setStyle(this.wrapper, 'overflow', 'hidden');\n    this.renderer.insertBefore(this.el.parentNode, this.wrapper, this.el);\n    this.renderer.appendChild(this.wrapper, this.el);\n    this.parentWrapper = this.renderer.createElement('div');\n    this.renderer.setStyle(this.parentWrapper, 'position', 'relative');\n    this.renderer.setStyle(this.parentWrapper, 'display', 'inline-block');\n    this.renderer.insertBefore(\n      this.wrapper.parentNode,\n      this.parentWrapper,\n      this.wrapper\n    );\n    this.renderer.appendChild(this.parentWrapper, this.wrapper);\n    this.renderer.appendChild(this.parentWrapper, this.canvas);\n  }\n\n  setOptions(options) {\n    this.options = { ...this.options, ...options };\n  }\n  loop() {\n    this.updateParticles();\n    this.renderParticles();\n    if (this.isAnimating()) {\n      this.frame = requestAnimationFrame(this.loop.bind(this));\n    }\n  }\n  updateParticles() {\n    let p;\n    for (let i = 0; i < this.particles.length; i++) {\n      p = this.particles[i];\n      if (p.life > p.death) {\n        this.particles.splice(i, 1);\n      } else {\n        p.x += p.speed;\n        p.y = this.o.oscillationCoefficient * Math.sin(p.counter * p.increase);\n        p.life++;\n        p.counter += this.disintegrating ? 1 : -1;\n      }\n    }\n    if (!this.particles.length) {\n      this.pause();\n      this.renderer.setStyle(this.canvas, 'display', 'none');\n      if (is.fnc(this.o.complete)) {\n        this.o.complete();\n      }\n    }\n  }\n  renderParticles() {\n    this.ctx.clearRect(0, 0, this.width, this.height);\n    let p;\n    for (let i = 0; i < this.particles.length; i++) {\n      p = this.particles[i];\n      if (p.life < p.death) {\n        this.ctx.translate(p.startX, p.startY);\n        this.ctx.rotate(p.angle * Math.PI / 180);\n        this.ctx.globalAlpha = this.disintegrating\n          ? 1 - p.life / p.death\n          : p.life / p.death;\n        this.ctx.fillStyle = this.ctx.strokeStyle = this.o.color;\n        this.ctx.beginPath();\n\n        if (this.o.type === 'circle') {\n          this.ctx.arc(p.x, p.y, p.size, 0, 2 * Math.PI);\n        } else if (this.o.type === 'triangle') {\n          this.ctx.moveTo(p.x, p.y);\n          this.ctx.lineTo(p.x + p.size, p.y + p.size);\n          this.ctx.lineTo(p.x + p.size, p.y - p.size);\n        } else if (this.o.type === 'rectangle') {\n          this.ctx.rect(p.x, p.y, p.size, p.size);\n        }\n\n        if (this.o.style === 'fill') {\n          this.ctx.fill();\n        } else if (this.o.style === 'stroke') {\n          this.ctx.closePath();\n          this.ctx.stroke();\n        }\n\n        this.ctx.globalAlpha = 1;\n        this.ctx.rotate(-p.angle * Math.PI / 180);\n        this.ctx.translate(-p.startX, -p.startY);\n      }\n    }\n  }\n  play() {\n    this.frame = requestAnimationFrame(this.loop.bind(this));\n  }\n  pause() {\n    cancelAnimationFrame(this.frame);\n    this.frame = null;\n  }\n  addParticle(options) {\n    const frames = this.o.duration * 60 / 1000;\n    const speed: number = (is.fnc(this.o.speed)\n      ? this.o.speed()\n      : this.o.speed) as number;\n    this.particles.push({\n      startX: options.x,\n      startY: options.y,\n      x: this.disintegrating ? 0 : speed * -frames,\n      y: 0,\n      angle: rand(360),\n      counter: this.disintegrating ? 0 : frames,\n      increase: Math.PI * 2 / 100,\n      life: 0,\n      death: this.disintegrating ? frames - 20 + Math.random() * 40 : frames,\n      speed: speed,\n      size: is.fnc(this.o.size) ? this.o.size() : this.o.size\n    });\n  }\n  addParticles(rect: any, progress) {\n    const progressDiff = this.disintegrating\n      ? progress - this.lastProgress\n      : this.lastProgress - progress;\n    this.lastProgress = progress;\n    let x = this.options.canvasPadding;\n    let y = this.options.canvasPadding;\n    const progressValue =\n      (this.isHorizontal() ? rect.width : rect.height) * progress +\n      progressDiff * (this.disintegrating ? 100 : 220);\n    if (this.isHorizontal()) {\n      x +=\n        this.o.direction === 'left'\n          ? progressValue\n          : rect.width - progressValue;\n    } else {\n      y +=\n        this.o.direction === 'top'\n          ? progressValue\n          : rect.height - progressValue;\n    }\n    let i = Math.floor(\n      this.o.particlesAmountCoefficient * (progressDiff * 100 + 1)\n    );\n    if (i > 0) {\n      while (i--) {\n        this.addParticle({\n          x: x + (this.isHorizontal() ? 0 : rect.width * Math.random()),\n          y: y + (this.isHorizontal() ? rect.height * Math.random() : 0)\n        });\n      }\n    }\n    if (!this.isAnimating()) {\n      this.renderer.setStyle(this.canvas, 'display', 'block');\n      this.play();\n    }\n  }\n  addTransforms(value) {\n    const translateProperty = this.isHorizontal() ? 'translateX' : 'translateY';\n    const translateValue =\n      this.o.direction === 'left' || this.o.direction === 'top'\n        ? value\n        : -value;\n    this.renderer.setStyle(this.wrapper, transformString, `${translateProperty}(${translateValue}%)`);\n    this.renderer.setStyle(this.el, transformString, `${translateProperty}(${-translateValue}%)`);\n  }\n  disintegrate(options: IOption = {}) {\n    if (!this.isAnimating()) {\n      this.disintegrating = true;\n      this.lastProgress = 0;\n      this.setup(options);\n      const _ = this;\n      this.animate(anim => {\n        const value = anim.animatables[0].target.value;\n        _.addTransforms(value);\n        if (_.o.duration) {\n          _.addParticles(_.rect, value / 100);\n        }\n      });\n    }\n  }\n  integrate(options: IOption = {}) {\n    if (!this.isAnimating()) {\n      this.disintegrating = false;\n      this.lastProgress = 1;\n      this.setup(options);\n      const _ = this;\n      this.animate(anim => {\n        const value = anim.animatables[0].target.value;\n        setTimeout(() => {\n          _.addTransforms(value);\n        }, _.o.duration);\n        if (_.o.duration) {\n          _.addParticles(_.rect, value / 100);\n        }\n      });\n    }\n  }\n  setup(options) {\n    this.o = { ...this.options, ...options };\n    this.renderer.setStyle(this.wrapper, 'visibility', 'visible');\n    if (this.o.duration) {\n      this.rect = this.el.getBoundingClientRect();\n      this.width = this.canvas.width =\n        this.o.width || this.rect.width + this.o.canvasPadding * 2;\n      this.height = this.canvas.height =\n        this.o.height || this.rect.height + this.o.canvasPadding * 2;\n    }\n  }\n\n  public isDisintegrated() {\n    return this.disintegrating;\n  }\n  animate(update) {\n    const _ = this;\n    anime({\n      targets: { value: _.disintegrating ? 0 : 100 },\n      value: _.disintegrating ? 100 : 0,\n      duration: _.o.duration,\n      easing: _.o.easing,\n      begin: _.o.begin,\n      update: update,\n      complete: () => {\n        if (_.disintegrating) {\n          this.renderer.setStyle(_.wrapper, 'visibility', 'hidden');\n        }\n      }\n    });\n  }\n  isAnimating() {\n    return !!this.frame;\n  }\n  isHorizontal() {\n    return this.o.direction === 'left' || this.o.direction === 'right';\n  }\n}\n\n\n"]} |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
const ɵ0 = /** | ||
* @param {?} a | ||
* @return {?} | ||
*/ | ||
a => Array.isArray(a), ɵ1 = /** | ||
* @param {?} a | ||
* @return {?} | ||
*/ | ||
a => typeof a === 'string', ɵ2 = /** | ||
* @param {?} a | ||
* @return {?} | ||
*/ | ||
a => typeof a === 'function'; | ||
/** @type {?} */ | ||
export const is = { | ||
arr: a => Array.isArray(a), | ||
str: a => typeof a === 'string', | ||
fnc: a => typeof a === 'function' | ||
arr: (ɵ0), | ||
str: (ɵ1), | ||
fnc: (ɵ2) | ||
}; | ||
/** @type {?} */ | ||
export const stringToHyphens = str => { | ||
export const stringToHyphens = (/** | ||
* @param {?} str | ||
* @return {?} | ||
*/ | ||
str => { | ||
return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase(); | ||
}; | ||
}); | ||
/** @type {?} */ | ||
export const getCSSValue = (el, prop) => { | ||
export const getCSSValue = (/** | ||
* @param {?} el | ||
* @param {?} prop | ||
* @return {?} | ||
*/ | ||
(el, prop) => { | ||
if (prop in el.style) { | ||
return getComputedStyle(el).getPropertyValue(stringToHyphens(prop)) || '0'; | ||
} | ||
}; | ||
}); | ||
/** @type {?} */ | ||
@@ -26,9 +48,18 @@ export const t = 'transform'; | ||
/** @type {?} */ | ||
export const rand = value => { | ||
export const rand = (/** | ||
* @param {?} value | ||
* @return {?} | ||
*/ | ||
value => { | ||
return Math.random() * value - value / 2; | ||
}; | ||
}); | ||
/** @type {?} */ | ||
export const getElement = element => { | ||
export const getElement = (/** | ||
* @param {?} element | ||
* @return {?} | ||
*/ | ||
element => { | ||
return is.str(element) ? document.querySelector(element) : element; | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9hbmd1bGFyLXBhcnRpY2xlLWVmZmVjdC1idXR0b24vIiwic291cmNlcyI6WyJsaWIvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxNQUFNLE9BQU8sRUFBRSxHQUFHO0lBQ2hCLEdBQUcsRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDO0lBQzFCLEdBQUcsRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLE9BQU8sQ0FBQyxLQUFLLFFBQVE7SUFDL0IsR0FBRyxFQUFFLENBQUMsQ0FBQyxFQUFFLENBQUMsT0FBTyxDQUFDLEtBQUssVUFBVTtDQUNsQzs7QUFFRCxNQUFNLE9BQU8sZUFBZSxHQUFHLEdBQUcsQ0FBQyxFQUFFO0lBQ25DLE9BQU8sR0FBRyxDQUFDLE9BQU8sQ0FBQyxpQkFBaUIsRUFBRSxPQUFPLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQztBQUMvRCxDQUFDOztBQUVELE1BQU0sT0FBTyxXQUFXLEdBQUcsQ0FBQyxFQUFFLEVBQUUsSUFBSSxFQUFFLEVBQUU7SUFDdEMsSUFBSSxJQUFJLElBQUksRUFBRSxDQUFDLEtBQUssRUFBRTtRQUNwQixPQUFPLGdCQUFnQixDQUFDLEVBQUUsQ0FBQyxDQUFDLGdCQUFnQixDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLEdBQUcsQ0FBQztLQUM1RTtBQUNILENBQUM7O0FBRUQsTUFBTSxPQUFPLENBQUMsR0FBRyxXQUFXOztBQUM1QixNQUFNLE9BQU8sZUFBZSxHQUFHLFdBQVcsQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLFVBQVUsR0FBRyxDQUFDOztBQUVqRixNQUFNLE9BQU8sSUFBSSxHQUFHLEtBQUssQ0FBQyxFQUFFO0lBQzFCLE9BQU8sSUFBSSxDQUFDLE1BQU0sRUFBRSxHQUFHLEtBQUssR0FBRyxLQUFLLEdBQUcsQ0FBQyxDQUFDO0FBQzNDLENBQUM7O0FBRUQsTUFBTSxPQUFPLFVBQVUsR0FBRyxPQUFPLENBQUMsRUFBRTtJQUNsQyxPQUFPLEVBQUUsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQztBQUNyRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IGlzID0ge1xuICBhcnI6IGEgPT4gQXJyYXkuaXNBcnJheShhKSxcbiAgc3RyOiBhID0+IHR5cGVvZiBhID09PSAnc3RyaW5nJyxcbiAgZm5jOiBhID0+IHR5cGVvZiBhID09PSAnZnVuY3Rpb24nXG59O1xuXG5leHBvcnQgY29uc3Qgc3RyaW5nVG9IeXBoZW5zID0gc3RyID0+IHtcbiAgcmV0dXJuIHN0ci5yZXBsYWNlKC8oW2Etel0pKFtBLVpdKS9nLCAnJDEtJDInKS50b0xvd2VyQ2FzZSgpO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldENTU1ZhbHVlID0gKGVsLCBwcm9wKSA9PiB7XG4gIGlmIChwcm9wIGluIGVsLnN0eWxlKSB7XG4gICAgcmV0dXJuIGdldENvbXB1dGVkU3R5bGUoZWwpLmdldFByb3BlcnR5VmFsdWUoc3RyaW5nVG9IeXBoZW5zKHByb3ApKSB8fCAnMCc7XG4gIH1cbn07XG5cbmV4cG9ydCBjb25zdCB0ID0gJ3RyYW5zZm9ybSc7XG5leHBvcnQgY29uc3QgdHJhbnNmb3JtU3RyaW5nID0gZ2V0Q1NTVmFsdWUoZG9jdW1lbnQuYm9keSwgdCkgPyB0IDogJy13ZWJraXQtJyArIHQ7XG5cbmV4cG9ydCBjb25zdCByYW5kID0gdmFsdWUgPT4ge1xuICByZXR1cm4gTWF0aC5yYW5kb20oKSAqIHZhbHVlIC0gdmFsdWUgLyAyO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldEVsZW1lbnQgPSBlbGVtZW50ID0+IHtcbiAgcmV0dXJuIGlzLnN0cihlbGVtZW50KSA/IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3IoZWxlbWVudCkgOiBlbGVtZW50O1xufTtcbiJdfQ== | ||
}); | ||
export { ɵ0, ɵ1, ɵ2 }; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9hbmd1bGFyLXBhcnRpY2xlLWVmZmVjdC1idXR0b24vIiwic291cmNlcyI6WyJsaWIvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFDTyxDQUFDLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDOzs7O0FBQ3JCLENBQUMsQ0FBQyxFQUFFLENBQUMsT0FBTyxDQUFDLEtBQUssUUFBUTs7OztBQUMxQixDQUFDLENBQUMsRUFBRSxDQUFDLE9BQU8sQ0FBQyxLQUFLLFVBQVU7O0FBSG5DLE1BQU0sT0FBTyxFQUFFLEdBQUc7SUFDaEIsR0FBRyxNQUF1QjtJQUMxQixHQUFHLE1BQTRCO0lBQy9CLEdBQUcsTUFBOEI7Q0FDbEM7O0FBRUQsTUFBTSxPQUFPLGVBQWU7Ozs7QUFBRyxHQUFHLENBQUMsRUFBRTtJQUNuQyxPQUFPLEdBQUcsQ0FBQyxPQUFPLENBQUMsaUJBQWlCLEVBQUUsT0FBTyxDQUFDLENBQUMsV0FBVyxFQUFFLENBQUM7QUFDL0QsQ0FBQyxDQUFBOztBQUVELE1BQU0sT0FBTyxXQUFXOzs7OztBQUFHLENBQUMsRUFBRSxFQUFFLElBQUksRUFBRSxFQUFFO0lBQ3RDLElBQUksSUFBSSxJQUFJLEVBQUUsQ0FBQyxLQUFLLEVBQUU7UUFDcEIsT0FBTyxnQkFBZ0IsQ0FBQyxFQUFFLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxHQUFHLENBQUM7S0FDNUU7QUFDSCxDQUFDLENBQUE7O0FBRUQsTUFBTSxPQUFPLENBQUMsR0FBRyxXQUFXOztBQUM1QixNQUFNLE9BQU8sZUFBZSxHQUFHLFdBQVcsQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLFVBQVUsR0FBRyxDQUFDOztBQUVqRixNQUFNLE9BQU8sSUFBSTs7OztBQUFHLEtBQUssQ0FBQyxFQUFFO0lBQzFCLE9BQU8sSUFBSSxDQUFDLE1BQU0sRUFBRSxHQUFHLEtBQUssR0FBRyxLQUFLLEdBQUcsQ0FBQyxDQUFDO0FBQzNDLENBQUMsQ0FBQTs7QUFFRCxNQUFNLE9BQU8sVUFBVTs7OztBQUFHLE9BQU8sQ0FBQyxFQUFFO0lBQ2xDLE9BQU8sRUFBRSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDO0FBQ3JFLENBQUMsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBpcyA9IHtcbiAgYXJyOiBhID0+IEFycmF5LmlzQXJyYXkoYSksXG4gIHN0cjogYSA9PiB0eXBlb2YgYSA9PT0gJ3N0cmluZycsXG4gIGZuYzogYSA9PiB0eXBlb2YgYSA9PT0gJ2Z1bmN0aW9uJ1xufTtcblxuZXhwb3J0IGNvbnN0IHN0cmluZ1RvSHlwaGVucyA9IHN0ciA9PiB7XG4gIHJldHVybiBzdHIucmVwbGFjZSgvKFthLXpdKShbQS1aXSkvZywgJyQxLSQyJykudG9Mb3dlckNhc2UoKTtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRDU1NWYWx1ZSA9IChlbCwgcHJvcCkgPT4ge1xuICBpZiAocHJvcCBpbiBlbC5zdHlsZSkge1xuICAgIHJldHVybiBnZXRDb21wdXRlZFN0eWxlKGVsKS5nZXRQcm9wZXJ0eVZhbHVlKHN0cmluZ1RvSHlwaGVucyhwcm9wKSkgfHwgJzAnO1xuICB9XG59O1xuXG5leHBvcnQgY29uc3QgdCA9ICd0cmFuc2Zvcm0nO1xuZXhwb3J0IGNvbnN0IHRyYW5zZm9ybVN0cmluZyA9IGdldENTU1ZhbHVlKGRvY3VtZW50LmJvZHksIHQpID8gdCA6ICctd2Via2l0LScgKyB0O1xuXG5leHBvcnQgY29uc3QgcmFuZCA9IHZhbHVlID0+IHtcbiAgcmV0dXJuIE1hdGgucmFuZG9tKCkgKiB2YWx1ZSAtIHZhbHVlIC8gMjtcbn07XG5cbmV4cG9ydCBjb25zdCBnZXRFbGVtZW50ID0gZWxlbWVudCA9PiB7XG4gIHJldHVybiBpcy5zdHIoZWxlbWVudCkgPyBkb2N1bWVudC5xdWVyeVNlbGVjdG9yKGVsZW1lbnQpIDogZWxlbWVudDtcbn07XG4iXX0= |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -5,0 +5,0 @@ /* |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -5,0 +5,0 @@ /** |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -24,4 +24,10 @@ import { ElementRef, Input, Directive, EventEmitter, Output, Renderer2 } from '@angular/core'; | ||
this.pComplete = new EventEmitter(); | ||
this.pSize = function () { return Math.floor((Math.random() * 3) + 1); }; | ||
this.pSpeed = function () { return rand(4); }; | ||
this.pSize = (/** | ||
* @return {?} | ||
*/ | ||
function () { return Math.floor((Math.random() * 3) + 1); }); | ||
this.pSpeed = (/** | ||
* @return {?} | ||
*/ | ||
function () { return rand(4); }); | ||
} | ||
@@ -87,8 +93,14 @@ Object.defineProperty(ParticleEffectButtonDirective.prototype, "pHidden", { | ||
oscillationCoefficient: this.pOscillationCoefficient, | ||
begin: function () { | ||
begin: (/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
_this.pBegin.emit(); | ||
}, | ||
complete: function () { | ||
}), | ||
complete: (/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
_this.pComplete.emit(); | ||
} | ||
}) | ||
}; | ||
@@ -125,7 +137,11 @@ }; | ||
var allowedProps = this.pOptions; | ||
Object.keys(options).map(function (key) { | ||
Object.keys(options).map((/** | ||
* @param {?} key | ||
* @return {?} | ||
*/ | ||
function (key) { | ||
if (allowedProps[key]) { | ||
_this[key] = options[key]; | ||
} | ||
}); | ||
})); | ||
}, | ||
@@ -212,2 +228,2 @@ enumerable: true, | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-particle-effect-button.directive.js","sourceRoot":"ng://angular-particle-effect-button/","sources":["lib/angular-particle-effect-button.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ElementRef,\n  Input,\n  Directive,\n  EventEmitter,\n  Output,\n  Renderer2,\n  AfterContentInit,\n  OnDestroy,\n  OnInit\n} from '@angular/core';\nimport { rand } from './utils';\nimport { Particles, IOption } from './particles';\n\n@Directive({\n  selector: '[libParticleEffectButton]'\n})\nexport class ParticleEffectButtonDirective implements AfterContentInit {\n  private _particles: Particles;\n  private _pHidden = false;\n  @Input() pColor = '#000';\n  @Input() pDuration = 1000;\n  @Input() pEasing = 'easeInOutCubic';\n  @Input() pType = 'circle';\n  @Input() pStyle = 'fill';\n  @Input() pDirection = 'left';\n  @Input() pCanvasPadding = 150;\n  @Input() pOscillationCoefficient = 30;\n  @Input() pParticlesAmountCoefficient = 3;\n  @Output() pBegin = new EventEmitter<void>();\n  @Output() pComplete = new EventEmitter<void>();\n  @Input() pSize: () => number | number = () => Math.floor((Math.random() * 3) + 1);\n  @Input() pSpeed: () => number | number = () => rand(4);\n\n  @Input('pHidden')\n  set pHidden(value: boolean) {\n    this._pHidden = value;\n    if (this._particles) {\n      if (value && !this._particles.isDisintegrated()) {\n         this._particles.disintegrate(this.getFormattedOptions());\n      } else if (!value && this._particles.isDisintegrated()) {\n         this._particles.integrate(this.getFormattedOptions());\n      }\n    }\n  }\n  get pHidden(): boolean {\n    return this._pHidden;\n  }\n\n  constructor(private renderer: Renderer2, private el: ElementRef) {}\n\n  ngAfterContentInit() {\n    this._particles = new Particles(\n      this.el.nativeElement,\n      this.getFormattedOptions(),\n      this.renderer\n    );\n\n      if (this._pHidden) {\n          this._particles.disintegrate({duration: 0});\n      }\n  }\n  private getFormattedOptions(): IOption {\n     return {\n        color: this.pColor,\n        type: this.pType,\n        style: this.pStyle,\n        canvasPadding: this.pCanvasPadding,\n        duration: this.pDuration,\n        easing: this.pEasing,\n        direction: this.pDirection,\n        size: this.pSize,\n        speed: this.pSpeed,\n        particlesAmountCoefficient: this.pParticlesAmountCoefficient,\n        oscillationCoefficient: this.pOscillationCoefficient,\n        begin: () => {\n          this.pBegin.emit();\n        },\n        complete: () => {\n          this.pComplete.emit();\n        }\n    };\n  }\n  public get pOptions(): any {\n    return {\n        pColor: this.pColor,\n        pType: this.pType,\n        pStyle: this.pStyle,\n        pCanvasPadding: this.pCanvasPadding,\n        pDuration: this.pDuration,\n        pEasing: this.pEasing,\n        pDirection: this.pDirection,\n        pSize: this.pSize,\n        pSpeed: this.pSpeed,\n        pParticlesAmountCoefficient: this.pParticlesAmountCoefficient,\n        pOscillationCoefficient: this.pOscillationCoefficient,\n        pBegin: this.pBegin,\n        pComplete: this.pComplete\n    };\n  }\n  public set pOptions(options: any) {\n    const allowedProps = this.pOptions;\n    Object.keys(options).map( key => {\n      if (allowedProps[key]) {\n        this[key] = options[key];\n      }\n    });\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-particle-effect-button.directive.js","sourceRoot":"ng://angular-particle-effect-button/","sources":["lib/angular-particle-effect-button.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ElementRef,\n  Input,\n  Directive,\n  EventEmitter,\n  Output,\n  Renderer2,\n  AfterContentInit,\n  OnDestroy,\n  OnInit\n} from '@angular/core';\nimport { rand } from './utils';\nimport { Particles, IOption } from './particles';\n\n@Directive({\n  selector: '[libParticleEffectButton]'\n})\nexport class ParticleEffectButtonDirective implements AfterContentInit {\n  private _particles: Particles;\n  private _pHidden = false;\n  @Input() pColor = '#000';\n  @Input() pDuration = 1000;\n  @Input() pEasing = 'easeInOutCubic';\n  @Input() pType = 'circle';\n  @Input() pStyle = 'fill';\n  @Input() pDirection = 'left';\n  @Input() pCanvasPadding = 150;\n  @Input() pOscillationCoefficient = 30;\n  @Input() pParticlesAmountCoefficient = 3;\n  @Output() pBegin = new EventEmitter<void>();\n  @Output() pComplete = new EventEmitter<void>();\n  @Input() pSize: () => number | number = () => Math.floor((Math.random() * 3) + 1);\n  @Input() pSpeed: () => number | number = () => rand(4);\n\n  @Input('pHidden')\n  set pHidden(value: boolean) {\n    this._pHidden = value;\n    if (this._particles) {\n      if (value && !this._particles.isDisintegrated()) {\n         this._particles.disintegrate(this.getFormattedOptions());\n      } else if (!value && this._particles.isDisintegrated()) {\n         this._particles.integrate(this.getFormattedOptions());\n      }\n    }\n  }\n  get pHidden(): boolean {\n    return this._pHidden;\n  }\n\n  constructor(private renderer: Renderer2, private el: ElementRef) {}\n\n  ngAfterContentInit() {\n    this._particles = new Particles(\n      this.el.nativeElement,\n      this.getFormattedOptions(),\n      this.renderer\n    );\n\n      if (this._pHidden) {\n          this._particles.disintegrate({duration: 0});\n      }\n  }\n  private getFormattedOptions(): IOption {\n     return {\n        color: this.pColor,\n        type: this.pType,\n        style: this.pStyle,\n        canvasPadding: this.pCanvasPadding,\n        duration: this.pDuration,\n        easing: this.pEasing,\n        direction: this.pDirection,\n        size: this.pSize,\n        speed: this.pSpeed,\n        particlesAmountCoefficient: this.pParticlesAmountCoefficient,\n        oscillationCoefficient: this.pOscillationCoefficient,\n        begin: () => {\n          this.pBegin.emit();\n        },\n        complete: () => {\n          this.pComplete.emit();\n        }\n    };\n  }\n  public get pOptions(): any {\n    return {\n        pColor: this.pColor,\n        pType: this.pType,\n        pStyle: this.pStyle,\n        pCanvasPadding: this.pCanvasPadding,\n        pDuration: this.pDuration,\n        pEasing: this.pEasing,\n        pDirection: this.pDirection,\n        pSize: this.pSize,\n        pSpeed: this.pSpeed,\n        pParticlesAmountCoefficient: this.pParticlesAmountCoefficient,\n        pOscillationCoefficient: this.pOscillationCoefficient,\n        pBegin: this.pBegin,\n        pComplete: this.pComplete\n    };\n  }\n  public set pOptions(options: any) {\n    const allowedProps = this.pOptions;\n    Object.keys(options).map( key => {\n      if (allowedProps[key]) {\n        this[key] = options[key];\n      }\n    });\n  }\n}\n"]} |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -5,0 +5,0 @@ import { NgModule } from '@angular/core'; |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -311,3 +311,7 @@ import * as tslib_1 from "tslib"; | ||
var _1 = this; | ||
this.animate(function (anim) { | ||
this.animate((/** | ||
* @param {?} anim | ||
* @return {?} | ||
*/ | ||
function (anim) { | ||
/** @type {?} */ | ||
@@ -319,3 +323,3 @@ var value = anim.animatables[0].target.value; | ||
} | ||
}); | ||
})); | ||
} | ||
@@ -339,12 +343,19 @@ }; | ||
var _2 = this; | ||
this.animate(function (anim) { | ||
this.animate((/** | ||
* @param {?} anim | ||
* @return {?} | ||
*/ | ||
function (anim) { | ||
/** @type {?} */ | ||
var value = anim.animatables[0].target.value; | ||
setTimeout(function () { | ||
setTimeout((/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
_2.addTransforms(value); | ||
}, _2.o.duration); | ||
}), _2.o.duration); | ||
if (_2.o.duration) { | ||
_2.addParticles(_2.rect, value / 100); | ||
} | ||
}); | ||
})); | ||
} | ||
@@ -399,7 +410,10 @@ }; | ||
update: update, | ||
complete: function () { | ||
complete: (/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
if (_.disintegrating) { | ||
_this.renderer.setStyle(_.wrapper, 'visibility', 'hidden'); | ||
} | ||
} | ||
}) | ||
}); | ||
@@ -469,2 +483,2 @@ }; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"particles.js","sourceRoot":"ng://angular-particle-effect-button/","sources":["lib/particles.ts"],"names":[],"mappings":"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","sourcesContent":["import anime from 'animejs'; // tslint:disable-line\n\nimport { ElementRef, Renderer2 } from '@angular/core';\nimport { rand, is, stringToHyphens, getCSSValue, transformString, getElement } from './utils';\n\nexport interface IOption {\n  color?: string;\n  type?: string;\n  style?: string;\n  canvasPadding?: number;\n  duration?: number;\n  easing?: Array<number> | string;\n  direction?: string;\n  size?: () => number | number;\n  speed?: () => number | number;\n  particlesAmountCoefficient?: number;\n  oscillationCoefficient?: number;\n  begin?: () => void;\n  width?: number;\n  height?: number;\n  complete?: () => void;\n}\n\nexport class Particles {\n  particles = [];\n  frame = null;\n  canvas: HTMLCanvasElement;\n  ctx: CanvasRenderingContext2D;\n  wrapper: HTMLDivElement;\n  parentWrapper: HTMLDivElement;\n  o: IOption;\n  disintegrating: boolean;\n  width: number;\n  height: number;\n  lastProgress: number;\n  rect: HTMLCanvasElement;\n  constructor(\n    private el: any,\n    private options: IOption,\n    private renderer: Renderer2\n  ) {\n    this.options = { ...options };\n    this.init();\n  }\n\n  init(): void {\n   this.canvas = this.renderer.createElement('canvas');\n    this.ctx = this.canvas.getContext('2d');\n    this.renderer.setStyle(this.canvas, 'position', 'absolute');\n    this.renderer.setStyle(this.canvas, 'pointerEvents', 'none');\n    this.renderer.setStyle(this.canvas, 'top', '50%');\n    this.renderer.setStyle(this.canvas, 'left', '50%');\n    this.renderer.setStyle(this.canvas, 'transform', 'translate3d(-50%, -50%, 0)');\n    this.renderer.setStyle(this.canvas, 'display', 'none');\n    this.wrapper = this.renderer.createElement('div');\n    this.renderer.setStyle(this.wrapper, 'position', 'relative');\n    this.renderer.setStyle(this.wrapper, 'display', 'inline-block');\n    this.renderer.setStyle(this.wrapper, 'overflow', 'hidden');\n    this.renderer.insertBefore(this.el.parentNode, this.wrapper, this.el);\n    this.renderer.appendChild(this.wrapper, this.el);\n    this.parentWrapper = this.renderer.createElement('div');\n    this.renderer.setStyle(this.parentWrapper, 'position', 'relative');\n    this.renderer.setStyle(this.parentWrapper, 'display', 'inline-block');\n    this.renderer.insertBefore(\n      this.wrapper.parentNode,\n      this.parentWrapper,\n      this.wrapper\n    );\n    this.renderer.appendChild(this.parentWrapper, this.wrapper);\n    this.renderer.appendChild(this.parentWrapper, this.canvas);\n  }\n\n  setOptions(options) {\n    this.options = { ...this.options, ...options };\n  }\n  loop() {\n    this.updateParticles();\n    this.renderParticles();\n    if (this.isAnimating()) {\n      this.frame = requestAnimationFrame(this.loop.bind(this));\n    }\n  }\n  updateParticles() {\n    let p;\n    for (let i = 0; i < this.particles.length; i++) {\n      p = this.particles[i];\n      if (p.life > p.death) {\n        this.particles.splice(i, 1);\n      } else {\n        p.x += p.speed;\n        p.y = this.o.oscillationCoefficient * Math.sin(p.counter * p.increase);\n        p.life++;\n        p.counter += this.disintegrating ? 1 : -1;\n      }\n    }\n    if (!this.particles.length) {\n      this.pause();\n      this.renderer.setStyle(this.canvas, 'display', 'none');\n      if (is.fnc(this.o.complete)) {\n        this.o.complete();\n      }\n    }\n  }\n  renderParticles() {\n    this.ctx.clearRect(0, 0, this.width, this.height);\n    let p;\n    for (let i = 0; i < this.particles.length; i++) {\n      p = this.particles[i];\n      if (p.life < p.death) {\n        this.ctx.translate(p.startX, p.startY);\n        this.ctx.rotate(p.angle * Math.PI / 180);\n        this.ctx.globalAlpha = this.disintegrating\n          ? 1 - p.life / p.death\n          : p.life / p.death;\n        this.ctx.fillStyle = this.ctx.strokeStyle = this.o.color;\n        this.ctx.beginPath();\n\n        if (this.o.type === 'circle') {\n          this.ctx.arc(p.x, p.y, p.size, 0, 2 * Math.PI);\n        } else if (this.o.type === 'triangle') {\n          this.ctx.moveTo(p.x, p.y);\n          this.ctx.lineTo(p.x + p.size, p.y + p.size);\n          this.ctx.lineTo(p.x + p.size, p.y - p.size);\n        } else if (this.o.type === 'rectangle') {\n          this.ctx.rect(p.x, p.y, p.size, p.size);\n        }\n\n        if (this.o.style === 'fill') {\n          this.ctx.fill();\n        } else if (this.o.style === 'stroke') {\n          this.ctx.closePath();\n          this.ctx.stroke();\n        }\n\n        this.ctx.globalAlpha = 1;\n        this.ctx.rotate(-p.angle * Math.PI / 180);\n        this.ctx.translate(-p.startX, -p.startY);\n      }\n    }\n  }\n  play() {\n    this.frame = requestAnimationFrame(this.loop.bind(this));\n  }\n  pause() {\n    cancelAnimationFrame(this.frame);\n    this.frame = null;\n  }\n  addParticle(options) {\n    const frames = this.o.duration * 60 / 1000;\n    const speed: number = (is.fnc(this.o.speed)\n      ? this.o.speed()\n      : this.o.speed) as number;\n    this.particles.push({\n      startX: options.x,\n      startY: options.y,\n      x: this.disintegrating ? 0 : speed * -frames,\n      y: 0,\n      angle: rand(360),\n      counter: this.disintegrating ? 0 : frames,\n      increase: Math.PI * 2 / 100,\n      life: 0,\n      death: this.disintegrating ? frames - 20 + Math.random() * 40 : frames,\n      speed: speed,\n      size: is.fnc(this.o.size) ? this.o.size() : this.o.size\n    });\n  }\n  addParticles(rect: any, progress) {\n    const progressDiff = this.disintegrating\n      ? progress - this.lastProgress\n      : this.lastProgress - progress;\n    this.lastProgress = progress;\n    let x = this.options.canvasPadding;\n    let y = this.options.canvasPadding;\n    const progressValue =\n      (this.isHorizontal() ? rect.width : rect.height) * progress +\n      progressDiff * (this.disintegrating ? 100 : 220);\n    if (this.isHorizontal()) {\n      x +=\n        this.o.direction === 'left'\n          ? progressValue\n          : rect.width - progressValue;\n    } else {\n      y +=\n        this.o.direction === 'top'\n          ? progressValue\n          : rect.height - progressValue;\n    }\n    let i = Math.floor(\n      this.o.particlesAmountCoefficient * (progressDiff * 100 + 1)\n    );\n    if (i > 0) {\n      while (i--) {\n        this.addParticle({\n          x: x + (this.isHorizontal() ? 0 : rect.width * Math.random()),\n          y: y + (this.isHorizontal() ? rect.height * Math.random() : 0)\n        });\n      }\n    }\n    if (!this.isAnimating()) {\n      this.renderer.setStyle(this.canvas, 'display', 'block');\n      this.play();\n    }\n  }\n  addTransforms(value) {\n    const translateProperty = this.isHorizontal() ? 'translateX' : 'translateY';\n    const translateValue =\n      this.o.direction === 'left' || this.o.direction === 'top'\n        ? value\n        : -value;\n    this.renderer.setStyle(this.wrapper, transformString, `${translateProperty}(${translateValue}%)`);\n    this.renderer.setStyle(this.el, transformString, `${translateProperty}(${-translateValue}%)`);\n  }\n  disintegrate(options: IOption = {}) {\n    if (!this.isAnimating()) {\n      this.disintegrating = true;\n      this.lastProgress = 0;\n      this.setup(options);\n      const _ = this;\n      this.animate(anim => {\n        const value = anim.animatables[0].target.value;\n        _.addTransforms(value);\n        if (_.o.duration) {\n          _.addParticles(_.rect, value / 100);\n        }\n      });\n    }\n  }\n  integrate(options: IOption = {}) {\n    if (!this.isAnimating()) {\n      this.disintegrating = false;\n      this.lastProgress = 1;\n      this.setup(options);\n      const _ = this;\n      this.animate(anim => {\n        const value = anim.animatables[0].target.value;\n        setTimeout(() => {\n          _.addTransforms(value);\n        }, _.o.duration);\n        if (_.o.duration) {\n          _.addParticles(_.rect, value / 100);\n        }\n      });\n    }\n  }\n  setup(options) {\n    this.o = { ...this.options, ...options };\n    this.renderer.setStyle(this.wrapper, 'visibility', 'visible');\n    if (this.o.duration) {\n      this.rect = this.el.getBoundingClientRect();\n      this.width = this.canvas.width =\n        this.o.width || this.rect.width + this.o.canvasPadding * 2;\n      this.height = this.canvas.height =\n        this.o.height || this.rect.height + this.o.canvasPadding * 2;\n    }\n  }\n\n  public isDisintegrated() {\n    return this.disintegrating;\n  }\n  animate(update) {\n    const _ = this;\n    anime({\n      targets: { value: _.disintegrating ? 0 : 100 },\n      value: _.disintegrating ? 100 : 0,\n      duration: _.o.duration,\n      easing: _.o.easing,\n      begin: _.o.begin,\n      update: update,\n      complete: () => {\n        if (_.disintegrating) {\n          this.renderer.setStyle(_.wrapper, 'visibility', 'hidden');\n        }\n      }\n    });\n  }\n  isAnimating() {\n    return !!this.frame;\n  }\n  isHorizontal() {\n    return this.o.direction === 'left' || this.o.direction === 'right';\n  }\n}\n\n\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"particles.js","sourceRoot":"ng://angular-particle-effect-button/","sources":["lib/particles.ts"],"names":[],"mappings":"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","sourcesContent":["import anime from 'animejs'; // tslint:disable-line\n\nimport { ElementRef, Renderer2 } from '@angular/core';\nimport { rand, is, stringToHyphens, getCSSValue, transformString, getElement } from './utils';\n\nexport interface IOption {\n  color?: string;\n  type?: string;\n  style?: string;\n  canvasPadding?: number;\n  duration?: number;\n  easing?: Array<number> | string;\n  direction?: string;\n  size?: () => number | number;\n  speed?: () => number | number;\n  particlesAmountCoefficient?: number;\n  oscillationCoefficient?: number;\n  begin?: () => void;\n  width?: number;\n  height?: number;\n  complete?: () => void;\n}\n\nexport class Particles {\n  particles = [];\n  frame = null;\n  canvas: HTMLCanvasElement;\n  ctx: CanvasRenderingContext2D;\n  wrapper: HTMLDivElement;\n  parentWrapper: HTMLDivElement;\n  o: IOption;\n  disintegrating: boolean;\n  width: number;\n  height: number;\n  lastProgress: number;\n  rect: HTMLCanvasElement;\n  constructor(\n    private el: any,\n    private options: IOption,\n    private renderer: Renderer2\n  ) {\n    this.options = { ...options };\n    this.init();\n  }\n\n  init(): void {\n   this.canvas = this.renderer.createElement('canvas');\n    this.ctx = this.canvas.getContext('2d');\n    this.renderer.setStyle(this.canvas, 'position', 'absolute');\n    this.renderer.setStyle(this.canvas, 'pointerEvents', 'none');\n    this.renderer.setStyle(this.canvas, 'top', '50%');\n    this.renderer.setStyle(this.canvas, 'left', '50%');\n    this.renderer.setStyle(this.canvas, 'transform', 'translate3d(-50%, -50%, 0)');\n    this.renderer.setStyle(this.canvas, 'display', 'none');\n    this.wrapper = this.renderer.createElement('div');\n    this.renderer.setStyle(this.wrapper, 'position', 'relative');\n    this.renderer.setStyle(this.wrapper, 'display', 'inline-block');\n    this.renderer.setStyle(this.wrapper, 'overflow', 'hidden');\n    this.renderer.insertBefore(this.el.parentNode, this.wrapper, this.el);\n    this.renderer.appendChild(this.wrapper, this.el);\n    this.parentWrapper = this.renderer.createElement('div');\n    this.renderer.setStyle(this.parentWrapper, 'position', 'relative');\n    this.renderer.setStyle(this.parentWrapper, 'display', 'inline-block');\n    this.renderer.insertBefore(\n      this.wrapper.parentNode,\n      this.parentWrapper,\n      this.wrapper\n    );\n    this.renderer.appendChild(this.parentWrapper, this.wrapper);\n    this.renderer.appendChild(this.parentWrapper, this.canvas);\n  }\n\n  setOptions(options) {\n    this.options = { ...this.options, ...options };\n  }\n  loop() {\n    this.updateParticles();\n    this.renderParticles();\n    if (this.isAnimating()) {\n      this.frame = requestAnimationFrame(this.loop.bind(this));\n    }\n  }\n  updateParticles() {\n    let p;\n    for (let i = 0; i < this.particles.length; i++) {\n      p = this.particles[i];\n      if (p.life > p.death) {\n        this.particles.splice(i, 1);\n      } else {\n        p.x += p.speed;\n        p.y = this.o.oscillationCoefficient * Math.sin(p.counter * p.increase);\n        p.life++;\n        p.counter += this.disintegrating ? 1 : -1;\n      }\n    }\n    if (!this.particles.length) {\n      this.pause();\n      this.renderer.setStyle(this.canvas, 'display', 'none');\n      if (is.fnc(this.o.complete)) {\n        this.o.complete();\n      }\n    }\n  }\n  renderParticles() {\n    this.ctx.clearRect(0, 0, this.width, this.height);\n    let p;\n    for (let i = 0; i < this.particles.length; i++) {\n      p = this.particles[i];\n      if (p.life < p.death) {\n        this.ctx.translate(p.startX, p.startY);\n        this.ctx.rotate(p.angle * Math.PI / 180);\n        this.ctx.globalAlpha = this.disintegrating\n          ? 1 - p.life / p.death\n          : p.life / p.death;\n        this.ctx.fillStyle = this.ctx.strokeStyle = this.o.color;\n        this.ctx.beginPath();\n\n        if (this.o.type === 'circle') {\n          this.ctx.arc(p.x, p.y, p.size, 0, 2 * Math.PI);\n        } else if (this.o.type === 'triangle') {\n          this.ctx.moveTo(p.x, p.y);\n          this.ctx.lineTo(p.x + p.size, p.y + p.size);\n          this.ctx.lineTo(p.x + p.size, p.y - p.size);\n        } else if (this.o.type === 'rectangle') {\n          this.ctx.rect(p.x, p.y, p.size, p.size);\n        }\n\n        if (this.o.style === 'fill') {\n          this.ctx.fill();\n        } else if (this.o.style === 'stroke') {\n          this.ctx.closePath();\n          this.ctx.stroke();\n        }\n\n        this.ctx.globalAlpha = 1;\n        this.ctx.rotate(-p.angle * Math.PI / 180);\n        this.ctx.translate(-p.startX, -p.startY);\n      }\n    }\n  }\n  play() {\n    this.frame = requestAnimationFrame(this.loop.bind(this));\n  }\n  pause() {\n    cancelAnimationFrame(this.frame);\n    this.frame = null;\n  }\n  addParticle(options) {\n    const frames = this.o.duration * 60 / 1000;\n    const speed: number = (is.fnc(this.o.speed)\n      ? this.o.speed()\n      : this.o.speed) as number;\n    this.particles.push({\n      startX: options.x,\n      startY: options.y,\n      x: this.disintegrating ? 0 : speed * -frames,\n      y: 0,\n      angle: rand(360),\n      counter: this.disintegrating ? 0 : frames,\n      increase: Math.PI * 2 / 100,\n      life: 0,\n      death: this.disintegrating ? frames - 20 + Math.random() * 40 : frames,\n      speed: speed,\n      size: is.fnc(this.o.size) ? this.o.size() : this.o.size\n    });\n  }\n  addParticles(rect: any, progress) {\n    const progressDiff = this.disintegrating\n      ? progress - this.lastProgress\n      : this.lastProgress - progress;\n    this.lastProgress = progress;\n    let x = this.options.canvasPadding;\n    let y = this.options.canvasPadding;\n    const progressValue =\n      (this.isHorizontal() ? rect.width : rect.height) * progress +\n      progressDiff * (this.disintegrating ? 100 : 220);\n    if (this.isHorizontal()) {\n      x +=\n        this.o.direction === 'left'\n          ? progressValue\n          : rect.width - progressValue;\n    } else {\n      y +=\n        this.o.direction === 'top'\n          ? progressValue\n          : rect.height - progressValue;\n    }\n    let i = Math.floor(\n      this.o.particlesAmountCoefficient * (progressDiff * 100 + 1)\n    );\n    if (i > 0) {\n      while (i--) {\n        this.addParticle({\n          x: x + (this.isHorizontal() ? 0 : rect.width * Math.random()),\n          y: y + (this.isHorizontal() ? rect.height * Math.random() : 0)\n        });\n      }\n    }\n    if (!this.isAnimating()) {\n      this.renderer.setStyle(this.canvas, 'display', 'block');\n      this.play();\n    }\n  }\n  addTransforms(value) {\n    const translateProperty = this.isHorizontal() ? 'translateX' : 'translateY';\n    const translateValue =\n      this.o.direction === 'left' || this.o.direction === 'top'\n        ? value\n        : -value;\n    this.renderer.setStyle(this.wrapper, transformString, `${translateProperty}(${translateValue}%)`);\n    this.renderer.setStyle(this.el, transformString, `${translateProperty}(${-translateValue}%)`);\n  }\n  disintegrate(options: IOption = {}) {\n    if (!this.isAnimating()) {\n      this.disintegrating = true;\n      this.lastProgress = 0;\n      this.setup(options);\n      const _ = this;\n      this.animate(anim => {\n        const value = anim.animatables[0].target.value;\n        _.addTransforms(value);\n        if (_.o.duration) {\n          _.addParticles(_.rect, value / 100);\n        }\n      });\n    }\n  }\n  integrate(options: IOption = {}) {\n    if (!this.isAnimating()) {\n      this.disintegrating = false;\n      this.lastProgress = 1;\n      this.setup(options);\n      const _ = this;\n      this.animate(anim => {\n        const value = anim.animatables[0].target.value;\n        setTimeout(() => {\n          _.addTransforms(value);\n        }, _.o.duration);\n        if (_.o.duration) {\n          _.addParticles(_.rect, value / 100);\n        }\n      });\n    }\n  }\n  setup(options) {\n    this.o = { ...this.options, ...options };\n    this.renderer.setStyle(this.wrapper, 'visibility', 'visible');\n    if (this.o.duration) {\n      this.rect = this.el.getBoundingClientRect();\n      this.width = this.canvas.width =\n        this.o.width || this.rect.width + this.o.canvasPadding * 2;\n      this.height = this.canvas.height =\n        this.o.height || this.rect.height + this.o.canvasPadding * 2;\n    }\n  }\n\n  public isDisintegrated() {\n    return this.disintegrating;\n  }\n  animate(update) {\n    const _ = this;\n    anime({\n      targets: { value: _.disintegrating ? 0 : 100 },\n      value: _.disintegrating ? 100 : 0,\n      duration: _.o.duration,\n      easing: _.o.easing,\n      begin: _.o.begin,\n      update: update,\n      complete: () => {\n        if (_.disintegrating) {\n          this.renderer.setStyle(_.wrapper, 'visibility', 'hidden');\n        }\n      }\n    });\n  }\n  isAnimating() {\n    return !!this.frame;\n  }\n  isHorizontal() {\n    return this.o.direction === 'left' || this.o.direction === 'right';\n  }\n}\n\n\n"]} |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
var ɵ0 = /** | ||
* @param {?} a | ||
* @return {?} | ||
*/ | ||
function (a) { return Array.isArray(a); }, ɵ1 = /** | ||
* @param {?} a | ||
* @return {?} | ||
*/ | ||
function (a) { return typeof a === 'string'; }, ɵ2 = /** | ||
* @param {?} a | ||
* @return {?} | ||
*/ | ||
function (a) { return typeof a === 'function'; }; | ||
/** @type {?} */ | ||
export var is = { | ||
arr: function (a) { return Array.isArray(a); }, | ||
str: function (a) { return typeof a === 'string'; }, | ||
fnc: function (a) { return typeof a === 'function'; } | ||
arr: (ɵ0), | ||
str: (ɵ1), | ||
fnc: (ɵ2) | ||
}; | ||
/** @type {?} */ | ||
export var stringToHyphens = function (str) { | ||
export var stringToHyphens = (/** | ||
* @param {?} str | ||
* @return {?} | ||
*/ | ||
function (str) { | ||
return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase(); | ||
}; | ||
}); | ||
/** @type {?} */ | ||
export var getCSSValue = function (el, prop) { | ||
export var getCSSValue = (/** | ||
* @param {?} el | ||
* @param {?} prop | ||
* @return {?} | ||
*/ | ||
function (el, prop) { | ||
if (prop in el.style) { | ||
return getComputedStyle(el).getPropertyValue(stringToHyphens(prop)) || '0'; | ||
} | ||
}; | ||
}); | ||
/** @type {?} */ | ||
@@ -26,9 +48,18 @@ export var t = 'transform'; | ||
/** @type {?} */ | ||
export var rand = function (value) { | ||
export var rand = (/** | ||
* @param {?} value | ||
* @return {?} | ||
*/ | ||
function (value) { | ||
return Math.random() * value - value / 2; | ||
}; | ||
}); | ||
/** @type {?} */ | ||
export var getElement = function (element) { | ||
export var getElement = (/** | ||
* @param {?} element | ||
* @return {?} | ||
*/ | ||
function (element) { | ||
return is.str(element) ? document.querySelector(element) : element; | ||
}; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9hbmd1bGFyLXBhcnRpY2xlLWVmZmVjdC1idXR0b24vIiwic291cmNlcyI6WyJsaWIvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxNQUFNLEtBQU8sRUFBRSxHQUFHO0lBQ2hCLEdBQUcsRUFBRSxVQUFBLENBQUMsSUFBSSxPQUFBLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQWhCLENBQWdCO0lBQzFCLEdBQUcsRUFBRSxVQUFBLENBQUMsSUFBSSxPQUFBLE9BQU8sQ0FBQyxLQUFLLFFBQVEsRUFBckIsQ0FBcUI7SUFDL0IsR0FBRyxFQUFFLFVBQUEsQ0FBQyxJQUFJLE9BQUEsT0FBTyxDQUFDLEtBQUssVUFBVSxFQUF2QixDQUF1QjtDQUNsQzs7QUFFRCxNQUFNLEtBQU8sZUFBZSxHQUFHLFVBQUEsR0FBRztJQUNoQyxPQUFPLEdBQUcsQ0FBQyxPQUFPLENBQUMsaUJBQWlCLEVBQUUsT0FBTyxDQUFDLENBQUMsV0FBVyxFQUFFLENBQUM7QUFDL0QsQ0FBQzs7QUFFRCxNQUFNLEtBQU8sV0FBVyxHQUFHLFVBQUMsRUFBRSxFQUFFLElBQUk7SUFDbEMsSUFBSSxJQUFJLElBQUksRUFBRSxDQUFDLEtBQUssRUFBRTtRQUNwQixPQUFPLGdCQUFnQixDQUFDLEVBQUUsQ0FBQyxDQUFDLGdCQUFnQixDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLEdBQUcsQ0FBQztLQUM1RTtBQUNILENBQUM7O0FBRUQsTUFBTSxLQUFPLENBQUMsR0FBRyxXQUFXOztBQUM1QixNQUFNLEtBQU8sZUFBZSxHQUFHLFdBQVcsQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLFVBQVUsR0FBRyxDQUFDOztBQUVqRixNQUFNLEtBQU8sSUFBSSxHQUFHLFVBQUEsS0FBSztJQUN2QixPQUFPLElBQUksQ0FBQyxNQUFNLEVBQUUsR0FBRyxLQUFLLEdBQUcsS0FBSyxHQUFHLENBQUMsQ0FBQztBQUMzQyxDQUFDOztBQUVELE1BQU0sS0FBTyxVQUFVLEdBQUcsVUFBQSxPQUFPO0lBQy9CLE9BQU8sRUFBRSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDO0FBQ3JFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgaXMgPSB7XG4gIGFycjogYSA9PiBBcnJheS5pc0FycmF5KGEpLFxuICBzdHI6IGEgPT4gdHlwZW9mIGEgPT09ICdzdHJpbmcnLFxuICBmbmM6IGEgPT4gdHlwZW9mIGEgPT09ICdmdW5jdGlvbidcbn07XG5cbmV4cG9ydCBjb25zdCBzdHJpbmdUb0h5cGhlbnMgPSBzdHIgPT4ge1xuICByZXR1cm4gc3RyLnJlcGxhY2UoLyhbYS16XSkoW0EtWl0pL2csICckMS0kMicpLnRvTG93ZXJDYXNlKCk7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0Q1NTVmFsdWUgPSAoZWwsIHByb3ApID0+IHtcbiAgaWYgKHByb3AgaW4gZWwuc3R5bGUpIHtcbiAgICByZXR1cm4gZ2V0Q29tcHV0ZWRTdHlsZShlbCkuZ2V0UHJvcGVydHlWYWx1ZShzdHJpbmdUb0h5cGhlbnMocHJvcCkpIHx8ICcwJztcbiAgfVxufTtcblxuZXhwb3J0IGNvbnN0IHQgPSAndHJhbnNmb3JtJztcbmV4cG9ydCBjb25zdCB0cmFuc2Zvcm1TdHJpbmcgPSBnZXRDU1NWYWx1ZShkb2N1bWVudC5ib2R5LCB0KSA/IHQgOiAnLXdlYmtpdC0nICsgdDtcblxuZXhwb3J0IGNvbnN0IHJhbmQgPSB2YWx1ZSA9PiB7XG4gIHJldHVybiBNYXRoLnJhbmRvbSgpICogdmFsdWUgLSB2YWx1ZSAvIDI7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0RWxlbWVudCA9IGVsZW1lbnQgPT4ge1xuICByZXR1cm4gaXMuc3RyKGVsZW1lbnQpID8gZG9jdW1lbnQucXVlcnlTZWxlY3RvcihlbGVtZW50KSA6IGVsZW1lbnQ7XG59O1xuIl19 | ||
}); | ||
export { ɵ0, ɵ1, ɵ2 }; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9hbmd1bGFyLXBhcnRpY2xlLWVmZmVjdC1idXR0b24vIiwic291cmNlcyI6WyJsaWIvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7QUFDTyxVQUFBLENBQUMsSUFBSSxPQUFBLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQWhCLENBQWdCOzs7O0FBQ3JCLFVBQUEsQ0FBQyxJQUFJLE9BQUEsT0FBTyxDQUFDLEtBQUssUUFBUSxFQUFyQixDQUFxQjs7OztBQUMxQixVQUFBLENBQUMsSUFBSSxPQUFBLE9BQU8sQ0FBQyxLQUFLLFVBQVUsRUFBdkIsQ0FBdUI7O0FBSG5DLE1BQU0sS0FBTyxFQUFFLEdBQUc7SUFDaEIsR0FBRyxNQUF1QjtJQUMxQixHQUFHLE1BQTRCO0lBQy9CLEdBQUcsTUFBOEI7Q0FDbEM7O0FBRUQsTUFBTSxLQUFPLGVBQWU7Ozs7QUFBRyxVQUFBLEdBQUc7SUFDaEMsT0FBTyxHQUFHLENBQUMsT0FBTyxDQUFDLGlCQUFpQixFQUFFLE9BQU8sQ0FBQyxDQUFDLFdBQVcsRUFBRSxDQUFDO0FBQy9ELENBQUMsQ0FBQTs7QUFFRCxNQUFNLEtBQU8sV0FBVzs7Ozs7QUFBRyxVQUFDLEVBQUUsRUFBRSxJQUFJO0lBQ2xDLElBQUksSUFBSSxJQUFJLEVBQUUsQ0FBQyxLQUFLLEVBQUU7UUFDcEIsT0FBTyxnQkFBZ0IsQ0FBQyxFQUFFLENBQUMsQ0FBQyxnQkFBZ0IsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxHQUFHLENBQUM7S0FDNUU7QUFDSCxDQUFDLENBQUE7O0FBRUQsTUFBTSxLQUFPLENBQUMsR0FBRyxXQUFXOztBQUM1QixNQUFNLEtBQU8sZUFBZSxHQUFHLFdBQVcsQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLFVBQVUsR0FBRyxDQUFDOztBQUVqRixNQUFNLEtBQU8sSUFBSTs7OztBQUFHLFVBQUEsS0FBSztJQUN2QixPQUFPLElBQUksQ0FBQyxNQUFNLEVBQUUsR0FBRyxLQUFLLEdBQUcsS0FBSyxHQUFHLENBQUMsQ0FBQztBQUMzQyxDQUFDLENBQUE7O0FBRUQsTUFBTSxLQUFPLFVBQVU7Ozs7QUFBRyxVQUFBLE9BQU87SUFDL0IsT0FBTyxFQUFFLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUM7QUFDckUsQ0FBQyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IGlzID0ge1xuICBhcnI6IGEgPT4gQXJyYXkuaXNBcnJheShhKSxcbiAgc3RyOiBhID0+IHR5cGVvZiBhID09PSAnc3RyaW5nJyxcbiAgZm5jOiBhID0+IHR5cGVvZiBhID09PSAnZnVuY3Rpb24nXG59O1xuXG5leHBvcnQgY29uc3Qgc3RyaW5nVG9IeXBoZW5zID0gc3RyID0+IHtcbiAgcmV0dXJuIHN0ci5yZXBsYWNlKC8oW2Etel0pKFtBLVpdKS9nLCAnJDEtJDInKS50b0xvd2VyQ2FzZSgpO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldENTU1ZhbHVlID0gKGVsLCBwcm9wKSA9PiB7XG4gIGlmIChwcm9wIGluIGVsLnN0eWxlKSB7XG4gICAgcmV0dXJuIGdldENvbXB1dGVkU3R5bGUoZWwpLmdldFByb3BlcnR5VmFsdWUoc3RyaW5nVG9IeXBoZW5zKHByb3ApKSB8fCAnMCc7XG4gIH1cbn07XG5cbmV4cG9ydCBjb25zdCB0ID0gJ3RyYW5zZm9ybSc7XG5leHBvcnQgY29uc3QgdHJhbnNmb3JtU3RyaW5nID0gZ2V0Q1NTVmFsdWUoZG9jdW1lbnQuYm9keSwgdCkgPyB0IDogJy13ZWJraXQtJyArIHQ7XG5cbmV4cG9ydCBjb25zdCByYW5kID0gdmFsdWUgPT4ge1xuICByZXR1cm4gTWF0aC5yYW5kb20oKSAqIHZhbHVlIC0gdmFsdWUgLyAyO1xufTtcblxuZXhwb3J0IGNvbnN0IGdldEVsZW1lbnQgPSBlbGVtZW50ID0+IHtcbiAgcmV0dXJuIGlzLnN0cihlbGVtZW50KSA/IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3IoZWxlbWVudCkgOiBlbGVtZW50O1xufTtcbiJdfQ== |
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -5,0 +5,0 @@ /* |
@@ -0,24 +1,46 @@ | ||
import { EventEmitter, Directive, Renderer2, ElementRef, Input, Output, NgModule } from '@angular/core'; | ||
import anime from 'animejs'; | ||
import { ElementRef, Input, Directive, EventEmitter, Output, Renderer2, NgModule } from '@angular/core'; | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
const ɵ0 = /** | ||
* @param {?} a | ||
* @return {?} | ||
*/ | ||
a => Array.isArray(a), ɵ1 = /** | ||
* @param {?} a | ||
* @return {?} | ||
*/ | ||
a => typeof a === 'string', ɵ2 = /** | ||
* @param {?} a | ||
* @return {?} | ||
*/ | ||
a => typeof a === 'function'; | ||
/** @type {?} */ | ||
const is = { | ||
arr: a => Array.isArray(a), | ||
str: a => typeof a === 'string', | ||
fnc: a => typeof a === 'function' | ||
arr: (ɵ0), | ||
str: (ɵ1), | ||
fnc: (ɵ2) | ||
}; | ||
/** @type {?} */ | ||
const stringToHyphens = str => { | ||
const stringToHyphens = (/** | ||
* @param {?} str | ||
* @return {?} | ||
*/ | ||
str => { | ||
return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase(); | ||
}; | ||
}); | ||
/** @type {?} */ | ||
const getCSSValue = (el, prop) => { | ||
const getCSSValue = (/** | ||
* @param {?} el | ||
* @param {?} prop | ||
* @return {?} | ||
*/ | ||
(el, prop) => { | ||
if (prop in el.style) { | ||
return getComputedStyle(el).getPropertyValue(stringToHyphens(prop)) || '0'; | ||
} | ||
}; | ||
}); | ||
/** @type {?} */ | ||
@@ -29,10 +51,58 @@ const t = 'transform'; | ||
/** @type {?} */ | ||
const rand = value => { | ||
const rand = (/** | ||
* @param {?} value | ||
* @return {?} | ||
*/ | ||
value => { | ||
return Math.random() * value - value / 2; | ||
}; | ||
}); | ||
/** @type {?} */ | ||
const getElement = (/** | ||
* @param {?} element | ||
* @return {?} | ||
*/ | ||
element => { | ||
return is.str(element) ? document.querySelector(element) : element; | ||
}); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @record | ||
*/ | ||
function IOption() { } | ||
if (false) { | ||
/** @type {?|undefined} */ | ||
IOption.prototype.color; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.type; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.style; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.canvasPadding; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.duration; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.easing; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.direction; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.size; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.speed; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.particlesAmountCoefficient; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.oscillationCoefficient; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.begin; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.width; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.height; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.complete; | ||
} | ||
class Particles { | ||
@@ -270,3 +340,7 @@ /** | ||
const _ = this; | ||
this.animate(anim => { | ||
this.animate((/** | ||
* @param {?} anim | ||
* @return {?} | ||
*/ | ||
anim => { | ||
/** @type {?} */ | ||
@@ -278,3 +352,3 @@ const value = anim.animatables[0].target.value; | ||
} | ||
}); | ||
})); | ||
} | ||
@@ -293,12 +367,19 @@ } | ||
const _ = this; | ||
this.animate(anim => { | ||
this.animate((/** | ||
* @param {?} anim | ||
* @return {?} | ||
*/ | ||
anim => { | ||
/** @type {?} */ | ||
const value = anim.animatables[0].target.value; | ||
setTimeout(() => { | ||
setTimeout((/** | ||
* @return {?} | ||
*/ | ||
() => { | ||
_.addTransforms(value); | ||
}, _.o.duration); | ||
}), _.o.duration); | ||
if (_.o.duration) { | ||
_.addParticles(_.rect, value / 100); | ||
} | ||
}); | ||
})); | ||
} | ||
@@ -341,7 +422,10 @@ } | ||
update: update, | ||
complete: () => { | ||
complete: (/** | ||
* @return {?} | ||
*/ | ||
() => { | ||
if (_.disintegrating) { | ||
this.renderer.setStyle(_.wrapper, 'visibility', 'hidden'); | ||
} | ||
} | ||
}) | ||
}); | ||
@@ -362,6 +446,47 @@ } | ||
} | ||
if (false) { | ||
/** @type {?} */ | ||
Particles.prototype.particles; | ||
/** @type {?} */ | ||
Particles.prototype.frame; | ||
/** @type {?} */ | ||
Particles.prototype.canvas; | ||
/** @type {?} */ | ||
Particles.prototype.ctx; | ||
/** @type {?} */ | ||
Particles.prototype.wrapper; | ||
/** @type {?} */ | ||
Particles.prototype.parentWrapper; | ||
/** @type {?} */ | ||
Particles.prototype.o; | ||
/** @type {?} */ | ||
Particles.prototype.disintegrating; | ||
/** @type {?} */ | ||
Particles.prototype.width; | ||
/** @type {?} */ | ||
Particles.prototype.height; | ||
/** @type {?} */ | ||
Particles.prototype.lastProgress; | ||
/** @type {?} */ | ||
Particles.prototype.rect; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
Particles.prototype.el; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
Particles.prototype.options; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
Particles.prototype.renderer; | ||
} | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -388,4 +513,10 @@ class ParticleEffectButtonDirective { | ||
this.pComplete = new EventEmitter(); | ||
this.pSize = () => Math.floor((Math.random() * 3) + 1); | ||
this.pSpeed = () => rand(4); | ||
this.pSize = (/** | ||
* @return {?} | ||
*/ | ||
() => Math.floor((Math.random() * 3) + 1)); | ||
this.pSpeed = (/** | ||
* @return {?} | ||
*/ | ||
() => rand(4)); | ||
} | ||
@@ -439,8 +570,14 @@ /** | ||
oscillationCoefficient: this.pOscillationCoefficient, | ||
begin: () => { | ||
begin: (/** | ||
* @return {?} | ||
*/ | ||
() => { | ||
this.pBegin.emit(); | ||
}, | ||
complete: () => { | ||
}), | ||
complete: (/** | ||
* @return {?} | ||
*/ | ||
() => { | ||
this.pComplete.emit(); | ||
} | ||
}) | ||
}; | ||
@@ -475,7 +612,11 @@ } | ||
const allowedProps = this.pOptions; | ||
Object.keys(options).map(key => { | ||
Object.keys(options).map((/** | ||
* @param {?} key | ||
* @return {?} | ||
*/ | ||
key => { | ||
if (allowedProps[key]) { | ||
this[key] = options[key]; | ||
} | ||
}); | ||
})); | ||
} | ||
@@ -509,6 +650,54 @@ } | ||
}; | ||
if (false) { | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
ParticleEffectButtonDirective.prototype._particles; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
ParticleEffectButtonDirective.prototype._pHidden; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pColor; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pDuration; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pEasing; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pType; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pStyle; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pDirection; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pCanvasPadding; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pOscillationCoefficient; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pParticlesAmountCoefficient; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pBegin; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pComplete; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pSize; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pSpeed; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
ParticleEffectButtonDirective.prototype.renderer; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
ParticleEffectButtonDirective.prototype.el; | ||
} | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -526,3 +715,3 @@ class ParticleEffectButtonModule { | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -532,7 +721,6 @@ | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
export { ParticleEffectButtonDirective, ParticleEffectButtonModule }; | ||
//# sourceMappingURL=angular-particle-effect-button.js.map | ||
//# sourceMappingURL=angular-particle-effect-button.js.map |
@@ -0,25 +1,47 @@ | ||
import { EventEmitter, Directive, Renderer2, ElementRef, Input, Output, NgModule } from '@angular/core'; | ||
import { __assign } from 'tslib'; | ||
import anime from 'animejs'; | ||
import { ElementRef, Input, Directive, EventEmitter, Output, Renderer2, NgModule } from '@angular/core'; | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
var ɵ0 = /** | ||
* @param {?} a | ||
* @return {?} | ||
*/ | ||
function (a) { return Array.isArray(a); }, ɵ1 = /** | ||
* @param {?} a | ||
* @return {?} | ||
*/ | ||
function (a) { return typeof a === 'string'; }, ɵ2 = /** | ||
* @param {?} a | ||
* @return {?} | ||
*/ | ||
function (a) { return typeof a === 'function'; }; | ||
/** @type {?} */ | ||
var is = { | ||
arr: function (a) { return Array.isArray(a); }, | ||
str: function (a) { return typeof a === 'string'; }, | ||
fnc: function (a) { return typeof a === 'function'; } | ||
arr: (ɵ0), | ||
str: (ɵ1), | ||
fnc: (ɵ2) | ||
}; | ||
/** @type {?} */ | ||
var stringToHyphens = function (str) { | ||
var stringToHyphens = (/** | ||
* @param {?} str | ||
* @return {?} | ||
*/ | ||
function (str) { | ||
return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase(); | ||
}; | ||
}); | ||
/** @type {?} */ | ||
var getCSSValue = function (el, prop) { | ||
var getCSSValue = (/** | ||
* @param {?} el | ||
* @param {?} prop | ||
* @return {?} | ||
*/ | ||
function (el, prop) { | ||
if (prop in el.style) { | ||
return getComputedStyle(el).getPropertyValue(stringToHyphens(prop)) || '0'; | ||
} | ||
}; | ||
}); | ||
/** @type {?} */ | ||
@@ -30,10 +52,58 @@ var t = 'transform'; | ||
/** @type {?} */ | ||
var rand = function (value) { | ||
var rand = (/** | ||
* @param {?} value | ||
* @return {?} | ||
*/ | ||
function (value) { | ||
return Math.random() * value - value / 2; | ||
}; | ||
}); | ||
/** @type {?} */ | ||
var getElement = (/** | ||
* @param {?} element | ||
* @return {?} | ||
*/ | ||
function (element) { | ||
return is.str(element) ? document.querySelector(element) : element; | ||
}); | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
/** | ||
* @record | ||
*/ | ||
function IOption() { } | ||
if (false) { | ||
/** @type {?|undefined} */ | ||
IOption.prototype.color; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.type; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.style; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.canvasPadding; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.duration; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.easing; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.direction; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.size; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.speed; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.particlesAmountCoefficient; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.oscillationCoefficient; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.begin; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.width; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.height; | ||
/** @type {?|undefined} */ | ||
IOption.prototype.complete; | ||
} | ||
var Particles = /** @class */ (function () { | ||
@@ -306,3 +376,7 @@ function Particles(el, options, renderer) { | ||
var _1 = this; | ||
this.animate(function (anim) { | ||
this.animate((/** | ||
* @param {?} anim | ||
* @return {?} | ||
*/ | ||
function (anim) { | ||
/** @type {?} */ | ||
@@ -314,3 +388,3 @@ var value = anim.animatables[0].target.value; | ||
} | ||
}); | ||
})); | ||
} | ||
@@ -334,12 +408,19 @@ }; | ||
var _2 = this; | ||
this.animate(function (anim) { | ||
this.animate((/** | ||
* @param {?} anim | ||
* @return {?} | ||
*/ | ||
function (anim) { | ||
/** @type {?} */ | ||
var value = anim.animatables[0].target.value; | ||
setTimeout(function () { | ||
setTimeout((/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
_2.addTransforms(value); | ||
}, _2.o.duration); | ||
}), _2.o.duration); | ||
if (_2.o.duration) { | ||
_2.addParticles(_2.rect, value / 100); | ||
} | ||
}); | ||
})); | ||
} | ||
@@ -394,7 +475,10 @@ }; | ||
update: update, | ||
complete: function () { | ||
complete: (/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
if (_.disintegrating) { | ||
_this.renderer.setStyle(_.wrapper, 'visibility', 'hidden'); | ||
} | ||
} | ||
}) | ||
}); | ||
@@ -422,6 +506,47 @@ }; | ||
}()); | ||
if (false) { | ||
/** @type {?} */ | ||
Particles.prototype.particles; | ||
/** @type {?} */ | ||
Particles.prototype.frame; | ||
/** @type {?} */ | ||
Particles.prototype.canvas; | ||
/** @type {?} */ | ||
Particles.prototype.ctx; | ||
/** @type {?} */ | ||
Particles.prototype.wrapper; | ||
/** @type {?} */ | ||
Particles.prototype.parentWrapper; | ||
/** @type {?} */ | ||
Particles.prototype.o; | ||
/** @type {?} */ | ||
Particles.prototype.disintegrating; | ||
/** @type {?} */ | ||
Particles.prototype.width; | ||
/** @type {?} */ | ||
Particles.prototype.height; | ||
/** @type {?} */ | ||
Particles.prototype.lastProgress; | ||
/** @type {?} */ | ||
Particles.prototype.rect; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
Particles.prototype.el; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
Particles.prototype.options; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
Particles.prototype.renderer; | ||
} | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -444,4 +569,10 @@ var ParticleEffectButtonDirective = /** @class */ (function () { | ||
this.pComplete = new EventEmitter(); | ||
this.pSize = function () { return Math.floor((Math.random() * 3) + 1); }; | ||
this.pSpeed = function () { return rand(4); }; | ||
this.pSize = (/** | ||
* @return {?} | ||
*/ | ||
function () { return Math.floor((Math.random() * 3) + 1); }); | ||
this.pSpeed = (/** | ||
* @return {?} | ||
*/ | ||
function () { return rand(4); }); | ||
} | ||
@@ -507,8 +638,14 @@ Object.defineProperty(ParticleEffectButtonDirective.prototype, "pHidden", { | ||
oscillationCoefficient: this.pOscillationCoefficient, | ||
begin: function () { | ||
begin: (/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
_this.pBegin.emit(); | ||
}, | ||
complete: function () { | ||
}), | ||
complete: (/** | ||
* @return {?} | ||
*/ | ||
function () { | ||
_this.pComplete.emit(); | ||
} | ||
}) | ||
}; | ||
@@ -545,7 +682,11 @@ }; | ||
var allowedProps = this.pOptions; | ||
Object.keys(options).map(function (key) { | ||
Object.keys(options).map((/** | ||
* @param {?} key | ||
* @return {?} | ||
*/ | ||
function (key) { | ||
if (allowedProps[key]) { | ||
_this[key] = options[key]; | ||
} | ||
}); | ||
})); | ||
}, | ||
@@ -583,6 +724,54 @@ enumerable: true, | ||
}()); | ||
if (false) { | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
ParticleEffectButtonDirective.prototype._particles; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
ParticleEffectButtonDirective.prototype._pHidden; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pColor; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pDuration; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pEasing; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pType; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pStyle; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pDirection; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pCanvasPadding; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pOscillationCoefficient; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pParticlesAmountCoefficient; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pBegin; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pComplete; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pSize; | ||
/** @type {?} */ | ||
ParticleEffectButtonDirective.prototype.pSpeed; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
ParticleEffectButtonDirective.prototype.renderer; | ||
/** | ||
* @type {?} | ||
* @private | ||
*/ | ||
ParticleEffectButtonDirective.prototype.el; | ||
} | ||
/** | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -603,3 +792,3 @@ var ParticleEffectButtonModule = /** @class */ (function () { | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
@@ -609,7 +798,6 @@ | ||
* @fileoverview added by tsickle | ||
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc | ||
*/ | ||
export { ParticleEffectButtonDirective, ParticleEffectButtonModule }; | ||
//# sourceMappingURL=angular-particle-effect-button.js.map | ||
//# sourceMappingURL=angular-particle-effect-button.js.map |
{ | ||
"name": "angular-particle-effect-button", | ||
"version": "0.0.42", | ||
"version": "0.0.43", | ||
"peerDependencies": { | ||
"@angular/common": "^7.2.0", | ||
"@angular/core": "^7.2.0" | ||
"@angular/common": "^8.2.0", | ||
"@angular/core": "^8.2.0" | ||
}, | ||
@@ -8,0 +8,0 @@ "dependencies": { |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
New author
Supply chain riskA new npm collaborator published a version of the package for the first time. New collaborators are usually benign additions to a project, but do indicate a change to the security surface area of a package.
Found 1 instance in 1 package
No README
QualityPackage does not have a README. This may indicate a failed publish or a low quality package.
Found 1 instance in 1 package
372932
4100
28
2
0
1