@tsparticles/interaction-external-grab 3.0.3 → 3.1.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/browser/Grabber.js +4 -3
- package/browser/Utils.js +2 -1
- package/cjs/Grabber.js +4 -3
- package/cjs/Utils.js +2 -1
- package/esm/Grabber.js +4 -3
- package/esm/Utils.js +2 -1
- package/package.json +2 -2
- package/report.html +2 -2
- package/tsparticles.interaction.external.grab.js +9 -5
- package/tsparticles.interaction.external.grab.min.js +1 -1
- package/tsparticles.interaction.external.grab.min.js.LICENSE.txt +1 -1
- package/types/Types.d.ts +4 -4
- package/umd/Grabber.js +4 -3
- package/umd/Utils.js +2 -1
package/browser/Grabber.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { ExternalInteractorBase, getDistance, getLinkColor, getLinkRandomColor, isInArray, mouseMoveEvent, } from "@tsparticles/engine";
|
|
2
2
|
import { Grab } from "./Options/Classes/Grab.js";
|
|
3
3
|
import { drawGrab } from "./Utils.js";
|
|
4
|
-
const grabMode = "grab";
|
|
4
|
+
const grabMode = "grab", minDistance = 0, minOpacity = 0;
|
|
5
5
|
export class Grabber extends ExternalInteractorBase {
|
|
6
6
|
constructor(container) {
|
|
7
7
|
super(container);
|
|
@@ -27,7 +27,7 @@ export class Grabber extends ExternalInteractorBase {
|
|
|
27
27
|
return;
|
|
28
28
|
}
|
|
29
29
|
const distance = container.retina.grabModeDistance;
|
|
30
|
-
if (!distance || distance <
|
|
30
|
+
if (!distance || distance < minDistance) {
|
|
31
31
|
return;
|
|
32
32
|
}
|
|
33
33
|
const query = container.particles.quadTree.queryCircle(mousePos, distance, (p) => this.isEnabled(p));
|
|
@@ -37,7 +37,7 @@ export class Grabber extends ExternalInteractorBase {
|
|
|
37
37
|
continue;
|
|
38
38
|
}
|
|
39
39
|
const grabLineOptions = interactivity.modes.grab.links, lineOpacity = grabLineOptions.opacity, opacityLine = lineOpacity - (pointDistance * lineOpacity) / distance;
|
|
40
|
-
if (opacityLine <=
|
|
40
|
+
if (opacityLine <= minOpacity) {
|
|
41
41
|
continue;
|
|
42
42
|
}
|
|
43
43
|
const optColor = grabLineOptions.color ?? particle.options.links?.color;
|
|
@@ -51,6 +51,7 @@ export class Grabber extends ExternalInteractorBase {
|
|
|
51
51
|
}
|
|
52
52
|
drawGrab(container, particle, colorLine, opacityLine, mousePos);
|
|
53
53
|
}
|
|
54
|
+
await Promise.resolve();
|
|
54
55
|
}
|
|
55
56
|
isEnabled(particle) {
|
|
56
57
|
const container = this.container, mouse = container.interactivity.mouse, events = (particle?.interactivity ?? container.actualOptions.interactivity).events;
|
package/browser/Utils.js
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { drawLine, getStyleFromRgb } from "@tsparticles/engine";
|
|
2
|
+
const defaultWidth = 0;
|
|
2
3
|
export function drawGrabLine(context, width, begin, end, colorLine, opacity) {
|
|
3
4
|
drawLine(context, begin, end);
|
|
4
5
|
context.strokeStyle = getStyleFromRgb(colorLine, opacity);
|
|
@@ -8,6 +9,6 @@ export function drawGrabLine(context, width, begin, end, colorLine, opacity) {
|
|
|
8
9
|
export function drawGrab(container, particle, lineColor, opacity, mousePos) {
|
|
9
10
|
container.canvas.draw((ctx) => {
|
|
10
11
|
const beginPos = particle.getPosition();
|
|
11
|
-
drawGrabLine(ctx, particle.retina.linksWidth ??
|
|
12
|
+
drawGrabLine(ctx, particle.retina.linksWidth ?? defaultWidth, beginPos, mousePos, lineColor, opacity);
|
|
12
13
|
});
|
|
13
14
|
}
|
package/cjs/Grabber.js
CHANGED
|
@@ -4,7 +4,7 @@ exports.Grabber = void 0;
|
|
|
4
4
|
const engine_1 = require("@tsparticles/engine");
|
|
5
5
|
const Grab_js_1 = require("./Options/Classes/Grab.js");
|
|
6
6
|
const Utils_js_1 = require("./Utils.js");
|
|
7
|
-
const grabMode = "grab";
|
|
7
|
+
const grabMode = "grab", minDistance = 0, minOpacity = 0;
|
|
8
8
|
class Grabber extends engine_1.ExternalInteractorBase {
|
|
9
9
|
constructor(container) {
|
|
10
10
|
super(container);
|
|
@@ -30,7 +30,7 @@ class Grabber extends engine_1.ExternalInteractorBase {
|
|
|
30
30
|
return;
|
|
31
31
|
}
|
|
32
32
|
const distance = container.retina.grabModeDistance;
|
|
33
|
-
if (!distance || distance <
|
|
33
|
+
if (!distance || distance < minDistance) {
|
|
34
34
|
return;
|
|
35
35
|
}
|
|
36
36
|
const query = container.particles.quadTree.queryCircle(mousePos, distance, (p) => this.isEnabled(p));
|
|
@@ -40,7 +40,7 @@ class Grabber extends engine_1.ExternalInteractorBase {
|
|
|
40
40
|
continue;
|
|
41
41
|
}
|
|
42
42
|
const grabLineOptions = interactivity.modes.grab.links, lineOpacity = grabLineOptions.opacity, opacityLine = lineOpacity - (pointDistance * lineOpacity) / distance;
|
|
43
|
-
if (opacityLine <=
|
|
43
|
+
if (opacityLine <= minOpacity) {
|
|
44
44
|
continue;
|
|
45
45
|
}
|
|
46
46
|
const optColor = grabLineOptions.color ?? particle.options.links?.color;
|
|
@@ -54,6 +54,7 @@ class Grabber extends engine_1.ExternalInteractorBase {
|
|
|
54
54
|
}
|
|
55
55
|
(0, Utils_js_1.drawGrab)(container, particle, colorLine, opacityLine, mousePos);
|
|
56
56
|
}
|
|
57
|
+
await Promise.resolve();
|
|
57
58
|
}
|
|
58
59
|
isEnabled(particle) {
|
|
59
60
|
const container = this.container, mouse = container.interactivity.mouse, events = (particle?.interactivity ?? container.actualOptions.interactivity).events;
|
package/cjs/Utils.js
CHANGED
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.drawGrab = exports.drawGrabLine = void 0;
|
|
4
4
|
const engine_1 = require("@tsparticles/engine");
|
|
5
|
+
const defaultWidth = 0;
|
|
5
6
|
function drawGrabLine(context, width, begin, end, colorLine, opacity) {
|
|
6
7
|
(0, engine_1.drawLine)(context, begin, end);
|
|
7
8
|
context.strokeStyle = (0, engine_1.getStyleFromRgb)(colorLine, opacity);
|
|
@@ -12,7 +13,7 @@ exports.drawGrabLine = drawGrabLine;
|
|
|
12
13
|
function drawGrab(container, particle, lineColor, opacity, mousePos) {
|
|
13
14
|
container.canvas.draw((ctx) => {
|
|
14
15
|
const beginPos = particle.getPosition();
|
|
15
|
-
drawGrabLine(ctx, particle.retina.linksWidth ??
|
|
16
|
+
drawGrabLine(ctx, particle.retina.linksWidth ?? defaultWidth, beginPos, mousePos, lineColor, opacity);
|
|
16
17
|
});
|
|
17
18
|
}
|
|
18
19
|
exports.drawGrab = drawGrab;
|
package/esm/Grabber.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { ExternalInteractorBase, getDistance, getLinkColor, getLinkRandomColor, isInArray, mouseMoveEvent, } from "@tsparticles/engine";
|
|
2
2
|
import { Grab } from "./Options/Classes/Grab.js";
|
|
3
3
|
import { drawGrab } from "./Utils.js";
|
|
4
|
-
const grabMode = "grab";
|
|
4
|
+
const grabMode = "grab", minDistance = 0, minOpacity = 0;
|
|
5
5
|
export class Grabber extends ExternalInteractorBase {
|
|
6
6
|
constructor(container) {
|
|
7
7
|
super(container);
|
|
@@ -27,7 +27,7 @@ export class Grabber extends ExternalInteractorBase {
|
|
|
27
27
|
return;
|
|
28
28
|
}
|
|
29
29
|
const distance = container.retina.grabModeDistance;
|
|
30
|
-
if (!distance || distance <
|
|
30
|
+
if (!distance || distance < minDistance) {
|
|
31
31
|
return;
|
|
32
32
|
}
|
|
33
33
|
const query = container.particles.quadTree.queryCircle(mousePos, distance, (p) => this.isEnabled(p));
|
|
@@ -37,7 +37,7 @@ export class Grabber extends ExternalInteractorBase {
|
|
|
37
37
|
continue;
|
|
38
38
|
}
|
|
39
39
|
const grabLineOptions = interactivity.modes.grab.links, lineOpacity = grabLineOptions.opacity, opacityLine = lineOpacity - (pointDistance * lineOpacity) / distance;
|
|
40
|
-
if (opacityLine <=
|
|
40
|
+
if (opacityLine <= minOpacity) {
|
|
41
41
|
continue;
|
|
42
42
|
}
|
|
43
43
|
const optColor = grabLineOptions.color ?? particle.options.links?.color;
|
|
@@ -51,6 +51,7 @@ export class Grabber extends ExternalInteractorBase {
|
|
|
51
51
|
}
|
|
52
52
|
drawGrab(container, particle, colorLine, opacityLine, mousePos);
|
|
53
53
|
}
|
|
54
|
+
await Promise.resolve();
|
|
54
55
|
}
|
|
55
56
|
isEnabled(particle) {
|
|
56
57
|
const container = this.container, mouse = container.interactivity.mouse, events = (particle?.interactivity ?? container.actualOptions.interactivity).events;
|
package/esm/Utils.js
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { drawLine, getStyleFromRgb } from "@tsparticles/engine";
|
|
2
|
+
const defaultWidth = 0;
|
|
2
3
|
export function drawGrabLine(context, width, begin, end, colorLine, opacity) {
|
|
3
4
|
drawLine(context, begin, end);
|
|
4
5
|
context.strokeStyle = getStyleFromRgb(colorLine, opacity);
|
|
@@ -8,6 +9,6 @@ export function drawGrabLine(context, width, begin, end, colorLine, opacity) {
|
|
|
8
9
|
export function drawGrab(container, particle, lineColor, opacity, mousePos) {
|
|
9
10
|
container.canvas.draw((ctx) => {
|
|
10
11
|
const beginPos = particle.getPosition();
|
|
11
|
-
drawGrabLine(ctx, particle.retina.linksWidth ??
|
|
12
|
+
drawGrabLine(ctx, particle.retina.linksWidth ?? defaultWidth, beginPos, mousePos, lineColor, opacity);
|
|
12
13
|
});
|
|
13
14
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tsparticles/interaction-external-grab",
|
|
3
|
-
"version": "3.0
|
|
3
|
+
"version": "3.1.0",
|
|
4
4
|
"description": "tsParticles grab 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.1.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-grab [
|
|
6
|
+
<title>@tsparticles/interaction-external-grab [13 Jan 2024 at 22:59]</title>
|
|
7
7
|
<link rel="shortcut icon" href="" type="image/x-icon" />
|
|
8
8
|
|
|
9
9
|
<script>
|
|
@@ -31,7 +31,7 @@
|
|
|
31
31
|
<body>
|
|
32
32
|
<div id="app"></div>
|
|
33
33
|
<script>
|
|
34
|
-
window.chartData = [{"label":"tsparticles.interaction.external.grab.js","isAsset":true,"statSize":
|
|
34
|
+
window.chartData = [{"label":"tsparticles.interaction.external.grab.js","isAsset":true,"statSize":4700,"parsedSize":8433,"gzipSize":2474,"groups":[{"label":"dist/browser","path":"./dist/browser","statSize":4658,"groups":[{"id":540,"label":"index.js + 4 modules (concatenated)","path":"./dist/browser/index.js + 4 modules (concatenated)","statSize":4658,"parsedSize":8433,"gzipSize":2474,"concatenated":true,"groups":[{"label":"dist/browser","path":"./dist/browser/index.js + 4 modules (concatenated)/dist/browser","statSize":4658,"groups":[{"id":null,"label":"index.js","path":"./dist/browser/index.js + 4 modules (concatenated)/dist/browser/index.js","statSize":399,"parsedSize":722,"gzipSize":211,"inaccurateSizes":true},{"id":null,"label":"Grabber.js","path":"./dist/browser/index.js + 4 modules (concatenated)/dist/browser/Grabber.js","statSize":2794,"parsedSize":5058,"gzipSize":1483,"inaccurateSizes":true},{"label":"Options/Classes","path":"./dist/browser/index.js + 4 modules (concatenated)/dist/browser/Options/Classes","statSize":882,"groups":[{"id":null,"label":"Grab.js","path":"./dist/browser/index.js + 4 modules (concatenated)/dist/browser/Options/Classes/Grab.js","statSize":317,"parsedSize":573,"gzipSize":168,"inaccurateSizes":true},{"id":null,"label":"GrabLinks.js","path":"./dist/browser/index.js + 4 modules (concatenated)/dist/browser/Options/Classes/GrabLinks.js","statSize":565,"parsedSize":1022,"gzipSize":300,"inaccurateSizes":true}],"parsedSize":1596,"gzipSize":468,"inaccurateSizes":true},{"id":null,"label":"Utils.js","path":"./dist/browser/index.js + 4 modules (concatenated)/dist/browser/Utils.js","statSize":583,"parsedSize":1055,"gzipSize":309,"inaccurateSizes":true}],"parsedSize":8433,"gzipSize":2474,"inaccurateSizes":true}]}],"parsedSize":8433,"gzipSize":2474},{"label":"engine\",\"commonjs2\":\"@tsparticles/engine\",\"amd\":\"@tsparticles","path":"./engine\",\"commonjs2\":\"@tsparticles/engine\",\"amd\":\"@tsparticles","statSize":42,"groups":[{"id":533,"label":"engine\",\"root\":\"window\"}","path":"./engine\",\"commonjs2\":\"@tsparticles/engine\",\"amd\":\"@tsparticles/engine\",\"root\":\"window\"}","statSize":42}],"parsedSize":0,"gzipSize":0}],"isInitialByEntrypoint":{"tsparticles.interaction.external.grab":true}}];
|
|
35
35
|
window.entrypoints = ["tsparticles.interaction.external.grab","tsparticles.interaction.external.grab.min"];
|
|
36
36
|
window.defaultSizes = "parsed";
|
|
37
37
|
</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.0
|
|
7
|
+
* v3.1.0
|
|
8
8
|
*/
|
|
9
9
|
(function webpackUniversalModuleDefinition(root, factory) {
|
|
10
10
|
if(typeof exports === 'object' && typeof module === 'object')
|
|
@@ -143,6 +143,7 @@ class Grab {
|
|
|
143
143
|
}
|
|
144
144
|
;// CONCATENATED MODULE: ./dist/browser/Utils.js
|
|
145
145
|
|
|
146
|
+
const defaultWidth = 0;
|
|
146
147
|
function drawGrabLine(context, width, begin, end, colorLine, opacity) {
|
|
147
148
|
(0,engine_root_window_.drawLine)(context, begin, end);
|
|
148
149
|
context.strokeStyle = (0,engine_root_window_.getStyleFromRgb)(colorLine, opacity);
|
|
@@ -152,14 +153,16 @@ function drawGrabLine(context, width, begin, end, colorLine, opacity) {
|
|
|
152
153
|
function drawGrab(container, particle, lineColor, opacity, mousePos) {
|
|
153
154
|
container.canvas.draw(ctx => {
|
|
154
155
|
const beginPos = particle.getPosition();
|
|
155
|
-
drawGrabLine(ctx, particle.retina.linksWidth ??
|
|
156
|
+
drawGrabLine(ctx, particle.retina.linksWidth ?? defaultWidth, beginPos, mousePos, lineColor, opacity);
|
|
156
157
|
});
|
|
157
158
|
}
|
|
158
159
|
;// CONCATENATED MODULE: ./dist/browser/Grabber.js
|
|
159
160
|
|
|
160
161
|
|
|
161
162
|
|
|
162
|
-
const grabMode = "grab"
|
|
163
|
+
const grabMode = "grab",
|
|
164
|
+
minDistance = 0,
|
|
165
|
+
minOpacity = 0;
|
|
163
166
|
class Grabber extends engine_root_window_.ExternalInteractorBase {
|
|
164
167
|
constructor(container) {
|
|
165
168
|
super(container);
|
|
@@ -185,7 +188,7 @@ class Grabber extends engine_root_window_.ExternalInteractorBase {
|
|
|
185
188
|
return;
|
|
186
189
|
}
|
|
187
190
|
const distance = container.retina.grabModeDistance;
|
|
188
|
-
if (!distance || distance <
|
|
191
|
+
if (!distance || distance < minDistance) {
|
|
189
192
|
return;
|
|
190
193
|
}
|
|
191
194
|
const query = container.particles.quadTree.queryCircle(mousePos, distance, p => this.isEnabled(p));
|
|
@@ -198,7 +201,7 @@ class Grabber extends engine_root_window_.ExternalInteractorBase {
|
|
|
198
201
|
const grabLineOptions = interactivity.modes.grab.links,
|
|
199
202
|
lineOpacity = grabLineOptions.opacity,
|
|
200
203
|
opacityLine = lineOpacity - pointDistance * lineOpacity / distance;
|
|
201
|
-
if (opacityLine <=
|
|
204
|
+
if (opacityLine <= minOpacity) {
|
|
202
205
|
continue;
|
|
203
206
|
}
|
|
204
207
|
const optColor = grabLineOptions.color ?? particle.options.links?.color;
|
|
@@ -212,6 +215,7 @@ class Grabber extends engine_root_window_.ExternalInteractorBase {
|
|
|
212
215
|
}
|
|
213
216
|
drawGrab(container, particle, colorLine, opacityLine, mousePos);
|
|
214
217
|
}
|
|
218
|
+
await Promise.resolve();
|
|
215
219
|
}
|
|
216
220
|
isEnabled(particle) {
|
|
217
221
|
const container = this.container,
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
/*! For license information please see tsparticles.interaction.external.grab.min.js.LICENSE.txt */
|
|
2
|
-
!function(t,e){if("object"==typeof exports&&"object"==typeof module)module.exports=e(require("@tsparticles/engine"));else if("function"==typeof define&&define.amd)define(["@tsparticles/engine"],e);else{var o="object"==typeof exports?e(require("@tsparticles/engine")):e(t.window);for(var i in o)("object"==typeof exports?exports:t)[i]=o[i]}}(this,(t=>(()=>{"use strict";var e={533:e=>{e.exports=t}},o={};function i(t){var n=o[t];if(void 0!==n)return n.exports;var r=o[t]={exports:{}};return e[t](r,r.exports,i),r.exports}i.d=(t,e)=>{for(var o in e)i.o(e,o)&&!i.o(t,o)&&Object.defineProperty(t,o,{enumerable:!0,get:e[o]})},i.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),i.r=t=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})};var n={};return(()=>{i.r(n),i.d(n,{Grab:()=>o,GrabLinks:()=>e,loadExternalGrabInteraction:()=>a});var t=i(533);class e{constructor(){this.blink=!1,this.consent=!1,this.opacity=1}load(e){e&&(void 0!==e.blink&&(this.blink=e.blink),void 0!==e.color&&(this.color=t.OptionsColor.create(this.color,e.color)),void 0!==e.consent&&(this.consent=e.consent),void 0!==e.opacity&&(this.opacity=e.opacity))}}class o{constructor(){this.distance=100,this.links=new e}load(t){t&&(void 0!==t.distance&&(this.distance=t.distance),this.links.load(t.links))}}function r(e,o,i,n,r){e.canvas.draw((e=>{const s=o.getPosition();!function(e,o,i,n,r,s){(0,t.drawLine)(e,i,n),e.strokeStyle=(0,t.getStyleFromRgb)(r,s),e.lineWidth=o,e.stroke()}(e,o.retina.linksWidth??0,s,r,i,n)}))}class s extends t.ExternalInteractorBase{constructor(t){super(t)}clear(){}init(){const t=this.container,e=t.actualOptions.interactivity.modes.grab;e&&(t.retina.grabModeDistance=e.distance*t.retina.pixelRatio)}async interact(){const e=this.container,o=e.actualOptions.interactivity;if(!o.modes.grab||!o.events.onHover.enable||e.interactivity.status!==t.mouseMoveEvent)return;const i=e.interactivity.mouse.position;if(!i)return;const n=e.retina.grabModeDistance;if(!n||n<0)return;const s=e.particles.quadTree.queryCircle(i,n,(t=>this.isEnabled(t)));for(const a of s){const s=a.getPosition(),c=(0,t.getDistance)(s,i);if(c>n)continue;const l=o.modes.grab.links,d=l.opacity,p=d-c*d/n;if(p<=0)continue;const b=l.color??a.options.links?.color;if(!e.particles.grabLineColor&&b){const i=o.modes.grab.links;e.particles.grabLineColor=(0,t.getLinkRandomColor)(b,i.blink,i.consent)}const u=(0,t.getLinkColor)(a,void 0,e.particles.grabLineColor);u&&r(e,a,u,p,i)}}isEnabled(e){const o=this.container,i=o.interactivity.mouse,n=(e?.interactivity??o.actualOptions.interactivity).events;return n.onHover.enable&&!!i.position&&(0,t.isInArray)("grab",n.onHover.mode)}loadModeOptions(t,...e){t.grab||(t.grab=new o);for(const o of e)t.grab.load(o?.grab)}reset(){}}async function a(t,e=!0){await t.addInteractor("externalGrab",(t=>new s(t)),e)}})(),n})()));
|
|
2
|
+
!function(t,e){if("object"==typeof exports&&"object"==typeof module)module.exports=e(require("@tsparticles/engine"));else if("function"==typeof define&&define.amd)define(["@tsparticles/engine"],e);else{var o="object"==typeof exports?e(require("@tsparticles/engine")):e(t.window);for(var i in o)("object"==typeof exports?exports:t)[i]=o[i]}}(this,(t=>(()=>{"use strict";var e={533:e=>{e.exports=t}},o={};function i(t){var n=o[t];if(void 0!==n)return n.exports;var r=o[t]={exports:{}};return e[t](r,r.exports,i),r.exports}i.d=(t,e)=>{for(var o in e)i.o(e,o)&&!i.o(t,o)&&Object.defineProperty(t,o,{enumerable:!0,get:e[o]})},i.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),i.r=t=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})};var n={};return(()=>{i.r(n),i.d(n,{Grab:()=>o,GrabLinks:()=>e,loadExternalGrabInteraction:()=>a});var t=i(533);class e{constructor(){this.blink=!1,this.consent=!1,this.opacity=1}load(e){e&&(void 0!==e.blink&&(this.blink=e.blink),void 0!==e.color&&(this.color=t.OptionsColor.create(this.color,e.color)),void 0!==e.consent&&(this.consent=e.consent),void 0!==e.opacity&&(this.opacity=e.opacity))}}class o{constructor(){this.distance=100,this.links=new e}load(t){t&&(void 0!==t.distance&&(this.distance=t.distance),this.links.load(t.links))}}function r(e,o,i,n,r){e.canvas.draw((e=>{const s=o.getPosition();!function(e,o,i,n,r,s){(0,t.drawLine)(e,i,n),e.strokeStyle=(0,t.getStyleFromRgb)(r,s),e.lineWidth=o,e.stroke()}(e,o.retina.linksWidth??0,s,r,i,n)}))}class s extends t.ExternalInteractorBase{constructor(t){super(t)}clear(){}init(){const t=this.container,e=t.actualOptions.interactivity.modes.grab;e&&(t.retina.grabModeDistance=e.distance*t.retina.pixelRatio)}async interact(){const e=this.container,o=e.actualOptions.interactivity;if(!o.modes.grab||!o.events.onHover.enable||e.interactivity.status!==t.mouseMoveEvent)return;const i=e.interactivity.mouse.position;if(!i)return;const n=e.retina.grabModeDistance;if(!n||n<0)return;const s=e.particles.quadTree.queryCircle(i,n,(t=>this.isEnabled(t)));for(const a of s){const s=a.getPosition(),c=(0,t.getDistance)(s,i);if(c>n)continue;const l=o.modes.grab.links,d=l.opacity,p=d-c*d/n;if(p<=0)continue;const b=l.color??a.options.links?.color;if(!e.particles.grabLineColor&&b){const i=o.modes.grab.links;e.particles.grabLineColor=(0,t.getLinkRandomColor)(b,i.blink,i.consent)}const u=(0,t.getLinkColor)(a,void 0,e.particles.grabLineColor);u&&r(e,a,u,p,i)}await Promise.resolve()}isEnabled(e){const o=this.container,i=o.interactivity.mouse,n=(e?.interactivity??o.actualOptions.interactivity).events;return n.onHover.enable&&!!i.position&&(0,t.isInArray)("grab",n.onHover.mode)}loadModeOptions(t,...e){t.grab||(t.grab=new o);for(const o of e)t.grab.load(o?.grab)}reset(){}}async function a(t,e=!0){await t.addInteractor("externalGrab",(t=>new s(t)),e)}})(),n})()));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
/*! tsParticles Grab External Interaction v3.0
|
|
1
|
+
/*! tsParticles Grab External Interaction v3.1.0 by Matteo Bruni */
|
package/types/Types.d.ts
CHANGED
|
@@ -2,12 +2,12 @@ import type { Container, IRgb, OptionsColor, Particle } from "@tsparticles/engin
|
|
|
2
2
|
import type { Grab } from "./Options/Classes/Grab.js";
|
|
3
3
|
import type { GrabOptions } from "./Options/Classes/GrabOptions.js";
|
|
4
4
|
import type { IGrab } from "./Options/Interfaces/IGrab.js";
|
|
5
|
-
export
|
|
5
|
+
export interface IGrabMode {
|
|
6
6
|
grab: IGrab;
|
|
7
|
-
}
|
|
8
|
-
export
|
|
7
|
+
}
|
|
8
|
+
export interface GrabMode {
|
|
9
9
|
grab?: Grab;
|
|
10
|
-
}
|
|
10
|
+
}
|
|
11
11
|
export type GrabContainer = Container & {
|
|
12
12
|
actualOptions: GrabOptions;
|
|
13
13
|
particles: {
|
package/umd/Grabber.js
CHANGED
|
@@ -13,7 +13,7 @@
|
|
|
13
13
|
const engine_1 = require("@tsparticles/engine");
|
|
14
14
|
const Grab_js_1 = require("./Options/Classes/Grab.js");
|
|
15
15
|
const Utils_js_1 = require("./Utils.js");
|
|
16
|
-
const grabMode = "grab";
|
|
16
|
+
const grabMode = "grab", minDistance = 0, minOpacity = 0;
|
|
17
17
|
class Grabber extends engine_1.ExternalInteractorBase {
|
|
18
18
|
constructor(container) {
|
|
19
19
|
super(container);
|
|
@@ -39,7 +39,7 @@
|
|
|
39
39
|
return;
|
|
40
40
|
}
|
|
41
41
|
const distance = container.retina.grabModeDistance;
|
|
42
|
-
if (!distance || distance <
|
|
42
|
+
if (!distance || distance < minDistance) {
|
|
43
43
|
return;
|
|
44
44
|
}
|
|
45
45
|
const query = container.particles.quadTree.queryCircle(mousePos, distance, (p) => this.isEnabled(p));
|
|
@@ -49,7 +49,7 @@
|
|
|
49
49
|
continue;
|
|
50
50
|
}
|
|
51
51
|
const grabLineOptions = interactivity.modes.grab.links, lineOpacity = grabLineOptions.opacity, opacityLine = lineOpacity - (pointDistance * lineOpacity) / distance;
|
|
52
|
-
if (opacityLine <=
|
|
52
|
+
if (opacityLine <= minOpacity) {
|
|
53
53
|
continue;
|
|
54
54
|
}
|
|
55
55
|
const optColor = grabLineOptions.color ?? particle.options.links?.color;
|
|
@@ -63,6 +63,7 @@
|
|
|
63
63
|
}
|
|
64
64
|
(0, Utils_js_1.drawGrab)(container, particle, colorLine, opacityLine, mousePos);
|
|
65
65
|
}
|
|
66
|
+
await Promise.resolve();
|
|
66
67
|
}
|
|
67
68
|
isEnabled(particle) {
|
|
68
69
|
const container = this.container, mouse = container.interactivity.mouse, events = (particle?.interactivity ?? container.actualOptions.interactivity).events;
|
package/umd/Utils.js
CHANGED
|
@@ -11,6 +11,7 @@
|
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
12
|
exports.drawGrab = exports.drawGrabLine = void 0;
|
|
13
13
|
const engine_1 = require("@tsparticles/engine");
|
|
14
|
+
const defaultWidth = 0;
|
|
14
15
|
function drawGrabLine(context, width, begin, end, colorLine, opacity) {
|
|
15
16
|
(0, engine_1.drawLine)(context, begin, end);
|
|
16
17
|
context.strokeStyle = (0, engine_1.getStyleFromRgb)(colorLine, opacity);
|
|
@@ -21,7 +22,7 @@
|
|
|
21
22
|
function drawGrab(container, particle, lineColor, opacity, mousePos) {
|
|
22
23
|
container.canvas.draw((ctx) => {
|
|
23
24
|
const beginPos = particle.getPosition();
|
|
24
|
-
drawGrabLine(ctx, particle.retina.linksWidth ??
|
|
25
|
+
drawGrabLine(ctx, particle.retina.linksWidth ?? defaultWidth, beginPos, mousePos, lineColor, opacity);
|
|
25
26
|
});
|
|
26
27
|
}
|
|
27
28
|
exports.drawGrab = drawGrab;
|