@tsparticles/updater-out-modes 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/103.min.js +2 -0
- package/103.min.js.LICENSE.txt +1 -0
- package/388.min.js +2 -0
- package/388.min.js.LICENSE.txt +1 -0
- package/53.min.js +2 -0
- package/53.min.js.LICENSE.txt +1 -0
- package/569.min.js +2 -0
- package/569.min.js.LICENSE.txt +1 -0
- package/886.min.js +2 -0
- package/886.min.js.LICENSE.txt +1 -0
- package/920.min.js +2 -0
- package/920.min.js.LICENSE.txt +1 -0
- package/browser/BounceOutMode.js +3 -8
- package/browser/DestroyOutMode.js +8 -7
- package/browser/NoneOutMode.js +9 -9
- package/browser/OutOfCanvasUpdater.js +35 -19
- package/browser/OutOutMode.js +7 -2
- package/browser/Utils.js +15 -16
- package/browser/index.js +4 -2
- package/cjs/BounceOutMode.js +28 -10
- package/cjs/DestroyOutMode.js +8 -7
- package/cjs/NoneOutMode.js +9 -9
- package/cjs/OutOfCanvasUpdater.js +58 -19
- package/cjs/OutOutMode.js +7 -2
- package/cjs/Utils.js +15 -16
- package/cjs/index.js +27 -2
- package/dist_browser_BounceOutMode_js.js +30 -0
- package/dist_browser_DestroyOutMode_js.js +30 -0
- package/dist_browser_NoneOutMode_js.js +30 -0
- package/dist_browser_OutOfCanvasUpdater_js.js +30 -0
- package/dist_browser_OutOutMode_js.js +30 -0
- package/dist_browser_Utils_js.js +30 -0
- package/esm/BounceOutMode.js +3 -8
- package/esm/DestroyOutMode.js +8 -7
- package/esm/NoneOutMode.js +9 -9
- package/esm/OutOfCanvasUpdater.js +35 -19
- package/esm/OutOutMode.js +7 -2
- package/esm/Utils.js +15 -16
- package/esm/index.js +4 -2
- package/package.json +2 -2
- package/report.html +3 -3
- package/tsparticles.updater.out-modes.js +241 -354
- package/tsparticles.updater.out-modes.min.js +1 -1
- package/tsparticles.updater.out-modes.min.js.LICENSE.txt +1 -1
- package/types/BounceOutMode.d.ts +3 -3
- package/types/DestroyOutMode.d.ts +3 -3
- package/types/IBounceData.d.ts +2 -2
- package/types/IOutModeManager.d.ts +3 -3
- package/types/NoneOutMode.d.ts +3 -3
- package/types/OutOfCanvasUpdater.d.ts +3 -3
- package/types/OutOutMode.d.ts +3 -3
- package/umd/BounceOutMode.js +30 -11
- package/umd/DestroyOutMode.js +8 -7
- package/umd/NoneOutMode.js +9 -9
- package/umd/OutOfCanvasUpdater.js +60 -20
- package/umd/OutOutMode.js +7 -2
- package/umd/Utils.js +15 -16
- package/umd/index.js +29 -3
package/esm/Utils.js
CHANGED
|
@@ -1,13 +1,11 @@
|
|
|
1
1
|
import { getRangeValue } from "@tsparticles/engine";
|
|
2
|
+
const minVelocity = 0, boundsMin = 0;
|
|
2
3
|
export function bounceHorizontal(data) {
|
|
3
|
-
if ((data.outMode !== "bounce" &&
|
|
4
|
-
data.outMode !== "bounce-horizontal" &&
|
|
5
|
-
data.outMode !== "bounceHorizontal" &&
|
|
6
|
-
data.outMode !== "split") ||
|
|
4
|
+
if ((data.outMode !== "bounce" && data.outMode !== "split") ||
|
|
7
5
|
(data.direction !== "left" && data.direction !== "right")) {
|
|
8
6
|
return;
|
|
9
7
|
}
|
|
10
|
-
if (data.bounds.right <
|
|
8
|
+
if (data.bounds.right < boundsMin && data.direction === "left") {
|
|
11
9
|
data.particle.position.x = data.size + data.offset.x;
|
|
12
10
|
}
|
|
13
11
|
else if (data.bounds.left > data.canvasSize.width && data.direction === "right") {
|
|
@@ -15,8 +13,10 @@ export function bounceHorizontal(data) {
|
|
|
15
13
|
}
|
|
16
14
|
const velocity = data.particle.velocity.x;
|
|
17
15
|
let bounced = false;
|
|
18
|
-
if ((data.direction === "right" &&
|
|
19
|
-
|
|
16
|
+
if ((data.direction === "right" &&
|
|
17
|
+
data.bounds.right >= data.canvasSize.width &&
|
|
18
|
+
velocity > minVelocity) ||
|
|
19
|
+
(data.direction === "left" && data.bounds.left <= boundsMin && velocity < minVelocity)) {
|
|
20
20
|
const newVelocity = getRangeValue(data.particle.options.bounce.horizontal.value);
|
|
21
21
|
data.particle.velocity.x *= -newVelocity;
|
|
22
22
|
bounced = true;
|
|
@@ -28,7 +28,7 @@ export function bounceHorizontal(data) {
|
|
|
28
28
|
if (data.bounds.right >= data.canvasSize.width && data.direction === "right") {
|
|
29
29
|
data.particle.position.x = data.canvasSize.width - minPos;
|
|
30
30
|
}
|
|
31
|
-
else if (data.bounds.left <=
|
|
31
|
+
else if (data.bounds.left <= boundsMin && data.direction === "left") {
|
|
32
32
|
data.particle.position.x = minPos;
|
|
33
33
|
}
|
|
34
34
|
if (data.outMode === "split") {
|
|
@@ -36,14 +36,11 @@ export function bounceHorizontal(data) {
|
|
|
36
36
|
}
|
|
37
37
|
}
|
|
38
38
|
export function bounceVertical(data) {
|
|
39
|
-
if ((data.outMode !== "bounce" &&
|
|
40
|
-
data.outMode !== "bounce-vertical" &&
|
|
41
|
-
data.outMode !== "bounceVertical" &&
|
|
42
|
-
data.outMode !== "split") ||
|
|
39
|
+
if ((data.outMode !== "bounce" && data.outMode !== "split") ||
|
|
43
40
|
(data.direction !== "bottom" && data.direction !== "top")) {
|
|
44
41
|
return;
|
|
45
42
|
}
|
|
46
|
-
if (data.bounds.bottom <
|
|
43
|
+
if (data.bounds.bottom < boundsMin && data.direction === "top") {
|
|
47
44
|
data.particle.position.y = data.size + data.offset.y;
|
|
48
45
|
}
|
|
49
46
|
else if (data.bounds.top > data.canvasSize.height && data.direction === "bottom") {
|
|
@@ -51,8 +48,10 @@ export function bounceVertical(data) {
|
|
|
51
48
|
}
|
|
52
49
|
const velocity = data.particle.velocity.y;
|
|
53
50
|
let bounced = false;
|
|
54
|
-
if ((data.direction === "bottom" &&
|
|
55
|
-
|
|
51
|
+
if ((data.direction === "bottom" &&
|
|
52
|
+
data.bounds.bottom >= data.canvasSize.height &&
|
|
53
|
+
velocity > minVelocity) ||
|
|
54
|
+
(data.direction === "top" && data.bounds.top <= boundsMin && velocity < minVelocity)) {
|
|
56
55
|
const newVelocity = getRangeValue(data.particle.options.bounce.vertical.value);
|
|
57
56
|
data.particle.velocity.y *= -newVelocity;
|
|
58
57
|
bounced = true;
|
|
@@ -64,7 +63,7 @@ export function bounceVertical(data) {
|
|
|
64
63
|
if (data.bounds.bottom >= data.canvasSize.height && data.direction === "bottom") {
|
|
65
64
|
data.particle.position.y = data.canvasSize.height - minPos;
|
|
66
65
|
}
|
|
67
|
-
else if (data.bounds.top <=
|
|
66
|
+
else if (data.bounds.top <= boundsMin && data.direction === "top") {
|
|
68
67
|
data.particle.position.y = minPos;
|
|
69
68
|
}
|
|
70
69
|
if (data.outMode === "split") {
|
package/esm/index.js
CHANGED
|
@@ -1,4 +1,6 @@
|
|
|
1
|
-
import { OutOfCanvasUpdater } from "./OutOfCanvasUpdater.js";
|
|
2
1
|
export async function loadOutModesUpdater(engine, refresh = true) {
|
|
3
|
-
await engine.addParticleUpdater("outModes", (container) =>
|
|
2
|
+
await engine.addParticleUpdater("outModes", async (container) => {
|
|
3
|
+
const { OutOfCanvasUpdater } = await import("./OutOfCanvasUpdater.js");
|
|
4
|
+
return new OutOfCanvasUpdater(container);
|
|
5
|
+
}, refresh);
|
|
4
6
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tsparticles/updater-out-modes",
|
|
3
|
-
"version": "3.0
|
|
3
|
+
"version": "3.2.0",
|
|
4
4
|
"description": "tsParticles particles out modes updater",
|
|
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/updater-out-modes [
|
|
6
|
+
<title>@tsparticles/updater-out-modes [31 Jan 2024 at 02:11]</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.updater.out-modes
|
|
34
|
+
window.chartData = [];
|
|
35
|
+
window.entrypoints = ["tsparticles.updater.out-modes.min"];
|
|
36
36
|
window.defaultSizes = "parsed";
|
|
37
37
|
</script>
|
|
38
38
|
</body>
|