@tsparticles/plugin-emitters 4.0.0-beta.0 → 4.0.0-beta.10

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.
Files changed (87) hide show
  1. package/{803.min.js → 100.min.js} +1 -1
  2. package/106.min.js +1 -0
  3. package/443.min.js +1 -0
  4. package/475.min.js +1 -0
  5. package/{588.min.js → 515.min.js} +1 -1
  6. package/746.min.js +1 -0
  7. package/{526.min.js → 812.min.js} +1 -1
  8. package/903.min.js +1 -0
  9. package/README.md +27 -0
  10. package/browser/EmitterInstance.js +39 -43
  11. package/browser/EmittersInstancesManager.js +4 -4
  12. package/browser/addEmittersShapesManager.js +7 -0
  13. package/browser/ensureEmittersPluginLoaded.js +5 -0
  14. package/browser/getEmittersInstancesManager.js +15 -0
  15. package/browser/index.js +5 -24
  16. package/browser/interaction.js +18 -0
  17. package/browser/plugin.js +14 -0
  18. package/cjs/EmitterInstance.js +39 -43
  19. package/cjs/EmittersInstancesManager.js +4 -4
  20. package/cjs/addEmittersShapesManager.js +7 -0
  21. package/cjs/ensureEmittersPluginLoaded.js +5 -0
  22. package/cjs/getEmittersInstancesManager.js +15 -0
  23. package/cjs/index.js +5 -24
  24. package/cjs/interaction.js +18 -0
  25. package/cjs/plugin.js +14 -0
  26. package/dist_browser_EmitterInstance_js.js +2 -2
  27. package/dist_browser_EmittersInstancesManager_js.js +2 -2
  28. package/dist_browser_EmittersInteractor_js.js +1 -1
  29. package/dist_browser_EmittersPluginInstance_js.js +1 -1
  30. package/dist_browser_EmittersPlugin_js.js +1 -1
  31. package/dist_browser_ShapeManager_js.js +1 -1
  32. package/dist_browser_addEmittersShapesManager_js.js +30 -0
  33. package/dist_browser_getEmittersInstancesManager_js.js +30 -0
  34. package/esm/EmitterInstance.js +39 -43
  35. package/esm/EmittersInstancesManager.js +4 -4
  36. package/esm/addEmittersShapesManager.js +7 -0
  37. package/esm/ensureEmittersPluginLoaded.js +5 -0
  38. package/esm/getEmittersInstancesManager.js +15 -0
  39. package/esm/index.js +5 -24
  40. package/esm/interaction.js +18 -0
  41. package/esm/plugin.js +14 -0
  42. package/package.json +24 -6
  43. package/report.html +84 -29
  44. package/tsparticles.plugin.emitters.js +32 -2
  45. package/tsparticles.plugin.emitters.min.js +2 -2
  46. package/types/EmitterInstance.d.ts +5 -5
  47. package/types/EmittersEngine.d.ts +5 -2
  48. package/types/EmittersInstancesManager.d.ts +3 -3
  49. package/types/addEmittersShapesManager.d.ts +2 -0
  50. package/types/ensureEmittersPluginLoaded.d.ts +2 -0
  51. package/types/getEmittersInstancesManager.d.ts +3 -0
  52. package/types/index.d.ts +1 -1
  53. package/types/interaction.d.ts +9 -0
  54. package/types/plugin.d.ts +9 -0
  55. package/772.min.js +0 -1
  56. package/784.min.js +0 -1
  57. package/795.min.js +0 -1
  58. package/umd/EmitterContainer.js +0 -12
  59. package/umd/EmitterInstance.js +0 -366
  60. package/umd/EmitterShapeBase.js +0 -30
  61. package/umd/EmittersEngine.js +0 -12
  62. package/umd/EmittersInstancesManager.js +0 -119
  63. package/umd/EmittersInteractor.js +0 -130
  64. package/umd/EmittersPlugin.js +0 -80
  65. package/umd/EmittersPluginInstance.js +0 -58
  66. package/umd/Enums/EmitterClickMode.js +0 -17
  67. package/umd/IEmitterShape.js +0 -12
  68. package/umd/IEmitterShapeGenerator.js +0 -12
  69. package/umd/IRandomPositionData.js +0 -12
  70. package/umd/Options/Classes/Emitter.js +0 -93
  71. package/umd/Options/Classes/EmitterLife.js +0 -41
  72. package/umd/Options/Classes/EmitterRate.js +0 -34
  73. package/umd/Options/Classes/EmitterShape.js +0 -38
  74. package/umd/Options/Classes/EmitterShapeReplace.js +0 -34
  75. package/umd/Options/Classes/EmitterSize.js +0 -39
  76. package/umd/Options/Classes/EmitterSpawn.js +0 -32
  77. package/umd/Options/Interfaces/IEmitter.js +0 -12
  78. package/umd/Options/Interfaces/IEmitterLife.js +0 -12
  79. package/umd/Options/Interfaces/IEmitterRate.js +0 -12
  80. package/umd/Options/Interfaces/IEmitterShape.js +0 -12
  81. package/umd/Options/Interfaces/IEmitterShapeReplace.js +0 -12
  82. package/umd/Options/Interfaces/IEmitterSize.js +0 -12
  83. package/umd/Options/Interfaces/IEmitterSpawn.js +0 -12
  84. package/umd/ShapeManager.js +0 -28
  85. package/umd/constants.js +0 -17
  86. package/umd/index.js +0 -79
  87. package/umd/types.js +0 -12
@@ -1,22 +1,24 @@
1
- import { AnimatableColor, Fill, PixelMode, Stroke, Vector, calcPositionOrRandomFromSizeRanged, deepExtend, defaultOpacity, getRangeValue, getSize, hMax, half, isPointInside, itemFromSingleOrMultiple, lMax, millisecondsToSeconds, randomInRangeValue, rangeColorToHsl, sMax, safeDocument, } from "@tsparticles/engine";
1
+ import { AnimatableColor, Paint, PixelMode, Vector, calcPositionOrRandomFromSizeRanged, deepExtend, defaultOpacity, getRangeValue, getSize, hMax, half, isPointInside, itemFromSingleOrMultiple, lMax, millisecondsToSeconds, randomInRangeValue, rangeColorToHsl, sMax, safeDocument, } from "@tsparticles/engine";
2
2
  import { Emitter } from "./Options/Classes/Emitter.js";
3
3
  import { EmitterSize } from "./Options/Classes/EmitterSize.js";
4
4
  const defaultLifeDelay = 0, minLifeCount = 0, defaultSpawnDelay = 0, defaultEmitDelay = 0, defaultLifeCount = -1, defaultColorAnimationFactor = 1, colorFactor = 3.6, defaultStrokeWidth = 1;
5
5
  function setParticlesOptionsFillColor(particlesOptions, color, opacity, enable) {
6
- particlesOptions.fill = new Fill();
7
- particlesOptions.fill.color = AnimatableColor.create(undefined, { value: color });
8
- particlesOptions.fill.enable = enable;
9
- particlesOptions.fill.opacity = opacity;
6
+ const paint = (particlesOptions.paint ??= new Paint());
7
+ paint.fill = {
8
+ color: AnimatableColor.create(undefined, { value: color }),
9
+ enable,
10
+ opacity,
11
+ };
10
12
  }
11
13
  function setParticlesOptionsStrokeColor(particlesOptions, color, opacity, width) {
12
- particlesOptions.stroke = new Stroke();
13
- particlesOptions.stroke.color = AnimatableColor.create(undefined, { value: color });
14
- particlesOptions.stroke.opacity = opacity;
15
- particlesOptions.stroke.width = width;
14
+ const paint = (particlesOptions.paint ??= new Paint());
15
+ paint.stroke = {
16
+ color: AnimatableColor.create(undefined, { value: color }),
17
+ opacity,
18
+ width,
19
+ };
16
20
  }
17
21
  export class EmitterInstance {
18
- container;
19
- removeCallback;
20
22
  fill;
21
23
  name;
22
24
  options;
@@ -28,12 +30,12 @@ export class EmitterInstance {
28
30
  spawnStrokeColor;
29
31
  spawnStrokeOpacity;
30
32
  spawnStrokeWidth;
33
+ _container;
31
34
  _currentDuration;
32
35
  _currentEmitDelay;
33
36
  _currentSpawnDelay;
34
37
  _duration;
35
38
  _emitDelay;
36
- _engine;
37
39
  _firstSpawn;
38
40
  _immortal;
39
41
  _initialPosition;
@@ -41,15 +43,17 @@ export class EmitterInstance {
41
43
  _mutationObserver;
42
44
  _particlesOptions;
43
45
  _paused;
46
+ _pluginManager;
47
+ _removeCallback;
44
48
  _resizeObserver;
45
49
  _shape;
46
50
  _size;
47
51
  _spawnDelay;
48
52
  _startParticlesAdded;
49
- constructor(engine, container, removeCallback, options, position) {
50
- this.container = container;
51
- this.removeCallback = removeCallback;
52
- this._engine = engine;
53
+ constructor(pluginManager, container, removeCallback, options, position) {
54
+ this._pluginManager = pluginManager;
55
+ this._container = container;
56
+ this._removeCallback = removeCallback;
53
57
  this._currentDuration = 0;
54
58
  this._currentEmitDelay = 0;
55
59
  this._currentSpawnDelay = 0;
@@ -74,15 +78,15 @@ export class EmitterInstance {
74
78
  particlesOptions.move ??= {};
75
79
  particlesOptions.move.direction ??= this.options.direction;
76
80
  if (this.options.spawn.fill?.color) {
77
- this.spawnFillColor = rangeColorToHsl(this._engine, this.options.spawn.fill.color);
81
+ this.spawnFillColor = rangeColorToHsl(this._pluginManager, this.options.spawn.fill.color);
78
82
  }
79
83
  if (this.options.spawn.stroke?.color) {
80
- this.spawnStrokeColor = rangeColorToHsl(this._engine, this.options.spawn.stroke.color);
84
+ this.spawnStrokeColor = rangeColorToHsl(this._pluginManager, this.options.spawn.stroke.color);
81
85
  }
82
86
  this._paused = !this.options.autoPlay;
83
87
  this._particlesOptions = particlesOptions;
84
88
  this._size = this._calcSize();
85
- this.size = getSize(this._size, this.container.canvas.size);
89
+ this.size = getSize(this._size, this._container.canvas.size);
86
90
  this._lifeCount = this.options.life.count ?? defaultLifeCount;
87
91
  this._immortal = this._lifeCount <= minLifeCount;
88
92
  if (this.options.domId) {
@@ -101,15 +105,12 @@ export class EmitterInstance {
101
105
  this._resizeObserver.observe(element);
102
106
  }
103
107
  }
104
- const shapeOptions = this.options.shape, shapeGenerator = this._engine.emitterShapeManager?.getShapeGenerator(shapeOptions.type);
108
+ const shapeOptions = this.options.shape, shapeGenerator = this._pluginManager.emitterShapeManager?.getShapeGenerator(shapeOptions.type);
105
109
  if (shapeGenerator) {
106
- this._shape = shapeGenerator.generate(this.container, this.position, this.size, this.fill, shapeOptions.options);
110
+ this._shape = shapeGenerator.generate(this._container, this.position, this.size, this.fill, shapeOptions.options);
107
111
  }
108
- this._engine.dispatchEvent("emitterCreated", {
109
- container,
110
- data: {
111
- emitter: this,
112
- },
112
+ this._container.dispatchEvent("emitterCreated", {
113
+ emitter: this,
113
114
  });
114
115
  this.play();
115
116
  }
@@ -138,7 +139,7 @@ export class EmitterInstance {
138
139
  (this._firstSpawn || this._currentSpawnDelay >= (this._spawnDelay ?? defaultSpawnDelay)))) {
139
140
  return;
140
141
  }
141
- const container = this.container;
142
+ const container = this._container;
142
143
  if (this._emitDelay === undefined) {
143
144
  const delay = getRangeValue(this.options.rate.delay);
144
145
  this._emitDelay = container.retina.reduceFactor
@@ -150,7 +151,7 @@ export class EmitterInstance {
150
151
  }
151
152
  }
152
153
  resize() {
153
- const initialPosition = this._initialPosition, container = this.container;
154
+ const initialPosition = this._initialPosition, container = this._container;
154
155
  this.position =
155
156
  initialPosition && isPointInside(initialPosition, container.canvas.size, Vector.origin)
156
157
  ? initialPosition
@@ -163,7 +164,7 @@ export class EmitterInstance {
163
164
  if (this._paused) {
164
165
  return;
165
166
  }
166
- const container = this.container;
167
+ const container = this._container;
167
168
  if (this._firstSpawn) {
168
169
  this._firstSpawn = false;
169
170
  this._currentSpawnDelay = this._spawnDelay ?? defaultSpawnDelay;
@@ -201,9 +202,7 @@ export class EmitterInstance {
201
202
  if (this._spawnDelay !== undefined) {
202
203
  this._currentSpawnDelay += delta.value;
203
204
  if (this._currentSpawnDelay >= this._spawnDelay) {
204
- this._engine.dispatchEvent("emitterPlay", {
205
- container: this.container,
206
- });
205
+ this._container.dispatchEvent("emitterPlay");
207
206
  this.play();
208
207
  this._currentSpawnDelay -= this._spawnDelay;
209
208
  delete this._spawnDelay;
@@ -218,7 +217,7 @@ export class EmitterInstance {
218
217
  }
219
218
  }
220
219
  _calcPosition() {
221
- const container = this.container;
220
+ const container = this._container;
222
221
  if (this.options.domId) {
223
222
  const element = safeDocument().getElementById(this.options.domId);
224
223
  if (element) {
@@ -235,7 +234,7 @@ export class EmitterInstance {
235
234
  });
236
235
  }
237
236
  _calcSize() {
238
- const container = this.container;
237
+ const container = this._container;
239
238
  if (this.options.domId) {
240
239
  const element = safeDocument().getElementById(this.options.domId);
241
240
  if (element) {
@@ -263,12 +262,9 @@ export class EmitterInstance {
263
262
  this._mutationObserver = undefined;
264
263
  this._resizeObserver?.disconnect();
265
264
  this._resizeObserver = undefined;
266
- this.removeCallback(this);
267
- this._engine.dispatchEvent("emitterDestroyed", {
268
- container: this.container,
269
- data: {
270
- emitter: this,
271
- },
265
+ this._removeCallback(this);
266
+ this._container.dispatchEvent("emitterDestroyed", {
267
+ emitter: this,
272
268
  });
273
269
  };
274
270
  _emit() {
@@ -286,7 +282,7 @@ export class EmitterInstance {
286
282
  ? defaultOpacity
287
283
  : getRangeValue(this.options.spawn.stroke.opacity), strokeWidth = this.options.spawn.stroke?.width === undefined
288
284
  ? defaultStrokeWidth
289
- : getRangeValue(this.options.spawn.stroke.width), reduceFactor = this.container.retina.reduceFactor, needsFillColorAnimation = !!fillHslAnimation, needsStrokeColorAnimation = !!strokeHslAnimation, needsShapeData = !!this._shape, needsColorAnimation = needsFillColorAnimation || needsStrokeColorAnimation, needsCopy = needsColorAnimation || needsShapeData, maxValues = needsColorAnimation ? { h: hMax, s: sMax, l: lMax } : null, shapeOptions = this.options.shape;
285
+ : getRangeValue(this.options.spawn.stroke.width), reduceFactor = this._container.retina.reduceFactor, needsFillColorAnimation = !!fillHslAnimation, needsStrokeColorAnimation = !!strokeHslAnimation, needsShapeData = !!this._shape, needsColorAnimation = needsFillColorAnimation || needsStrokeColorAnimation, needsCopy = needsColorAnimation || needsShapeData, maxValues = needsColorAnimation ? { h: hMax, s: sMax, l: lMax } : null, shapeOptions = this.options.shape;
290
286
  for (let i = 0; i < quantity * reduceFactor; i++) {
291
287
  const particlesOptions = needsCopy
292
288
  ? deepExtend({}, singleParticlesOptions)
@@ -326,7 +322,7 @@ export class EmitterInstance {
326
322
  }
327
323
  }
328
324
  if (position) {
329
- this.container.particles.addParticle(position, particlesOptions);
325
+ this._container.particles.addParticle(position, particlesOptions);
330
326
  }
331
327
  }
332
328
  }
@@ -340,7 +336,7 @@ export class EmitterInstance {
340
336
  }
341
337
  };
342
338
  _setColorAnimation = (animation, initValue, maxValue, factor = defaultColorAnimationFactor) => {
343
- const container = this.container;
339
+ const container = this._container;
344
340
  if (!animation.enable) {
345
341
  return initValue;
346
342
  }
@@ -3,15 +3,15 @@ import { Emitter } from "./Options/Classes/Emitter.js";
3
3
  const defaultIndex = 0;
4
4
  export class EmittersInstancesManager {
5
5
  _containerArrays;
6
- _engine;
7
- constructor(engine) {
6
+ _pluginManager;
7
+ constructor(pluginManager) {
8
8
  this._containerArrays = new Map();
9
- this._engine = engine;
9
+ this._pluginManager = pluginManager;
10
10
  }
11
11
  async addEmitter(container, options, position) {
12
12
  const emitterOptions = new Emitter();
13
13
  emitterOptions.load(options);
14
- const { EmitterInstance } = await import("./EmitterInstance.js"), emitter = new EmitterInstance(this._engine, container, (emitter) => {
14
+ const { EmitterInstance } = await import("./EmitterInstance.js"), emitter = new EmitterInstance(this._pluginManager, container, (emitter) => {
15
15
  this.removeEmitter(container, emitter);
16
16
  }, emitterOptions, position);
17
17
  await emitter.init();
@@ -0,0 +1,7 @@
1
+ export async function addEmittersShapesManager(e) {
2
+ const { ShapeManager } = await import("./ShapeManager.js"), pluginManager = e.pluginManager;
3
+ pluginManager.emitterShapeManager ??= new ShapeManager();
4
+ pluginManager.addEmitterShapeGenerator ??= (name, generator) => {
5
+ pluginManager.emitterShapeManager?.addShapeGenerator(name, generator);
6
+ };
7
+ }
@@ -0,0 +1,5 @@
1
+ export function ensureEmittersPluginLoaded(e) {
2
+ if (!e.pluginManager.addEmitterShapeGenerator) {
3
+ throw new Error("tsParticles Emitters Plugin is not loaded");
4
+ }
5
+ }
@@ -0,0 +1,15 @@
1
+ const instancesManagers = new WeakMap();
2
+ export function getEmittersInstancesManager(e) {
3
+ const pluginManager = e.pluginManager;
4
+ let manager = instancesManagers.get(pluginManager);
5
+ if (!manager) {
6
+ manager = import("./EmittersInstancesManager.js")
7
+ .then(({ EmittersInstancesManager }) => new EmittersInstancesManager(pluginManager))
8
+ .catch((error) => {
9
+ instancesManagers.delete(pluginManager);
10
+ throw error;
11
+ });
12
+ instancesManagers.set(pluginManager, manager);
13
+ }
14
+ return manager;
15
+ }
package/esm/index.js CHANGED
@@ -1,28 +1,9 @@
1
+ import { loadEmittersInteraction } from "./interaction.js";
2
+ import { loadEmittersPluginSimple } from "./plugin.js";
1
3
  export async function loadEmittersPlugin(engine) {
2
- engine.checkVersion("4.0.0-beta.0");
3
- await engine.register(async (e) => {
4
- const [{ ensureInteractivityPluginLoaded }, { ShapeManager }, { EmittersInstancesManager }, { EmittersPlugin },] = await Promise.all([
5
- import("@tsparticles/plugin-interactivity"),
6
- import("./ShapeManager.js"),
7
- import("./EmittersInstancesManager.js"),
8
- import("./EmittersPlugin.js"),
9
- ]), instancesManager = new EmittersInstancesManager(e);
10
- ensureInteractivityPluginLoaded(e);
11
- e.emitterShapeManager ??= new ShapeManager();
12
- e.addEmitterShapeGenerator ??= (name, generator) => {
13
- e.emitterShapeManager?.addShapeGenerator(name, generator);
14
- };
15
- e.addPlugin(new EmittersPlugin(instancesManager));
16
- e.addInteractor?.("externalEmitters", async (container) => {
17
- const { EmittersInteractor } = await import("./EmittersInteractor.js");
18
- return new EmittersInteractor(instancesManager, container);
19
- });
20
- });
21
- }
22
- export function ensureEmittersPluginLoaded(e) {
23
- if (!e.addEmitterShapeGenerator) {
24
- throw new Error("tsParticles Emitters Plugin is not loaded");
25
- }
4
+ await loadEmittersPluginSimple(engine);
5
+ await loadEmittersInteraction(engine);
26
6
  }
7
+ export * from "./ensureEmittersPluginLoaded.js";
27
8
  export * from "./EmitterShapeBase.js";
28
9
  export * from "./Enums/EmitterClickMode.js";
@@ -0,0 +1,18 @@
1
+ export async function loadEmittersInteraction(engine) {
2
+ engine.checkVersion("4.0.0-beta.10");
3
+ await engine.pluginManager.register(async (e) => {
4
+ const [{ ensureInteractivityPluginLoaded }, { addEmittersShapesManager }, { getEmittersInstancesManager },] = await Promise.all([
5
+ import("@tsparticles/plugin-interactivity"),
6
+ import("./addEmittersShapesManager.js"),
7
+ import("./getEmittersInstancesManager.js"),
8
+ ]), instancesManager = await getEmittersInstancesManager(e);
9
+ ensureInteractivityPluginLoaded(e);
10
+ await addEmittersShapesManager(e);
11
+ e.pluginManager.addInteractor?.("externalEmitters", async (container) => {
12
+ const { EmittersInteractor } = await import("./EmittersInteractor.js");
13
+ return new EmittersInteractor(instancesManager, container);
14
+ });
15
+ });
16
+ }
17
+ export * from "./EmitterShapeBase.js";
18
+ export * from "./Enums/EmitterClickMode.js";
package/esm/plugin.js ADDED
@@ -0,0 +1,14 @@
1
+ export async function loadEmittersPluginSimple(engine) {
2
+ engine.checkVersion("4.0.0-beta.10");
3
+ await engine.pluginManager.register(async (e) => {
4
+ const [{ addEmittersShapesManager }, { getEmittersInstancesManager }, { EmittersPlugin },] = await Promise.all([
5
+ import("./addEmittersShapesManager.js"),
6
+ import("./getEmittersInstancesManager.js"),
7
+ import("./EmittersPlugin.js"),
8
+ ]), instancesManager = await getEmittersInstancesManager(e);
9
+ await addEmittersShapesManager(e);
10
+ e.pluginManager.addPlugin(new EmittersPlugin(instancesManager));
11
+ });
12
+ }
13
+ export * from "./EmitterShapeBase.js";
14
+ export * from "./Enums/EmitterClickMode.js";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tsparticles/plugin-emitters",
3
- "version": "4.0.0-beta.0",
3
+ "version": "4.0.0-beta.10",
4
4
  "description": "tsParticles emitters plugin",
5
5
  "homepage": "https://particles.js.org",
6
6
  "repository": {
@@ -80,14 +80,32 @@
80
80
  "browser": "./browser/index.js",
81
81
  "import": "./esm/index.js",
82
82
  "require": "./cjs/index.js",
83
- "umd": "./umd/index.js",
84
- "default": "./cjs/index.js"
83
+ "default": "./esm/index.js"
84
+ },
85
+ "./interaction": {
86
+ "types": "./types/interaction.d.ts",
87
+ "browser": "./browser/interaction.js",
88
+ "import": "./esm/interaction.js",
89
+ "require": "./cjs/interaction.js",
90
+ "default": "./esm/interaction.js"
91
+ },
92
+ "./plugin": {
93
+ "types": "./types/plugin.d.ts",
94
+ "browser": "./browser/plugin.js",
95
+ "import": "./esm/plugin.js",
96
+ "require": "./cjs/plugin.js",
97
+ "default": "./esm/plugin.js"
85
98
  },
86
99
  "./package.json": "./package.json"
87
100
  },
88
- "dependencies": {
89
- "@tsparticles/engine": "4.0.0-beta.0",
90
- "@tsparticles/plugin-interactivity": "4.0.0-beta.0"
101
+ "peerDependencies": {
102
+ "@tsparticles/engine": "4.0.0-beta.10",
103
+ "@tsparticles/plugin-interactivity": "4.0.0-beta.10"
104
+ },
105
+ "peerDependenciesMeta": {
106
+ "@tsparticles/plugin-interactivity": {
107
+ "optional": true
108
+ }
91
109
  },
92
110
  "publishConfig": {
93
111
  "access": "public"