@tsparticles/interaction-external-bounce 3.0.3 → 3.2.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/33.min.js +2 -0
- package/33.min.js.LICENSE.txt +1 -0
- package/409.min.js +2 -0
- package/409.min.js.LICENSE.txt +1 -0
- package/browser/Bouncer.js +6 -43
- package/browser/Utils.js +44 -0
- package/browser/index.js +4 -2
- package/cjs/Bouncer.js +28 -42
- package/cjs/Utils.js +49 -0
- package/cjs/index.js +16 -2
- package/dist_browser_Bouncer_js.js +30 -0
- package/dist_browser_Utils_js.js +30 -0
- package/esm/Bouncer.js +6 -43
- package/esm/Utils.js +44 -0
- package/esm/index.js +4 -2
- package/package.json +2 -2
- package/report.html +3 -3
- package/tsparticles.interaction.external.bounce.js +251 -136
- package/tsparticles.interaction.external.bounce.min.js +1 -1
- package/tsparticles.interaction.external.bounce.min.js.LICENSE.txt +1 -1
- package/types/Bouncer.d.ts +0 -3
- package/types/Types.d.ts +4 -4
- package/types/Utils.d.ts +4 -0
- package/umd/Bouncer.js +29 -42
- package/umd/Utils.js +59 -0
- package/umd/index.js +18 -3
package/33.min.js
ADDED
@@ -0,0 +1,2 @@
|
|
1
|
+
/*! For license information please see 33.min.js.LICENSE.txt */
|
2
|
+
(this.webpackChunk_tsparticles_interaction_external_bounce=this.webpackChunk_tsparticles_interaction_external_bounce||[]).push([[33],{33:(e,n,t)=>{t.d(n,{Bouncer:()=>s});var i=t(533),o=t(523);const a="bounce";class s extends i.ExternalInteractorBase{constructor(e){super(e)}clear(){}init(){const e=this.container,n=e.actualOptions.interactivity.modes.bounce;n&&(e.retina.bounceModeDistance=n.distance*e.retina.pixelRatio)}async interact(){const e=this.container,n=e.actualOptions.interactivity.events,o=e.interactivity.status===i.mouseMoveEvent,s=n.onHover.enable,c=n.onHover.mode,r=n.onDiv;if(o&&s&&(0,i.isInArray)(a,c)){const{mouseBounce:e}=await t.e(409).then(t.bind(t,409));e(this.container,(e=>this.isEnabled(e)))}else{const{divBounce:e}=await t.e(409).then(t.bind(t,409));e(this.container,r,a,(e=>this.isEnabled(e)))}}isEnabled(e){const n=this.container,t=n.actualOptions,o=n.interactivity.mouse,s=(e?.interactivity??t.interactivity).events,c=s.onDiv;return!!o.position&&s.onHover.enable&&(0,i.isInArray)(a,s.onHover.mode)||(0,i.isDivModeEnabled)(a,c)}loadModeOptions(e,...n){e.bounce||(e.bounce=new o.s);for(const t of n)e.bounce.load(t?.bounce)}reset(){}}}}]);
|
@@ -0,0 +1 @@
|
|
1
|
+
/*! tsParticles Bounce External Interaction v3.2.0 by Matteo Bruni */
|
package/409.min.js
ADDED
@@ -0,0 +1,2 @@
|
|
1
|
+
/*! For license information please see 409.min.js.LICENSE.txt */
|
2
|
+
(this.webpackChunk_tsparticles_interaction_external_bounce=this.webpackChunk_tsparticles_interaction_external_bounce||[]).push([[409],{409:(e,t,o)=>{o.d(t,{divBounce:()=>l,mouseBounce:()=>h});var c=o(533);const n=2,i=.5,s=Math.PI*i,r=2,a=10,f=0;function u(e,t,o,i,r){const a=e.particles.quadTree.query(i,r);for(const e of a)i instanceof c.Circle?(0,c.circleBounce)((0,c.circleBounceDataFromParticle)(e),{position:t,radius:o,mass:o**n*s,velocity:c.Vector.origin,factor:c.Vector.origin}):i instanceof c.Rectangle&&(0,c.rectBounce)(e,(0,c.calculateBounds)(t,o))}function l(e,t,o,n){(0,c.divModeExecute)(o,t,((t,o)=>function(e,t,o,n){const s=document.querySelectorAll(t);s.length&&s.forEach((t=>{const s=t,f=e.retina.pixelRatio,u={x:(s.offsetLeft+s.offsetWidth*i)*f,y:(s.offsetTop+s.offsetHeight*i)*f},l=s.offsetWidth*i*f,h=a*f,p="circle"===o.type?new c.Circle(u.x,u.y,l+h):new c.Rectangle(s.offsetLeft*f-h,s.offsetTop*f-h,s.offsetWidth*f+h*r,s.offsetHeight*f+h*r);n(u,l,p)}))}(e,t,o,((t,o,c)=>u(e,t,o,c,n)))))}function h(e,t){const o=e.retina.pixelRatio,n=a*o,i=e.interactivity.mouse.position,s=e.retina.bounceModeDistance;!s||s<f||!i||u(e,i,s,new c.Circle(i.x,i.y,s+n),t)}}}]);
|
@@ -0,0 +1 @@
|
|
1
|
+
/*! tsParticles Bounce External Interaction v3.2.0 by Matteo Bruni */
|
package/browser/Bouncer.js
CHANGED
@@ -1,48 +1,9 @@
|
|
1
|
-
import {
|
1
|
+
import { ExternalInteractorBase, isDivModeEnabled, isInArray, mouseMoveEvent, } from "@tsparticles/engine";
|
2
2
|
import { Bounce } from "./Options/Classes/Bounce.js";
|
3
3
|
const bounceMode = "bounce";
|
4
4
|
export class Bouncer extends ExternalInteractorBase {
|
5
5
|
constructor(container) {
|
6
6
|
super(container);
|
7
|
-
this._processBounce = (position, radius, area) => {
|
8
|
-
const query = this.container.particles.quadTree.query(area, (p) => this.isEnabled(p));
|
9
|
-
for (const particle of query) {
|
10
|
-
if (area instanceof Circle) {
|
11
|
-
circleBounce(circleBounceDataFromParticle(particle), {
|
12
|
-
position,
|
13
|
-
radius,
|
14
|
-
mass: (radius ** 2 * Math.PI) / 2,
|
15
|
-
velocity: Vector.origin,
|
16
|
-
factor: Vector.origin,
|
17
|
-
});
|
18
|
-
}
|
19
|
-
else if (area instanceof Rectangle) {
|
20
|
-
rectBounce(particle, calculateBounds(position, radius));
|
21
|
-
}
|
22
|
-
}
|
23
|
-
};
|
24
|
-
this._processMouseBounce = () => {
|
25
|
-
const container = this.container, pxRatio = container.retina.pixelRatio, tolerance = 10 * pxRatio, mousePos = container.interactivity.mouse.position, radius = container.retina.bounceModeDistance;
|
26
|
-
if (!radius || radius < 0 || !mousePos) {
|
27
|
-
return;
|
28
|
-
}
|
29
|
-
this._processBounce(mousePos, radius, new Circle(mousePos.x, mousePos.y, radius + tolerance));
|
30
|
-
};
|
31
|
-
this._singleSelectorBounce = (selector, div) => {
|
32
|
-
const container = this.container, query = document.querySelectorAll(selector);
|
33
|
-
if (!query.length) {
|
34
|
-
return;
|
35
|
-
}
|
36
|
-
query.forEach((item) => {
|
37
|
-
const elem = item, pxRatio = container.retina.pixelRatio, pos = {
|
38
|
-
x: (elem.offsetLeft + elem.offsetWidth / 2) * pxRatio,
|
39
|
-
y: (elem.offsetTop + elem.offsetHeight / 2) * pxRatio,
|
40
|
-
}, radius = (elem.offsetWidth / 2) * pxRatio, tolerance = 10 * pxRatio, area = div.type === "circle"
|
41
|
-
? new Circle(pos.x, pos.y, radius + tolerance)
|
42
|
-
: new Rectangle(elem.offsetLeft * pxRatio - tolerance, elem.offsetTop * pxRatio - tolerance, elem.offsetWidth * pxRatio + tolerance * 2, elem.offsetHeight * pxRatio + tolerance * 2);
|
43
|
-
this._processBounce(pos, radius, area);
|
44
|
-
});
|
45
|
-
};
|
46
7
|
}
|
47
8
|
clear() {
|
48
9
|
}
|
@@ -56,15 +17,17 @@ export class Bouncer extends ExternalInteractorBase {
|
|
56
17
|
async interact() {
|
57
18
|
const container = this.container, options = container.actualOptions, events = options.interactivity.events, mouseMoveStatus = container.interactivity.status === mouseMoveEvent, hoverEnabled = events.onHover.enable, hoverMode = events.onHover.mode, divs = events.onDiv;
|
58
19
|
if (mouseMoveStatus && hoverEnabled && isInArray(bounceMode, hoverMode)) {
|
59
|
-
|
20
|
+
const { mouseBounce } = await import("./Utils.js");
|
21
|
+
mouseBounce(this.container, (p) => this.isEnabled(p));
|
60
22
|
}
|
61
23
|
else {
|
62
|
-
|
24
|
+
const { divBounce } = await import("./Utils.js");
|
25
|
+
divBounce(this.container, divs, bounceMode, (p) => this.isEnabled(p));
|
63
26
|
}
|
64
27
|
}
|
65
28
|
isEnabled(particle) {
|
66
29
|
const container = this.container, options = container.actualOptions, mouse = container.interactivity.mouse, events = (particle?.interactivity ?? options.interactivity).events, divs = events.onDiv;
|
67
|
-
return ((mouse.position && events.onHover.enable && isInArray(bounceMode, events.onHover.mode)) ||
|
30
|
+
return ((!!mouse.position && events.onHover.enable && isInArray(bounceMode, events.onHover.mode)) ||
|
68
31
|
isDivModeEnabled(bounceMode, divs));
|
69
32
|
}
|
70
33
|
loadModeOptions(options, ...sources) {
|
package/browser/Utils.js
ADDED
@@ -0,0 +1,44 @@
|
|
1
|
+
import { Circle, Rectangle, Vector, calculateBounds, circleBounce, circleBounceDataFromParticle, divModeExecute, rectBounce, } from "@tsparticles/engine";
|
2
|
+
const squareExp = 2, half = 0.5, halfPI = Math.PI * half, double = 2, toleranceFactor = 10, minRadius = 0;
|
3
|
+
function processBounce(container, position, radius, area, enabledCb) {
|
4
|
+
const query = container.particles.quadTree.query(area, enabledCb);
|
5
|
+
for (const particle of query) {
|
6
|
+
if (area instanceof Circle) {
|
7
|
+
circleBounce(circleBounceDataFromParticle(particle), {
|
8
|
+
position,
|
9
|
+
radius,
|
10
|
+
mass: radius ** squareExp * halfPI,
|
11
|
+
velocity: Vector.origin,
|
12
|
+
factor: Vector.origin,
|
13
|
+
});
|
14
|
+
}
|
15
|
+
else if (area instanceof Rectangle) {
|
16
|
+
rectBounce(particle, calculateBounds(position, radius));
|
17
|
+
}
|
18
|
+
}
|
19
|
+
}
|
20
|
+
function singleSelectorBounce(container, selector, div, bounceCb) {
|
21
|
+
const query = document.querySelectorAll(selector);
|
22
|
+
if (!query.length) {
|
23
|
+
return;
|
24
|
+
}
|
25
|
+
query.forEach((item) => {
|
26
|
+
const elem = item, pxRatio = container.retina.pixelRatio, pos = {
|
27
|
+
x: (elem.offsetLeft + elem.offsetWidth * half) * pxRatio,
|
28
|
+
y: (elem.offsetTop + elem.offsetHeight * half) * pxRatio,
|
29
|
+
}, radius = elem.offsetWidth * half * pxRatio, tolerance = toleranceFactor * pxRatio, area = div.type === "circle"
|
30
|
+
? new Circle(pos.x, pos.y, radius + tolerance)
|
31
|
+
: new Rectangle(elem.offsetLeft * pxRatio - tolerance, elem.offsetTop * pxRatio - tolerance, elem.offsetWidth * pxRatio + tolerance * double, elem.offsetHeight * pxRatio + tolerance * double);
|
32
|
+
bounceCb(pos, radius, area);
|
33
|
+
});
|
34
|
+
}
|
35
|
+
export function divBounce(container, divs, bounceMode, enabledCb) {
|
36
|
+
divModeExecute(bounceMode, divs, (selector, div) => singleSelectorBounce(container, selector, div, (pos, radius, area) => processBounce(container, pos, radius, area, enabledCb)));
|
37
|
+
}
|
38
|
+
export function mouseBounce(container, enabledCb) {
|
39
|
+
const pxRatio = container.retina.pixelRatio, tolerance = toleranceFactor * pxRatio, mousePos = container.interactivity.mouse.position, radius = container.retina.bounceModeDistance;
|
40
|
+
if (!radius || radius < minRadius || !mousePos) {
|
41
|
+
return;
|
42
|
+
}
|
43
|
+
processBounce(container, mousePos, radius, new Circle(mousePos.x, mousePos.y, radius + tolerance), enabledCb);
|
44
|
+
}
|
package/browser/index.js
CHANGED
@@ -1,6 +1,8 @@
|
|
1
|
-
import { Bouncer } from "./Bouncer.js";
|
2
1
|
export async function loadExternalBounceInteraction(engine, refresh = true) {
|
3
|
-
await engine.addInteractor("externalBounce", (container) =>
|
2
|
+
await engine.addInteractor("externalBounce", async (container) => {
|
3
|
+
const { Bouncer } = await import("./Bouncer.js");
|
4
|
+
return new Bouncer(container);
|
5
|
+
}, refresh);
|
4
6
|
}
|
5
7
|
export * from "./Options/Classes/Bounce.js";
|
6
8
|
export * from "./Options/Interfaces/IBounce.js";
|
package/cjs/Bouncer.js
CHANGED
@@ -1,4 +1,27 @@
|
|
1
1
|
"use strict";
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
3
|
+
if (k2 === undefined) k2 = k;
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
7
|
+
}
|
8
|
+
Object.defineProperty(o, k2, desc);
|
9
|
+
}) : (function(o, m, k, k2) {
|
10
|
+
if (k2 === undefined) k2 = k;
|
11
|
+
o[k2] = m[k];
|
12
|
+
}));
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
15
|
+
}) : function(o, v) {
|
16
|
+
o["default"] = v;
|
17
|
+
});
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
19
|
+
if (mod && mod.__esModule) return mod;
|
20
|
+
var result = {};
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
22
|
+
__setModuleDefault(result, mod);
|
23
|
+
return result;
|
24
|
+
};
|
2
25
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
26
|
exports.Bouncer = void 0;
|
4
27
|
const engine_1 = require("@tsparticles/engine");
|
@@ -7,45 +30,6 @@ const bounceMode = "bounce";
|
|
7
30
|
class Bouncer extends engine_1.ExternalInteractorBase {
|
8
31
|
constructor(container) {
|
9
32
|
super(container);
|
10
|
-
this._processBounce = (position, radius, area) => {
|
11
|
-
const query = this.container.particles.quadTree.query(area, (p) => this.isEnabled(p));
|
12
|
-
for (const particle of query) {
|
13
|
-
if (area instanceof engine_1.Circle) {
|
14
|
-
(0, engine_1.circleBounce)((0, engine_1.circleBounceDataFromParticle)(particle), {
|
15
|
-
position,
|
16
|
-
radius,
|
17
|
-
mass: (radius ** 2 * Math.PI) / 2,
|
18
|
-
velocity: engine_1.Vector.origin,
|
19
|
-
factor: engine_1.Vector.origin,
|
20
|
-
});
|
21
|
-
}
|
22
|
-
else if (area instanceof engine_1.Rectangle) {
|
23
|
-
(0, engine_1.rectBounce)(particle, (0, engine_1.calculateBounds)(position, radius));
|
24
|
-
}
|
25
|
-
}
|
26
|
-
};
|
27
|
-
this._processMouseBounce = () => {
|
28
|
-
const container = this.container, pxRatio = container.retina.pixelRatio, tolerance = 10 * pxRatio, mousePos = container.interactivity.mouse.position, radius = container.retina.bounceModeDistance;
|
29
|
-
if (!radius || radius < 0 || !mousePos) {
|
30
|
-
return;
|
31
|
-
}
|
32
|
-
this._processBounce(mousePos, radius, new engine_1.Circle(mousePos.x, mousePos.y, radius + tolerance));
|
33
|
-
};
|
34
|
-
this._singleSelectorBounce = (selector, div) => {
|
35
|
-
const container = this.container, query = document.querySelectorAll(selector);
|
36
|
-
if (!query.length) {
|
37
|
-
return;
|
38
|
-
}
|
39
|
-
query.forEach((item) => {
|
40
|
-
const elem = item, pxRatio = container.retina.pixelRatio, pos = {
|
41
|
-
x: (elem.offsetLeft + elem.offsetWidth / 2) * pxRatio,
|
42
|
-
y: (elem.offsetTop + elem.offsetHeight / 2) * pxRatio,
|
43
|
-
}, radius = (elem.offsetWidth / 2) * pxRatio, tolerance = 10 * pxRatio, area = div.type === "circle"
|
44
|
-
? new engine_1.Circle(pos.x, pos.y, radius + tolerance)
|
45
|
-
: new engine_1.Rectangle(elem.offsetLeft * pxRatio - tolerance, elem.offsetTop * pxRatio - tolerance, elem.offsetWidth * pxRatio + tolerance * 2, elem.offsetHeight * pxRatio + tolerance * 2);
|
46
|
-
this._processBounce(pos, radius, area);
|
47
|
-
});
|
48
|
-
};
|
49
33
|
}
|
50
34
|
clear() {
|
51
35
|
}
|
@@ -59,15 +43,17 @@ class Bouncer extends engine_1.ExternalInteractorBase {
|
|
59
43
|
async interact() {
|
60
44
|
const container = this.container, options = container.actualOptions, events = options.interactivity.events, mouseMoveStatus = container.interactivity.status === engine_1.mouseMoveEvent, hoverEnabled = events.onHover.enable, hoverMode = events.onHover.mode, divs = events.onDiv;
|
61
45
|
if (mouseMoveStatus && hoverEnabled && (0, engine_1.isInArray)(bounceMode, hoverMode)) {
|
62
|
-
|
46
|
+
const { mouseBounce } = await Promise.resolve().then(() => __importStar(require("./Utils.js")));
|
47
|
+
mouseBounce(this.container, (p) => this.isEnabled(p));
|
63
48
|
}
|
64
49
|
else {
|
65
|
-
|
50
|
+
const { divBounce } = await Promise.resolve().then(() => __importStar(require("./Utils.js")));
|
51
|
+
divBounce(this.container, divs, bounceMode, (p) => this.isEnabled(p));
|
66
52
|
}
|
67
53
|
}
|
68
54
|
isEnabled(particle) {
|
69
55
|
const container = this.container, options = container.actualOptions, mouse = container.interactivity.mouse, events = (particle?.interactivity ?? options.interactivity).events, divs = events.onDiv;
|
70
|
-
return ((mouse.position && events.onHover.enable && (0, engine_1.isInArray)(bounceMode, events.onHover.mode)) ||
|
56
|
+
return ((!!mouse.position && events.onHover.enable && (0, engine_1.isInArray)(bounceMode, events.onHover.mode)) ||
|
71
57
|
(0, engine_1.isDivModeEnabled)(bounceMode, divs));
|
72
58
|
}
|
73
59
|
loadModeOptions(options, ...sources) {
|
package/cjs/Utils.js
ADDED
@@ -0,0 +1,49 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.mouseBounce = exports.divBounce = void 0;
|
4
|
+
const engine_1 = require("@tsparticles/engine");
|
5
|
+
const squareExp = 2, half = 0.5, halfPI = Math.PI * half, double = 2, toleranceFactor = 10, minRadius = 0;
|
6
|
+
function processBounce(container, position, radius, area, enabledCb) {
|
7
|
+
const query = container.particles.quadTree.query(area, enabledCb);
|
8
|
+
for (const particle of query) {
|
9
|
+
if (area instanceof engine_1.Circle) {
|
10
|
+
(0, engine_1.circleBounce)((0, engine_1.circleBounceDataFromParticle)(particle), {
|
11
|
+
position,
|
12
|
+
radius,
|
13
|
+
mass: radius ** squareExp * halfPI,
|
14
|
+
velocity: engine_1.Vector.origin,
|
15
|
+
factor: engine_1.Vector.origin,
|
16
|
+
});
|
17
|
+
}
|
18
|
+
else if (area instanceof engine_1.Rectangle) {
|
19
|
+
(0, engine_1.rectBounce)(particle, (0, engine_1.calculateBounds)(position, radius));
|
20
|
+
}
|
21
|
+
}
|
22
|
+
}
|
23
|
+
function singleSelectorBounce(container, selector, div, bounceCb) {
|
24
|
+
const query = document.querySelectorAll(selector);
|
25
|
+
if (!query.length) {
|
26
|
+
return;
|
27
|
+
}
|
28
|
+
query.forEach((item) => {
|
29
|
+
const elem = item, pxRatio = container.retina.pixelRatio, pos = {
|
30
|
+
x: (elem.offsetLeft + elem.offsetWidth * half) * pxRatio,
|
31
|
+
y: (elem.offsetTop + elem.offsetHeight * half) * pxRatio,
|
32
|
+
}, radius = elem.offsetWidth * half * pxRatio, tolerance = toleranceFactor * pxRatio, area = div.type === "circle"
|
33
|
+
? new engine_1.Circle(pos.x, pos.y, radius + tolerance)
|
34
|
+
: new engine_1.Rectangle(elem.offsetLeft * pxRatio - tolerance, elem.offsetTop * pxRatio - tolerance, elem.offsetWidth * pxRatio + tolerance * double, elem.offsetHeight * pxRatio + tolerance * double);
|
35
|
+
bounceCb(pos, radius, area);
|
36
|
+
});
|
37
|
+
}
|
38
|
+
function divBounce(container, divs, bounceMode, enabledCb) {
|
39
|
+
(0, engine_1.divModeExecute)(bounceMode, divs, (selector, div) => singleSelectorBounce(container, selector, div, (pos, radius, area) => processBounce(container, pos, radius, area, enabledCb)));
|
40
|
+
}
|
41
|
+
exports.divBounce = divBounce;
|
42
|
+
function mouseBounce(container, enabledCb) {
|
43
|
+
const pxRatio = container.retina.pixelRatio, tolerance = toleranceFactor * pxRatio, mousePos = container.interactivity.mouse.position, radius = container.retina.bounceModeDistance;
|
44
|
+
if (!radius || radius < minRadius || !mousePos) {
|
45
|
+
return;
|
46
|
+
}
|
47
|
+
processBounce(container, mousePos, radius, new engine_1.Circle(mousePos.x, mousePos.y, radius + tolerance), enabledCb);
|
48
|
+
}
|
49
|
+
exports.mouseBounce = mouseBounce;
|
package/cjs/index.js
CHANGED
@@ -10,14 +10,28 @@ var __createBinding = (this && this.__createBinding) || (Object.create ? (functi
|
|
10
10
|
if (k2 === undefined) k2 = k;
|
11
11
|
o[k2] = m[k];
|
12
12
|
}));
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
15
|
+
}) : function(o, v) {
|
16
|
+
o["default"] = v;
|
17
|
+
});
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
19
|
+
if (mod && mod.__esModule) return mod;
|
20
|
+
var result = {};
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
22
|
+
__setModuleDefault(result, mod);
|
23
|
+
return result;
|
24
|
+
};
|
13
25
|
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
14
26
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
15
27
|
};
|
16
28
|
Object.defineProperty(exports, "__esModule", { value: true });
|
17
29
|
exports.loadExternalBounceInteraction = void 0;
|
18
|
-
const Bouncer_js_1 = require("./Bouncer.js");
|
19
30
|
async function loadExternalBounceInteraction(engine, refresh = true) {
|
20
|
-
await engine.addInteractor("externalBounce", (container) =>
|
31
|
+
await engine.addInteractor("externalBounce", async (container) => {
|
32
|
+
const { Bouncer } = await Promise.resolve().then(() => __importStar(require("./Bouncer.js")));
|
33
|
+
return new Bouncer(container);
|
34
|
+
}, refresh);
|
21
35
|
}
|
22
36
|
exports.loadExternalBounceInteraction = loadExternalBounceInteraction;
|
23
37
|
__exportStar(require("./Options/Classes/Bounce.js"), exports);
|
@@ -0,0 +1,30 @@
|
|
1
|
+
/*!
|
2
|
+
* Author : Matteo Bruni
|
3
|
+
* MIT license: https://opensource.org/licenses/MIT
|
4
|
+
* Demo / Generator : https://particles.js.org/
|
5
|
+
* GitHub : https://www.github.com/matteobruni/tsparticles
|
6
|
+
* How to use? : Check the GitHub README
|
7
|
+
* v3.2.0
|
8
|
+
*/
|
9
|
+
"use strict";
|
10
|
+
/*
|
11
|
+
* ATTENTION: The "eval" devtool has been used (maybe by default in mode: "development").
|
12
|
+
* This devtool is neither made for production nor for readable output files.
|
13
|
+
* It uses "eval()" calls to create a separate source file in the browser devtools.
|
14
|
+
* If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
|
15
|
+
* or disable the default devtool with "devtool: false".
|
16
|
+
* If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
|
17
|
+
*/
|
18
|
+
(this["webpackChunk_tsparticles_interaction_external_bounce"] = this["webpackChunk_tsparticles_interaction_external_bounce"] || []).push([["dist_browser_Bouncer_js"],{
|
19
|
+
|
20
|
+
/***/ "./dist/browser/Bouncer.js":
|
21
|
+
/*!*********************************!*\
|
22
|
+
!*** ./dist/browser/Bouncer.js ***!
|
23
|
+
\*********************************/
|
24
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
25
|
+
|
26
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Bouncer: () => (/* binding */ Bouncer)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/engine */ \"@tsparticles/engine\");\n/* harmony import */ var _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _Options_Classes_Bounce_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Options/Classes/Bounce.js */ \"./dist/browser/Options/Classes/Bounce.js\");\n\n\nconst bounceMode = \"bounce\";\nclass Bouncer extends _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.ExternalInteractorBase {\n constructor(container) {\n super(container);\n }\n clear() {}\n init() {\n const container = this.container,\n bounce = container.actualOptions.interactivity.modes.bounce;\n if (!bounce) {\n return;\n }\n container.retina.bounceModeDistance = bounce.distance * container.retina.pixelRatio;\n }\n async interact() {\n const container = this.container,\n options = container.actualOptions,\n events = options.interactivity.events,\n mouseMoveStatus = container.interactivity.status === _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.mouseMoveEvent,\n hoverEnabled = events.onHover.enable,\n hoverMode = events.onHover.mode,\n divs = events.onDiv;\n if (mouseMoveStatus && hoverEnabled && (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.isInArray)(bounceMode, hoverMode)) {\n const {\n mouseBounce\n } = await __webpack_require__.e(/*! import() */ \"dist_browser_Utils_js\").then(__webpack_require__.bind(__webpack_require__, /*! ./Utils.js */ \"./dist/browser/Utils.js\"));\n mouseBounce(this.container, p => this.isEnabled(p));\n } else {\n const {\n divBounce\n } = await __webpack_require__.e(/*! import() */ \"dist_browser_Utils_js\").then(__webpack_require__.bind(__webpack_require__, /*! ./Utils.js */ \"./dist/browser/Utils.js\"));\n divBounce(this.container, divs, bounceMode, p => this.isEnabled(p));\n }\n }\n isEnabled(particle) {\n const container = this.container,\n options = container.actualOptions,\n mouse = container.interactivity.mouse,\n events = (particle?.interactivity ?? options.interactivity).events,\n divs = events.onDiv;\n return !!mouse.position && events.onHover.enable && (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.isInArray)(bounceMode, events.onHover.mode) || (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.isDivModeEnabled)(bounceMode, divs);\n }\n loadModeOptions(options, ...sources) {\n if (!options.bounce) {\n options.bounce = new _Options_Classes_Bounce_js__WEBPACK_IMPORTED_MODULE_1__.Bounce();\n }\n for (const source of sources) {\n options.bounce.load(source?.bounce);\n }\n }\n reset() {}\n}\n\n//# sourceURL=webpack://@tsparticles/interaction-external-bounce/./dist/browser/Bouncer.js?");
|
27
|
+
|
28
|
+
/***/ })
|
29
|
+
|
30
|
+
}]);
|
@@ -0,0 +1,30 @@
|
|
1
|
+
/*!
|
2
|
+
* Author : Matteo Bruni
|
3
|
+
* MIT license: https://opensource.org/licenses/MIT
|
4
|
+
* Demo / Generator : https://particles.js.org/
|
5
|
+
* GitHub : https://www.github.com/matteobruni/tsparticles
|
6
|
+
* How to use? : Check the GitHub README
|
7
|
+
* v3.2.0
|
8
|
+
*/
|
9
|
+
"use strict";
|
10
|
+
/*
|
11
|
+
* ATTENTION: The "eval" devtool has been used (maybe by default in mode: "development").
|
12
|
+
* This devtool is neither made for production nor for readable output files.
|
13
|
+
* It uses "eval()" calls to create a separate source file in the browser devtools.
|
14
|
+
* If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
|
15
|
+
* or disable the default devtool with "devtool: false".
|
16
|
+
* If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
|
17
|
+
*/
|
18
|
+
(this["webpackChunk_tsparticles_interaction_external_bounce"] = this["webpackChunk_tsparticles_interaction_external_bounce"] || []).push([["dist_browser_Utils_js"],{
|
19
|
+
|
20
|
+
/***/ "./dist/browser/Utils.js":
|
21
|
+
/*!*******************************!*\
|
22
|
+
!*** ./dist/browser/Utils.js ***!
|
23
|
+
\*******************************/
|
24
|
+
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
25
|
+
|
26
|
+
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ divBounce: () => (/* binding */ divBounce),\n/* harmony export */ mouseBounce: () => (/* binding */ mouseBounce)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/engine */ \"@tsparticles/engine\");\n/* harmony import */ var _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__);\n\nconst squareExp = 2,\n half = 0.5,\n halfPI = Math.PI * half,\n double = 2,\n toleranceFactor = 10,\n minRadius = 0;\nfunction processBounce(container, position, radius, area, enabledCb) {\n const query = container.particles.quadTree.query(area, enabledCb);\n for (const particle of query) {\n if (area instanceof _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.Circle) {\n (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.circleBounce)((0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.circleBounceDataFromParticle)(particle), {\n position,\n radius,\n mass: radius ** squareExp * halfPI,\n velocity: _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.Vector.origin,\n factor: _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.Vector.origin\n });\n } else if (area instanceof _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.Rectangle) {\n (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.rectBounce)(particle, (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.calculateBounds)(position, radius));\n }\n }\n}\nfunction singleSelectorBounce(container, selector, div, bounceCb) {\n const query = document.querySelectorAll(selector);\n if (!query.length) {\n return;\n }\n query.forEach(item => {\n const elem = item,\n pxRatio = container.retina.pixelRatio,\n pos = {\n x: (elem.offsetLeft + elem.offsetWidth * half) * pxRatio,\n y: (elem.offsetTop + elem.offsetHeight * half) * pxRatio\n },\n radius = elem.offsetWidth * half * pxRatio,\n tolerance = toleranceFactor * pxRatio,\n area = div.type === \"circle\" ? new _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.Circle(pos.x, pos.y, radius + tolerance) : new _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.Rectangle(elem.offsetLeft * pxRatio - tolerance, elem.offsetTop * pxRatio - tolerance, elem.offsetWidth * pxRatio + tolerance * double, elem.offsetHeight * pxRatio + tolerance * double);\n bounceCb(pos, radius, area);\n });\n}\nfunction divBounce(container, divs, bounceMode, enabledCb) {\n (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.divModeExecute)(bounceMode, divs, (selector, div) => singleSelectorBounce(container, selector, div, (pos, radius, area) => processBounce(container, pos, radius, area, enabledCb)));\n}\nfunction mouseBounce(container, enabledCb) {\n const pxRatio = container.retina.pixelRatio,\n tolerance = toleranceFactor * pxRatio,\n mousePos = container.interactivity.mouse.position,\n radius = container.retina.bounceModeDistance;\n if (!radius || radius < minRadius || !mousePos) {\n return;\n }\n processBounce(container, mousePos, radius, new _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.Circle(mousePos.x, mousePos.y, radius + tolerance), enabledCb);\n}\n\n//# sourceURL=webpack://@tsparticles/interaction-external-bounce/./dist/browser/Utils.js?");
|
27
|
+
|
28
|
+
/***/ })
|
29
|
+
|
30
|
+
}]);
|
package/esm/Bouncer.js
CHANGED
@@ -1,48 +1,9 @@
|
|
1
|
-
import {
|
1
|
+
import { ExternalInteractorBase, isDivModeEnabled, isInArray, mouseMoveEvent, } from "@tsparticles/engine";
|
2
2
|
import { Bounce } from "./Options/Classes/Bounce.js";
|
3
3
|
const bounceMode = "bounce";
|
4
4
|
export class Bouncer extends ExternalInteractorBase {
|
5
5
|
constructor(container) {
|
6
6
|
super(container);
|
7
|
-
this._processBounce = (position, radius, area) => {
|
8
|
-
const query = this.container.particles.quadTree.query(area, (p) => this.isEnabled(p));
|
9
|
-
for (const particle of query) {
|
10
|
-
if (area instanceof Circle) {
|
11
|
-
circleBounce(circleBounceDataFromParticle(particle), {
|
12
|
-
position,
|
13
|
-
radius,
|
14
|
-
mass: (radius ** 2 * Math.PI) / 2,
|
15
|
-
velocity: Vector.origin,
|
16
|
-
factor: Vector.origin,
|
17
|
-
});
|
18
|
-
}
|
19
|
-
else if (area instanceof Rectangle) {
|
20
|
-
rectBounce(particle, calculateBounds(position, radius));
|
21
|
-
}
|
22
|
-
}
|
23
|
-
};
|
24
|
-
this._processMouseBounce = () => {
|
25
|
-
const container = this.container, pxRatio = container.retina.pixelRatio, tolerance = 10 * pxRatio, mousePos = container.interactivity.mouse.position, radius = container.retina.bounceModeDistance;
|
26
|
-
if (!radius || radius < 0 || !mousePos) {
|
27
|
-
return;
|
28
|
-
}
|
29
|
-
this._processBounce(mousePos, radius, new Circle(mousePos.x, mousePos.y, radius + tolerance));
|
30
|
-
};
|
31
|
-
this._singleSelectorBounce = (selector, div) => {
|
32
|
-
const container = this.container, query = document.querySelectorAll(selector);
|
33
|
-
if (!query.length) {
|
34
|
-
return;
|
35
|
-
}
|
36
|
-
query.forEach((item) => {
|
37
|
-
const elem = item, pxRatio = container.retina.pixelRatio, pos = {
|
38
|
-
x: (elem.offsetLeft + elem.offsetWidth / 2) * pxRatio,
|
39
|
-
y: (elem.offsetTop + elem.offsetHeight / 2) * pxRatio,
|
40
|
-
}, radius = (elem.offsetWidth / 2) * pxRatio, tolerance = 10 * pxRatio, area = div.type === "circle"
|
41
|
-
? new Circle(pos.x, pos.y, radius + tolerance)
|
42
|
-
: new Rectangle(elem.offsetLeft * pxRatio - tolerance, elem.offsetTop * pxRatio - tolerance, elem.offsetWidth * pxRatio + tolerance * 2, elem.offsetHeight * pxRatio + tolerance * 2);
|
43
|
-
this._processBounce(pos, radius, area);
|
44
|
-
});
|
45
|
-
};
|
46
7
|
}
|
47
8
|
clear() {
|
48
9
|
}
|
@@ -56,15 +17,17 @@ export class Bouncer extends ExternalInteractorBase {
|
|
56
17
|
async interact() {
|
57
18
|
const container = this.container, options = container.actualOptions, events = options.interactivity.events, mouseMoveStatus = container.interactivity.status === mouseMoveEvent, hoverEnabled = events.onHover.enable, hoverMode = events.onHover.mode, divs = events.onDiv;
|
58
19
|
if (mouseMoveStatus && hoverEnabled && isInArray(bounceMode, hoverMode)) {
|
59
|
-
|
20
|
+
const { mouseBounce } = await import("./Utils.js");
|
21
|
+
mouseBounce(this.container, (p) => this.isEnabled(p));
|
60
22
|
}
|
61
23
|
else {
|
62
|
-
|
24
|
+
const { divBounce } = await import("./Utils.js");
|
25
|
+
divBounce(this.container, divs, bounceMode, (p) => this.isEnabled(p));
|
63
26
|
}
|
64
27
|
}
|
65
28
|
isEnabled(particle) {
|
66
29
|
const container = this.container, options = container.actualOptions, mouse = container.interactivity.mouse, events = (particle?.interactivity ?? options.interactivity).events, divs = events.onDiv;
|
67
|
-
return ((mouse.position && events.onHover.enable && isInArray(bounceMode, events.onHover.mode)) ||
|
30
|
+
return ((!!mouse.position && events.onHover.enable && isInArray(bounceMode, events.onHover.mode)) ||
|
68
31
|
isDivModeEnabled(bounceMode, divs));
|
69
32
|
}
|
70
33
|
loadModeOptions(options, ...sources) {
|
package/esm/Utils.js
ADDED
@@ -0,0 +1,44 @@
|
|
1
|
+
import { Circle, Rectangle, Vector, calculateBounds, circleBounce, circleBounceDataFromParticle, divModeExecute, rectBounce, } from "@tsparticles/engine";
|
2
|
+
const squareExp = 2, half = 0.5, halfPI = Math.PI * half, double = 2, toleranceFactor = 10, minRadius = 0;
|
3
|
+
function processBounce(container, position, radius, area, enabledCb) {
|
4
|
+
const query = container.particles.quadTree.query(area, enabledCb);
|
5
|
+
for (const particle of query) {
|
6
|
+
if (area instanceof Circle) {
|
7
|
+
circleBounce(circleBounceDataFromParticle(particle), {
|
8
|
+
position,
|
9
|
+
radius,
|
10
|
+
mass: radius ** squareExp * halfPI,
|
11
|
+
velocity: Vector.origin,
|
12
|
+
factor: Vector.origin,
|
13
|
+
});
|
14
|
+
}
|
15
|
+
else if (area instanceof Rectangle) {
|
16
|
+
rectBounce(particle, calculateBounds(position, radius));
|
17
|
+
}
|
18
|
+
}
|
19
|
+
}
|
20
|
+
function singleSelectorBounce(container, selector, div, bounceCb) {
|
21
|
+
const query = document.querySelectorAll(selector);
|
22
|
+
if (!query.length) {
|
23
|
+
return;
|
24
|
+
}
|
25
|
+
query.forEach((item) => {
|
26
|
+
const elem = item, pxRatio = container.retina.pixelRatio, pos = {
|
27
|
+
x: (elem.offsetLeft + elem.offsetWidth * half) * pxRatio,
|
28
|
+
y: (elem.offsetTop + elem.offsetHeight * half) * pxRatio,
|
29
|
+
}, radius = elem.offsetWidth * half * pxRatio, tolerance = toleranceFactor * pxRatio, area = div.type === "circle"
|
30
|
+
? new Circle(pos.x, pos.y, radius + tolerance)
|
31
|
+
: new Rectangle(elem.offsetLeft * pxRatio - tolerance, elem.offsetTop * pxRatio - tolerance, elem.offsetWidth * pxRatio + tolerance * double, elem.offsetHeight * pxRatio + tolerance * double);
|
32
|
+
bounceCb(pos, radius, area);
|
33
|
+
});
|
34
|
+
}
|
35
|
+
export function divBounce(container, divs, bounceMode, enabledCb) {
|
36
|
+
divModeExecute(bounceMode, divs, (selector, div) => singleSelectorBounce(container, selector, div, (pos, radius, area) => processBounce(container, pos, radius, area, enabledCb)));
|
37
|
+
}
|
38
|
+
export function mouseBounce(container, enabledCb) {
|
39
|
+
const pxRatio = container.retina.pixelRatio, tolerance = toleranceFactor * pxRatio, mousePos = container.interactivity.mouse.position, radius = container.retina.bounceModeDistance;
|
40
|
+
if (!radius || radius < minRadius || !mousePos) {
|
41
|
+
return;
|
42
|
+
}
|
43
|
+
processBounce(container, mousePos, radius, new Circle(mousePos.x, mousePos.y, radius + tolerance), enabledCb);
|
44
|
+
}
|
package/esm/index.js
CHANGED
@@ -1,6 +1,8 @@
|
|
1
|
-
import { Bouncer } from "./Bouncer.js";
|
2
1
|
export async function loadExternalBounceInteraction(engine, refresh = true) {
|
3
|
-
await engine.addInteractor("externalBounce", (container) =>
|
2
|
+
await engine.addInteractor("externalBounce", async (container) => {
|
3
|
+
const { Bouncer } = await import("./Bouncer.js");
|
4
|
+
return new Bouncer(container);
|
5
|
+
}, refresh);
|
4
6
|
}
|
5
7
|
export * from "./Options/Classes/Bounce.js";
|
6
8
|
export * from "./Options/Interfaces/IBounce.js";
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@tsparticles/interaction-external-bounce",
|
3
|
-
"version": "3.0
|
3
|
+
"version": "3.2.0",
|
4
4
|
"description": "tsParticles bounce external interaction",
|
5
5
|
"homepage": "https://particles.js.org",
|
6
6
|
"repository": {
|
@@ -87,7 +87,7 @@
|
|
87
87
|
"./package.json": "./package.json"
|
88
88
|
},
|
89
89
|
"dependencies": {
|
90
|
-
"@tsparticles/engine": "^3.0
|
90
|
+
"@tsparticles/engine": "^3.2.0"
|
91
91
|
},
|
92
92
|
"publishConfig": {
|
93
93
|
"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/interaction-external-bounce [
|
6
|
+
<title>@tsparticles/interaction-external-bounce [31 Jan 2024 at 02:03]</title>
|
7
7
|
<link rel="shortcut icon" href="" type="image/x-icon" />
|
8
8
|
|
9
9
|
<script>
|
@@ -31,8 +31,8 @@
|
|
31
31
|
<body>
|
32
32
|
<div id="app"></div>
|
33
33
|
<script>
|
34
|
-
window.chartData = [
|
35
|
-
window.entrypoints = ["tsparticles.interaction.external.bounce
|
34
|
+
window.chartData = [];
|
35
|
+
window.entrypoints = ["tsparticles.interaction.external.bounce.min"];
|
36
36
|
window.defaultSizes = "parsed";
|
37
37
|
</script>
|
38
38
|
</body>
|