@tsparticles/updater-out-modes 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.
@@ -1,4 +1,5 @@
1
1
  import { Vector, getDistances, isPointInside, } from "@tsparticles/engine";
2
+ const minVelocity = 0;
2
3
  export class DestroyOutMode {
3
4
  constructor(container) {
4
5
  this.container = container;
@@ -19,10 +20,10 @@ export class DestroyOutMode {
19
20
  case "inside": {
20
21
  const { dx, dy } = getDistances(particle.position, particle.moveCenter);
21
22
  const { x: vx, y: vy } = particle.velocity;
22
- if ((vx < 0 && dx > particle.moveCenter.radius) ||
23
- (vy < 0 && dy > particle.moveCenter.radius) ||
24
- (vx >= 0 && dx < -particle.moveCenter.radius) ||
25
- (vy >= 0 && dy < -particle.moveCenter.radius)) {
23
+ if ((vx < minVelocity && dx > particle.moveCenter.radius) ||
24
+ (vy < minVelocity && dy > particle.moveCenter.radius) ||
25
+ (vx >= minVelocity && dx < -particle.moveCenter.radius) ||
26
+ (vy >= minVelocity && dy < -particle.moveCenter.radius)) {
26
27
  return;
27
28
  }
28
29
  break;
@@ -1,4 +1,5 @@
1
1
  import { Vector, isPointInside, } from "@tsparticles/engine";
2
+ const minVelocity = 0;
2
3
  export class NoneOutMode {
3
4
  constructor(container) {
4
5
  this.container = container;
@@ -9,7 +10,7 @@ export class NoneOutMode {
9
10
  return;
10
11
  }
11
12
  if ((particle.options.move.distance.horizontal &&
12
- (direction === "left" || direction === "right")) ||
13
+ (direction === "left" || direction === "right")) ??
13
14
  (particle.options.move.distance.vertical &&
14
15
  (direction === "top" || direction === "bottom"))) {
15
16
  return;
@@ -18,10 +19,10 @@ export class NoneOutMode {
18
19
  const canvasSize = container.canvas.size;
19
20
  const pRadius = particle.getRadius();
20
21
  if (!gravityOptions.enable) {
21
- if ((particle.velocity.y > 0 && particle.position.y <= canvasSize.height + pRadius) ||
22
- (particle.velocity.y < 0 && particle.position.y >= -pRadius) ||
23
- (particle.velocity.x > 0 && particle.position.x <= canvasSize.width + pRadius) ||
24
- (particle.velocity.x < 0 && particle.position.x >= -pRadius)) {
22
+ if ((particle.velocity.y > minVelocity && particle.position.y <= canvasSize.height + pRadius) ||
23
+ (particle.velocity.y < minVelocity && particle.position.y >= -pRadius) ||
24
+ (particle.velocity.x > minVelocity && particle.position.x <= canvasSize.width + pRadius) ||
25
+ (particle.velocity.x < minVelocity && particle.position.x >= -pRadius)) {
25
26
  return;
26
27
  }
27
28
  if (!isPointInside(particle.position, container.canvas.size, Vector.origin, pRadius, direction)) {
@@ -4,12 +4,12 @@ import { NoneOutMode } from "./NoneOutMode.js";
4
4
  import { OutOutMode } from "./OutOutMode.js";
5
5
  export class OutOfCanvasUpdater {
6
6
  constructor(container) {
7
- this.container = container;
8
7
  this._updateOutMode = (particle, delta, outMode, direction) => {
9
8
  for (const updater of this.updaters) {
10
9
  updater.update(particle, direction, delta, outMode);
11
10
  }
12
11
  };
12
+ this.container = container;
13
13
  this.updaters = [
14
14
  new BounceOutMode(container),
15
15
  new DestroyOutMode(container),
@@ -1,4 +1,5 @@
1
1
  import { Vector, calculateBounds, getDistances, getRandom, isPointInside, randomInRange, } from "@tsparticles/engine";
2
+ const minVelocity = 0, minDistance = 0;
2
3
  export class OutOutMode {
3
4
  constructor(container) {
4
5
  this.container = container;
@@ -17,7 +18,10 @@ export class OutOutMode {
17
18
  circVec.angle = particle.velocity.angle + Math.PI;
18
19
  circVec.addTo(Vector.create(particle.moveCenter));
19
20
  const { dx, dy } = getDistances(particle.position, circVec);
20
- if ((vx <= 0 && dx >= 0) || (vy <= 0 && dy >= 0) || (vx >= 0 && dx <= 0) || (vy >= 0 && dy <= 0)) {
21
+ if ((vx <= minVelocity && dx >= minDistance) ||
22
+ (vy <= minVelocity && dy >= minDistance) ||
23
+ (vx >= minVelocity && dx <= minDistance) ||
24
+ (vy >= minVelocity && dy <= minDistance)) {
21
25
  return;
22
26
  }
23
27
  particle.position.x = Math.floor(randomInRange({
package/browser/Utils.js CHANGED
@@ -1,4 +1,5 @@
1
1
  import { getRangeValue } from "@tsparticles/engine";
2
+ const minVelocity = 0, boundsMin = 0;
2
3
  export function bounceHorizontal(data) {
3
4
  if ((data.outMode !== "bounce" &&
4
5
  data.outMode !== "bounce-horizontal" &&
@@ -7,7 +8,7 @@ export function bounceHorizontal(data) {
7
8
  (data.direction !== "left" && data.direction !== "right")) {
8
9
  return;
9
10
  }
10
- if (data.bounds.right < 0 && data.direction === "left") {
11
+ if (data.bounds.right < boundsMin && data.direction === "left") {
11
12
  data.particle.position.x = data.size + data.offset.x;
12
13
  }
13
14
  else if (data.bounds.left > data.canvasSize.width && data.direction === "right") {
@@ -15,8 +16,10 @@ export function bounceHorizontal(data) {
15
16
  }
16
17
  const velocity = data.particle.velocity.x;
17
18
  let bounced = false;
18
- if ((data.direction === "right" && data.bounds.right >= data.canvasSize.width && velocity > 0) ||
19
- (data.direction === "left" && data.bounds.left <= 0 && velocity < 0)) {
19
+ if ((data.direction === "right" &&
20
+ data.bounds.right >= data.canvasSize.width &&
21
+ velocity > minVelocity) ||
22
+ (data.direction === "left" && data.bounds.left <= boundsMin && velocity < minVelocity)) {
20
23
  const newVelocity = getRangeValue(data.particle.options.bounce.horizontal.value);
21
24
  data.particle.velocity.x *= -newVelocity;
22
25
  bounced = true;
@@ -28,7 +31,7 @@ export function bounceHorizontal(data) {
28
31
  if (data.bounds.right >= data.canvasSize.width && data.direction === "right") {
29
32
  data.particle.position.x = data.canvasSize.width - minPos;
30
33
  }
31
- else if (data.bounds.left <= 0 && data.direction === "left") {
34
+ else if (data.bounds.left <= boundsMin && data.direction === "left") {
32
35
  data.particle.position.x = minPos;
33
36
  }
34
37
  if (data.outMode === "split") {
@@ -43,7 +46,7 @@ export function bounceVertical(data) {
43
46
  (data.direction !== "bottom" && data.direction !== "top")) {
44
47
  return;
45
48
  }
46
- if (data.bounds.bottom < 0 && data.direction === "top") {
49
+ if (data.bounds.bottom < boundsMin && data.direction === "top") {
47
50
  data.particle.position.y = data.size + data.offset.y;
48
51
  }
49
52
  else if (data.bounds.top > data.canvasSize.height && data.direction === "bottom") {
@@ -51,8 +54,10 @@ export function bounceVertical(data) {
51
54
  }
52
55
  const velocity = data.particle.velocity.y;
53
56
  let bounced = false;
54
- if ((data.direction === "bottom" && data.bounds.bottom >= data.canvasSize.height && velocity > 0) ||
55
- (data.direction === "top" && data.bounds.top <= 0 && velocity < 0)) {
57
+ if ((data.direction === "bottom" &&
58
+ data.bounds.bottom >= data.canvasSize.height &&
59
+ velocity > minVelocity) ||
60
+ (data.direction === "top" && data.bounds.top <= boundsMin && velocity < minVelocity)) {
56
61
  const newVelocity = getRangeValue(data.particle.options.bounce.vertical.value);
57
62
  data.particle.velocity.y *= -newVelocity;
58
63
  bounced = true;
@@ -64,7 +69,7 @@ export function bounceVertical(data) {
64
69
  if (data.bounds.bottom >= data.canvasSize.height && data.direction === "bottom") {
65
70
  data.particle.position.y = data.canvasSize.height - minPos;
66
71
  }
67
- else if (data.bounds.top <= 0 && data.direction === "top") {
72
+ else if (data.bounds.top <= boundsMin && data.direction === "top") {
68
73
  data.particle.position.y = minPos;
69
74
  }
70
75
  if (data.outMode === "split") {
@@ -2,6 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.DestroyOutMode = void 0;
4
4
  const engine_1 = require("@tsparticles/engine");
5
+ const minVelocity = 0;
5
6
  class DestroyOutMode {
6
7
  constructor(container) {
7
8
  this.container = container;
@@ -22,10 +23,10 @@ class DestroyOutMode {
22
23
  case "inside": {
23
24
  const { dx, dy } = (0, engine_1.getDistances)(particle.position, particle.moveCenter);
24
25
  const { x: vx, y: vy } = particle.velocity;
25
- if ((vx < 0 && dx > particle.moveCenter.radius) ||
26
- (vy < 0 && dy > particle.moveCenter.radius) ||
27
- (vx >= 0 && dx < -particle.moveCenter.radius) ||
28
- (vy >= 0 && dy < -particle.moveCenter.radius)) {
26
+ if ((vx < minVelocity && dx > particle.moveCenter.radius) ||
27
+ (vy < minVelocity && dy > particle.moveCenter.radius) ||
28
+ (vx >= minVelocity && dx < -particle.moveCenter.radius) ||
29
+ (vy >= minVelocity && dy < -particle.moveCenter.radius)) {
29
30
  return;
30
31
  }
31
32
  break;
@@ -2,6 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.NoneOutMode = void 0;
4
4
  const engine_1 = require("@tsparticles/engine");
5
+ const minVelocity = 0;
5
6
  class NoneOutMode {
6
7
  constructor(container) {
7
8
  this.container = container;
@@ -12,7 +13,7 @@ class NoneOutMode {
12
13
  return;
13
14
  }
14
15
  if ((particle.options.move.distance.horizontal &&
15
- (direction === "left" || direction === "right")) ||
16
+ (direction === "left" || direction === "right")) ??
16
17
  (particle.options.move.distance.vertical &&
17
18
  (direction === "top" || direction === "bottom"))) {
18
19
  return;
@@ -21,10 +22,10 @@ class NoneOutMode {
21
22
  const canvasSize = container.canvas.size;
22
23
  const pRadius = particle.getRadius();
23
24
  if (!gravityOptions.enable) {
24
- if ((particle.velocity.y > 0 && particle.position.y <= canvasSize.height + pRadius) ||
25
- (particle.velocity.y < 0 && particle.position.y >= -pRadius) ||
26
- (particle.velocity.x > 0 && particle.position.x <= canvasSize.width + pRadius) ||
27
- (particle.velocity.x < 0 && particle.position.x >= -pRadius)) {
25
+ if ((particle.velocity.y > minVelocity && particle.position.y <= canvasSize.height + pRadius) ||
26
+ (particle.velocity.y < minVelocity && particle.position.y >= -pRadius) ||
27
+ (particle.velocity.x > minVelocity && particle.position.x <= canvasSize.width + pRadius) ||
28
+ (particle.velocity.x < minVelocity && particle.position.x >= -pRadius)) {
28
29
  return;
29
30
  }
30
31
  if (!(0, engine_1.isPointInside)(particle.position, container.canvas.size, engine_1.Vector.origin, pRadius, direction)) {
@@ -7,12 +7,12 @@ const NoneOutMode_js_1 = require("./NoneOutMode.js");
7
7
  const OutOutMode_js_1 = require("./OutOutMode.js");
8
8
  class OutOfCanvasUpdater {
9
9
  constructor(container) {
10
- this.container = container;
11
10
  this._updateOutMode = (particle, delta, outMode, direction) => {
12
11
  for (const updater of this.updaters) {
13
12
  updater.update(particle, direction, delta, outMode);
14
13
  }
15
14
  };
15
+ this.container = container;
16
16
  this.updaters = [
17
17
  new BounceOutMode_js_1.BounceOutMode(container),
18
18
  new DestroyOutMode_js_1.DestroyOutMode(container),
package/cjs/OutOutMode.js CHANGED
@@ -2,6 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.OutOutMode = void 0;
4
4
  const engine_1 = require("@tsparticles/engine");
5
+ const minVelocity = 0, minDistance = 0;
5
6
  class OutOutMode {
6
7
  constructor(container) {
7
8
  this.container = container;
@@ -20,7 +21,10 @@ class OutOutMode {
20
21
  circVec.angle = particle.velocity.angle + Math.PI;
21
22
  circVec.addTo(engine_1.Vector.create(particle.moveCenter));
22
23
  const { dx, dy } = (0, engine_1.getDistances)(particle.position, circVec);
23
- if ((vx <= 0 && dx >= 0) || (vy <= 0 && dy >= 0) || (vx >= 0 && dx <= 0) || (vy >= 0 && dy <= 0)) {
24
+ if ((vx <= minVelocity && dx >= minDistance) ||
25
+ (vy <= minVelocity && dy >= minDistance) ||
26
+ (vx >= minVelocity && dx <= minDistance) ||
27
+ (vy >= minVelocity && dy <= minDistance)) {
24
28
  return;
25
29
  }
26
30
  particle.position.x = Math.floor((0, engine_1.randomInRange)({
package/cjs/Utils.js CHANGED
@@ -2,6 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.bounceVertical = exports.bounceHorizontal = void 0;
4
4
  const engine_1 = require("@tsparticles/engine");
5
+ const minVelocity = 0, boundsMin = 0;
5
6
  function bounceHorizontal(data) {
6
7
  if ((data.outMode !== "bounce" &&
7
8
  data.outMode !== "bounce-horizontal" &&
@@ -10,7 +11,7 @@ function bounceHorizontal(data) {
10
11
  (data.direction !== "left" && data.direction !== "right")) {
11
12
  return;
12
13
  }
13
- if (data.bounds.right < 0 && data.direction === "left") {
14
+ if (data.bounds.right < boundsMin && data.direction === "left") {
14
15
  data.particle.position.x = data.size + data.offset.x;
15
16
  }
16
17
  else if (data.bounds.left > data.canvasSize.width && data.direction === "right") {
@@ -18,8 +19,10 @@ function bounceHorizontal(data) {
18
19
  }
19
20
  const velocity = data.particle.velocity.x;
20
21
  let bounced = false;
21
- if ((data.direction === "right" && data.bounds.right >= data.canvasSize.width && velocity > 0) ||
22
- (data.direction === "left" && data.bounds.left <= 0 && velocity < 0)) {
22
+ if ((data.direction === "right" &&
23
+ data.bounds.right >= data.canvasSize.width &&
24
+ velocity > minVelocity) ||
25
+ (data.direction === "left" && data.bounds.left <= boundsMin && velocity < minVelocity)) {
23
26
  const newVelocity = (0, engine_1.getRangeValue)(data.particle.options.bounce.horizontal.value);
24
27
  data.particle.velocity.x *= -newVelocity;
25
28
  bounced = true;
@@ -31,7 +34,7 @@ function bounceHorizontal(data) {
31
34
  if (data.bounds.right >= data.canvasSize.width && data.direction === "right") {
32
35
  data.particle.position.x = data.canvasSize.width - minPos;
33
36
  }
34
- else if (data.bounds.left <= 0 && data.direction === "left") {
37
+ else if (data.bounds.left <= boundsMin && data.direction === "left") {
35
38
  data.particle.position.x = minPos;
36
39
  }
37
40
  if (data.outMode === "split") {
@@ -47,7 +50,7 @@ function bounceVertical(data) {
47
50
  (data.direction !== "bottom" && data.direction !== "top")) {
48
51
  return;
49
52
  }
50
- if (data.bounds.bottom < 0 && data.direction === "top") {
53
+ if (data.bounds.bottom < boundsMin && data.direction === "top") {
51
54
  data.particle.position.y = data.size + data.offset.y;
52
55
  }
53
56
  else if (data.bounds.top > data.canvasSize.height && data.direction === "bottom") {
@@ -55,8 +58,10 @@ function bounceVertical(data) {
55
58
  }
56
59
  const velocity = data.particle.velocity.y;
57
60
  let bounced = false;
58
- if ((data.direction === "bottom" && data.bounds.bottom >= data.canvasSize.height && velocity > 0) ||
59
- (data.direction === "top" && data.bounds.top <= 0 && velocity < 0)) {
61
+ if ((data.direction === "bottom" &&
62
+ data.bounds.bottom >= data.canvasSize.height &&
63
+ velocity > minVelocity) ||
64
+ (data.direction === "top" && data.bounds.top <= boundsMin && velocity < minVelocity)) {
60
65
  const newVelocity = (0, engine_1.getRangeValue)(data.particle.options.bounce.vertical.value);
61
66
  data.particle.velocity.y *= -newVelocity;
62
67
  bounced = true;
@@ -68,7 +73,7 @@ function bounceVertical(data) {
68
73
  if (data.bounds.bottom >= data.canvasSize.height && data.direction === "bottom") {
69
74
  data.particle.position.y = data.canvasSize.height - minPos;
70
75
  }
71
- else if (data.bounds.top <= 0 && data.direction === "top") {
76
+ else if (data.bounds.top <= boundsMin && data.direction === "top") {
72
77
  data.particle.position.y = minPos;
73
78
  }
74
79
  if (data.outMode === "split") {
@@ -1,4 +1,5 @@
1
1
  import { Vector, getDistances, isPointInside, } from "@tsparticles/engine";
2
+ const minVelocity = 0;
2
3
  export class DestroyOutMode {
3
4
  constructor(container) {
4
5
  this.container = container;
@@ -19,10 +20,10 @@ export class DestroyOutMode {
19
20
  case "inside": {
20
21
  const { dx, dy } = getDistances(particle.position, particle.moveCenter);
21
22
  const { x: vx, y: vy } = particle.velocity;
22
- if ((vx < 0 && dx > particle.moveCenter.radius) ||
23
- (vy < 0 && dy > particle.moveCenter.radius) ||
24
- (vx >= 0 && dx < -particle.moveCenter.radius) ||
25
- (vy >= 0 && dy < -particle.moveCenter.radius)) {
23
+ if ((vx < minVelocity && dx > particle.moveCenter.radius) ||
24
+ (vy < minVelocity && dy > particle.moveCenter.radius) ||
25
+ (vx >= minVelocity && dx < -particle.moveCenter.radius) ||
26
+ (vy >= minVelocity && dy < -particle.moveCenter.radius)) {
26
27
  return;
27
28
  }
28
29
  break;
@@ -1,4 +1,5 @@
1
1
  import { Vector, isPointInside, } from "@tsparticles/engine";
2
+ const minVelocity = 0;
2
3
  export class NoneOutMode {
3
4
  constructor(container) {
4
5
  this.container = container;
@@ -9,7 +10,7 @@ export class NoneOutMode {
9
10
  return;
10
11
  }
11
12
  if ((particle.options.move.distance.horizontal &&
12
- (direction === "left" || direction === "right")) ||
13
+ (direction === "left" || direction === "right")) ??
13
14
  (particle.options.move.distance.vertical &&
14
15
  (direction === "top" || direction === "bottom"))) {
15
16
  return;
@@ -18,10 +19,10 @@ export class NoneOutMode {
18
19
  const canvasSize = container.canvas.size;
19
20
  const pRadius = particle.getRadius();
20
21
  if (!gravityOptions.enable) {
21
- if ((particle.velocity.y > 0 && particle.position.y <= canvasSize.height + pRadius) ||
22
- (particle.velocity.y < 0 && particle.position.y >= -pRadius) ||
23
- (particle.velocity.x > 0 && particle.position.x <= canvasSize.width + pRadius) ||
24
- (particle.velocity.x < 0 && particle.position.x >= -pRadius)) {
22
+ if ((particle.velocity.y > minVelocity && particle.position.y <= canvasSize.height + pRadius) ||
23
+ (particle.velocity.y < minVelocity && particle.position.y >= -pRadius) ||
24
+ (particle.velocity.x > minVelocity && particle.position.x <= canvasSize.width + pRadius) ||
25
+ (particle.velocity.x < minVelocity && particle.position.x >= -pRadius)) {
25
26
  return;
26
27
  }
27
28
  if (!isPointInside(particle.position, container.canvas.size, Vector.origin, pRadius, direction)) {
@@ -4,12 +4,12 @@ import { NoneOutMode } from "./NoneOutMode.js";
4
4
  import { OutOutMode } from "./OutOutMode.js";
5
5
  export class OutOfCanvasUpdater {
6
6
  constructor(container) {
7
- this.container = container;
8
7
  this._updateOutMode = (particle, delta, outMode, direction) => {
9
8
  for (const updater of this.updaters) {
10
9
  updater.update(particle, direction, delta, outMode);
11
10
  }
12
11
  };
12
+ this.container = container;
13
13
  this.updaters = [
14
14
  new BounceOutMode(container),
15
15
  new DestroyOutMode(container),
package/esm/OutOutMode.js CHANGED
@@ -1,4 +1,5 @@
1
1
  import { Vector, calculateBounds, getDistances, getRandom, isPointInside, randomInRange, } from "@tsparticles/engine";
2
+ const minVelocity = 0, minDistance = 0;
2
3
  export class OutOutMode {
3
4
  constructor(container) {
4
5
  this.container = container;
@@ -17,7 +18,10 @@ export class OutOutMode {
17
18
  circVec.angle = particle.velocity.angle + Math.PI;
18
19
  circVec.addTo(Vector.create(particle.moveCenter));
19
20
  const { dx, dy } = getDistances(particle.position, circVec);
20
- if ((vx <= 0 && dx >= 0) || (vy <= 0 && dy >= 0) || (vx >= 0 && dx <= 0) || (vy >= 0 && dy <= 0)) {
21
+ if ((vx <= minVelocity && dx >= minDistance) ||
22
+ (vy <= minVelocity && dy >= minDistance) ||
23
+ (vx >= minVelocity && dx <= minDistance) ||
24
+ (vy >= minVelocity && dy <= minDistance)) {
21
25
  return;
22
26
  }
23
27
  particle.position.x = Math.floor(randomInRange({
package/esm/Utils.js CHANGED
@@ -1,4 +1,5 @@
1
1
  import { getRangeValue } from "@tsparticles/engine";
2
+ const minVelocity = 0, boundsMin = 0;
2
3
  export function bounceHorizontal(data) {
3
4
  if ((data.outMode !== "bounce" &&
4
5
  data.outMode !== "bounce-horizontal" &&
@@ -7,7 +8,7 @@ export function bounceHorizontal(data) {
7
8
  (data.direction !== "left" && data.direction !== "right")) {
8
9
  return;
9
10
  }
10
- if (data.bounds.right < 0 && data.direction === "left") {
11
+ if (data.bounds.right < boundsMin && data.direction === "left") {
11
12
  data.particle.position.x = data.size + data.offset.x;
12
13
  }
13
14
  else if (data.bounds.left > data.canvasSize.width && data.direction === "right") {
@@ -15,8 +16,10 @@ export function bounceHorizontal(data) {
15
16
  }
16
17
  const velocity = data.particle.velocity.x;
17
18
  let bounced = false;
18
- if ((data.direction === "right" && data.bounds.right >= data.canvasSize.width && velocity > 0) ||
19
- (data.direction === "left" && data.bounds.left <= 0 && velocity < 0)) {
19
+ if ((data.direction === "right" &&
20
+ data.bounds.right >= data.canvasSize.width &&
21
+ velocity > minVelocity) ||
22
+ (data.direction === "left" && data.bounds.left <= boundsMin && velocity < minVelocity)) {
20
23
  const newVelocity = getRangeValue(data.particle.options.bounce.horizontal.value);
21
24
  data.particle.velocity.x *= -newVelocity;
22
25
  bounced = true;
@@ -28,7 +31,7 @@ export function bounceHorizontal(data) {
28
31
  if (data.bounds.right >= data.canvasSize.width && data.direction === "right") {
29
32
  data.particle.position.x = data.canvasSize.width - minPos;
30
33
  }
31
- else if (data.bounds.left <= 0 && data.direction === "left") {
34
+ else if (data.bounds.left <= boundsMin && data.direction === "left") {
32
35
  data.particle.position.x = minPos;
33
36
  }
34
37
  if (data.outMode === "split") {
@@ -43,7 +46,7 @@ export function bounceVertical(data) {
43
46
  (data.direction !== "bottom" && data.direction !== "top")) {
44
47
  return;
45
48
  }
46
- if (data.bounds.bottom < 0 && data.direction === "top") {
49
+ if (data.bounds.bottom < boundsMin && data.direction === "top") {
47
50
  data.particle.position.y = data.size + data.offset.y;
48
51
  }
49
52
  else if (data.bounds.top > data.canvasSize.height && data.direction === "bottom") {
@@ -51,8 +54,10 @@ export function bounceVertical(data) {
51
54
  }
52
55
  const velocity = data.particle.velocity.y;
53
56
  let bounced = false;
54
- if ((data.direction === "bottom" && data.bounds.bottom >= data.canvasSize.height && velocity > 0) ||
55
- (data.direction === "top" && data.bounds.top <= 0 && velocity < 0)) {
57
+ if ((data.direction === "bottom" &&
58
+ data.bounds.bottom >= data.canvasSize.height &&
59
+ velocity > minVelocity) ||
60
+ (data.direction === "top" && data.bounds.top <= boundsMin && velocity < minVelocity)) {
56
61
  const newVelocity = getRangeValue(data.particle.options.bounce.vertical.value);
57
62
  data.particle.velocity.y *= -newVelocity;
58
63
  bounced = true;
@@ -64,7 +69,7 @@ export function bounceVertical(data) {
64
69
  if (data.bounds.bottom >= data.canvasSize.height && data.direction === "bottom") {
65
70
  data.particle.position.y = data.canvasSize.height - minPos;
66
71
  }
67
- else if (data.bounds.top <= 0 && data.direction === "top") {
72
+ else if (data.bounds.top <= boundsMin && data.direction === "top") {
68
73
  data.particle.position.y = minPos;
69
74
  }
70
75
  if (data.outMode === "split") {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tsparticles/updater-out-modes",
3
- "version": "3.0.3",
3
+ "version": "3.1.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.3"
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/updater-out-modes [26 Dec 2023 at 19:32]</title>
6
+ <title>@tsparticles/updater-out-modes [13 Jan 2024 at 23:08]</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.updater.out-modes.js","isAsset":true,"statSize":13062,"parsedSize":17066,"gzipSize":3419,"groups":[{"label":"dist/browser","path":"./dist/browser","statSize":13020,"groups":[{"id":1,"label":"index.js + 6 modules (concatenated)","path":"./dist/browser/index.js + 6 modules (concatenated)","statSize":13020,"parsedSize":17066,"gzipSize":3419,"concatenated":true,"groups":[{"label":"dist/browser","path":"./dist/browser/index.js + 6 modules (concatenated)/dist/browser","statSize":13020,"groups":[{"id":null,"label":"index.js","path":"./dist/browser/index.js + 6 modules (concatenated)/dist/browser/index.js","statSize":235,"parsedSize":308,"gzipSize":61,"inaccurateSizes":true},{"id":null,"label":"OutOfCanvasUpdater.js","path":"./dist/browser/index.js + 6 modules (concatenated)/dist/browser/OutOfCanvasUpdater.js","statSize":1149,"parsedSize":1506,"gzipSize":301,"inaccurateSizes":true},{"id":null,"label":"BounceOutMode.js","path":"./dist/browser/index.js + 6 modules (concatenated)/dist/browser/BounceOutMode.js","statSize":1230,"parsedSize":1612,"gzipSize":322,"inaccurateSizes":true},{"id":null,"label":"DestroyOutMode.js","path":"./dist/browser/index.js + 6 modules (concatenated)/dist/browser/DestroyOutMode.js","statSize":1146,"parsedSize":1502,"gzipSize":300,"inaccurateSizes":true},{"id":null,"label":"OutOutMode.js","path":"./dist/browser/index.js + 6 modules (concatenated)/dist/browser/OutOutMode.js","statSize":5027,"parsedSize":6589,"gzipSize":1320,"inaccurateSizes":true},{"id":null,"label":"NoneOutMode.js","path":"./dist/browser/index.js + 6 modules (concatenated)/dist/browser/NoneOutMode.js","statSize":1498,"parsedSize":1963,"gzipSize":393,"inaccurateSizes":true},{"id":null,"label":"Utils.js","path":"./dist/browser/index.js + 6 modules (concatenated)/dist/browser/Utils.js","statSize":2735,"parsedSize":3584,"gzipSize":718,"inaccurateSizes":true}],"parsedSize":17066,"gzipSize":3419,"inaccurateSizes":true}]}],"parsedSize":17066,"gzipSize":3419},{"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.updater.out-modes":true}}];
34
+ window.chartData = [{"label":"tsparticles.updater.out-modes.js","isAsset":true,"statSize":13442,"parsedSize":17636,"gzipSize":3492,"groups":[{"label":"dist/browser","path":"./dist/browser","statSize":13400,"groups":[{"id":421,"label":"index.js + 6 modules (concatenated)","path":"./dist/browser/index.js + 6 modules (concatenated)","statSize":13400,"parsedSize":17636,"gzipSize":3492,"concatenated":true,"groups":[{"label":"dist/browser","path":"./dist/browser/index.js + 6 modules (concatenated)/dist/browser","statSize":13400,"groups":[{"id":null,"label":"index.js","path":"./dist/browser/index.js + 6 modules (concatenated)/dist/browser/index.js","statSize":235,"parsedSize":309,"gzipSize":61,"inaccurateSizes":true},{"id":null,"label":"OutOfCanvasUpdater.js","path":"./dist/browser/index.js + 6 modules (concatenated)/dist/browser/OutOfCanvasUpdater.js","statSize":1149,"parsedSize":1512,"gzipSize":299,"inaccurateSizes":true},{"id":null,"label":"BounceOutMode.js","path":"./dist/browser/index.js + 6 modules (concatenated)/dist/browser/BounceOutMode.js","statSize":1230,"parsedSize":1618,"gzipSize":320,"inaccurateSizes":true},{"id":null,"label":"DestroyOutMode.js","path":"./dist/browser/index.js + 6 modules (concatenated)/dist/browser/DestroyOutMode.js","statSize":1209,"parsedSize":1591,"gzipSize":315,"inaccurateSizes":true},{"id":null,"label":"OutOutMode.js","path":"./dist/browser/index.js + 6 modules (concatenated)/dist/browser/OutOutMode.js","statSize":5149,"parsedSize":6776,"gzipSize":1341,"inaccurateSizes":true},{"id":null,"label":"NoneOutMode.js","path":"./dist/browser/index.js + 6 modules (concatenated)/dist/browser/NoneOutMode.js","statSize":1565,"parsedSize":2059,"gzipSize":407,"inaccurateSizes":true},{"id":null,"label":"Utils.js","path":"./dist/browser/index.js + 6 modules (concatenated)/dist/browser/Utils.js","statSize":2863,"parsedSize":3768,"gzipSize":746,"inaccurateSizes":true}],"parsedSize":17636,"gzipSize":3492,"inaccurateSizes":true}]}],"parsedSize":17636,"gzipSize":3492},{"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.updater.out-modes":true}}];
35
35
  window.entrypoints = ["tsparticles.updater.out-modes","tsparticles.updater.out-modes.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.3
7
+ * v3.1.0
8
8
  */
9
9
  (function webpackUniversalModuleDefinition(root, factory) {
10
10
  if(typeof exports === 'object' && typeof module === 'object')
@@ -98,18 +98,20 @@ __webpack_require__.d(__webpack_exports__, {
98
98
  var engine_root_window_ = __webpack_require__(533);
99
99
  ;// CONCATENATED MODULE: ./dist/browser/Utils.js
100
100
 
101
+ const minVelocity = 0,
102
+ boundsMin = 0;
101
103
  function bounceHorizontal(data) {
102
104
  if (data.outMode !== "bounce" && data.outMode !== "bounce-horizontal" && data.outMode !== "bounceHorizontal" && data.outMode !== "split" || data.direction !== "left" && data.direction !== "right") {
103
105
  return;
104
106
  }
105
- if (data.bounds.right < 0 && data.direction === "left") {
107
+ if (data.bounds.right < boundsMin && data.direction === "left") {
106
108
  data.particle.position.x = data.size + data.offset.x;
107
109
  } else if (data.bounds.left > data.canvasSize.width && data.direction === "right") {
108
110
  data.particle.position.x = data.canvasSize.width - data.size - data.offset.x;
109
111
  }
110
112
  const velocity = data.particle.velocity.x;
111
113
  let bounced = false;
112
- if (data.direction === "right" && data.bounds.right >= data.canvasSize.width && velocity > 0 || data.direction === "left" && data.bounds.left <= 0 && velocity < 0) {
114
+ if (data.direction === "right" && data.bounds.right >= data.canvasSize.width && velocity > minVelocity || data.direction === "left" && data.bounds.left <= boundsMin && velocity < minVelocity) {
113
115
  const newVelocity = (0,engine_root_window_.getRangeValue)(data.particle.options.bounce.horizontal.value);
114
116
  data.particle.velocity.x *= -newVelocity;
115
117
  bounced = true;
@@ -120,7 +122,7 @@ function bounceHorizontal(data) {
120
122
  const minPos = data.offset.x + data.size;
121
123
  if (data.bounds.right >= data.canvasSize.width && data.direction === "right") {
122
124
  data.particle.position.x = data.canvasSize.width - minPos;
123
- } else if (data.bounds.left <= 0 && data.direction === "left") {
125
+ } else if (data.bounds.left <= boundsMin && data.direction === "left") {
124
126
  data.particle.position.x = minPos;
125
127
  }
126
128
  if (data.outMode === "split") {
@@ -131,14 +133,14 @@ function bounceVertical(data) {
131
133
  if (data.outMode !== "bounce" && data.outMode !== "bounce-vertical" && data.outMode !== "bounceVertical" && data.outMode !== "split" || data.direction !== "bottom" && data.direction !== "top") {
132
134
  return;
133
135
  }
134
- if (data.bounds.bottom < 0 && data.direction === "top") {
136
+ if (data.bounds.bottom < boundsMin && data.direction === "top") {
135
137
  data.particle.position.y = data.size + data.offset.y;
136
138
  } else if (data.bounds.top > data.canvasSize.height && data.direction === "bottom") {
137
139
  data.particle.position.y = data.canvasSize.height - data.size - data.offset.y;
138
140
  }
139
141
  const velocity = data.particle.velocity.y;
140
142
  let bounced = false;
141
- if (data.direction === "bottom" && data.bounds.bottom >= data.canvasSize.height && velocity > 0 || data.direction === "top" && data.bounds.top <= 0 && velocity < 0) {
143
+ if (data.direction === "bottom" && data.bounds.bottom >= data.canvasSize.height && velocity > minVelocity || data.direction === "top" && data.bounds.top <= boundsMin && velocity < minVelocity) {
142
144
  const newVelocity = (0,engine_root_window_.getRangeValue)(data.particle.options.bounce.vertical.value);
143
145
  data.particle.velocity.y *= -newVelocity;
144
146
  bounced = true;
@@ -149,7 +151,7 @@ function bounceVertical(data) {
149
151
  const minPos = data.offset.y + data.size;
150
152
  if (data.bounds.bottom >= data.canvasSize.height && data.direction === "bottom") {
151
153
  data.particle.position.y = data.canvasSize.height - minPos;
152
- } else if (data.bounds.top <= 0 && data.direction === "top") {
154
+ } else if (data.bounds.top <= boundsMin && data.direction === "top") {
153
155
  data.particle.position.y = minPos;
154
156
  }
155
157
  if (data.outMode === "split") {
@@ -208,6 +210,7 @@ class BounceOutMode {
208
210
  }
209
211
  ;// CONCATENATED MODULE: ./dist/browser/DestroyOutMode.js
210
212
 
213
+ const DestroyOutMode_minVelocity = 0;
211
214
  class DestroyOutMode {
212
215
  constructor(container) {
213
216
  this.container = container;
@@ -235,7 +238,7 @@ class DestroyOutMode {
235
238
  x: vx,
236
239
  y: vy
237
240
  } = particle.velocity;
238
- if (vx < 0 && dx > particle.moveCenter.radius || vy < 0 && dy > particle.moveCenter.radius || vx >= 0 && dx < -particle.moveCenter.radius || vy >= 0 && dy < -particle.moveCenter.radius) {
241
+ if (vx < DestroyOutMode_minVelocity && dx > particle.moveCenter.radius || vy < DestroyOutMode_minVelocity && dy > particle.moveCenter.radius || vx >= DestroyOutMode_minVelocity && dx < -particle.moveCenter.radius || vy >= DestroyOutMode_minVelocity && dy < -particle.moveCenter.radius) {
239
242
  return;
240
243
  }
241
244
  break;
@@ -246,6 +249,7 @@ class DestroyOutMode {
246
249
  }
247
250
  ;// CONCATENATED MODULE: ./dist/browser/NoneOutMode.js
248
251
 
252
+ const NoneOutMode_minVelocity = 0;
249
253
  class NoneOutMode {
250
254
  constructor(container) {
251
255
  this.container = container;
@@ -255,7 +259,7 @@ class NoneOutMode {
255
259
  if (!this.modes.includes(outMode)) {
256
260
  return;
257
261
  }
258
- if (particle.options.move.distance.horizontal && (direction === "left" || direction === "right") || particle.options.move.distance.vertical && (direction === "top" || direction === "bottom")) {
262
+ if ((particle.options.move.distance.horizontal && (direction === "left" || direction === "right")) ?? (particle.options.move.distance.vertical && (direction === "top" || direction === "bottom"))) {
259
263
  return;
260
264
  }
261
265
  const gravityOptions = particle.options.move.gravity,
@@ -263,7 +267,7 @@ class NoneOutMode {
263
267
  const canvasSize = container.canvas.size;
264
268
  const pRadius = particle.getRadius();
265
269
  if (!gravityOptions.enable) {
266
- if (particle.velocity.y > 0 && particle.position.y <= canvasSize.height + pRadius || particle.velocity.y < 0 && particle.position.y >= -pRadius || particle.velocity.x > 0 && particle.position.x <= canvasSize.width + pRadius || particle.velocity.x < 0 && particle.position.x >= -pRadius) {
270
+ if (particle.velocity.y > NoneOutMode_minVelocity && particle.position.y <= canvasSize.height + pRadius || particle.velocity.y < NoneOutMode_minVelocity && particle.position.y >= -pRadius || particle.velocity.x > NoneOutMode_minVelocity && particle.position.x <= canvasSize.width + pRadius || particle.velocity.x < NoneOutMode_minVelocity && particle.position.x >= -pRadius) {
267
271
  return;
268
272
  }
269
273
  if (!(0,engine_root_window_.isPointInside)(particle.position, container.canvas.size, engine_root_window_.Vector.origin, pRadius, direction)) {
@@ -279,6 +283,8 @@ class NoneOutMode {
279
283
  }
280
284
  ;// CONCATENATED MODULE: ./dist/browser/OutOutMode.js
281
285
 
286
+ const OutOutMode_minVelocity = 0,
287
+ minDistance = 0;
282
288
  class OutOutMode {
283
289
  constructor(container) {
284
290
  this.container = container;
@@ -304,7 +310,7 @@ class OutOutMode {
304
310
  dx,
305
311
  dy
306
312
  } = (0,engine_root_window_.getDistances)(particle.position, circVec);
307
- if (vx <= 0 && dx >= 0 || vy <= 0 && dy >= 0 || vx >= 0 && dx <= 0 || vy >= 0 && dy <= 0) {
313
+ if (vx <= OutOutMode_minVelocity && dx >= minDistance || vy <= OutOutMode_minVelocity && dy >= minDistance || vx >= OutOutMode_minVelocity && dx <= minDistance || vy >= OutOutMode_minVelocity && dy <= minDistance) {
308
314
  return;
309
315
  }
310
316
  particle.position.x = Math.floor((0,engine_root_window_.randomInRange)({
@@ -406,12 +412,12 @@ class OutOutMode {
406
412
 
407
413
  class OutOfCanvasUpdater {
408
414
  constructor(container) {
409
- this.container = container;
410
415
  this._updateOutMode = (particle, delta, outMode, direction) => {
411
416
  for (const updater of this.updaters) {
412
417
  updater.update(particle, direction, delta, outMode);
413
418
  }
414
419
  };
420
+ this.container = container;
415
421
  this.updaters = [new BounceOutMode(container), new DestroyOutMode(container), new OutOutMode(container), new NoneOutMode(container)];
416
422
  }
417
423
  init() {}
@@ -1,2 +1,2 @@
1
1
  /*! For license information please see tsparticles.updater.out-modes.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 s=o[t]={exports:{}};return e[t](s,s.exports,i),s.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,{loadOutModesUpdater:()=>c});var t=i(533);class e{constructor(t){this.container=t,this.modes=["bounce","bounce-vertical","bounce-horizontal","bounceVertical","bounceHorizontal","split"]}update(e,o,i,n){if(!this.modes.includes(n))return;const s=this.container;let r=!1;for(const[,t]of s.plugins)if(void 0!==t.particleBounce&&(r=t.particleBounce(e,i,o)),r)break;if(r)return;const a=e.getPosition(),c=e.offset,d=e.getRadius(),u=(0,t.calculateBounds)(a,d),p=s.canvas.size;!function(e){if("bounce"!==e.outMode&&"bounce-horizontal"!==e.outMode&&"bounceHorizontal"!==e.outMode&&"split"!==e.outMode||"left"!==e.direction&&"right"!==e.direction)return;e.bounds.right<0&&"left"===e.direction?e.particle.position.x=e.size+e.offset.x:e.bounds.left>e.canvasSize.width&&"right"===e.direction&&(e.particle.position.x=e.canvasSize.width-e.size-e.offset.x);const o=e.particle.velocity.x;let i=!1;if("right"===e.direction&&e.bounds.right>=e.canvasSize.width&&o>0||"left"===e.direction&&e.bounds.left<=0&&o<0){const o=(0,t.getRangeValue)(e.particle.options.bounce.horizontal.value);e.particle.velocity.x*=-o,i=!0}if(!i)return;const n=e.offset.x+e.size;e.bounds.right>=e.canvasSize.width&&"right"===e.direction?e.particle.position.x=e.canvasSize.width-n:e.bounds.left<=0&&"left"===e.direction&&(e.particle.position.x=n),"split"===e.outMode&&e.particle.destroy()}({particle:e,outMode:n,direction:o,bounds:u,canvasSize:p,offset:c,size:d}),function(e){if("bounce"!==e.outMode&&"bounce-vertical"!==e.outMode&&"bounceVertical"!==e.outMode&&"split"!==e.outMode||"bottom"!==e.direction&&"top"!==e.direction)return;e.bounds.bottom<0&&"top"===e.direction?e.particle.position.y=e.size+e.offset.y:e.bounds.top>e.canvasSize.height&&"bottom"===e.direction&&(e.particle.position.y=e.canvasSize.height-e.size-e.offset.y);const o=e.particle.velocity.y;let i=!1;if("bottom"===e.direction&&e.bounds.bottom>=e.canvasSize.height&&o>0||"top"===e.direction&&e.bounds.top<=0&&o<0){const o=(0,t.getRangeValue)(e.particle.options.bounce.vertical.value);e.particle.velocity.y*=-o,i=!0}if(!i)return;const n=e.offset.y+e.size;e.bounds.bottom>=e.canvasSize.height&&"bottom"===e.direction?e.particle.position.y=e.canvasSize.height-n:e.bounds.top<=0&&"top"===e.direction&&(e.particle.position.y=n),"split"===e.outMode&&e.particle.destroy()}({particle:e,outMode:n,direction:o,bounds:u,canvasSize:p,offset:c,size:d})}}class o{constructor(t){this.container=t,this.modes=["destroy"]}update(e,o,i,n){if(!this.modes.includes(n))return;const s=this.container;switch(e.outType){case"normal":case"outside":if((0,t.isPointInside)(e.position,s.canvas.size,t.Vector.origin,e.getRadius(),o))return;break;case"inside":{const{dx:o,dy:i}=(0,t.getDistances)(e.position,e.moveCenter),{x:n,y:s}=e.velocity;if(n<0&&o>e.moveCenter.radius||s<0&&i>e.moveCenter.radius||n>=0&&o<-e.moveCenter.radius||s>=0&&i<-e.moveCenter.radius)return;break}}s.particles.remove(e,void 0,!0)}}class s{constructor(t){this.container=t,this.modes=["none"]}update(e,o,i,n){if(!this.modes.includes(n))return;if(e.options.move.distance.horizontal&&("left"===o||"right"===o)||e.options.move.distance.vertical&&("top"===o||"bottom"===o))return;const s=e.options.move.gravity,r=this.container,a=r.canvas.size,c=e.getRadius();if(s.enable){const t=e.position;(!s.inverse&&t.y>a.height+c&&"bottom"===o||s.inverse&&t.y<-c&&"top"===o)&&r.particles.remove(e)}else{if(e.velocity.y>0&&e.position.y<=a.height+c||e.velocity.y<0&&e.position.y>=-c||e.velocity.x>0&&e.position.x<=a.width+c||e.velocity.x<0&&e.position.x>=-c)return;(0,t.isPointInside)(e.position,r.canvas.size,t.Vector.origin,c,o)||r.particles.remove(e)}}}class r{constructor(t){this.container=t,this.modes=["out"]}update(e,o,i,n){if(!this.modes.includes(n))return;const s=this.container;switch(e.outType){case"inside":{const{x:o,y:i}=e.velocity,n=t.Vector.origin;n.length=e.moveCenter.radius,n.angle=e.velocity.angle+Math.PI,n.addTo(t.Vector.create(e.moveCenter));const{dx:r,dy:a}=(0,t.getDistances)(e.position,n);if(o<=0&&r>=0||i<=0&&a>=0||o>=0&&r<=0||i>=0&&a<=0)return;e.position.x=Math.floor((0,t.randomInRange)({min:0,max:s.canvas.size.width})),e.position.y=Math.floor((0,t.randomInRange)({min:0,max:s.canvas.size.height}));const{dx:c,dy:d}=(0,t.getDistances)(e.position,e.moveCenter);e.direction=Math.atan2(-d,-c),e.velocity.angle=e.direction;break}default:if((0,t.isPointInside)(e.position,s.canvas.size,t.Vector.origin,e.getRadius(),o))return;switch(e.outType){case"outside":{e.position.x=Math.floor((0,t.randomInRange)({min:-e.moveCenter.radius,max:e.moveCenter.radius}))+e.moveCenter.x,e.position.y=Math.floor((0,t.randomInRange)({min:-e.moveCenter.radius,max:e.moveCenter.radius}))+e.moveCenter.y;const{dx:o,dy:i}=(0,t.getDistances)(e.position,e.moveCenter);e.moveCenter.radius&&(e.direction=Math.atan2(i,o),e.velocity.angle=e.direction);break}case"normal":{const i=e.options.move.warp,n=s.canvas.size,r={bottom:n.height+e.getRadius()+e.offset.y,left:-e.getRadius()-e.offset.x,right:n.width+e.getRadius()+e.offset.x,top:-e.getRadius()-e.offset.y},a=e.getRadius(),c=(0,t.calculateBounds)(e.position,a);"right"===o&&c.left>n.width+e.offset.x?(e.position.x=r.left,e.initialPosition.x=e.position.x,i||(e.position.y=(0,t.getRandom)()*n.height,e.initialPosition.y=e.position.y)):"left"===o&&c.right<-e.offset.x&&(e.position.x=r.right,e.initialPosition.x=e.position.x,i||(e.position.y=(0,t.getRandom)()*n.height,e.initialPosition.y=e.position.y)),"bottom"===o&&c.top>n.height+e.offset.y?(i||(e.position.x=(0,t.getRandom)()*n.width,e.initialPosition.x=e.position.x),e.position.y=r.top,e.initialPosition.y=e.position.y):"top"===o&&c.bottom<-e.offset.y&&(i||(e.position.x=(0,t.getRandom)()*n.width,e.initialPosition.x=e.position.x),e.position.y=r.bottom,e.initialPosition.y=e.position.y);break}}}}}class a{constructor(t){this.container=t,this._updateOutMode=(t,e,o,i)=>{for(const n of this.updaters)n.update(t,i,e,o)},this.updaters=[new e(t),new o(t),new r(t),new s(t)]}init(){}isEnabled(t){return!t.destroyed&&!t.spawning}update(t,e){const o=t.options.move.outModes;this._updateOutMode(t,e,o.bottom??o.default,"bottom"),this._updateOutMode(t,e,o.left??o.default,"left"),this._updateOutMode(t,e,o.right??o.default,"right"),this._updateOutMode(t,e,o.top??o.default,"top")}}async function c(t,e=!0){await t.addParticleUpdater("outModes",(t=>new a(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 s=o[t]={exports:{}};return e[t](s,s.exports,i),s.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,{loadOutModesUpdater:()=>c});var t=i(533);class e{constructor(t){this.container=t,this.modes=["bounce","bounce-vertical","bounce-horizontal","bounceVertical","bounceHorizontal","split"]}update(e,o,i,n){if(!this.modes.includes(n))return;const s=this.container;let r=!1;for(const[,t]of s.plugins)if(void 0!==t.particleBounce&&(r=t.particleBounce(e,i,o)),r)break;if(r)return;const a=e.getPosition(),c=e.offset,d=e.getRadius(),u=(0,t.calculateBounds)(a,d),p=s.canvas.size;!function(e){if("bounce"!==e.outMode&&"bounce-horizontal"!==e.outMode&&"bounceHorizontal"!==e.outMode&&"split"!==e.outMode||"left"!==e.direction&&"right"!==e.direction)return;e.bounds.right<0&&"left"===e.direction?e.particle.position.x=e.size+e.offset.x:e.bounds.left>e.canvasSize.width&&"right"===e.direction&&(e.particle.position.x=e.canvasSize.width-e.size-e.offset.x);const o=e.particle.velocity.x;let i=!1;if("right"===e.direction&&e.bounds.right>=e.canvasSize.width&&o>0||"left"===e.direction&&e.bounds.left<=0&&o<0){const o=(0,t.getRangeValue)(e.particle.options.bounce.horizontal.value);e.particle.velocity.x*=-o,i=!0}if(!i)return;const n=e.offset.x+e.size;e.bounds.right>=e.canvasSize.width&&"right"===e.direction?e.particle.position.x=e.canvasSize.width-n:e.bounds.left<=0&&"left"===e.direction&&(e.particle.position.x=n),"split"===e.outMode&&e.particle.destroy()}({particle:e,outMode:n,direction:o,bounds:u,canvasSize:p,offset:c,size:d}),function(e){if("bounce"!==e.outMode&&"bounce-vertical"!==e.outMode&&"bounceVertical"!==e.outMode&&"split"!==e.outMode||"bottom"!==e.direction&&"top"!==e.direction)return;e.bounds.bottom<0&&"top"===e.direction?e.particle.position.y=e.size+e.offset.y:e.bounds.top>e.canvasSize.height&&"bottom"===e.direction&&(e.particle.position.y=e.canvasSize.height-e.size-e.offset.y);const o=e.particle.velocity.y;let i=!1;if("bottom"===e.direction&&e.bounds.bottom>=e.canvasSize.height&&o>0||"top"===e.direction&&e.bounds.top<=0&&o<0){const o=(0,t.getRangeValue)(e.particle.options.bounce.vertical.value);e.particle.velocity.y*=-o,i=!0}if(!i)return;const n=e.offset.y+e.size;e.bounds.bottom>=e.canvasSize.height&&"bottom"===e.direction?e.particle.position.y=e.canvasSize.height-n:e.bounds.top<=0&&"top"===e.direction&&(e.particle.position.y=n),"split"===e.outMode&&e.particle.destroy()}({particle:e,outMode:n,direction:o,bounds:u,canvasSize:p,offset:c,size:d})}}class o{constructor(t){this.container=t,this.modes=["destroy"]}update(e,o,i,n){if(!this.modes.includes(n))return;const s=this.container;switch(e.outType){case"normal":case"outside":if((0,t.isPointInside)(e.position,s.canvas.size,t.Vector.origin,e.getRadius(),o))return;break;case"inside":{const{dx:o,dy:i}=(0,t.getDistances)(e.position,e.moveCenter),{x:n,y:s}=e.velocity;if(n<0&&o>e.moveCenter.radius||s<0&&i>e.moveCenter.radius||n>=0&&o<-e.moveCenter.radius||s>=0&&i<-e.moveCenter.radius)return;break}}s.particles.remove(e,void 0,!0)}}class s{constructor(t){this.container=t,this.modes=["none"]}update(e,o,i,n){if(!this.modes.includes(n))return;if((e.options.move.distance.horizontal&&("left"===o||"right"===o))??(e.options.move.distance.vertical&&("top"===o||"bottom"===o)))return;const s=e.options.move.gravity,r=this.container,a=r.canvas.size,c=e.getRadius();if(s.enable){const t=e.position;(!s.inverse&&t.y>a.height+c&&"bottom"===o||s.inverse&&t.y<-c&&"top"===o)&&r.particles.remove(e)}else{if(e.velocity.y>0&&e.position.y<=a.height+c||e.velocity.y<0&&e.position.y>=-c||e.velocity.x>0&&e.position.x<=a.width+c||e.velocity.x<0&&e.position.x>=-c)return;(0,t.isPointInside)(e.position,r.canvas.size,t.Vector.origin,c,o)||r.particles.remove(e)}}}class r{constructor(t){this.container=t,this.modes=["out"]}update(e,o,i,n){if(!this.modes.includes(n))return;const s=this.container;switch(e.outType){case"inside":{const{x:o,y:i}=e.velocity,n=t.Vector.origin;n.length=e.moveCenter.radius,n.angle=e.velocity.angle+Math.PI,n.addTo(t.Vector.create(e.moveCenter));const{dx:r,dy:a}=(0,t.getDistances)(e.position,n);if(o<=0&&r>=0||i<=0&&a>=0||o>=0&&r<=0||i>=0&&a<=0)return;e.position.x=Math.floor((0,t.randomInRange)({min:0,max:s.canvas.size.width})),e.position.y=Math.floor((0,t.randomInRange)({min:0,max:s.canvas.size.height}));const{dx:c,dy:d}=(0,t.getDistances)(e.position,e.moveCenter);e.direction=Math.atan2(-d,-c),e.velocity.angle=e.direction;break}default:if((0,t.isPointInside)(e.position,s.canvas.size,t.Vector.origin,e.getRadius(),o))return;switch(e.outType){case"outside":{e.position.x=Math.floor((0,t.randomInRange)({min:-e.moveCenter.radius,max:e.moveCenter.radius}))+e.moveCenter.x,e.position.y=Math.floor((0,t.randomInRange)({min:-e.moveCenter.radius,max:e.moveCenter.radius}))+e.moveCenter.y;const{dx:o,dy:i}=(0,t.getDistances)(e.position,e.moveCenter);e.moveCenter.radius&&(e.direction=Math.atan2(i,o),e.velocity.angle=e.direction);break}case"normal":{const i=e.options.move.warp,n=s.canvas.size,r={bottom:n.height+e.getRadius()+e.offset.y,left:-e.getRadius()-e.offset.x,right:n.width+e.getRadius()+e.offset.x,top:-e.getRadius()-e.offset.y},a=e.getRadius(),c=(0,t.calculateBounds)(e.position,a);"right"===o&&c.left>n.width+e.offset.x?(e.position.x=r.left,e.initialPosition.x=e.position.x,i||(e.position.y=(0,t.getRandom)()*n.height,e.initialPosition.y=e.position.y)):"left"===o&&c.right<-e.offset.x&&(e.position.x=r.right,e.initialPosition.x=e.position.x,i||(e.position.y=(0,t.getRandom)()*n.height,e.initialPosition.y=e.position.y)),"bottom"===o&&c.top>n.height+e.offset.y?(i||(e.position.x=(0,t.getRandom)()*n.width,e.initialPosition.x=e.position.x),e.position.y=r.top,e.initialPosition.y=e.position.y):"top"===o&&c.bottom<-e.offset.y&&(i||(e.position.x=(0,t.getRandom)()*n.width,e.initialPosition.x=e.position.x),e.position.y=r.bottom,e.initialPosition.y=e.position.y);break}}}}}class a{constructor(t){this._updateOutMode=(t,e,o,i)=>{for(const n of this.updaters)n.update(t,i,e,o)},this.container=t,this.updaters=[new e(t),new o(t),new r(t),new s(t)]}init(){}isEnabled(t){return!t.destroyed&&!t.spawning}update(t,e){const o=t.options.move.outModes;this._updateOutMode(t,e,o.bottom??o.default,"bottom"),this._updateOutMode(t,e,o.left??o.default,"left"),this._updateOutMode(t,e,o.right??o.default,"right"),this._updateOutMode(t,e,o.top??o.default,"top")}}async function c(t,e=!0){await t.addParticleUpdater("outModes",(t=>new a(t)),e)}})(),n})()));
@@ -1 +1 @@
1
- /*! tsParticles Out Modes Updater v3.0.3 by Matteo Bruni */
1
+ /*! tsParticles Out Modes Updater v3.1.0 by Matteo Bruni */
@@ -1,8 +1,8 @@
1
1
  import { type Container, type IDelta, type IParticleUpdater, type Particle } from "@tsparticles/engine";
2
2
  import type { IOutModeManager } from "./IOutModeManager.js";
3
3
  export declare class OutOfCanvasUpdater implements IParticleUpdater {
4
- private readonly container;
5
4
  updaters: IOutModeManager[];
5
+ private readonly container;
6
6
  constructor(container: Container);
7
7
  init(): void;
8
8
  isEnabled(particle: Particle): boolean;
@@ -11,6 +11,7 @@
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.DestroyOutMode = void 0;
13
13
  const engine_1 = require("@tsparticles/engine");
14
+ const minVelocity = 0;
14
15
  class DestroyOutMode {
15
16
  constructor(container) {
16
17
  this.container = container;
@@ -31,10 +32,10 @@
31
32
  case "inside": {
32
33
  const { dx, dy } = (0, engine_1.getDistances)(particle.position, particle.moveCenter);
33
34
  const { x: vx, y: vy } = particle.velocity;
34
- if ((vx < 0 && dx > particle.moveCenter.radius) ||
35
- (vy < 0 && dy > particle.moveCenter.radius) ||
36
- (vx >= 0 && dx < -particle.moveCenter.radius) ||
37
- (vy >= 0 && dy < -particle.moveCenter.radius)) {
35
+ if ((vx < minVelocity && dx > particle.moveCenter.radius) ||
36
+ (vy < minVelocity && dy > particle.moveCenter.radius) ||
37
+ (vx >= minVelocity && dx < -particle.moveCenter.radius) ||
38
+ (vy >= minVelocity && dy < -particle.moveCenter.radius)) {
38
39
  return;
39
40
  }
40
41
  break;
@@ -11,6 +11,7 @@
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.NoneOutMode = void 0;
13
13
  const engine_1 = require("@tsparticles/engine");
14
+ const minVelocity = 0;
14
15
  class NoneOutMode {
15
16
  constructor(container) {
16
17
  this.container = container;
@@ -21,7 +22,7 @@
21
22
  return;
22
23
  }
23
24
  if ((particle.options.move.distance.horizontal &&
24
- (direction === "left" || direction === "right")) ||
25
+ (direction === "left" || direction === "right")) ??
25
26
  (particle.options.move.distance.vertical &&
26
27
  (direction === "top" || direction === "bottom"))) {
27
28
  return;
@@ -30,10 +31,10 @@
30
31
  const canvasSize = container.canvas.size;
31
32
  const pRadius = particle.getRadius();
32
33
  if (!gravityOptions.enable) {
33
- if ((particle.velocity.y > 0 && particle.position.y <= canvasSize.height + pRadius) ||
34
- (particle.velocity.y < 0 && particle.position.y >= -pRadius) ||
35
- (particle.velocity.x > 0 && particle.position.x <= canvasSize.width + pRadius) ||
36
- (particle.velocity.x < 0 && particle.position.x >= -pRadius)) {
34
+ if ((particle.velocity.y > minVelocity && particle.position.y <= canvasSize.height + pRadius) ||
35
+ (particle.velocity.y < minVelocity && particle.position.y >= -pRadius) ||
36
+ (particle.velocity.x > minVelocity && particle.position.x <= canvasSize.width + pRadius) ||
37
+ (particle.velocity.x < minVelocity && particle.position.x >= -pRadius)) {
37
38
  return;
38
39
  }
39
40
  if (!(0, engine_1.isPointInside)(particle.position, container.canvas.size, engine_1.Vector.origin, pRadius, direction)) {
@@ -16,12 +16,12 @@
16
16
  const OutOutMode_js_1 = require("./OutOutMode.js");
17
17
  class OutOfCanvasUpdater {
18
18
  constructor(container) {
19
- this.container = container;
20
19
  this._updateOutMode = (particle, delta, outMode, direction) => {
21
20
  for (const updater of this.updaters) {
22
21
  updater.update(particle, direction, delta, outMode);
23
22
  }
24
23
  };
24
+ this.container = container;
25
25
  this.updaters = [
26
26
  new BounceOutMode_js_1.BounceOutMode(container),
27
27
  new DestroyOutMode_js_1.DestroyOutMode(container),
package/umd/OutOutMode.js CHANGED
@@ -11,6 +11,7 @@
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.OutOutMode = void 0;
13
13
  const engine_1 = require("@tsparticles/engine");
14
+ const minVelocity = 0, minDistance = 0;
14
15
  class OutOutMode {
15
16
  constructor(container) {
16
17
  this.container = container;
@@ -29,7 +30,10 @@
29
30
  circVec.angle = particle.velocity.angle + Math.PI;
30
31
  circVec.addTo(engine_1.Vector.create(particle.moveCenter));
31
32
  const { dx, dy } = (0, engine_1.getDistances)(particle.position, circVec);
32
- if ((vx <= 0 && dx >= 0) || (vy <= 0 && dy >= 0) || (vx >= 0 && dx <= 0) || (vy >= 0 && dy <= 0)) {
33
+ if ((vx <= minVelocity && dx >= minDistance) ||
34
+ (vy <= minVelocity && dy >= minDistance) ||
35
+ (vx >= minVelocity && dx <= minDistance) ||
36
+ (vy >= minVelocity && dy <= minDistance)) {
33
37
  return;
34
38
  }
35
39
  particle.position.x = Math.floor((0, engine_1.randomInRange)({
package/umd/Utils.js CHANGED
@@ -11,6 +11,7 @@
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.bounceVertical = exports.bounceHorizontal = void 0;
13
13
  const engine_1 = require("@tsparticles/engine");
14
+ const minVelocity = 0, boundsMin = 0;
14
15
  function bounceHorizontal(data) {
15
16
  if ((data.outMode !== "bounce" &&
16
17
  data.outMode !== "bounce-horizontal" &&
@@ -19,7 +20,7 @@
19
20
  (data.direction !== "left" && data.direction !== "right")) {
20
21
  return;
21
22
  }
22
- if (data.bounds.right < 0 && data.direction === "left") {
23
+ if (data.bounds.right < boundsMin && data.direction === "left") {
23
24
  data.particle.position.x = data.size + data.offset.x;
24
25
  }
25
26
  else if (data.bounds.left > data.canvasSize.width && data.direction === "right") {
@@ -27,8 +28,10 @@
27
28
  }
28
29
  const velocity = data.particle.velocity.x;
29
30
  let bounced = false;
30
- if ((data.direction === "right" && data.bounds.right >= data.canvasSize.width && velocity > 0) ||
31
- (data.direction === "left" && data.bounds.left <= 0 && velocity < 0)) {
31
+ if ((data.direction === "right" &&
32
+ data.bounds.right >= data.canvasSize.width &&
33
+ velocity > minVelocity) ||
34
+ (data.direction === "left" && data.bounds.left <= boundsMin && velocity < minVelocity)) {
32
35
  const newVelocity = (0, engine_1.getRangeValue)(data.particle.options.bounce.horizontal.value);
33
36
  data.particle.velocity.x *= -newVelocity;
34
37
  bounced = true;
@@ -40,7 +43,7 @@
40
43
  if (data.bounds.right >= data.canvasSize.width && data.direction === "right") {
41
44
  data.particle.position.x = data.canvasSize.width - minPos;
42
45
  }
43
- else if (data.bounds.left <= 0 && data.direction === "left") {
46
+ else if (data.bounds.left <= boundsMin && data.direction === "left") {
44
47
  data.particle.position.x = minPos;
45
48
  }
46
49
  if (data.outMode === "split") {
@@ -56,7 +59,7 @@
56
59
  (data.direction !== "bottom" && data.direction !== "top")) {
57
60
  return;
58
61
  }
59
- if (data.bounds.bottom < 0 && data.direction === "top") {
62
+ if (data.bounds.bottom < boundsMin && data.direction === "top") {
60
63
  data.particle.position.y = data.size + data.offset.y;
61
64
  }
62
65
  else if (data.bounds.top > data.canvasSize.height && data.direction === "bottom") {
@@ -64,8 +67,10 @@
64
67
  }
65
68
  const velocity = data.particle.velocity.y;
66
69
  let bounced = false;
67
- if ((data.direction === "bottom" && data.bounds.bottom >= data.canvasSize.height && velocity > 0) ||
68
- (data.direction === "top" && data.bounds.top <= 0 && velocity < 0)) {
70
+ if ((data.direction === "bottom" &&
71
+ data.bounds.bottom >= data.canvasSize.height &&
72
+ velocity > minVelocity) ||
73
+ (data.direction === "top" && data.bounds.top <= boundsMin && velocity < minVelocity)) {
69
74
  const newVelocity = (0, engine_1.getRangeValue)(data.particle.options.bounce.vertical.value);
70
75
  data.particle.velocity.y *= -newVelocity;
71
76
  bounced = true;
@@ -77,7 +82,7 @@
77
82
  if (data.bounds.bottom >= data.canvasSize.height && data.direction === "bottom") {
78
83
  data.particle.position.y = data.canvasSize.height - minPos;
79
84
  }
80
- else if (data.bounds.top <= 0 && data.direction === "top") {
85
+ else if (data.bounds.top <= boundsMin && data.direction === "top") {
81
86
  data.particle.position.y = minPos;
82
87
  }
83
88
  if (data.outMode === "split") {