@tsparticles/updater-destroy 3.0.2 → 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,10 +1,10 @@
1
- import { getRangeValue, } from "@tsparticles/engine";
1
+ import { getRangeValue, percentDenominator, } from "@tsparticles/engine";
2
2
  import { Destroy } from "./Options/Classes/Destroy.js";
3
3
  import { split } from "./Utils.js";
4
4
  export class DestroyUpdater {
5
5
  constructor(engine, container) {
6
- this.engine = engine;
7
6
  this.container = container;
7
+ this.engine = engine;
8
8
  }
9
9
  init(particle) {
10
10
  const container = this.container, particlesOptions = particle.options, destroyOptions = particlesOptions.destroy;
@@ -18,16 +18,16 @@ export class DestroyUpdater {
18
18
  }
19
19
  const { bottom, left, right, top } = destroyBoundsOptions, { destroyBounds } = particle, canvasSize = container.canvas.size;
20
20
  if (bottom) {
21
- destroyBounds.bottom = (getRangeValue(bottom) * canvasSize.height) / 100;
21
+ destroyBounds.bottom = (getRangeValue(bottom) * canvasSize.height) / percentDenominator;
22
22
  }
23
23
  if (left) {
24
- destroyBounds.left = (getRangeValue(left) * canvasSize.width) / 100;
24
+ destroyBounds.left = (getRangeValue(left) * canvasSize.width) / percentDenominator;
25
25
  }
26
26
  if (right) {
27
- destroyBounds.right = (getRangeValue(right) * canvasSize.width) / 100;
27
+ destroyBounds.right = (getRangeValue(right) * canvasSize.width) / percentDenominator;
28
28
  }
29
29
  if (top) {
30
- destroyBounds.top = (getRangeValue(top) * canvasSize.height) / 100;
30
+ destroyBounds.top = (getRangeValue(top) * canvasSize.height) / percentDenominator;
31
31
  }
32
32
  }
33
33
  isEnabled(particle) {
package/browser/Utils.js CHANGED
@@ -1,4 +1,5 @@
1
1
  import { getRangeValue, isNumber, itemFromSingleOrMultiple, loadParticlesOptions, randomInRange, setRangeValue, } from "@tsparticles/engine";
2
+ const defaultOffset = 0, minDestroySize = 0.5, defaultSplitCount = 0, increment = 1, unbreakableTime = 500, minSplitCount = 0;
2
3
  function addSplitParticle(engine, container, parent, splitParticlesOptions) {
3
4
  const destroyOptions = parent.options.destroy;
4
5
  if (!destroyOptions) {
@@ -12,9 +13,9 @@ function addSplitParticle(engine, container, parent, splitParticlesOptions) {
12
13
  options.color.load({
13
14
  value: {
14
15
  hsl: {
15
- h: parentColor.h + getRangeValue(splitOptions.colorOffset.h ?? 0),
16
- s: parentColor.s + getRangeValue(splitOptions.colorOffset.s ?? 0),
17
- l: parentColor.l + getRangeValue(splitOptions.colorOffset.l ?? 0),
16
+ h: parentColor.h + getRangeValue(splitOptions.colorOffset.h ?? defaultOffset),
17
+ s: parentColor.s + getRangeValue(splitOptions.colorOffset.s ?? defaultOffset),
18
+ l: parentColor.l + getRangeValue(splitOptions.colorOffset.l ?? defaultOffset),
18
19
  },
19
20
  },
20
21
  });
@@ -41,20 +42,20 @@ function addSplitParticle(engine, container, parent, splitParticlesOptions) {
41
42
  options.size.value.max /= factor;
42
43
  }
43
44
  options.load(splitParticlesOptions);
44
- const offset = splitOptions.sizeOffset ? setRangeValue(-parent.size.value, parent.size.value) : 0, position = {
45
+ const offset = splitOptions.sizeOffset ? setRangeValue(-parent.size.value, parent.size.value) : defaultOffset, position = {
45
46
  x: parent.position.x + randomInRange(offset),
46
47
  y: parent.position.y + randomInRange(offset),
47
48
  };
48
49
  return container.particles.addParticle(position, options, parent.group, (particle) => {
49
- if (particle.size.value < 0.5) {
50
+ if (particle.size.value < minDestroySize) {
50
51
  return false;
51
52
  }
52
53
  particle.velocity.length = randomInRange(setRangeValue(parent.velocity.length, particle.velocity.length));
53
- particle.splitCount = (parent.splitCount ?? 0) + 1;
54
+ particle.splitCount = (parent.splitCount ?? defaultSplitCount) + increment;
54
55
  particle.unbreakable = true;
55
56
  setTimeout(() => {
56
57
  particle.unbreakable = false;
57
- }, 500);
58
+ }, unbreakableTime);
58
59
  return true;
59
60
  });
60
61
  }
@@ -64,7 +65,8 @@ export function split(engine, container, particle) {
64
65
  return;
65
66
  }
66
67
  const splitOptions = destroyOptions.split;
67
- if (splitOptions.count >= 0 && (particle.splitCount === undefined || particle.splitCount++ > splitOptions.count)) {
68
+ if (splitOptions.count >= minSplitCount &&
69
+ (particle.splitCount === undefined || particle.splitCount++ > splitOptions.count)) {
68
70
  return;
69
71
  }
70
72
  const rate = getRangeValue(splitOptions.rate.value), particlesSplitOptions = itemFromSingleOrMultiple(splitOptions.particles);
@@ -6,8 +6,8 @@ const Destroy_js_1 = require("./Options/Classes/Destroy.js");
6
6
  const Utils_js_1 = require("./Utils.js");
7
7
  class DestroyUpdater {
8
8
  constructor(engine, container) {
9
- this.engine = engine;
10
9
  this.container = container;
10
+ this.engine = engine;
11
11
  }
12
12
  init(particle) {
13
13
  const container = this.container, particlesOptions = particle.options, destroyOptions = particlesOptions.destroy;
@@ -21,16 +21,16 @@ class DestroyUpdater {
21
21
  }
22
22
  const { bottom, left, right, top } = destroyBoundsOptions, { destroyBounds } = particle, canvasSize = container.canvas.size;
23
23
  if (bottom) {
24
- destroyBounds.bottom = ((0, engine_1.getRangeValue)(bottom) * canvasSize.height) / 100;
24
+ destroyBounds.bottom = ((0, engine_1.getRangeValue)(bottom) * canvasSize.height) / engine_1.percentDenominator;
25
25
  }
26
26
  if (left) {
27
- destroyBounds.left = ((0, engine_1.getRangeValue)(left) * canvasSize.width) / 100;
27
+ destroyBounds.left = ((0, engine_1.getRangeValue)(left) * canvasSize.width) / engine_1.percentDenominator;
28
28
  }
29
29
  if (right) {
30
- destroyBounds.right = ((0, engine_1.getRangeValue)(right) * canvasSize.width) / 100;
30
+ destroyBounds.right = ((0, engine_1.getRangeValue)(right) * canvasSize.width) / engine_1.percentDenominator;
31
31
  }
32
32
  if (top) {
33
- destroyBounds.top = ((0, engine_1.getRangeValue)(top) * canvasSize.height) / 100;
33
+ destroyBounds.top = ((0, engine_1.getRangeValue)(top) * canvasSize.height) / engine_1.percentDenominator;
34
34
  }
35
35
  }
36
36
  isEnabled(particle) {
package/cjs/Utils.js CHANGED
@@ -2,6 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.split = void 0;
4
4
  const engine_1 = require("@tsparticles/engine");
5
+ const defaultOffset = 0, minDestroySize = 0.5, defaultSplitCount = 0, increment = 1, unbreakableTime = 500, minSplitCount = 0;
5
6
  function addSplitParticle(engine, container, parent, splitParticlesOptions) {
6
7
  const destroyOptions = parent.options.destroy;
7
8
  if (!destroyOptions) {
@@ -15,9 +16,9 @@ function addSplitParticle(engine, container, parent, splitParticlesOptions) {
15
16
  options.color.load({
16
17
  value: {
17
18
  hsl: {
18
- h: parentColor.h + (0, engine_1.getRangeValue)(splitOptions.colorOffset.h ?? 0),
19
- s: parentColor.s + (0, engine_1.getRangeValue)(splitOptions.colorOffset.s ?? 0),
20
- l: parentColor.l + (0, engine_1.getRangeValue)(splitOptions.colorOffset.l ?? 0),
19
+ h: parentColor.h + (0, engine_1.getRangeValue)(splitOptions.colorOffset.h ?? defaultOffset),
20
+ s: parentColor.s + (0, engine_1.getRangeValue)(splitOptions.colorOffset.s ?? defaultOffset),
21
+ l: parentColor.l + (0, engine_1.getRangeValue)(splitOptions.colorOffset.l ?? defaultOffset),
21
22
  },
22
23
  },
23
24
  });
@@ -44,20 +45,20 @@ function addSplitParticle(engine, container, parent, splitParticlesOptions) {
44
45
  options.size.value.max /= factor;
45
46
  }
46
47
  options.load(splitParticlesOptions);
47
- const offset = splitOptions.sizeOffset ? (0, engine_1.setRangeValue)(-parent.size.value, parent.size.value) : 0, position = {
48
+ const offset = splitOptions.sizeOffset ? (0, engine_1.setRangeValue)(-parent.size.value, parent.size.value) : defaultOffset, position = {
48
49
  x: parent.position.x + (0, engine_1.randomInRange)(offset),
49
50
  y: parent.position.y + (0, engine_1.randomInRange)(offset),
50
51
  };
51
52
  return container.particles.addParticle(position, options, parent.group, (particle) => {
52
- if (particle.size.value < 0.5) {
53
+ if (particle.size.value < minDestroySize) {
53
54
  return false;
54
55
  }
55
56
  particle.velocity.length = (0, engine_1.randomInRange)((0, engine_1.setRangeValue)(parent.velocity.length, particle.velocity.length));
56
- particle.splitCount = (parent.splitCount ?? 0) + 1;
57
+ particle.splitCount = (parent.splitCount ?? defaultSplitCount) + increment;
57
58
  particle.unbreakable = true;
58
59
  setTimeout(() => {
59
60
  particle.unbreakable = false;
60
- }, 500);
61
+ }, unbreakableTime);
61
62
  return true;
62
63
  });
63
64
  }
@@ -67,7 +68,8 @@ function split(engine, container, particle) {
67
68
  return;
68
69
  }
69
70
  const splitOptions = destroyOptions.split;
70
- if (splitOptions.count >= 0 && (particle.splitCount === undefined || particle.splitCount++ > splitOptions.count)) {
71
+ if (splitOptions.count >= minSplitCount &&
72
+ (particle.splitCount === undefined || particle.splitCount++ > splitOptions.count)) {
71
73
  return;
72
74
  }
73
75
  const rate = (0, engine_1.getRangeValue)(splitOptions.rate.value), particlesSplitOptions = (0, engine_1.itemFromSingleOrMultiple)(splitOptions.particles);
@@ -1,10 +1,10 @@
1
- import { getRangeValue, } from "@tsparticles/engine";
1
+ import { getRangeValue, percentDenominator, } from "@tsparticles/engine";
2
2
  import { Destroy } from "./Options/Classes/Destroy.js";
3
3
  import { split } from "./Utils.js";
4
4
  export class DestroyUpdater {
5
5
  constructor(engine, container) {
6
- this.engine = engine;
7
6
  this.container = container;
7
+ this.engine = engine;
8
8
  }
9
9
  init(particle) {
10
10
  const container = this.container, particlesOptions = particle.options, destroyOptions = particlesOptions.destroy;
@@ -18,16 +18,16 @@ export class DestroyUpdater {
18
18
  }
19
19
  const { bottom, left, right, top } = destroyBoundsOptions, { destroyBounds } = particle, canvasSize = container.canvas.size;
20
20
  if (bottom) {
21
- destroyBounds.bottom = (getRangeValue(bottom) * canvasSize.height) / 100;
21
+ destroyBounds.bottom = (getRangeValue(bottom) * canvasSize.height) / percentDenominator;
22
22
  }
23
23
  if (left) {
24
- destroyBounds.left = (getRangeValue(left) * canvasSize.width) / 100;
24
+ destroyBounds.left = (getRangeValue(left) * canvasSize.width) / percentDenominator;
25
25
  }
26
26
  if (right) {
27
- destroyBounds.right = (getRangeValue(right) * canvasSize.width) / 100;
27
+ destroyBounds.right = (getRangeValue(right) * canvasSize.width) / percentDenominator;
28
28
  }
29
29
  if (top) {
30
- destroyBounds.top = (getRangeValue(top) * canvasSize.height) / 100;
30
+ destroyBounds.top = (getRangeValue(top) * canvasSize.height) / percentDenominator;
31
31
  }
32
32
  }
33
33
  isEnabled(particle) {
package/esm/Utils.js CHANGED
@@ -1,4 +1,5 @@
1
1
  import { getRangeValue, isNumber, itemFromSingleOrMultiple, loadParticlesOptions, randomInRange, setRangeValue, } from "@tsparticles/engine";
2
+ const defaultOffset = 0, minDestroySize = 0.5, defaultSplitCount = 0, increment = 1, unbreakableTime = 500, minSplitCount = 0;
2
3
  function addSplitParticle(engine, container, parent, splitParticlesOptions) {
3
4
  const destroyOptions = parent.options.destroy;
4
5
  if (!destroyOptions) {
@@ -12,9 +13,9 @@ function addSplitParticle(engine, container, parent, splitParticlesOptions) {
12
13
  options.color.load({
13
14
  value: {
14
15
  hsl: {
15
- h: parentColor.h + getRangeValue(splitOptions.colorOffset.h ?? 0),
16
- s: parentColor.s + getRangeValue(splitOptions.colorOffset.s ?? 0),
17
- l: parentColor.l + getRangeValue(splitOptions.colorOffset.l ?? 0),
16
+ h: parentColor.h + getRangeValue(splitOptions.colorOffset.h ?? defaultOffset),
17
+ s: parentColor.s + getRangeValue(splitOptions.colorOffset.s ?? defaultOffset),
18
+ l: parentColor.l + getRangeValue(splitOptions.colorOffset.l ?? defaultOffset),
18
19
  },
19
20
  },
20
21
  });
@@ -41,20 +42,20 @@ function addSplitParticle(engine, container, parent, splitParticlesOptions) {
41
42
  options.size.value.max /= factor;
42
43
  }
43
44
  options.load(splitParticlesOptions);
44
- const offset = splitOptions.sizeOffset ? setRangeValue(-parent.size.value, parent.size.value) : 0, position = {
45
+ const offset = splitOptions.sizeOffset ? setRangeValue(-parent.size.value, parent.size.value) : defaultOffset, position = {
45
46
  x: parent.position.x + randomInRange(offset),
46
47
  y: parent.position.y + randomInRange(offset),
47
48
  };
48
49
  return container.particles.addParticle(position, options, parent.group, (particle) => {
49
- if (particle.size.value < 0.5) {
50
+ if (particle.size.value < minDestroySize) {
50
51
  return false;
51
52
  }
52
53
  particle.velocity.length = randomInRange(setRangeValue(parent.velocity.length, particle.velocity.length));
53
- particle.splitCount = (parent.splitCount ?? 0) + 1;
54
+ particle.splitCount = (parent.splitCount ?? defaultSplitCount) + increment;
54
55
  particle.unbreakable = true;
55
56
  setTimeout(() => {
56
57
  particle.unbreakable = false;
57
- }, 500);
58
+ }, unbreakableTime);
58
59
  return true;
59
60
  });
60
61
  }
@@ -64,7 +65,8 @@ export function split(engine, container, particle) {
64
65
  return;
65
66
  }
66
67
  const splitOptions = destroyOptions.split;
67
- if (splitOptions.count >= 0 && (particle.splitCount === undefined || particle.splitCount++ > splitOptions.count)) {
68
+ if (splitOptions.count >= minSplitCount &&
69
+ (particle.splitCount === undefined || particle.splitCount++ > splitOptions.count)) {
68
70
  return;
69
71
  }
70
72
  const rate = getRangeValue(splitOptions.rate.value), particlesSplitOptions = itemFromSingleOrMultiple(splitOptions.particles);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tsparticles/updater-destroy",
3
- "version": "3.0.2",
3
+ "version": "3.1.0",
4
4
  "description": "tsParticles particles destroy 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.2"
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-destroy [6 Dec 2023 at 17:45]</title>
6
+ <title>@tsparticles/updater-destroy [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.destroy.js","isAsset":true,"statSize":7657,"parsedSize":11748,"gzipSize":2961,"groups":[{"label":"dist/browser","path":"./dist/browser","statSize":7615,"groups":[{"id":759,"label":"index.js + 7 modules (concatenated)","path":"./dist/browser/index.js + 7 modules (concatenated)","statSize":7615,"parsedSize":11748,"gzipSize":2961,"concatenated":true,"groups":[{"label":"dist/browser","path":"./dist/browser/index.js + 7 modules (concatenated)/dist/browser","statSize":7615,"groups":[{"id":null,"label":"index.js","path":"./dist/browser/index.js + 7 modules (concatenated)/dist/browser/index.js","statSize":229,"parsedSize":353,"gzipSize":89,"inaccurateSizes":true},{"id":null,"label":"DestroyUpdater.js","path":"./dist/browser/index.js + 7 modules (concatenated)/dist/browser/DestroyUpdater.js","statSize":2215,"parsedSize":3417,"gzipSize":861,"inaccurateSizes":true},{"label":"Options/Classes","path":"./dist/browser/index.js + 7 modules (concatenated)/dist/browser/Options/Classes","statSize":2530,"groups":[{"id":null,"label":"Destroy.js","path":"./dist/browser/index.js + 7 modules (concatenated)/dist/browser/Options/Classes/Destroy.js","statSize":438,"parsedSize":675,"gzipSize":170,"inaccurateSizes":true},{"id":null,"label":"DestroyBounds.js","path":"./dist/browser/index.js + 7 modules (concatenated)/dist/browser/Options/Classes/DestroyBounds.js","statSize":485,"parsedSize":748,"gzipSize":188,"inaccurateSizes":true},{"id":null,"label":"Split.js","path":"./dist/browser/index.js + 7 modules (concatenated)/dist/browser/Options/Classes/Split.js","statSize":1252,"parsedSize":1931,"gzipSize":486,"inaccurateSizes":true},{"id":null,"label":"SplitFactor.js","path":"./dist/browser/index.js + 7 modules (concatenated)/dist/browser/Options/Classes/SplitFactor.js","statSize":162,"parsedSize":249,"gzipSize":62,"inaccurateSizes":true},{"id":null,"label":"SplitRate.js","path":"./dist/browser/index.js + 7 modules (concatenated)/dist/browser/Options/Classes/SplitRate.js","statSize":193,"parsedSize":297,"gzipSize":75,"inaccurateSizes":true}],"parsedSize":3903,"gzipSize":983,"inaccurateSizes":true},{"id":null,"label":"Utils.js","path":"./dist/browser/index.js + 7 modules (concatenated)/dist/browser/Utils.js","statSize":2641,"parsedSize":4074,"gzipSize":1026,"inaccurateSizes":true}],"parsedSize":11748,"gzipSize":2961,"inaccurateSizes":true}]}],"parsedSize":11748,"gzipSize":2961},{"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.destroy":true}}];
34
+ window.chartData = [{"label":"tsparticles.updater.destroy.js","isAsset":true,"statSize":7981,"parsedSize":12132,"gzipSize":3030,"groups":[{"label":"dist/browser","path":"./dist/browser","statSize":7939,"groups":[{"id":105,"label":"index.js + 7 modules (concatenated)","path":"./dist/browser/index.js + 7 modules (concatenated)","statSize":7939,"parsedSize":12132,"gzipSize":3030,"concatenated":true,"groups":[{"label":"dist/browser","path":"./dist/browser/index.js + 7 modules (concatenated)/dist/browser","statSize":7939,"groups":[{"id":null,"label":"index.js","path":"./dist/browser/index.js + 7 modules (concatenated)/dist/browser/index.js","statSize":229,"parsedSize":349,"gzipSize":87,"inaccurateSizes":true},{"id":null,"label":"DestroyUpdater.js","path":"./dist/browser/index.js + 7 modules (concatenated)/dist/browser/DestroyUpdater.js","statSize":2295,"parsedSize":3507,"gzipSize":875,"inaccurateSizes":true},{"label":"Options/Classes","path":"./dist/browser/index.js + 7 modules (concatenated)/dist/browser/Options/Classes","statSize":2530,"groups":[{"id":null,"label":"Destroy.js","path":"./dist/browser/index.js + 7 modules (concatenated)/dist/browser/Options/Classes/Destroy.js","statSize":438,"parsedSize":669,"gzipSize":167,"inaccurateSizes":true},{"id":null,"label":"DestroyBounds.js","path":"./dist/browser/index.js + 7 modules (concatenated)/dist/browser/Options/Classes/DestroyBounds.js","statSize":485,"parsedSize":741,"gzipSize":185,"inaccurateSizes":true},{"id":null,"label":"Split.js","path":"./dist/browser/index.js + 7 modules (concatenated)/dist/browser/Options/Classes/Split.js","statSize":1252,"parsedSize":1913,"gzipSize":477,"inaccurateSizes":true},{"id":null,"label":"SplitFactor.js","path":"./dist/browser/index.js + 7 modules (concatenated)/dist/browser/Options/Classes/SplitFactor.js","statSize":162,"parsedSize":247,"gzipSize":61,"inaccurateSizes":true},{"id":null,"label":"SplitRate.js","path":"./dist/browser/index.js + 7 modules (concatenated)/dist/browser/Options/Classes/SplitRate.js","statSize":193,"parsedSize":294,"gzipSize":73,"inaccurateSizes":true}],"parsedSize":3866,"gzipSize":965,"inaccurateSizes":true},{"id":null,"label":"Utils.js","path":"./dist/browser/index.js + 7 modules (concatenated)/dist/browser/Utils.js","statSize":2885,"parsedSize":4408,"gzipSize":1101,"inaccurateSizes":true}],"parsedSize":12132,"gzipSize":3030,"inaccurateSizes":true}]}],"parsedSize":12132,"gzipSize":3030},{"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.destroy":true}}];
35
35
  window.entrypoints = ["tsparticles.updater.destroy","tsparticles.updater.destroy.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.2
7
+ * v3.1.0
8
8
  */
9
9
  (function webpackUniversalModuleDefinition(root, factory) {
10
10
  if(typeof exports === 'object' && typeof module === 'object')
@@ -203,6 +203,12 @@ class Destroy {
203
203
  }
204
204
  ;// CONCATENATED MODULE: ./dist/browser/Utils.js
205
205
 
206
+ const defaultOffset = 0,
207
+ minDestroySize = 0.5,
208
+ defaultSplitCount = 0,
209
+ increment = 1,
210
+ unbreakableTime = 500,
211
+ minSplitCount = 0;
206
212
  function addSplitParticle(engine, container, parent, splitParticlesOptions) {
207
213
  const destroyOptions = parent.options.destroy;
208
214
  if (!destroyOptions) {
@@ -218,9 +224,9 @@ function addSplitParticle(engine, container, parent, splitParticlesOptions) {
218
224
  options.color.load({
219
225
  value: {
220
226
  hsl: {
221
- h: parentColor.h + (0,engine_root_window_.getRangeValue)(splitOptions.colorOffset.h ?? 0),
222
- s: parentColor.s + (0,engine_root_window_.getRangeValue)(splitOptions.colorOffset.s ?? 0),
223
- l: parentColor.l + (0,engine_root_window_.getRangeValue)(splitOptions.colorOffset.l ?? 0)
227
+ h: parentColor.h + (0,engine_root_window_.getRangeValue)(splitOptions.colorOffset.h ?? defaultOffset),
228
+ s: parentColor.s + (0,engine_root_window_.getRangeValue)(splitOptions.colorOffset.s ?? defaultOffset),
229
+ l: parentColor.l + (0,engine_root_window_.getRangeValue)(splitOptions.colorOffset.l ?? defaultOffset)
224
230
  }
225
231
  }
226
232
  });
@@ -245,21 +251,21 @@ function addSplitParticle(engine, container, parent, splitParticlesOptions) {
245
251
  options.size.value.max /= factor;
246
252
  }
247
253
  options.load(splitParticlesOptions);
248
- const offset = splitOptions.sizeOffset ? (0,engine_root_window_.setRangeValue)(-parent.size.value, parent.size.value) : 0,
254
+ const offset = splitOptions.sizeOffset ? (0,engine_root_window_.setRangeValue)(-parent.size.value, parent.size.value) : defaultOffset,
249
255
  position = {
250
256
  x: parent.position.x + (0,engine_root_window_.randomInRange)(offset),
251
257
  y: parent.position.y + (0,engine_root_window_.randomInRange)(offset)
252
258
  };
253
259
  return container.particles.addParticle(position, options, parent.group, particle => {
254
- if (particle.size.value < 0.5) {
260
+ if (particle.size.value < minDestroySize) {
255
261
  return false;
256
262
  }
257
263
  particle.velocity.length = (0,engine_root_window_.randomInRange)((0,engine_root_window_.setRangeValue)(parent.velocity.length, particle.velocity.length));
258
- particle.splitCount = (parent.splitCount ?? 0) + 1;
264
+ particle.splitCount = (parent.splitCount ?? defaultSplitCount) + increment;
259
265
  particle.unbreakable = true;
260
266
  setTimeout(() => {
261
267
  particle.unbreakable = false;
262
- }, 500);
268
+ }, unbreakableTime);
263
269
  return true;
264
270
  });
265
271
  }
@@ -269,7 +275,7 @@ function split(engine, container, particle) {
269
275
  return;
270
276
  }
271
277
  const splitOptions = destroyOptions.split;
272
- if (splitOptions.count >= 0 && (particle.splitCount === undefined || particle.splitCount++ > splitOptions.count)) {
278
+ if (splitOptions.count >= minSplitCount && (particle.splitCount === undefined || particle.splitCount++ > splitOptions.count)) {
273
279
  return;
274
280
  }
275
281
  const rate = (0,engine_root_window_.getRangeValue)(splitOptions.rate.value),
@@ -284,8 +290,8 @@ function split(engine, container, particle) {
284
290
 
285
291
  class DestroyUpdater {
286
292
  constructor(engine, container) {
287
- this.engine = engine;
288
293
  this.container = container;
294
+ this.engine = engine;
289
295
  }
290
296
  init(particle) {
291
297
  const container = this.container,
@@ -310,16 +316,16 @@ class DestroyUpdater {
310
316
  } = particle,
311
317
  canvasSize = container.canvas.size;
312
318
  if (bottom) {
313
- destroyBounds.bottom = (0,engine_root_window_.getRangeValue)(bottom) * canvasSize.height / 100;
319
+ destroyBounds.bottom = (0,engine_root_window_.getRangeValue)(bottom) * canvasSize.height / engine_root_window_.percentDenominator;
314
320
  }
315
321
  if (left) {
316
- destroyBounds.left = (0,engine_root_window_.getRangeValue)(left) * canvasSize.width / 100;
322
+ destroyBounds.left = (0,engine_root_window_.getRangeValue)(left) * canvasSize.width / engine_root_window_.percentDenominator;
317
323
  }
318
324
  if (right) {
319
- destroyBounds.right = (0,engine_root_window_.getRangeValue)(right) * canvasSize.width / 100;
325
+ destroyBounds.right = (0,engine_root_window_.getRangeValue)(right) * canvasSize.width / engine_root_window_.percentDenominator;
320
326
  }
321
327
  if (top) {
322
- destroyBounds.top = (0,engine_root_window_.getRangeValue)(top) * canvasSize.height / 100;
328
+ destroyBounds.top = (0,engine_root_window_.getRangeValue)(top) * canvasSize.height / engine_root_window_.percentDenominator;
323
329
  }
324
330
  }
325
331
  isEnabled(particle) {
@@ -1,2 +1,2 @@
1
1
  /*! For license information please see tsparticles.updater.destroy.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 s in o)("object"==typeof exports?exports:t)[s]=o[s]}}(this,(t=>(()=>{"use strict";var e={533:e=>{e.exports=t}},o={};function s(t){var i=o[t];if(void 0!==i)return i.exports;var r=o[t]={exports:{}};return e[t](r,r.exports,s),r.exports}s.d=(t,e)=>{for(var o in e)s.o(e,o)&&!s.o(t,o)&&Object.defineProperty(t,o,{enumerable:!0,get:e[o]})},s.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),s.r=t=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})};var i={};return(()=>{s.r(i),s.d(i,{loadDestroyUpdater:()=>d});var t=s(533);class e{load(e){e&&(void 0!==e.bottom&&(this.bottom=(0,t.setRangeValue)(e.bottom)),void 0!==e.left&&(this.left=(0,t.setRangeValue)(e.left)),void 0!==e.right&&(this.right=(0,t.setRangeValue)(e.right)),void 0!==e.top&&(this.top=(0,t.setRangeValue)(e.top)))}}class o extends t.ValueWithRandom{constructor(){super(),this.value=3}}class r extends t.ValueWithRandom{constructor(){super(),this.value={min:4,max:9}}}class n{constructor(){this.count=1,this.factor=new o,this.rate=new r,this.sizeOffset=!0}load(e){e&&(void 0!==e.color&&(this.color=t.OptionsColor.create(this.color,e.color)),void 0!==e.count&&(this.count=e.count),this.factor.load(e.factor),this.rate.load(e.rate),this.particles=(0,t.executeOnSingleOrMultiple)(e.particles,(e=>(0,t.deepExtend)({},e))),void 0!==e.sizeOffset&&(this.sizeOffset=e.sizeOffset),e.colorOffset&&(this.colorOffset=this.colorOffset??{},void 0!==e.colorOffset.h&&(this.colorOffset.h=e.colorOffset.h),void 0!==e.colorOffset.s&&(this.colorOffset.s=e.colorOffset.s),void 0!==e.colorOffset.l&&(this.colorOffset.l=e.colorOffset.l)))}}class l{constructor(){this.bounds=new e,this.mode="none",this.split=new n}load(t){t&&(t.mode&&(this.mode=t.mode),t.bounds&&this.bounds.load(t.bounds),this.split.load(t.split))}}function a(e,o,s,i){const r=s.options.destroy;if(!r)return;const n=r.split,l=(0,t.loadParticlesOptions)(e,o,s.options),a=(0,t.getRangeValue)(n.factor.value),c=s.getFillColor();n.color?l.color.load(n.color):n.colorOffset&&c?l.color.load({value:{hsl:{h:c.h+(0,t.getRangeValue)(n.colorOffset.h??0),s:c.s+(0,t.getRangeValue)(n.colorOffset.s??0),l:c.l+(0,t.getRangeValue)(n.colorOffset.l??0)}}}):l.color.load({value:{hsl:s.getFillColor()}}),l.move.load({center:{x:s.position.x,y:s.position.y,mode:"precise"}}),(0,t.isNumber)(l.size.value)?l.size.value/=a:(l.size.value.min/=a,l.size.value.max/=a),l.load(i);const d=n.sizeOffset?(0,t.setRangeValue)(-s.size.value,s.size.value):0,u={x:s.position.x+(0,t.randomInRange)(d),y:s.position.y+(0,t.randomInRange)(d)};return o.particles.addParticle(u,l,s.group,(e=>!(e.size.value<.5)&&(e.velocity.length=(0,t.randomInRange)((0,t.setRangeValue)(s.velocity.length,e.velocity.length)),e.splitCount=(s.splitCount??0)+1,e.unbreakable=!0,setTimeout((()=>{e.unbreakable=!1}),500),!0)))}class c{constructor(t,e){this.engine=t,this.container=e}init(e){const o=this.container,s=e.options.destroy;if(!s)return;e.splitCount=0;const i=s.bounds;e.destroyBounds||(e.destroyBounds={});const{bottom:r,left:n,right:l,top:a}=i,{destroyBounds:c}=e,d=o.canvas.size;r&&(c.bottom=(0,t.getRangeValue)(r)*d.height/100),n&&(c.left=(0,t.getRangeValue)(n)*d.width/100),l&&(c.right=(0,t.getRangeValue)(l)*d.width/100),a&&(c.top=(0,t.getRangeValue)(a)*d.height/100)}isEnabled(t){return!t.destroyed}loadOptions(t,...e){t.destroy||(t.destroy=new l);for(const o of e)t.destroy.load(o?.destroy)}particleDestroyed(e,o){if(o)return;const s=e.options.destroy;s&&"split"===s.mode&&function(e,o,s){const i=s.options.destroy;if(!i)return;const r=i.split;if(r.count>=0&&(void 0===s.splitCount||s.splitCount++>r.count))return;const n=(0,t.getRangeValue)(r.rate.value),l=(0,t.itemFromSingleOrMultiple)(r.particles);for(let t=0;t<n;t++)a(e,o,s,l)}(this.engine,this.container,e)}update(t){if(!this.isEnabled(t))return;const e=t.getPosition(),o=t.destroyBounds;o&&(void 0!==o.bottom&&e.y>=o.bottom||void 0!==o.left&&e.x<=o.left||void 0!==o.right&&e.x>=o.right||void 0!==o.top&&e.y<=o.top)&&t.destroy()}}async function d(t,e=!0){await t.addParticleUpdater("destroy",(e=>new c(t,e)),e)}})(),i})()));
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 s in o)("object"==typeof exports?exports:t)[s]=o[s]}}(this,(t=>(()=>{"use strict";var e={533:e=>{e.exports=t}},o={};function s(t){var i=o[t];if(void 0!==i)return i.exports;var r=o[t]={exports:{}};return e[t](r,r.exports,s),r.exports}s.d=(t,e)=>{for(var o in e)s.o(e,o)&&!s.o(t,o)&&Object.defineProperty(t,o,{enumerable:!0,get:e[o]})},s.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e),s.r=t=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})};var i={};return(()=>{s.r(i),s.d(i,{loadDestroyUpdater:()=>g});var t=s(533);class e{load(e){e&&(void 0!==e.bottom&&(this.bottom=(0,t.setRangeValue)(e.bottom)),void 0!==e.left&&(this.left=(0,t.setRangeValue)(e.left)),void 0!==e.right&&(this.right=(0,t.setRangeValue)(e.right)),void 0!==e.top&&(this.top=(0,t.setRangeValue)(e.top)))}}class o extends t.ValueWithRandom{constructor(){super(),this.value=3}}class r extends t.ValueWithRandom{constructor(){super(),this.value={min:4,max:9}}}class n{constructor(){this.count=1,this.factor=new o,this.rate=new r,this.sizeOffset=!0}load(e){e&&(void 0!==e.color&&(this.color=t.OptionsColor.create(this.color,e.color)),void 0!==e.count&&(this.count=e.count),this.factor.load(e.factor),this.rate.load(e.rate),this.particles=(0,t.executeOnSingleOrMultiple)(e.particles,(e=>(0,t.deepExtend)({},e))),void 0!==e.sizeOffset&&(this.sizeOffset=e.sizeOffset),e.colorOffset&&(this.colorOffset=this.colorOffset??{},void 0!==e.colorOffset.h&&(this.colorOffset.h=e.colorOffset.h),void 0!==e.colorOffset.s&&(this.colorOffset.s=e.colorOffset.s),void 0!==e.colorOffset.l&&(this.colorOffset.l=e.colorOffset.l)))}}class l{constructor(){this.bounds=new e,this.mode="none",this.split=new n}load(t){t&&(t.mode&&(this.mode=t.mode),t.bounds&&this.bounds.load(t.bounds),this.split.load(t.split))}}const a=0,c=.5,d=0,u=1,f=500;function p(e,o,s,i){const r=s.options.destroy;if(!r)return;const n=r.split,l=(0,t.loadParticlesOptions)(e,o,s.options),p=(0,t.getRangeValue)(n.factor.value),h=s.getFillColor();n.color?l.color.load(n.color):n.colorOffset&&h?l.color.load({value:{hsl:{h:h.h+(0,t.getRangeValue)(n.colorOffset.h??a),s:h.s+(0,t.getRangeValue)(n.colorOffset.s??a),l:h.l+(0,t.getRangeValue)(n.colorOffset.l??a)}}}):l.color.load({value:{hsl:s.getFillColor()}}),l.move.load({center:{x:s.position.x,y:s.position.y,mode:"precise"}}),(0,t.isNumber)(l.size.value)?l.size.value/=p:(l.size.value.min/=p,l.size.value.max/=p),l.load(i);const g=n.sizeOffset?(0,t.setRangeValue)(-s.size.value,s.size.value):a,v={x:s.position.x+(0,t.randomInRange)(g),y:s.position.y+(0,t.randomInRange)(g)};return o.particles.addParticle(v,l,s.group,(e=>!(e.size.value<c)&&(e.velocity.length=(0,t.randomInRange)((0,t.setRangeValue)(s.velocity.length,e.velocity.length)),e.splitCount=(s.splitCount??d)+u,e.unbreakable=!0,setTimeout((()=>{e.unbreakable=!1}),f),!0)))}class h{constructor(t,e){this.container=e,this.engine=t}init(e){const o=this.container,s=e.options.destroy;if(!s)return;e.splitCount=0;const i=s.bounds;e.destroyBounds||(e.destroyBounds={});const{bottom:r,left:n,right:l,top:a}=i,{destroyBounds:c}=e,d=o.canvas.size;r&&(c.bottom=(0,t.getRangeValue)(r)*d.height/t.percentDenominator),n&&(c.left=(0,t.getRangeValue)(n)*d.width/t.percentDenominator),l&&(c.right=(0,t.getRangeValue)(l)*d.width/t.percentDenominator),a&&(c.top=(0,t.getRangeValue)(a)*d.height/t.percentDenominator)}isEnabled(t){return!t.destroyed}loadOptions(t,...e){t.destroy||(t.destroy=new l);for(const o of e)t.destroy.load(o?.destroy)}particleDestroyed(e,o){if(o)return;const s=e.options.destroy;s&&"split"===s.mode&&function(e,o,s){const i=s.options.destroy;if(!i)return;const r=i.split;if(r.count>=0&&(void 0===s.splitCount||s.splitCount++>r.count))return;const n=(0,t.getRangeValue)(r.rate.value),l=(0,t.itemFromSingleOrMultiple)(r.particles);for(let t=0;t<n;t++)p(e,o,s,l)}(this.engine,this.container,e)}update(t){if(!this.isEnabled(t))return;const e=t.getPosition(),o=t.destroyBounds;o&&(void 0!==o.bottom&&e.y>=o.bottom||void 0!==o.left&&e.x<=o.left||void 0!==o.right&&e.x>=o.right||void 0!==o.top&&e.y<=o.top)&&t.destroy()}}async function g(t,e=!0){await t.addParticleUpdater("destroy",(e=>new h(t,e)),e)}})(),i})()));
@@ -1 +1 @@
1
- /*! tsParticles Destroy Updater v3.0.2 by Matteo Bruni */
1
+ /*! tsParticles Destroy Updater v3.1.0 by Matteo Bruni */
@@ -1,8 +1,8 @@
1
1
  import { type Container, type Engine, type IParticleUpdater, type Particle, type RecursivePartial } from "@tsparticles/engine";
2
2
  import type { DestroyParticle, DestroyParticlesOptions, IDestroyParticlesOptions } from "./Types.js";
3
3
  export declare class DestroyUpdater implements IParticleUpdater {
4
- private readonly engine;
5
4
  private readonly container;
5
+ private readonly engine;
6
6
  constructor(engine: Engine, container: Container);
7
7
  init(particle: DestroyParticle): void;
8
8
  isEnabled(particle: Particle): boolean;
@@ -15,8 +15,8 @@
15
15
  const Utils_js_1 = require("./Utils.js");
16
16
  class DestroyUpdater {
17
17
  constructor(engine, container) {
18
- this.engine = engine;
19
18
  this.container = container;
19
+ this.engine = engine;
20
20
  }
21
21
  init(particle) {
22
22
  const container = this.container, particlesOptions = particle.options, destroyOptions = particlesOptions.destroy;
@@ -30,16 +30,16 @@
30
30
  }
31
31
  const { bottom, left, right, top } = destroyBoundsOptions, { destroyBounds } = particle, canvasSize = container.canvas.size;
32
32
  if (bottom) {
33
- destroyBounds.bottom = ((0, engine_1.getRangeValue)(bottom) * canvasSize.height) / 100;
33
+ destroyBounds.bottom = ((0, engine_1.getRangeValue)(bottom) * canvasSize.height) / engine_1.percentDenominator;
34
34
  }
35
35
  if (left) {
36
- destroyBounds.left = ((0, engine_1.getRangeValue)(left) * canvasSize.width) / 100;
36
+ destroyBounds.left = ((0, engine_1.getRangeValue)(left) * canvasSize.width) / engine_1.percentDenominator;
37
37
  }
38
38
  if (right) {
39
- destroyBounds.right = ((0, engine_1.getRangeValue)(right) * canvasSize.width) / 100;
39
+ destroyBounds.right = ((0, engine_1.getRangeValue)(right) * canvasSize.width) / engine_1.percentDenominator;
40
40
  }
41
41
  if (top) {
42
- destroyBounds.top = ((0, engine_1.getRangeValue)(top) * canvasSize.height) / 100;
42
+ destroyBounds.top = ((0, engine_1.getRangeValue)(top) * canvasSize.height) / engine_1.percentDenominator;
43
43
  }
44
44
  }
45
45
  isEnabled(particle) {
package/umd/Utils.js CHANGED
@@ -11,6 +11,7 @@
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.split = void 0;
13
13
  const engine_1 = require("@tsparticles/engine");
14
+ const defaultOffset = 0, minDestroySize = 0.5, defaultSplitCount = 0, increment = 1, unbreakableTime = 500, minSplitCount = 0;
14
15
  function addSplitParticle(engine, container, parent, splitParticlesOptions) {
15
16
  const destroyOptions = parent.options.destroy;
16
17
  if (!destroyOptions) {
@@ -24,9 +25,9 @@
24
25
  options.color.load({
25
26
  value: {
26
27
  hsl: {
27
- h: parentColor.h + (0, engine_1.getRangeValue)(splitOptions.colorOffset.h ?? 0),
28
- s: parentColor.s + (0, engine_1.getRangeValue)(splitOptions.colorOffset.s ?? 0),
29
- l: parentColor.l + (0, engine_1.getRangeValue)(splitOptions.colorOffset.l ?? 0),
28
+ h: parentColor.h + (0, engine_1.getRangeValue)(splitOptions.colorOffset.h ?? defaultOffset),
29
+ s: parentColor.s + (0, engine_1.getRangeValue)(splitOptions.colorOffset.s ?? defaultOffset),
30
+ l: parentColor.l + (0, engine_1.getRangeValue)(splitOptions.colorOffset.l ?? defaultOffset),
30
31
  },
31
32
  },
32
33
  });
@@ -53,20 +54,20 @@
53
54
  options.size.value.max /= factor;
54
55
  }
55
56
  options.load(splitParticlesOptions);
56
- const offset = splitOptions.sizeOffset ? (0, engine_1.setRangeValue)(-parent.size.value, parent.size.value) : 0, position = {
57
+ const offset = splitOptions.sizeOffset ? (0, engine_1.setRangeValue)(-parent.size.value, parent.size.value) : defaultOffset, position = {
57
58
  x: parent.position.x + (0, engine_1.randomInRange)(offset),
58
59
  y: parent.position.y + (0, engine_1.randomInRange)(offset),
59
60
  };
60
61
  return container.particles.addParticle(position, options, parent.group, (particle) => {
61
- if (particle.size.value < 0.5) {
62
+ if (particle.size.value < minDestroySize) {
62
63
  return false;
63
64
  }
64
65
  particle.velocity.length = (0, engine_1.randomInRange)((0, engine_1.setRangeValue)(parent.velocity.length, particle.velocity.length));
65
- particle.splitCount = (parent.splitCount ?? 0) + 1;
66
+ particle.splitCount = (parent.splitCount ?? defaultSplitCount) + increment;
66
67
  particle.unbreakable = true;
67
68
  setTimeout(() => {
68
69
  particle.unbreakable = false;
69
- }, 500);
70
+ }, unbreakableTime);
70
71
  return true;
71
72
  });
72
73
  }
@@ -76,7 +77,8 @@
76
77
  return;
77
78
  }
78
79
  const splitOptions = destroyOptions.split;
79
- if (splitOptions.count >= 0 && (particle.splitCount === undefined || particle.splitCount++ > splitOptions.count)) {
80
+ if (splitOptions.count >= minSplitCount &&
81
+ (particle.splitCount === undefined || particle.splitCount++ > splitOptions.count)) {
80
82
  return;
81
83
  }
82
84
  const rate = (0, engine_1.getRangeValue)(splitOptions.rate.value), particlesSplitOptions = (0, engine_1.itemFromSingleOrMultiple)(splitOptions.particles);