@tsparticles/plugin-absorbers 3.4.0 → 3.6.0-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/cjs/index.js CHANGED
@@ -14,11 +14,10 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
14
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
- exports.loadAbsorbersPlugin = void 0;
17
+ exports.loadAbsorbersPlugin = loadAbsorbersPlugin;
18
18
  const AbsorbersPlugin_js_1 = require("./AbsorbersPlugin.js");
19
19
  async function loadAbsorbersPlugin(engine, refresh = true) {
20
20
  await engine.addPlugin(new AbsorbersPlugin_js_1.AbsorbersPlugin(), refresh);
21
21
  }
22
- exports.loadAbsorbersPlugin = loadAbsorbersPlugin;
23
22
  __exportStar(require("./AbsorberContainer.js"), exports);
24
23
  __exportStar(require("./Enums/AbsorberClickMode.js"), exports);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tsparticles/plugin-absorbers",
3
- "version": "3.4.0",
3
+ "version": "3.6.0-beta.0",
4
4
  "description": "tsParticles absorbers plugin",
5
5
  "homepage": "https://particles.js.org",
6
6
  "repository": {
@@ -86,7 +86,7 @@
86
86
  "./package.json": "./package.json"
87
87
  },
88
88
  "dependencies": {
89
- "@tsparticles/engine": "^3.4.0"
89
+ "@tsparticles/engine": "^3.6.0-beta.0"
90
90
  },
91
91
  "publishConfig": {
92
92
  "access": "public"
package/report.html CHANGED
@@ -3,7 +3,7 @@
3
3
  <head>
4
4
  <meta charset="UTF-8"/>
5
5
  <meta name="viewport" content="width=device-width, initial-scale=1"/>
6
- <title>@tsparticles/plugin-absorbers [13 May 2024 at 00:09]</title>
6
+ <title>@tsparticles/plugin-absorbers [7 Oct 2024 at 10:34]</title>
7
7
  <link rel="shortcut icon" href="" type="image/x-icon" />
8
8
 
9
9
  <script>
@@ -4,7 +4,7 @@
4
4
  * Demo / Generator : https://particles.js.org/
5
5
  * GitHub : https://www.github.com/matteobruni/tsparticles
6
6
  * How to use? : Check the GitHub README
7
- * v3.4.0
7
+ * v3.6.0-beta.0
8
8
  */
9
9
  /*
10
10
  * ATTENTION: The "eval" devtool has been used (maybe by default in mode: "development").
@@ -1,2 +1,2 @@
1
1
  /*! For license information please see tsparticles.plugin.absorbers.min.js.LICENSE.txt */
2
- !function(i,t){if("object"==typeof exports&&"object"==typeof module)module.exports=t(require("@tsparticles/engine"));else if("function"==typeof define&&define.amd)define(["@tsparticles/engine"],t);else{var s="object"==typeof exports?t(require("@tsparticles/engine")):t(i.window);for(var o in s)("object"==typeof exports?exports:i)[o]=s[o]}}(this,(i=>(()=>{var t={303:t=>{t.exports=i}},s={};function o(i){var e=s[i];if(void 0!==e)return e.exports;var r=s[i]={exports:{}};return t[i](r,r.exports,o),r.exports}o.d=(i,t)=>{for(var s in t)o.o(t,s)&&!o.o(i,s)&&Object.defineProperty(i,s,{enumerable:!0,get:t[s]})},o.o=(i,t)=>Object.prototype.hasOwnProperty.call(i,t),o.r=i=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(i,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(i,"__esModule",{value:!0})};var e={};return(()=>{o.r(e),o.d(e,{AbsorberClickMode:()=>i,loadAbsorbersPlugin:()=>p});var i,t=o(303);class s{constructor(){this.radius=0,this.mass=0}load(i){i&&(void 0!==i.mass&&(this.mass=i.mass),void 0!==i.radius&&(this.radius=i.radius))}}class r extends t.ValueWithRandom{constructor(){super(),this.density=5,this.value=50,this.limit=new s}load(i){i&&(super.load(i),void 0!==i.density&&(this.density=i.density),(0,t.isNumber)(i.limit)?this.limit.radius=i.limit:this.limit.load(i.limit))}}class n{constructor(){this.color=new t.OptionsColor,this.color.value="#000000",this.draggable=!1,this.opacity=1,this.destroy=!0,this.orbits=!1,this.size=new r}load(i){void 0!==i&&(void 0!==i.color&&(this.color=t.OptionsColor.create(this.color,i.color)),void 0!==i.draggable&&(this.draggable=i.draggable),this.name=i.name,void 0!==i.opacity&&(this.opacity=i.opacity),void 0!==i.position&&(this.position={},void 0!==i.position.x&&(this.position.x=(0,t.setRangeValue)(i.position.x)),void 0!==i.position.y&&(this.position.y=(0,t.setRangeValue)(i.position.y))),void 0!==i.size&&this.size.load(i.size),void 0!==i.destroy&&(this.destroy=i.destroy),void 0!==i.orbits&&(this.orbits=i.orbits))}}!function(i){i.absorber="absorber"}(i||(i={}));const a=0,c=0,l=2*Math.PI;class h{constructor(i,s,o,e){this.absorbers=i,this.container=s,this._calcPosition=()=>{const i=(0,t.calcPositionOrRandomFromSizeRanged)({size:this.container.canvas.size,position:this.options.position});return t.Vector.create(i.x,i.y)},this._updateParticlePosition=(i,s)=>{if(i.destroyed)return;const o=this.container,e=o.canvas.size;if(i.needsNewPosition){const s=(0,t.calcPositionOrRandomFromSize)({size:e});i.position.setTo(s),i.velocity.setTo(i.initialVelocity),i.absorberOrbit=void 0,i.needsNewPosition=!1}if(this.options.orbits){if(void 0===i.absorberOrbit&&(i.absorberOrbit=t.Vector.origin,i.absorberOrbit.length=(0,t.getDistance)(i.getPosition(),this.position),i.absorberOrbit.angle=(0,t.getRandom)()*l),i.absorberOrbit.length<=this.size&&!this.options.destroy){const s=Math.min(e.width,e.height),o=1,r=.1,n=.2;i.absorberOrbit.length=s*(o+((0,t.getRandom)()*n-r))}void 0===i.absorberOrbitDirection&&(i.absorberOrbitDirection=i.velocity.x>=0?t.RotateDirection.clockwise:t.RotateDirection.counterClockwise);const r=i.absorberOrbit.length,n=i.absorberOrbit.angle,a=i.absorberOrbitDirection;i.velocity.setTo(t.Vector.origin);const c={x:a===t.RotateDirection.clockwise?Math.cos:Math.sin,y:a===t.RotateDirection.clockwise?Math.sin:Math.cos};i.position.x=this.position.x+r*c.x(n),i.position.y=this.position.y+r*c.y(n),i.absorberOrbit.length-=s.length,i.absorberOrbit.angle+=(i.retina.moveSpeed??0)*o.retina.pixelRatio/t.percentDenominator*o.retina.reduceFactor}else{const o=t.Vector.origin;o.length=s.length,o.angle=s.angle,i.velocity.addTo(o)}},this.initialPosition=e?t.Vector.create(e.x,e.y):void 0,o instanceof n?this.options=o:(this.options=new n,this.options.load(o)),this.dragging=!1,this.name=this.options.name,this.opacity=this.options.opacity,this.size=(0,t.getRangeValue)(this.options.size.value)*s.retina.pixelRatio,this.mass=this.size*this.options.size.density*s.retina.reduceFactor;const r=this.options.size.limit;this.limit={radius:r.radius*s.retina.pixelRatio*s.retina.reduceFactor,mass:r.mass},this.color=(0,t.rangeColorToRgb)(this.options.color)??{b:0,g:0,r:0},this.position=this.initialPosition?.copy()??this._calcPosition()}attract(i){const s=this.container,o=this.options;if(o.draggable){const i=s.interactivity.mouse;if(i.clicking&&i.downPosition){(0,t.getDistance)(this.position,i.downPosition)<=this.size&&(this.dragging=!0)}else this.dragging=!1;this.dragging&&i.position&&(this.position.x=i.position.x,this.position.y=i.position.y)}const e=i.getPosition(),{dx:r,dy:n,distance:a}=(0,t.getDistances)(this.position,e),c=t.Vector.create(r,n);if(c.length=this.mass/Math.pow(a,2)*s.retina.reduceFactor,a<this.size+i.getRadius()){const t=.033*i.getRadius()*s.retina.pixelRatio;this.size>i.getRadius()&&a<this.size-i.getRadius()||void 0!==i.absorberOrbit&&i.absorberOrbit.length<0?o.destroy?i.destroy():(i.needsNewPosition=!0,this._updateParticlePosition(i,c)):(o.destroy&&(i.size.value-=t),this._updateParticlePosition(i,c)),(this.limit.radius<=0||this.size<this.limit.radius)&&(this.size+=t),(this.limit.mass<=0||this.mass<this.limit.mass)&&(this.mass+=t*this.options.size.density*s.retina.reduceFactor)}else this._updateParticlePosition(i,c)}draw(i){i.translate(this.position.x,this.position.y),i.beginPath(),i.arc(a,c,this.size,0,l,!1),i.closePath(),i.fillStyle=(0,t.getStyleFromRgb)(this.color,this.opacity),i.fill()}resize(){const i=this.initialPosition;this.position=i&&(0,t.isPointInside)(i,this.container.canvas.size,t.Vector.origin)?i:this._calcPosition()}}class d{constructor(i){this.container=i,this.array=[],this.absorbers=[],this.interactivityAbsorbers=[],i.getAbsorber=i=>void 0===i||(0,t.isNumber)(i)?this.array[i??0]:this.array.find((t=>t.name===i)),i.addAbsorber=async(i,t)=>this.addAbsorber(i,t)}async addAbsorber(i,t){const s=new h(this,this.container,i,t);return this.array.push(s),Promise.resolve(s)}draw(i){for(const t of this.array)t.draw(i)}handleClickMode(s){const o=this.absorbers,e=this.interactivityAbsorbers;if(s===i.absorber){const i=(0,t.itemFromSingleOrMultiple)(e)??(0,t.itemFromSingleOrMultiple)(o),s=this.container.interactivity.mouse.clickPosition;this.addAbsorber(i,s)}}async init(){this.absorbers=this.container.actualOptions.absorbers,this.interactivityAbsorbers=this.container.actualOptions.interactivity.modes.absorbers;const i=(0,t.executeOnSingleOrMultiple)(this.absorbers,(async i=>{await this.addAbsorber(i)}));i instanceof Array?await Promise.all(i):await i}particleUpdate(i){for(const t of this.array)if(t.attract(i),i.destroyed)break}removeAbsorber(i){const t=this.array.indexOf(i);t>=0&&this.array.splice(t,1)}resize(){for(const i of this.array)i.resize()}stop(){this.array=[]}}class b{constructor(){this.id="absorbers"}async getPlugin(i){return Promise.resolve(new d(i))}loadOptions(i,s){(this.needsPlugin(i)||this.needsPlugin(s))&&(s?.absorbers&&(i.absorbers=(0,t.executeOnSingleOrMultiple)(s.absorbers,(i=>{const t=new n;return t.load(i),t}))),i.interactivity.modes.absorbers=(0,t.executeOnSingleOrMultiple)(s?.interactivity?.modes?.absorbers,(i=>{const t=new n;return t.load(i),t})))}needsPlugin(s){if(!s)return!1;const o=s.absorbers;return(0,t.isArray)(o)?!!o.length:!!o||!(!s.interactivity?.events?.onClick?.mode||!(0,t.isInArray)(i.absorber,s.interactivity.events.onClick.mode))}}async function p(i,t=!0){await i.addPlugin(new b,t)}})(),e})()));
2
+ !function(i,t){if("object"==typeof exports&&"object"==typeof module)module.exports=t(require("@tsparticles/engine"));else if("function"==typeof define&&define.amd)define(["@tsparticles/engine"],t);else{var s="object"==typeof exports?t(require("@tsparticles/engine")):t(i.window);for(var o in s)("object"==typeof exports?exports:i)[o]=s[o]}}(this,(i=>(()=>{var t={303:t=>{t.exports=i}},s={};function o(i){var e=s[i];if(void 0!==e)return e.exports;var r=s[i]={exports:{}};return t[i](r,r.exports,o),r.exports}o.d=(i,t)=>{for(var s in t)o.o(t,s)&&!o.o(i,s)&&Object.defineProperty(i,s,{enumerable:!0,get:t[s]})},o.o=(i,t)=>Object.prototype.hasOwnProperty.call(i,t),o.r=i=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(i,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(i,"__esModule",{value:!0})};var e={};o.r(e),o.d(e,{AbsorberClickMode:()=>r,loadAbsorbersPlugin:()=>u});var r,n=o(303);class a{constructor(){this.radius=0,this.mass=0}load(i){i&&(void 0!==i.mass&&(this.mass=i.mass),void 0!==i.radius&&(this.radius=i.radius))}}class c extends n.ValueWithRandom{constructor(){super(),this.density=5,this.value=50,this.limit=new a}load(i){i&&(super.load(i),void 0!==i.density&&(this.density=i.density),(0,n.isNumber)(i.limit)?this.limit.radius=i.limit:this.limit.load(i.limit))}}class l{constructor(){this.color=new n.OptionsColor,this.color.value="#000000",this.draggable=!1,this.opacity=1,this.destroy=!0,this.orbits=!1,this.size=new c}load(i){void 0!==i&&(void 0!==i.color&&(this.color=n.OptionsColor.create(this.color,i.color)),void 0!==i.draggable&&(this.draggable=i.draggable),this.name=i.name,void 0!==i.opacity&&(this.opacity=i.opacity),void 0!==i.position&&(this.position={},void 0!==i.position.x&&(this.position.x=(0,n.setRangeValue)(i.position.x)),void 0!==i.position.y&&(this.position.y=(0,n.setRangeValue)(i.position.y))),void 0!==i.size&&this.size.load(i.size),void 0!==i.destroy&&(this.destroy=i.destroy),void 0!==i.orbits&&(this.orbits=i.orbits))}}!function(i){i.absorber="absorber"}(r||(r={}));const h=0,d=0,b=2*Math.PI;class p{constructor(i,t,s,o){this.absorbers=i,this.container=t,this._calcPosition=()=>{const i=(0,n.calcPositionOrRandomFromSizeRanged)({size:this.container.canvas.size,position:this.options.position});return n.Vector.create(i.x,i.y)},this._updateParticlePosition=(i,t)=>{if(i.destroyed)return;const s=this.container,o=s.canvas.size;if(i.needsNewPosition){const t=(0,n.calcPositionOrRandomFromSize)({size:o});i.position.setTo(t),i.velocity.setTo(i.initialVelocity),i.absorberOrbit=void 0,i.needsNewPosition=!1}if(this.options.orbits){if(void 0===i.absorberOrbit&&(i.absorberOrbit=n.Vector.origin,i.absorberOrbit.length=(0,n.getDistance)(i.getPosition(),this.position),i.absorberOrbit.angle=(0,n.getRandom)()*b),i.absorberOrbit.length<=this.size&&!this.options.destroy){const t=Math.min(o.width,o.height),s=1,e=.1,r=.2;i.absorberOrbit.length=t*(s+((0,n.getRandom)()*r-e))}void 0===i.absorberOrbitDirection&&(i.absorberOrbitDirection=i.velocity.x>=0?n.RotateDirection.clockwise:n.RotateDirection.counterClockwise);const e=i.absorberOrbit.length,r=i.absorberOrbit.angle,a=i.absorberOrbitDirection;i.velocity.setTo(n.Vector.origin);const c={x:a===n.RotateDirection.clockwise?Math.cos:Math.sin,y:a===n.RotateDirection.clockwise?Math.sin:Math.cos};i.position.x=this.position.x+e*c.x(r),i.position.y=this.position.y+e*c.y(r),i.absorberOrbit.length-=t.length,i.absorberOrbit.angle+=(i.retina.moveSpeed??0)*s.retina.pixelRatio/n.percentDenominator*s.retina.reduceFactor}else{const s=n.Vector.origin;s.length=t.length,s.angle=t.angle,i.velocity.addTo(s)}},this.initialPosition=o?n.Vector.create(o.x,o.y):void 0,s instanceof l?this.options=s:(this.options=new l,this.options.load(s)),this.dragging=!1,this.name=this.options.name,this.opacity=this.options.opacity,this.size=(0,n.getRangeValue)(this.options.size.value)*t.retina.pixelRatio,this.mass=this.size*this.options.size.density*t.retina.reduceFactor;const e=this.options.size.limit;this.limit={radius:e.radius*t.retina.pixelRatio*t.retina.reduceFactor,mass:e.mass},this.color=(0,n.rangeColorToRgb)(this.options.color)??{b:0,g:0,r:0},this.position=this.initialPosition?.copy()??this._calcPosition()}attract(i){const t=this.container,s=this.options;if(s.draggable){const i=t.interactivity.mouse;if(i.clicking&&i.downPosition){(0,n.getDistance)(this.position,i.downPosition)<=this.size&&(this.dragging=!0)}else this.dragging=!1;this.dragging&&i.position&&(this.position.x=i.position.x,this.position.y=i.position.y)}const o=i.getPosition(),{dx:e,dy:r,distance:a}=(0,n.getDistances)(this.position,o),c=n.Vector.create(e,r);if(c.length=this.mass/Math.pow(a,2)*t.retina.reduceFactor,a<this.size+i.getRadius()){const o=.033*i.getRadius()*t.retina.pixelRatio;this.size>i.getRadius()&&a<this.size-i.getRadius()||void 0!==i.absorberOrbit&&i.absorberOrbit.length<0?s.destroy?i.destroy():(i.needsNewPosition=!0,this._updateParticlePosition(i,c)):(s.destroy&&(i.size.value-=o),this._updateParticlePosition(i,c)),(this.limit.radius<=0||this.size<this.limit.radius)&&(this.size+=o),(this.limit.mass<=0||this.mass<this.limit.mass)&&(this.mass+=o*this.options.size.density*t.retina.reduceFactor)}else this._updateParticlePosition(i,c)}draw(i){i.translate(this.position.x,this.position.y),i.beginPath(),i.arc(h,d,this.size,0,b,!1),i.closePath(),i.fillStyle=(0,n.getStyleFromRgb)(this.color,this.opacity),i.fill()}resize(){const i=this.initialPosition;this.position=i&&(0,n.isPointInside)(i,this.container.canvas.size,n.Vector.origin)?i:this._calcPosition()}}class g{constructor(i){this.container=i,this.array=[],this.absorbers=[],this.interactivityAbsorbers=[],i.getAbsorber=i=>void 0===i||(0,n.isNumber)(i)?this.array[i??0]:this.array.find((t=>t.name===i)),i.addAbsorber=async(i,t)=>this.addAbsorber(i,t)}async addAbsorber(i,t){const s=new p(this,this.container,i,t);return this.array.push(s),Promise.resolve(s)}draw(i){for(const t of this.array)t.draw(i)}handleClickMode(i){const t=this.absorbers,s=this.interactivityAbsorbers;if(i===r.absorber){const i=(0,n.itemFromSingleOrMultiple)(s)??(0,n.itemFromSingleOrMultiple)(t),o=this.container.interactivity.mouse.clickPosition;this.addAbsorber(i,o)}}async init(){this.absorbers=this.container.actualOptions.absorbers,this.interactivityAbsorbers=this.container.actualOptions.interactivity.modes.absorbers;const i=(0,n.executeOnSingleOrMultiple)(this.absorbers,(async i=>{await this.addAbsorber(i)}));i instanceof Array?await Promise.all(i):await i}particleUpdate(i){for(const t of this.array)if(t.attract(i),i.destroyed)break}removeAbsorber(i){const t=this.array.indexOf(i);t>=0&&this.array.splice(t,1)}resize(){for(const i of this.array)i.resize()}stop(){this.array=[]}}class y{constructor(){this.id="absorbers"}async getPlugin(i){return Promise.resolve(new g(i))}loadOptions(i,t){(this.needsPlugin(i)||this.needsPlugin(t))&&(t?.absorbers&&(i.absorbers=(0,n.executeOnSingleOrMultiple)(t.absorbers,(i=>{const t=new l;return t.load(i),t}))),i.interactivity.modes.absorbers=(0,n.executeOnSingleOrMultiple)(t?.interactivity?.modes?.absorbers,(i=>{const t=new l;return t.load(i),t})))}needsPlugin(i){if(!i)return!1;const t=i.absorbers;return(0,n.isArray)(t)?!!t.length:!!t||!(!i.interactivity?.events?.onClick?.mode||!(0,n.isInArray)(r.absorber,i.interactivity.events.onClick.mode))}}async function u(i,t=!0){await i.addPlugin(new y,t)}return e})()));
@@ -1 +1 @@
1
- /*! tsParticles Absorbers Plugin v3.4.0 by Matteo Bruni */
1
+ /*! tsParticles Absorbers Plugin v3.6.0-beta.0 by Matteo Bruni */
package/umd/index.js CHANGED
@@ -23,12 +23,11 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
23
23
  })(function (require, exports) {
24
24
  "use strict";
25
25
  Object.defineProperty(exports, "__esModule", { value: true });
26
- exports.loadAbsorbersPlugin = void 0;
26
+ exports.loadAbsorbersPlugin = loadAbsorbersPlugin;
27
27
  const AbsorbersPlugin_js_1 = require("./AbsorbersPlugin.js");
28
28
  async function loadAbsorbersPlugin(engine, refresh = true) {
29
29
  await engine.addPlugin(new AbsorbersPlugin_js_1.AbsorbersPlugin(), refresh);
30
30
  }
31
- exports.loadAbsorbersPlugin = loadAbsorbersPlugin;
32
31
  __exportStar(require("./AbsorberContainer.js"), exports);
33
32
  __exportStar(require("./Enums/AbsorberClickMode.js"), exports);
34
33
  });