@tsparticles/plugin-interactivity 4.0.0-alpha.21 → 4.0.0-alpha.23

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 (98) hide show
  1. package/221.min.js +1 -1
  2. package/703.min.js +1 -1
  3. package/{esm → browser/BaseClasses}/ExternalInteractorBase.js +1 -1
  4. package/browser/{ParticlesInteractorBase.js → BaseClasses/ParticlesInteractorBase.js} +1 -1
  5. package/browser/InteractionManager.js +11 -9
  6. package/browser/InteractivityEventListeners.js +13 -5
  7. package/browser/InteractivityPlugin.js +1 -3
  8. package/browser/InteractivityPluginInstance.js +4 -2
  9. package/browser/Options/Classes/Events/DivEvent.js +1 -1
  10. package/browser/Options/Classes/Interactivity.js +1 -1
  11. package/browser/index.js +6 -6
  12. package/{browser → cjs/BaseClasses}/ExternalInteractorBase.js +1 -1
  13. package/{esm → cjs/BaseClasses}/ParticlesInteractorBase.js +1 -1
  14. package/cjs/InteractionManager.js +11 -9
  15. package/cjs/InteractivityEventListeners.js +13 -5
  16. package/cjs/InteractivityPlugin.js +1 -3
  17. package/cjs/InteractivityPluginInstance.js +4 -2
  18. package/cjs/Options/Classes/Events/DivEvent.js +1 -1
  19. package/cjs/Options/Classes/Interactivity.js +1 -1
  20. package/cjs/index.js +6 -6
  21. package/dist_browser_InteractivityPluginInstance_js.js +4 -4
  22. package/dist_browser_InteractivityPlugin_js.js +3 -3
  23. package/{cjs → esm/BaseClasses}/ExternalInteractorBase.js +1 -1
  24. package/{cjs → esm/BaseClasses}/ParticlesInteractorBase.js +1 -1
  25. package/esm/InteractionManager.js +11 -9
  26. package/esm/InteractivityEventListeners.js +13 -5
  27. package/esm/InteractivityPlugin.js +1 -3
  28. package/esm/InteractivityPluginInstance.js +4 -2
  29. package/esm/Interfaces/IMouseData.js +1 -0
  30. package/esm/Interfaces/IParticleInteractorBase.js +1 -0
  31. package/esm/Interfaces/IParticlesInteractor.js +1 -0
  32. package/esm/Options/Classes/Events/DivEvent.js +1 -1
  33. package/esm/Options/Classes/Interactivity.js +1 -1
  34. package/esm/index.js +6 -6
  35. package/package.json +2 -2
  36. package/report.html +1 -1
  37. package/tsparticles.plugin.interactivity.js +38 -38
  38. package/tsparticles.plugin.interactivity.min.js +2 -2
  39. package/types/{ExternalInteractorBase.d.ts → BaseClasses/ExternalInteractorBase.d.ts} +4 -4
  40. package/types/{ParticlesInteractorBase.d.ts → BaseClasses/ParticlesInteractorBase.d.ts} +4 -4
  41. package/types/InteractionManager.d.ts +3 -2
  42. package/types/{IExternalInteractor.d.ts → Interfaces/IExternalInteractor.d.ts} +4 -4
  43. package/types/Interfaces/IInteractor.d.ts +7 -0
  44. package/types/{IInteractor.d.ts → Interfaces/IParticleInteractorBase.d.ts} +4 -7
  45. package/types/{IParticlesInteractor.d.ts → Interfaces/IParticlesInteractor.d.ts} +2 -2
  46. package/types/Options/Classes/Events/DivEvent.d.ts +1 -1
  47. package/types/Options/Classes/Interactivity.d.ts +1 -1
  48. package/types/Options/Interfaces/Events/IDivEvent.d.ts +1 -1
  49. package/types/Options/Interfaces/IInteractivity.d.ts +1 -1
  50. package/types/index.d.ts +10 -9
  51. package/types/types.d.ts +1 -1
  52. package/umd/{ExternalInteractorBase.js → BaseClasses/ExternalInteractorBase.js} +2 -2
  53. package/umd/{ParticlesInteractorBase.js → BaseClasses/ParticlesInteractorBase.js} +2 -2
  54. package/umd/InteractionManager.js +12 -10
  55. package/umd/InteractivityEventListeners.js +14 -6
  56. package/umd/InteractivityPlugin.js +1 -3
  57. package/umd/InteractivityPluginInstance.js +4 -2
  58. package/umd/Interfaces/IParticlesInteractor.js +12 -0
  59. package/umd/Options/Classes/Events/DivEvent.js +2 -2
  60. package/umd/Options/Classes/Interactivity.js +2 -2
  61. package/umd/index.js +7 -7
  62. /package/browser/{DivType.js → Enums/DivType.js} +0 -0
  63. /package/browser/{InteractivityDetect.js → Enums/InteractivityDetect.js} +0 -0
  64. /package/browser/{InteractorType.js → Enums/InteractorType.js} +0 -0
  65. /package/browser/{IExternalInteractor.js → Interfaces/IExternalInteractor.js} +0 -0
  66. /package/browser/{IInteractivityData.js → Interfaces/IInteractivityData.js} +0 -0
  67. /package/browser/{IInteractor.js → Interfaces/IInteractor.js} +0 -0
  68. /package/browser/{IMouseData.js → Interfaces/IMouseData.js} +0 -0
  69. /package/browser/{IParticlesInteractor.js → Interfaces/IParticleInteractorBase.js} +0 -0
  70. /package/{cjs → browser/Interfaces}/IParticlesInteractor.js +0 -0
  71. /package/cjs/{DivType.js → Enums/DivType.js} +0 -0
  72. /package/cjs/{InteractivityDetect.js → Enums/InteractivityDetect.js} +0 -0
  73. /package/cjs/{InteractorType.js → Enums/InteractorType.js} +0 -0
  74. /package/cjs/{IExternalInteractor.js → Interfaces/IExternalInteractor.js} +0 -0
  75. /package/cjs/{IInteractivityData.js → Interfaces/IInteractivityData.js} +0 -0
  76. /package/cjs/{IInteractor.js → Interfaces/IInteractor.js} +0 -0
  77. /package/cjs/{IMouseData.js → Interfaces/IMouseData.js} +0 -0
  78. /package/{esm/IExternalInteractor.js → cjs/Interfaces/IParticleInteractorBase.js} +0 -0
  79. /package/{esm → cjs/Interfaces}/IParticlesInteractor.js +0 -0
  80. /package/esm/{DivType.js → Enums/DivType.js} +0 -0
  81. /package/esm/{InteractivityDetect.js → Enums/InteractivityDetect.js} +0 -0
  82. /package/esm/{InteractorType.js → Enums/InteractorType.js} +0 -0
  83. /package/esm/{IInteractivityData.js → Interfaces/IExternalInteractor.js} +0 -0
  84. /package/esm/{IInteractor.js → Interfaces/IInteractivityData.js} +0 -0
  85. /package/esm/{IMouseData.js → Interfaces/IInteractor.js} +0 -0
  86. /package/types/{DivType.d.ts → Enums/DivType.d.ts} +0 -0
  87. /package/types/{InteractivityDetect.d.ts → Enums/InteractivityDetect.d.ts} +0 -0
  88. /package/types/{InteractorType.d.ts → Enums/InteractorType.d.ts} +0 -0
  89. /package/types/{IInteractivityData.d.ts → Interfaces/IInteractivityData.d.ts} +0 -0
  90. /package/types/{IMouseData.d.ts → Interfaces/IMouseData.d.ts} +0 -0
  91. /package/umd/{DivType.js → Enums/DivType.js} +0 -0
  92. /package/umd/{InteractivityDetect.js → Enums/InteractivityDetect.js} +0 -0
  93. /package/umd/{InteractorType.js → Enums/InteractorType.js} +0 -0
  94. /package/umd/{IExternalInteractor.js → Interfaces/IExternalInteractor.js} +0 -0
  95. /package/umd/{IInteractivityData.js → Interfaces/IInteractivityData.js} +0 -0
  96. /package/umd/{IInteractor.js → Interfaces/IInteractor.js} +0 -0
  97. /package/umd/{IMouseData.js → Interfaces/IMouseData.js} +0 -0
  98. /package/umd/{IParticlesInteractor.js → Interfaces/IParticleInteractorBase.js} +0 -0
@@ -1,7 +1,7 @@
1
1
  import { clickRadius, minCoordinate, safeIntersectionObserver, touchEndLengthOffset, } from "@tsparticles/engine";
2
2
  import { clickEvent, touchCancelEvent, touchEndEvent, touchMoveEvent, touchStartEvent, } from "./InteractivityConstants.js";
3
3
  import { InteractivityEventListeners } from "./InteractivityEventListeners.js";
4
- import { InteractorType } from "./InteractorType.js";
4
+ import { InteractorType } from "./Enums/InteractorType.js";
5
5
  export class InteractionManager {
6
6
  container;
7
7
  interactivityData;
@@ -132,14 +132,7 @@ export class InteractionManager {
132
132
  interactor.handleClickMode?.(mode, interactivityData);
133
133
  }
134
134
  }
135
- async init() {
136
- const interactors = await this._engine.getInteractors?.(this.container, true);
137
- if (!interactors) {
138
- return;
139
- }
140
- this._interactors = interactors;
141
- this._externalInteractors = [];
142
- this._particleInteractors = [];
135
+ init() {
143
136
  this._eventListeners.init();
144
137
  for (const interactor of this._interactors) {
145
138
  switch (interactor.type) {
@@ -153,6 +146,15 @@ export class InteractionManager {
153
146
  interactor.init();
154
147
  }
155
148
  }
149
+ async initInteractors() {
150
+ const interactors = await this._engine.getInteractors?.(this.container, true);
151
+ if (!interactors) {
152
+ return;
153
+ }
154
+ this._interactors = interactors;
155
+ this._externalInteractors = [];
156
+ this._particleInteractors = [];
157
+ }
156
158
  particlesInteract(particle, delta) {
157
159
  const { interactivityData } = this;
158
160
  for (const interactor of this._externalInteractors) {
@@ -1,6 +1,6 @@
1
1
  import { double, executeOnSingleOrMultiple, lengthOffset, manageListener, touchDelay, visibilityChangeEvent, } from "@tsparticles/engine";
2
2
  import { mouseDownEvent, mouseLeaveEvent, mouseMoveEvent, mouseOutEvent, mouseUpEvent, touchCancelEvent, touchEndEvent, touchMoveEvent, touchStartEvent, } from "./InteractivityConstants.js";
3
- import { InteractivityDetect } from "./InteractivityDetect.js";
3
+ import { InteractivityDetect } from "./Enums/InteractivityDetect.js";
4
4
  export class InteractivityEventListeners {
5
5
  _canPush = true;
6
6
  _clickPositionPlugins;
@@ -91,18 +91,26 @@ export class InteractivityEventListeners {
91
91
  }
92
92
  const html = interactivityEl, canvas = container.canvas;
93
93
  canvas.setPointerEvents(html === canvas.element ? "initial" : "none");
94
- if (!(options.interactivity?.events.onHover.enable || options.interactivity?.events.onClick.enable)) {
94
+ if (add && !(options.interactivity?.events.onHover.enable || options.interactivity?.events.onClick.enable)) {
95
95
  return;
96
96
  }
97
97
  manageListener(interactivityEl, mouseMoveEvent, handlers.mouseMove, add);
98
98
  manageListener(interactivityEl, touchStartEvent, handlers.touchStart, add);
99
99
  manageListener(interactivityEl, touchMoveEvent, handlers.touchMove, add);
100
- if (options.interactivity.events.onClick.enable) {
100
+ if (add) {
101
+ if (options.interactivity?.events.onClick.enable) {
102
+ manageListener(interactivityEl, touchEndEvent, handlers.touchEndClick, add);
103
+ manageListener(interactivityEl, mouseUpEvent, handlers.mouseUp, add);
104
+ manageListener(interactivityEl, mouseDownEvent, handlers.mouseDown, add);
105
+ }
106
+ else {
107
+ manageListener(interactivityEl, touchEndEvent, handlers.touchEnd, add);
108
+ }
109
+ }
110
+ else {
101
111
  manageListener(interactivityEl, touchEndEvent, handlers.touchEndClick, add);
102
112
  manageListener(interactivityEl, mouseUpEvent, handlers.mouseUp, add);
103
113
  manageListener(interactivityEl, mouseDownEvent, handlers.mouseDown, add);
104
- }
105
- else {
106
114
  manageListener(interactivityEl, touchEndEvent, handlers.touchEnd, add);
107
115
  }
108
116
  manageListener(interactivityEl, mouseLeaveTmpEvent, handlers.mouseLeave, add);
@@ -38,9 +38,7 @@ export class InteractivityPlugin {
38
38
  return;
39
39
  }
40
40
  for (const interactor of interactors) {
41
- if (interactor.loadParticlesOptions) {
42
- interactor.loadParticlesOptions(options, source);
43
- }
41
+ interactor.loadParticlesOptions?.(options, source);
44
42
  }
45
43
  }
46
44
  needsPlugin() {
@@ -38,10 +38,12 @@ export class InteractivityPluginInstance {
38
38
  this.interactionManager.externalInteract(delta);
39
39
  }
40
40
  async preInit() {
41
- await this.interactionManager.init();
41
+ await this.interactionManager.initInteractors();
42
+ this.interactionManager.init();
42
43
  }
43
44
  async redrawInit() {
44
- await this.interactionManager.init();
45
+ await this.interactionManager.initInteractors();
46
+ this.interactionManager.init();
45
47
  }
46
48
  start() {
47
49
  this.interactionManager.addListeners();
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1 @@
1
+ export {};
@@ -1,5 +1,5 @@
1
1
  import { isNull } from "@tsparticles/engine";
2
- import { DivType } from "../../../DivType.js";
2
+ import { DivType } from "../../../Enums/DivType.js";
3
3
  export class DivEvent {
4
4
  enable;
5
5
  mode;
@@ -1,6 +1,6 @@
1
1
  import { isNull } from "@tsparticles/engine";
2
2
  import { Events } from "./Events/Events.js";
3
- import { InteractivityDetect } from "../../InteractivityDetect.js";
3
+ import { InteractivityDetect } from "../../Enums/InteractivityDetect.js";
4
4
  import { Modes } from "./Modes/Modes.js";
5
5
  export class Interactivity {
6
6
  detectsOn;
package/esm/index.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import { getItemsFromInitializer } from "@tsparticles/engine";
2
2
  export async function loadInteractivityPlugin(engine) {
3
- engine.checkVersion("4.0.0-alpha.21");
3
+ engine.checkVersion("4.0.0-alpha.23");
4
4
  await engine.register(async (e) => {
5
5
  const interactivityEngine = e, { InteractivityPlugin } = await import("./InteractivityPlugin.js");
6
6
  interactivityEngine.addPlugin(new InteractivityPlugin(interactivityEngine));
@@ -32,12 +32,12 @@ export function ensureInteractivityPluginLoaded(e) {
32
32
  throw new Error("tsParticles Interactivity Plugin is not loaded");
33
33
  }
34
34
  }
35
- export * from "./DivType.js";
36
- export * from "./ExternalInteractorBase.js";
35
+ export * from "./BaseClasses/ExternalInteractorBase.js";
36
+ export * from "./BaseClasses/ParticlesInteractorBase.js";
37
37
  export * from "./InteractivityConstants.js";
38
- export * from "./InteractivityDetect.js";
39
- export * from "./InteractorType.js";
40
- export * from "./ParticlesInteractorBase.js";
38
+ export * from "./Enums/DivType.js";
39
+ export * from "./Enums/InteractivityDetect.js";
40
+ export * from "./Enums/InteractorType.js";
41
41
  export * from "./utils.js";
42
42
  export * from "./Options/Classes/Events/DivEvent.js";
43
43
  export * from "./Options/Classes/Modes/Modes.js";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@tsparticles/plugin-interactivity",
3
- "version": "4.0.0-alpha.21",
3
+ "version": "4.0.0-alpha.23",
4
4
  "description": "tsParticles interactivity sickness plugin",
5
5
  "homepage": "https://particles.js.org",
6
6
  "repository": {
@@ -86,7 +86,7 @@
86
86
  "./package.json": "./package.json"
87
87
  },
88
88
  "dependencies": {
89
- "@tsparticles/engine": "4.0.0-alpha.21"
89
+ "@tsparticles/engine": "4.0.0-alpha.23"
90
90
  },
91
91
  "publishConfig": {
92
92
  "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/plugin-interactivity [4 Feb 2026 at 16:46]</title>
6
+ <title>@tsparticles/plugin-interactivity [11 Feb 2026 at 18:24]</title>
7
7
  <link rel="shortcut icon" href="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAEAAAABACAMAAACdt4HsAAABrVBMVEUAAAD///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////+O1foceMD///+J0/qK1Pr7/v8Xdr/9///W8P4UdL7L7P0Scr2r4Pyj3vwad8D5/f/2/f+55f3E6f34+/2H0/ojfMKpzOd0rNgQcb3F3O/j9f7c8v6g3Pz0/P/w+v/q+P7n9v6T1/uQ1vuE0vqLut/y+v+Z2fvt+f+15Pzv9fuc2/vR7v2V2Pvd6/bg9P7I6/285/2y4/yp3/zp8vk8i8kqgMT7/P31+fyv4vxGkcz6/P6/6P3j7vfS5PNnpNUxhcbO7f7F6v3O4vHK3/DA2u631Ouy0eqXweKJud5wqthfoNMMbLvY8f73+v2dxeR8sNtTmdDx9/zX6PSjyeaCtd1YnNGX2PuQveCGt95Nls42h8dLlM3F4vBtAAAAM3RSTlMAAyOx0/sKBvik8opWGBMOAe3l1snDm2E9LSb06eHcu5JpHbarfHZCN9CBb08zzkdNS0kYaptYAAAFV0lEQVRYw92X51/aYBDHHS2O2qqttVbrqNq9m+TJIAYIShBkWwqIiCgoWvfeq7Z2/s29hyQNyUcR7LveGwVyXy6XH8/9rqxglLfUPLxVduUor3h0rfp2TYvpivk37929TkG037hffoX0+peVtZQc1589rigVUdXS/ABSAyEmGIO/1XfvldSK8vs3OqB6u3m0nxmIrvgB0dj7rr7Y9IbuF68hnfFaiHA/sxqm0wciIG43P60qKv9WXWc1RXGh/mFESFABTSBi0sNAKzqet17eCtOb3kZIDwxEEU0oAIJGYxNBDhBND29e0rtXXbcpuPmED9IhEAAQ/AXEaF8EPmnrrKsv0LvWR3fg5sWDNAFZOgAgaKvZDogHNU9MFwnnYROkc56RD5CjAbQX9Ow4g7upCsvYu55aSI/Nj0H1akgKQEUM94dwK65hYRmFU9MIcH/fqJYOZYcnuJSU/waKDgTOEVaVKhwrTRP5XzgSpAITYzom7UvkhFX5VutmxeNnWDjjswTKTyfgluNDGbUpWissXhF3s7mlSml+czWkg3D0l1nNjGNjz3myOQOa1KM/jOS6ebdbAVTCi4gljHSFrviza7tOgRWcS0MOUX9zdNgag5w7rRqA44Lzw0hr1WqES36dFliSJFlh2rXIae3FFcDDgKdxrUIDePr8jGcSClV1u7A9xeN0ModY/pHMxmR1EzRh8TJiwqsHmKW0l4FCEZI+jHio+JdPPE9qwQtTRxku2D8sIeRL2LnxWSllANCQGOIiqVHAz2ye2JR0DcH+HoxDkaADLjgxjKQ+AwCX/g0+DNgdG0ukYCONAe+dbc2IAc6fwt1ARoDSezNHxV2Cmzwv3O6lDMV55edBGwGK9n1+x2F8EDfAGCxug8MhpsMEcTEAWf3rx2vZhe/LAmtIn/6apE6PN0ULKgywD9mmdxbmFl3OvD5AS5fW5zLbv/YHmcsBTjf/afDz3MaZTVCfAP9z6/Bw6ycv8EUBWJIn9zYcoAWWlW9+OzO3vkTy8H+RANLmdrpOuYWdZYEXpo+TlCJrW5EARb7fF+bWdqf3hhyZI1nWJQHgznErZhbjoEsWqi8dQNoE294aldzFurwSABL2XXMf9+H1VQGke9exw5P/AnA5Pv5ngMul7LOvO922iwACu8WkCwLCafvM4CeWPxfA8lNHcWZSoi8EwMAIciKX2Z4SWCMAa3snCZ/G4EA8D6CMLNFsGQhkkz/gQNEBbPCbWsxGUpYVu3z8IyNAknwJkfPMEhLyrdi5RTyUVACkw4GSFRNWJNEW+fgPGwHD8/JxnRuLabN4CGNRkAE23na2+VmEAUmrYymSGjMAYqH84YUIyzgzs3XC7gNgH36Vcc4zKY9o9fgPBXUAiHHwVboBHGLiX6Zcjp1f2wu4tvzZKo0ecPnDtQYDQvJXaBeNzce45Fp28ZQLrEZVuFqgBwOalArKXnW1UzlnSusQKJqKYNuz4tOnI6sZG4zanpemv+7ySU2jbA9h6uhcgpfy6G2PahirDZ6zvq6zDduMVFTKvzw8wgyEdelwY9in3XkEPs3osJuwRQ4qTkfzifndg9Gfc4pdsu82+tTnHZTBa2EAMrqr2t43pguc8tNm7JQVQ2S0ukj2d22dhXYP0/veWtwKrCkNoNimAN5+Xr/oLrxswKbVJjteWrX7eR63o4j9q0GxnaBdWgGA5VStpanIjQmEhV0/nVt5VOFUvix6awJhPcAaTEShgrG+iGyvb5a0Ndb1YGHFPEwoqAinoaykaID1o1pdPNu7XsnCKQ3R+hwWIIhGvORcJUBYXe3Xa3vq/mF/N9V13ugufMkfXn+KHsRD0B8AAAAASUVORK5CYII=" type="image/x-icon" />
8
8
 
9
9
  <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
- * v4.0.0-alpha.21
7
+ * v4.0.0-alpha.23
8
8
  */
9
9
  /*
10
10
  * ATTENTION: The "eval" devtool has been used (maybe by default in mode: "development").
@@ -38,53 +38,63 @@ module.exports = __WEBPACK_EXTERNAL_MODULE__tsparticles_engine__;
38
38
 
39
39
  /***/ },
40
40
 
41
- /***/ "./dist/browser/DivType.js"
42
- /*!*********************************!*\
43
- !*** ./dist/browser/DivType.js ***!
44
- \*********************************/
41
+ /***/ "./dist/browser/BaseClasses/ExternalInteractorBase.js"
42
+ /*!************************************************************!*\
43
+ !*** ./dist/browser/BaseClasses/ExternalInteractorBase.js ***!
44
+ \************************************************************/
45
45
  (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
46
46
 
47
- eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ DivType: () => (/* binding */ DivType)\n/* harmony export */ });\nvar DivType;\n(function(DivType) {\n DivType[\"circle\"] = \"circle\";\n DivType[\"rectangle\"] = \"rectangle\";\n})(DivType || (DivType = {}));\n\n\n//# sourceURL=webpack://@tsparticles/plugin-interactivity/./dist/browser/DivType.js?\n}");
47
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ ExternalInteractorBase: () => (/* binding */ ExternalInteractorBase)\n/* harmony export */ });\n/* harmony import */ var _Enums_InteractorType_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Enums/InteractorType.js */ \"./dist/browser/Enums/InteractorType.js\");\n\nclass ExternalInteractorBase {\n type = _Enums_InteractorType_js__WEBPACK_IMPORTED_MODULE_0__.InteractorType.external;\n container;\n constructor(container){\n this.container = container;\n }\n}\n\n\n//# sourceURL=webpack://@tsparticles/plugin-interactivity/./dist/browser/BaseClasses/ExternalInteractorBase.js?\n}");
48
48
 
49
49
  /***/ },
50
50
 
51
- /***/ "./dist/browser/ExternalInteractorBase.js"
52
- /*!************************************************!*\
53
- !*** ./dist/browser/ExternalInteractorBase.js ***!
54
- \************************************************/
51
+ /***/ "./dist/browser/BaseClasses/ParticlesInteractorBase.js"
52
+ /*!*************************************************************!*\
53
+ !*** ./dist/browser/BaseClasses/ParticlesInteractorBase.js ***!
54
+ \*************************************************************/
55
55
  (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
56
56
 
57
- eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ ExternalInteractorBase: () => (/* binding */ ExternalInteractorBase)\n/* harmony export */ });\n/* harmony import */ var _InteractorType_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./InteractorType.js */ \"./dist/browser/InteractorType.js\");\n\nclass ExternalInteractorBase {\n type = _InteractorType_js__WEBPACK_IMPORTED_MODULE_0__.InteractorType.external;\n container;\n constructor(container){\n this.container = container;\n }\n}\n\n\n//# sourceURL=webpack://@tsparticles/plugin-interactivity/./dist/browser/ExternalInteractorBase.js?\n}");
57
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ ParticlesInteractorBase: () => (/* binding */ ParticlesInteractorBase)\n/* harmony export */ });\n/* harmony import */ var _Enums_InteractorType_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Enums/InteractorType.js */ \"./dist/browser/Enums/InteractorType.js\");\n\nclass ParticlesInteractorBase {\n type = _Enums_InteractorType_js__WEBPACK_IMPORTED_MODULE_0__.InteractorType.particles;\n container;\n constructor(container){\n this.container = container;\n }\n}\n\n\n//# sourceURL=webpack://@tsparticles/plugin-interactivity/./dist/browser/BaseClasses/ParticlesInteractorBase.js?\n}");
58
58
 
59
59
  /***/ },
60
60
 
61
- /***/ "./dist/browser/InteractivityConstants.js"
62
- /*!************************************************!*\
63
- !*** ./dist/browser/InteractivityConstants.js ***!
64
- \************************************************/
61
+ /***/ "./dist/browser/Enums/DivType.js"
62
+ /*!***************************************!*\
63
+ !*** ./dist/browser/Enums/DivType.js ***!
64
+ \***************************************/
65
65
  (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
66
66
 
67
- eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ clickEvent: () => (/* binding */ clickEvent),\n/* harmony export */ mouseDownEvent: () => (/* binding */ mouseDownEvent),\n/* harmony export */ mouseLeaveEvent: () => (/* binding */ mouseLeaveEvent),\n/* harmony export */ mouseMoveEvent: () => (/* binding */ mouseMoveEvent),\n/* harmony export */ mouseOutEvent: () => (/* binding */ mouseOutEvent),\n/* harmony export */ mouseUpEvent: () => (/* binding */ mouseUpEvent),\n/* harmony export */ touchCancelEvent: () => (/* binding */ touchCancelEvent),\n/* harmony export */ touchEndEvent: () => (/* binding */ touchEndEvent),\n/* harmony export */ touchMoveEvent: () => (/* binding */ touchMoveEvent),\n/* harmony export */ touchStartEvent: () => (/* binding */ touchStartEvent)\n/* harmony export */ });\nconst clickEvent = \"click\", mouseDownEvent = \"pointerdown\", mouseUpEvent = \"pointerup\", mouseLeaveEvent = \"pointerleave\", mouseOutEvent = \"pointerout\", mouseMoveEvent = \"pointermove\", touchStartEvent = \"touchstart\", touchEndEvent = \"touchend\", touchMoveEvent = \"touchmove\", touchCancelEvent = \"touchcancel\";\n\n\n//# sourceURL=webpack://@tsparticles/plugin-interactivity/./dist/browser/InteractivityConstants.js?\n}");
67
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ DivType: () => (/* binding */ DivType)\n/* harmony export */ });\nvar DivType;\n(function(DivType) {\n DivType[\"circle\"] = \"circle\";\n DivType[\"rectangle\"] = \"rectangle\";\n})(DivType || (DivType = {}));\n\n\n//# sourceURL=webpack://@tsparticles/plugin-interactivity/./dist/browser/Enums/DivType.js?\n}");
68
+
69
+ /***/ },
70
+
71
+ /***/ "./dist/browser/Enums/InteractivityDetect.js"
72
+ /*!***************************************************!*\
73
+ !*** ./dist/browser/Enums/InteractivityDetect.js ***!
74
+ \***************************************************/
75
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
76
+
77
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ InteractivityDetect: () => (/* binding */ InteractivityDetect)\n/* harmony export */ });\nvar InteractivityDetect;\n(function(InteractivityDetect) {\n InteractivityDetect[\"canvas\"] = \"canvas\";\n InteractivityDetect[\"parent\"] = \"parent\";\n InteractivityDetect[\"window\"] = \"window\";\n})(InteractivityDetect || (InteractivityDetect = {}));\n\n\n//# sourceURL=webpack://@tsparticles/plugin-interactivity/./dist/browser/Enums/InteractivityDetect.js?\n}");
68
78
 
69
79
  /***/ },
70
80
 
71
- /***/ "./dist/browser/InteractivityDetect.js"
72
- /*!*********************************************!*\
73
- !*** ./dist/browser/InteractivityDetect.js ***!
74
- \*********************************************/
81
+ /***/ "./dist/browser/Enums/InteractorType.js"
82
+ /*!**********************************************!*\
83
+ !*** ./dist/browser/Enums/InteractorType.js ***!
84
+ \**********************************************/
75
85
  (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
76
86
 
77
- eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ InteractivityDetect: () => (/* binding */ InteractivityDetect)\n/* harmony export */ });\nvar InteractivityDetect;\n(function(InteractivityDetect) {\n InteractivityDetect[\"canvas\"] = \"canvas\";\n InteractivityDetect[\"parent\"] = \"parent\";\n InteractivityDetect[\"window\"] = \"window\";\n})(InteractivityDetect || (InteractivityDetect = {}));\n\n\n//# sourceURL=webpack://@tsparticles/plugin-interactivity/./dist/browser/InteractivityDetect.js?\n}");
87
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ InteractorType: () => (/* binding */ InteractorType)\n/* harmony export */ });\nvar InteractorType;\n(function(InteractorType) {\n InteractorType[\"external\"] = \"external\";\n InteractorType[\"particles\"] = \"particles\";\n})(InteractorType || (InteractorType = {}));\n\n\n//# sourceURL=webpack://@tsparticles/plugin-interactivity/./dist/browser/Enums/InteractorType.js?\n}");
78
88
 
79
89
  /***/ },
80
90
 
81
- /***/ "./dist/browser/InteractorType.js"
82
- /*!****************************************!*\
83
- !*** ./dist/browser/InteractorType.js ***!
84
- \****************************************/
91
+ /***/ "./dist/browser/InteractivityConstants.js"
92
+ /*!************************************************!*\
93
+ !*** ./dist/browser/InteractivityConstants.js ***!
94
+ \************************************************/
85
95
  (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
86
96
 
87
- eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ InteractorType: () => (/* binding */ InteractorType)\n/* harmony export */ });\nvar InteractorType;\n(function(InteractorType) {\n InteractorType[\"external\"] = \"external\";\n InteractorType[\"particles\"] = \"particles\";\n})(InteractorType || (InteractorType = {}));\n\n\n//# sourceURL=webpack://@tsparticles/plugin-interactivity/./dist/browser/InteractorType.js?\n}");
97
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ clickEvent: () => (/* binding */ clickEvent),\n/* harmony export */ mouseDownEvent: () => (/* binding */ mouseDownEvent),\n/* harmony export */ mouseLeaveEvent: () => (/* binding */ mouseLeaveEvent),\n/* harmony export */ mouseMoveEvent: () => (/* binding */ mouseMoveEvent),\n/* harmony export */ mouseOutEvent: () => (/* binding */ mouseOutEvent),\n/* harmony export */ mouseUpEvent: () => (/* binding */ mouseUpEvent),\n/* harmony export */ touchCancelEvent: () => (/* binding */ touchCancelEvent),\n/* harmony export */ touchEndEvent: () => (/* binding */ touchEndEvent),\n/* harmony export */ touchMoveEvent: () => (/* binding */ touchMoveEvent),\n/* harmony export */ touchStartEvent: () => (/* binding */ touchStartEvent)\n/* harmony export */ });\nconst clickEvent = \"click\", mouseDownEvent = \"pointerdown\", mouseUpEvent = \"pointerup\", mouseLeaveEvent = \"pointerleave\", mouseOutEvent = \"pointerout\", mouseMoveEvent = \"pointermove\", touchStartEvent = \"touchstart\", touchEndEvent = \"touchend\", touchMoveEvent = \"touchmove\", touchCancelEvent = \"touchcancel\";\n\n\n//# sourceURL=webpack://@tsparticles/plugin-interactivity/./dist/browser/InteractivityConstants.js?\n}");
88
98
 
89
99
  /***/ },
90
100
 
@@ -94,7 +104,7 @@ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpa
94
104
  \*********************************************************/
95
105
  (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
96
106
 
97
- eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ DivEvent: () => (/* binding */ DivEvent)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/engine */ \"@tsparticles/engine\");\n/* harmony import */ var _DivType_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../../DivType.js */ \"./dist/browser/DivType.js\");\n\n\nclass DivEvent {\n enable;\n mode;\n selectors;\n type;\n constructor(){\n this.selectors = [];\n this.enable = false;\n this.mode = [];\n this.type = _DivType_js__WEBPACK_IMPORTED_MODULE_1__.DivType.circle;\n }\n load(data) {\n if ((0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.isNull)(data)) {\n return;\n }\n if (data.selectors !== undefined) {\n this.selectors = data.selectors;\n }\n if (data.enable !== undefined) {\n this.enable = data.enable;\n }\n if (data.mode !== undefined) {\n this.mode = data.mode;\n }\n if (data.type !== undefined) {\n this.type = data.type;\n }\n }\n}\n\n\n//# sourceURL=webpack://@tsparticles/plugin-interactivity/./dist/browser/Options/Classes/Events/DivEvent.js?\n}");
107
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ DivEvent: () => (/* binding */ DivEvent)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/engine */ \"@tsparticles/engine\");\n/* harmony import */ var _Enums_DivType_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../../Enums/DivType.js */ \"./dist/browser/Enums/DivType.js\");\n\n\nclass DivEvent {\n enable;\n mode;\n selectors;\n type;\n constructor(){\n this.selectors = [];\n this.enable = false;\n this.mode = [];\n this.type = _Enums_DivType_js__WEBPACK_IMPORTED_MODULE_1__.DivType.circle;\n }\n load(data) {\n if ((0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.isNull)(data)) {\n return;\n }\n if (data.selectors !== undefined) {\n this.selectors = data.selectors;\n }\n if (data.enable !== undefined) {\n this.enable = data.enable;\n }\n if (data.mode !== undefined) {\n this.mode = data.mode;\n }\n if (data.type !== undefined) {\n this.type = data.type;\n }\n }\n}\n\n\n//# sourceURL=webpack://@tsparticles/plugin-interactivity/./dist/browser/Options/Classes/Events/DivEvent.js?\n}");
98
108
 
99
109
  /***/ },
100
110
 
@@ -108,23 +118,13 @@ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpa
108
118
 
109
119
  /***/ },
110
120
 
111
- /***/ "./dist/browser/ParticlesInteractorBase.js"
112
- /*!*************************************************!*\
113
- !*** ./dist/browser/ParticlesInteractorBase.js ***!
114
- \*************************************************/
115
- (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
116
-
117
- eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ ParticlesInteractorBase: () => (/* binding */ ParticlesInteractorBase)\n/* harmony export */ });\n/* harmony import */ var _InteractorType_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./InteractorType.js */ \"./dist/browser/InteractorType.js\");\n\nclass ParticlesInteractorBase {\n type = _InteractorType_js__WEBPACK_IMPORTED_MODULE_0__.InteractorType.particles;\n container;\n constructor(container){\n this.container = container;\n }\n}\n\n\n//# sourceURL=webpack://@tsparticles/plugin-interactivity/./dist/browser/ParticlesInteractorBase.js?\n}");
118
-
119
- /***/ },
120
-
121
121
  /***/ "./dist/browser/index.js"
122
122
  /*!*******************************!*\
123
123
  !*** ./dist/browser/index.js ***!
124
124
  \*******************************/
125
125
  (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
126
126
 
127
- eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ DivEvent: () => (/* reexport safe */ _Options_Classes_Events_DivEvent_js__WEBPACK_IMPORTED_MODULE_8__.DivEvent),\n/* harmony export */ DivType: () => (/* reexport safe */ _DivType_js__WEBPACK_IMPORTED_MODULE_1__.DivType),\n/* harmony export */ ExternalInteractorBase: () => (/* reexport safe */ _ExternalInteractorBase_js__WEBPACK_IMPORTED_MODULE_2__.ExternalInteractorBase),\n/* harmony export */ InteractivityDetect: () => (/* reexport safe */ _InteractivityDetect_js__WEBPACK_IMPORTED_MODULE_4__.InteractivityDetect),\n/* harmony export */ InteractorType: () => (/* reexport safe */ _InteractorType_js__WEBPACK_IMPORTED_MODULE_5__.InteractorType),\n/* harmony export */ Modes: () => (/* reexport safe */ _Options_Classes_Modes_Modes_js__WEBPACK_IMPORTED_MODULE_9__.Modes),\n/* harmony export */ ParticlesInteractorBase: () => (/* reexport safe */ _ParticlesInteractorBase_js__WEBPACK_IMPORTED_MODULE_6__.ParticlesInteractorBase),\n/* harmony export */ clickEvent: () => (/* reexport safe */ _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_3__.clickEvent),\n/* harmony export */ divMode: () => (/* reexport safe */ _utils_js__WEBPACK_IMPORTED_MODULE_7__.divMode),\n/* harmony export */ divModeExecute: () => (/* reexport safe */ _utils_js__WEBPACK_IMPORTED_MODULE_7__.divModeExecute),\n/* harmony export */ ensureInteractivityPluginLoaded: () => (/* binding */ ensureInteractivityPluginLoaded),\n/* harmony export */ isDivModeEnabled: () => (/* reexport safe */ _utils_js__WEBPACK_IMPORTED_MODULE_7__.isDivModeEnabled),\n/* harmony export */ loadInteractivityPlugin: () => (/* binding */ loadInteractivityPlugin),\n/* harmony export */ mouseDownEvent: () => (/* reexport safe */ _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_3__.mouseDownEvent),\n/* harmony export */ mouseLeaveEvent: () => (/* reexport safe */ _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_3__.mouseLeaveEvent),\n/* harmony export */ mouseMoveEvent: () => (/* reexport safe */ _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_3__.mouseMoveEvent),\n/* harmony export */ mouseOutEvent: () => (/* reexport safe */ _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_3__.mouseOutEvent),\n/* harmony export */ mouseUpEvent: () => (/* reexport safe */ _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_3__.mouseUpEvent),\n/* harmony export */ singleDivModeExecute: () => (/* reexport safe */ _utils_js__WEBPACK_IMPORTED_MODULE_7__.singleDivModeExecute),\n/* harmony export */ touchCancelEvent: () => (/* reexport safe */ _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_3__.touchCancelEvent),\n/* harmony export */ touchEndEvent: () => (/* reexport safe */ _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_3__.touchEndEvent),\n/* harmony export */ touchMoveEvent: () => (/* reexport safe */ _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_3__.touchMoveEvent),\n/* harmony export */ touchStartEvent: () => (/* reexport safe */ _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_3__.touchStartEvent)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/engine */ \"@tsparticles/engine\");\n/* harmony import */ var _DivType_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./DivType.js */ \"./dist/browser/DivType.js\");\n/* harmony import */ var _ExternalInteractorBase_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./ExternalInteractorBase.js */ \"./dist/browser/ExternalInteractorBase.js\");\n/* harmony import */ var _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./InteractivityConstants.js */ \"./dist/browser/InteractivityConstants.js\");\n/* harmony import */ var _InteractivityDetect_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./InteractivityDetect.js */ \"./dist/browser/InteractivityDetect.js\");\n/* harmony import */ var _InteractorType_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./InteractorType.js */ \"./dist/browser/InteractorType.js\");\n/* harmony import */ var _ParticlesInteractorBase_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./ParticlesInteractorBase.js */ \"./dist/browser/ParticlesInteractorBase.js\");\n/* harmony import */ var _utils_js__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./utils.js */ \"./dist/browser/utils.js\");\n/* harmony import */ var _Options_Classes_Events_DivEvent_js__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./Options/Classes/Events/DivEvent.js */ \"./dist/browser/Options/Classes/Events/DivEvent.js\");\n/* harmony import */ var _Options_Classes_Modes_Modes_js__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./Options/Classes/Modes/Modes.js */ \"./dist/browser/Options/Classes/Modes/Modes.js\");\n\nasync function loadInteractivityPlugin(engine) {\n engine.checkVersion(\"4.0.0-alpha.21\");\n await engine.register(async (e)=>{\n const interactivityEngine = e, { InteractivityPlugin } = await __webpack_require__.e(/*! import() */ \"dist_browser_InteractivityPlugin_js\").then(__webpack_require__.bind(__webpack_require__, /*! ./InteractivityPlugin.js */ \"./dist/browser/InteractivityPlugin.js\"));\n interactivityEngine.addPlugin(new InteractivityPlugin(interactivityEngine));\n interactivityEngine.initializers.interactors ??= new Map();\n interactivityEngine.interactors ??= new Map();\n interactivityEngine.addInteractor = (name, interactorInitializer)=>{\n interactivityEngine.initializers.interactors ??= new Map();\n interactivityEngine.initializers.interactors.set(name, interactorInitializer);\n };\n interactivityEngine.getInteractors = async (container, force = false)=>{\n interactivityEngine.interactors ??= new Map();\n interactivityEngine.initializers.interactors ??= new Map();\n return (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.getItemsFromInitializer)(container, interactivityEngine.interactors, interactivityEngine.initializers.interactors, force);\n };\n interactivityEngine.setOnClickHandler = (callback)=>{\n const { items } = interactivityEngine;\n if (!items.length) {\n throw new Error(\"Click handlers can only be set after calling tsParticles.load()\");\n }\n items.forEach((item)=>{\n const interactivityContainer = item;\n interactivityContainer.addClickHandler?.(callback);\n });\n };\n });\n}\nfunction ensureInteractivityPluginLoaded(e) {\n if (!e.addInteractor) {\n throw new Error(\"tsParticles Interactivity Plugin is not loaded\");\n }\n}\n\n\n\n\n\n\n\n\n\n\n\n//# sourceURL=webpack://@tsparticles/plugin-interactivity/./dist/browser/index.js?\n}");
127
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ DivEvent: () => (/* reexport safe */ _Options_Classes_Events_DivEvent_js__WEBPACK_IMPORTED_MODULE_8__.DivEvent),\n/* harmony export */ DivType: () => (/* reexport safe */ _Enums_DivType_js__WEBPACK_IMPORTED_MODULE_4__.DivType),\n/* harmony export */ ExternalInteractorBase: () => (/* reexport safe */ _BaseClasses_ExternalInteractorBase_js__WEBPACK_IMPORTED_MODULE_1__.ExternalInteractorBase),\n/* harmony export */ InteractivityDetect: () => (/* reexport safe */ _Enums_InteractivityDetect_js__WEBPACK_IMPORTED_MODULE_5__.InteractivityDetect),\n/* harmony export */ InteractorType: () => (/* reexport safe */ _Enums_InteractorType_js__WEBPACK_IMPORTED_MODULE_6__.InteractorType),\n/* harmony export */ Modes: () => (/* reexport safe */ _Options_Classes_Modes_Modes_js__WEBPACK_IMPORTED_MODULE_9__.Modes),\n/* harmony export */ ParticlesInteractorBase: () => (/* reexport safe */ _BaseClasses_ParticlesInteractorBase_js__WEBPACK_IMPORTED_MODULE_2__.ParticlesInteractorBase),\n/* harmony export */ clickEvent: () => (/* reexport safe */ _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_3__.clickEvent),\n/* harmony export */ divMode: () => (/* reexport safe */ _utils_js__WEBPACK_IMPORTED_MODULE_7__.divMode),\n/* harmony export */ divModeExecute: () => (/* reexport safe */ _utils_js__WEBPACK_IMPORTED_MODULE_7__.divModeExecute),\n/* harmony export */ ensureInteractivityPluginLoaded: () => (/* binding */ ensureInteractivityPluginLoaded),\n/* harmony export */ isDivModeEnabled: () => (/* reexport safe */ _utils_js__WEBPACK_IMPORTED_MODULE_7__.isDivModeEnabled),\n/* harmony export */ loadInteractivityPlugin: () => (/* binding */ loadInteractivityPlugin),\n/* harmony export */ mouseDownEvent: () => (/* reexport safe */ _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_3__.mouseDownEvent),\n/* harmony export */ mouseLeaveEvent: () => (/* reexport safe */ _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_3__.mouseLeaveEvent),\n/* harmony export */ mouseMoveEvent: () => (/* reexport safe */ _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_3__.mouseMoveEvent),\n/* harmony export */ mouseOutEvent: () => (/* reexport safe */ _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_3__.mouseOutEvent),\n/* harmony export */ mouseUpEvent: () => (/* reexport safe */ _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_3__.mouseUpEvent),\n/* harmony export */ singleDivModeExecute: () => (/* reexport safe */ _utils_js__WEBPACK_IMPORTED_MODULE_7__.singleDivModeExecute),\n/* harmony export */ touchCancelEvent: () => (/* reexport safe */ _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_3__.touchCancelEvent),\n/* harmony export */ touchEndEvent: () => (/* reexport safe */ _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_3__.touchEndEvent),\n/* harmony export */ touchMoveEvent: () => (/* reexport safe */ _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_3__.touchMoveEvent),\n/* harmony export */ touchStartEvent: () => (/* reexport safe */ _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_3__.touchStartEvent)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/engine */ \"@tsparticles/engine\");\n/* harmony import */ var _BaseClasses_ExternalInteractorBase_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./BaseClasses/ExternalInteractorBase.js */ \"./dist/browser/BaseClasses/ExternalInteractorBase.js\");\n/* harmony import */ var _BaseClasses_ParticlesInteractorBase_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./BaseClasses/ParticlesInteractorBase.js */ \"./dist/browser/BaseClasses/ParticlesInteractorBase.js\");\n/* harmony import */ var _InteractivityConstants_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./InteractivityConstants.js */ \"./dist/browser/InteractivityConstants.js\");\n/* harmony import */ var _Enums_DivType_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./Enums/DivType.js */ \"./dist/browser/Enums/DivType.js\");\n/* harmony import */ var _Enums_InteractivityDetect_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./Enums/InteractivityDetect.js */ \"./dist/browser/Enums/InteractivityDetect.js\");\n/* harmony import */ var _Enums_InteractorType_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./Enums/InteractorType.js */ \"./dist/browser/Enums/InteractorType.js\");\n/* harmony import */ var _utils_js__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./utils.js */ \"./dist/browser/utils.js\");\n/* harmony import */ var _Options_Classes_Events_DivEvent_js__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./Options/Classes/Events/DivEvent.js */ \"./dist/browser/Options/Classes/Events/DivEvent.js\");\n/* harmony import */ var _Options_Classes_Modes_Modes_js__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./Options/Classes/Modes/Modes.js */ \"./dist/browser/Options/Classes/Modes/Modes.js\");\n\nasync function loadInteractivityPlugin(engine) {\n engine.checkVersion(\"4.0.0-alpha.23\");\n await engine.register(async (e)=>{\n const interactivityEngine = e, { InteractivityPlugin } = await __webpack_require__.e(/*! import() */ \"dist_browser_InteractivityPlugin_js\").then(__webpack_require__.bind(__webpack_require__, /*! ./InteractivityPlugin.js */ \"./dist/browser/InteractivityPlugin.js\"));\n interactivityEngine.addPlugin(new InteractivityPlugin(interactivityEngine));\n interactivityEngine.initializers.interactors ??= new Map();\n interactivityEngine.interactors ??= new Map();\n interactivityEngine.addInteractor = (name, interactorInitializer)=>{\n interactivityEngine.initializers.interactors ??= new Map();\n interactivityEngine.initializers.interactors.set(name, interactorInitializer);\n };\n interactivityEngine.getInteractors = async (container, force = false)=>{\n interactivityEngine.interactors ??= new Map();\n interactivityEngine.initializers.interactors ??= new Map();\n return (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.getItemsFromInitializer)(container, interactivityEngine.interactors, interactivityEngine.initializers.interactors, force);\n };\n interactivityEngine.setOnClickHandler = (callback)=>{\n const { items } = interactivityEngine;\n if (!items.length) {\n throw new Error(\"Click handlers can only be set after calling tsParticles.load()\");\n }\n items.forEach((item)=>{\n const interactivityContainer = item;\n interactivityContainer.addClickHandler?.(callback);\n });\n };\n });\n}\nfunction ensureInteractivityPluginLoaded(e) {\n if (!e.addInteractor) {\n throw new Error(\"tsParticles Interactivity Plugin is not loaded\");\n }\n}\n\n\n\n\n\n\n\n\n\n\n\n//# sourceURL=webpack://@tsparticles/plugin-interactivity/./dist/browser/index.js?\n}");
128
128
 
129
129
  /***/ },
130
130
 
@@ -1,2 +1,2 @@
1
- !function(e,t){if("object"==typeof exports&&"object"==typeof module)module.exports=t(require("@tsparticles/engine"));else if("function"==typeof define&&define.amd)define(["@tsparticles/engine"],t);else{var r="object"==typeof exports?t(require("@tsparticles/engine")):t(e.window);for(var i in r)("object"==typeof exports?exports:e)[i]=r[i]}}(this,e=>(()=>{"use strict";var t,r,i,n={303(t){t.exports=e},44(e,t,r){var i,n;r.d(t,{Q:()=>i}),(n=i||(i={})).circle="circle",n.rectangle="rectangle"},731(e,t,r){r.d(t,{Bp:()=>u,DG:()=>d,G3:()=>p,Rb:()=>c,Z0:()=>a,ms:()=>n,s7:()=>l,sf:()=>s,vo:()=>o,xO:()=>i});let i="click",n="pointerdown",o="pointerup",a="pointerleave",s="pointerout",c="pointermove",l="touchstart",u="touchend",d="touchmove",p="touchcancel"},851(e,t,r){var i,n;r.d(t,{h:()=>i}),(n=i||(i={})).canvas="canvas",n.parent="parent",n.window="window"},500(e,t,r){var i,n;r.d(t,{e:()=>i}),(n=i||(i={})).external="external",n.particles="particles"},646(e,t,r){r.d(t,{G:()=>o});var i=r(303),n=r(44);class o{enable;mode;selectors;type;constructor(){this.selectors=[],this.enable=!1,this.mode=[],this.type=n.Q.circle}load(e){(0,i.isNull)(e)||(void 0!==e.selectors&&(this.selectors=e.selectors),void 0!==e.enable&&(this.enable=e.enable),void 0!==e.mode&&(this.mode=e.mode),void 0!==e.type&&(this.type=e.type))}}},802(e,t,r){r.d(t,{d:()=>n});var i=r(303);class n{_container;_engine;constructor(e,t){this._engine=e,this._container=t}load(e){if((0,i.isNull)(e)||!this._container)return;let t=this._engine.interactors?.get(this._container);if(t)for(let r of t)r.loadModeOptions&&r.loadModeOptions(this,e)}}}},o={};function a(e){var t=o[e];if(void 0!==t)return t.exports;var r=o[e]={exports:{}};return n[e](r,r.exports,a),r.exports}a.m=n,a.d=(e,t)=>{for(var r in t)a.o(t,r)&&!a.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},a.f={},a.e=e=>Promise.all(Object.keys(a.f).reduce((t,r)=>(a.f[r](e,t),t),[])),a.u=e=>""+e+".min.js",a.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||Function("return this")()}catch(e){if("object"==typeof window)return window}}(),a.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),s={},a.l=(e,t,r,i)=>{if(s[e])return void s[e].push(t);if(void 0!==r)for(var n,o,c=document.getElementsByTagName("script"),l=0;l<c.length;l++){var u=c[l];if(u.getAttribute("src")==e||u.getAttribute("data-webpack")=="@tsparticles/plugin-interactivity:"+r){n=u;break}}n||(o=!0,(n=document.createElement("script")).charset="utf-8",a.nc&&n.setAttribute("nonce",a.nc),n.setAttribute("data-webpack","@tsparticles/plugin-interactivity:"+r),n.src=e),s[e]=[t];var d=(t,r)=>{n.onerror=n.onload=null,clearTimeout(p);var i=s[e];if(delete s[e],n.parentNode&&n.parentNode.removeChild(n),i&&i.forEach(e=>e(r)),t)return t(r)},p=setTimeout(d.bind(null,void 0,{type:"timeout",target:n}),12e4);n.onerror=d.bind(null,n.onerror),n.onload=d.bind(null,n.onload),o&&document.head.appendChild(n)},a.r=e=>{"u">typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},a.g.importScripts&&(c=a.g.location+"");var s,c,l=a.g.document;if(!c&&l&&(l.currentScript&&"SCRIPT"===l.currentScript.tagName.toUpperCase()&&(c=l.currentScript.src),!c)){var u=l.getElementsByTagName("script");if(u.length)for(var d=u.length-1;d>-1&&(!c||!/^http(s?):/.test(c));)c=u[d--].src}if(!c)throw Error("Automatic publicPath is not supported in this browser");a.p=c=c.replace(/^blob:/,"").replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),t={301:0},a.f.j=(e,r)=>{var i=a.o(t,e)?t[e]:void 0;if(0!==i)if(i)r.push(i[2]);else{var n=new Promise((r,n)=>i=t[e]=[r,n]);r.push(i[2]=n);var o=a.p+a.u(e),s=Error();a.l(o,r=>{if(a.o(t,e)&&(0!==(i=t[e])&&(t[e]=void 0),i)){var n=r&&("load"===r.type?"missing":r.type),o=r&&r.target&&r.target.src;s.message="Loading chunk "+e+` failed.
2
- (`+n+": "+o+")",s.name="ChunkLoadError",s.type=n,s.request=o,i[1](s)}},"chunk-"+e,e)}},r=(e,r)=>{var i,n,[o,s,c]=r,l=0;if(o.some(e=>0!==t[e])){for(i in s)a.o(s,i)&&(a.m[i]=s[i]);c&&c(a)}for(e&&e(r);l<o.length;l++)n=o[l],a.o(t,n)&&t[n]&&t[n][0](),t[n]=0},(i=this.webpackChunk_tsparticles_plugin_interactivity=this.webpackChunk_tsparticles_plugin_interactivity||[]).forEach(r.bind(null,0)),i.push=r.bind(null,i.push.bind(i));var p={};a.r(p),a.d(p,{DivEvent:()=>O.G,DivType:()=>h.Q,ExternalInteractorBase:()=>g,InteractivityDetect:()=>b.h,InteractorType:()=>f.e,Modes:()=>k.d,ParticlesInteractorBase:()=>y,clickEvent:()=>m.xO,divMode:()=>M,divModeExecute:()=>E,ensureInteractivityPluginLoaded:()=>S,isDivModeEnabled:()=>w,loadInteractivityPlugin:()=>I,mouseDownEvent:()=>m.ms,mouseLeaveEvent:()=>m.Z0,mouseMoveEvent:()=>m.Rb,mouseOutEvent:()=>m.sf,mouseUpEvent:()=>m.vo,singleDivModeExecute:()=>x,touchCancelEvent:()=>m.G3,touchEndEvent:()=>m.Bp,touchMoveEvent:()=>m.DG,touchStartEvent:()=>m.s7});var v=a(303),h=a(44),f=a(500);class g{type=f.e.external;container;constructor(e){this.container=e}}var m=a(731),b=a(851);class y{type=f.e.particles;container;constructor(e){this.container=e}}function w(e,t){return!!(0,v.findItemFromSingleOrMultiple)(t,t=>t.enable&&(0,v.isInArray)(e,t.mode))}function E(e,t,r){(0,v.executeOnSingleOrMultiple)(t,t=>{let i=t.mode;t.enable&&(0,v.isInArray)(e,i)&&x(t,r)})}function x(e,t){let r=e.selectors;(0,v.executeOnSingleOrMultiple)(r,r=>{t(r,e)})}function M(e,t){if(t&&e)return(0,v.findItemFromSingleOrMultiple)(e,e=>{var r;let i;return r=e.selectors,i=(0,v.executeOnSingleOrMultiple)(r,e=>t.matches(e)),(0,v.isArray)(i)?i.some(e=>e):i})}var O=a(646),k=a(802);async function I(e){e.checkVersion("4.0.0-alpha.21"),await e.register(async e=>{let{InteractivityPlugin:t}=await a.e(703).then(a.bind(a,703));e.addPlugin(new t(e)),e.initializers.interactors??=new Map,e.interactors??=new Map,e.addInteractor=(t,r)=>{e.initializers.interactors??=new Map,e.initializers.interactors.set(t,r)},e.getInteractors=async(t,r=!1)=>(e.interactors??=new Map,e.initializers.interactors??=new Map,(0,v.getItemsFromInitializer)(t,e.interactors,e.initializers.interactors,r)),e.setOnClickHandler=t=>{let{items:r}=e;if(!r.length)throw Error("Click handlers can only be set after calling tsParticles.load()");r.forEach(e=>{e.addClickHandler?.(t)})}})}function S(e){if(!e.addInteractor)throw Error("tsParticles Interactivity Plugin is not loaded")}return p})());
1
+ !function(e,t){if("object"==typeof exports&&"object"==typeof module)module.exports=t(require("@tsparticles/engine"));else if("function"==typeof define&&define.amd)define(["@tsparticles/engine"],t);else{var r="object"==typeof exports?t(require("@tsparticles/engine")):t(e.window);for(var i in r)("object"==typeof exports?exports:e)[i]=r[i]}}(this,e=>(()=>{"use strict";var t,r,i,n={303(t){t.exports=e},585(e,t,r){var i,n;r.d(t,{Q:()=>i}),(n=i||(i={})).circle="circle",n.rectangle="rectangle"},366(e,t,r){var i,n;r.d(t,{h:()=>i}),(n=i||(i={})).canvas="canvas",n.parent="parent",n.window="window"},839(e,t,r){var i,n;r.d(t,{e:()=>i}),(n=i||(i={})).external="external",n.particles="particles"},731(e,t,r){r.d(t,{Bp:()=>u,DG:()=>d,G3:()=>p,Rb:()=>c,Z0:()=>a,ms:()=>n,s7:()=>l,sf:()=>s,vo:()=>o,xO:()=>i});let i="click",n="pointerdown",o="pointerup",a="pointerleave",s="pointerout",c="pointermove",l="touchstart",u="touchend",d="touchmove",p="touchcancel"},646(e,t,r){r.d(t,{G:()=>o});var i=r(303),n=r(585);class o{enable;mode;selectors;type;constructor(){this.selectors=[],this.enable=!1,this.mode=[],this.type=n.Q.circle}load(e){(0,i.isNull)(e)||(void 0!==e.selectors&&(this.selectors=e.selectors),void 0!==e.enable&&(this.enable=e.enable),void 0!==e.mode&&(this.mode=e.mode),void 0!==e.type&&(this.type=e.type))}}},802(e,t,r){r.d(t,{d:()=>n});var i=r(303);class n{_container;_engine;constructor(e,t){this._engine=e,this._container=t}load(e){if((0,i.isNull)(e)||!this._container)return;let t=this._engine.interactors?.get(this._container);if(t)for(let r of t)r.loadModeOptions&&r.loadModeOptions(this,e)}}}},o={};function a(e){var t=o[e];if(void 0!==t)return t.exports;var r=o[e]={exports:{}};return n[e](r,r.exports,a),r.exports}a.m=n,a.d=(e,t)=>{for(var r in t)a.o(t,r)&&!a.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},a.f={},a.e=e=>Promise.all(Object.keys(a.f).reduce((t,r)=>(a.f[r](e,t),t),[])),a.u=e=>""+e+".min.js",a.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||Function("return this")()}catch(e){if("object"==typeof window)return window}}(),a.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),s={},a.l=(e,t,r,i)=>{if(s[e])return void s[e].push(t);if(void 0!==r)for(var n,o,c=document.getElementsByTagName("script"),l=0;l<c.length;l++){var u=c[l];if(u.getAttribute("src")==e||u.getAttribute("data-webpack")=="@tsparticles/plugin-interactivity:"+r){n=u;break}}n||(o=!0,(n=document.createElement("script")).charset="utf-8",a.nc&&n.setAttribute("nonce",a.nc),n.setAttribute("data-webpack","@tsparticles/plugin-interactivity:"+r),n.src=e),s[e]=[t];var d=(t,r)=>{n.onerror=n.onload=null,clearTimeout(p);var i=s[e];if(delete s[e],n.parentNode&&n.parentNode.removeChild(n),i&&i.forEach(e=>e(r)),t)return t(r)},p=setTimeout(d.bind(null,void 0,{type:"timeout",target:n}),12e4);n.onerror=d.bind(null,n.onerror),n.onload=d.bind(null,n.onload),o&&document.head.appendChild(n)},a.r=e=>{"u">typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},a.g.importScripts&&(c=a.g.location+"");var s,c,l=a.g.document;if(!c&&l&&(l.currentScript&&"SCRIPT"===l.currentScript.tagName.toUpperCase()&&(c=l.currentScript.src),!c)){var u=l.getElementsByTagName("script");if(u.length)for(var d=u.length-1;d>-1&&(!c||!/^http(s?):/.test(c));)c=u[d--].src}if(!c)throw Error("Automatic publicPath is not supported in this browser");a.p=c=c.replace(/^blob:/,"").replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),t={301:0},a.f.j=(e,r)=>{var i=a.o(t,e)?t[e]:void 0;if(0!==i)if(i)r.push(i[2]);else{var n=new Promise((r,n)=>i=t[e]=[r,n]);r.push(i[2]=n);var o=a.p+a.u(e),s=Error();a.l(o,r=>{if(a.o(t,e)&&(0!==(i=t[e])&&(t[e]=void 0),i)){var n=r&&("load"===r.type?"missing":r.type),o=r&&r.target&&r.target.src;s.message="Loading chunk "+e+` failed.
2
+ (`+n+": "+o+")",s.name="ChunkLoadError",s.type=n,s.request=o,i[1](s)}},"chunk-"+e,e)}},r=(e,r)=>{var i,n,[o,s,c]=r,l=0;if(o.some(e=>0!==t[e])){for(i in s)a.o(s,i)&&(a.m[i]=s[i]);c&&c(a)}for(e&&e(r);l<o.length;l++)n=o[l],a.o(t,n)&&t[n]&&t[n][0](),t[n]=0},(i=this.webpackChunk_tsparticles_plugin_interactivity=this.webpackChunk_tsparticles_plugin_interactivity||[]).forEach(r.bind(null,0)),i.push=r.bind(null,i.push.bind(i));var p={};a.r(p),a.d(p,{DivEvent:()=>O.G,DivType:()=>b.Q,ExternalInteractorBase:()=>f,InteractivityDetect:()=>y.h,InteractorType:()=>h.e,Modes:()=>k.d,ParticlesInteractorBase:()=>g,clickEvent:()=>m.xO,divMode:()=>M,divModeExecute:()=>E,ensureInteractivityPluginLoaded:()=>S,isDivModeEnabled:()=>w,loadInteractivityPlugin:()=>I,mouseDownEvent:()=>m.ms,mouseLeaveEvent:()=>m.Z0,mouseMoveEvent:()=>m.Rb,mouseOutEvent:()=>m.sf,mouseUpEvent:()=>m.vo,singleDivModeExecute:()=>x,touchCancelEvent:()=>m.G3,touchEndEvent:()=>m.Bp,touchMoveEvent:()=>m.DG,touchStartEvent:()=>m.s7});var v=a(303),h=a(839);class f{type=h.e.external;container;constructor(e){this.container=e}}class g{type=h.e.particles;container;constructor(e){this.container=e}}var m=a(731),b=a(585),y=a(366);function w(e,t){return!!(0,v.findItemFromSingleOrMultiple)(t,t=>t.enable&&(0,v.isInArray)(e,t.mode))}function E(e,t,r){(0,v.executeOnSingleOrMultiple)(t,t=>{let i=t.mode;t.enable&&(0,v.isInArray)(e,i)&&x(t,r)})}function x(e,t){let r=e.selectors;(0,v.executeOnSingleOrMultiple)(r,r=>{t(r,e)})}function M(e,t){if(t&&e)return(0,v.findItemFromSingleOrMultiple)(e,e=>{var r;let i;return r=e.selectors,i=(0,v.executeOnSingleOrMultiple)(r,e=>t.matches(e)),(0,v.isArray)(i)?i.some(e=>e):i})}var O=a(646),k=a(802);async function I(e){e.checkVersion("4.0.0-alpha.23"),await e.register(async e=>{let{InteractivityPlugin:t}=await a.e(703).then(a.bind(a,703));e.addPlugin(new t(e)),e.initializers.interactors??=new Map,e.interactors??=new Map,e.addInteractor=(t,r)=>{e.initializers.interactors??=new Map,e.initializers.interactors.set(t,r)},e.getInteractors=async(t,r=!1)=>(e.interactors??=new Map,e.initializers.interactors??=new Map,(0,v.getItemsFromInitializer)(t,e.interactors,e.initializers.interactors,r)),e.setOnClickHandler=t=>{let{items:r}=e;if(!r.length)throw Error("Click handlers can only be set after calling tsParticles.load()");r.forEach(e=>{e.addClickHandler?.(t)})}})}function S(e){if(!e.addInteractor)throw Error("tsParticles Interactivity Plugin is not loaded")}return p})());
@@ -1,8 +1,8 @@
1
- import type { InteractivityContainer, InteractivityParticle } from "./types.js";
1
+ import type { InteractivityContainer, InteractivityParticle } from "../types.js";
2
2
  import { type IDelta } from "@tsparticles/engine";
3
- import type { IExternalInteractor } from "./IExternalInteractor.js";
4
- import type { IInteractivityData } from "./IInteractivityData.js";
5
- import { InteractorType } from "./InteractorType.js";
3
+ import type { IExternalInteractor } from "../Interfaces/IExternalInteractor.js";
4
+ import type { IInteractivityData } from "../Interfaces/IInteractivityData.js";
5
+ import { InteractorType } from "../Enums/InteractorType.js";
6
6
  export declare abstract class ExternalInteractorBase<TContainer extends InteractivityContainer = InteractivityContainer, TParticle extends InteractivityParticle = InteractivityParticle> implements IExternalInteractor<TParticle> {
7
7
  type: InteractorType;
8
8
  protected readonly container: TContainer;
@@ -1,8 +1,8 @@
1
- import type { InteractivityContainer, InteractivityParticle } from "./types.js";
1
+ import type { InteractivityContainer, InteractivityParticle } from "../types.js";
2
2
  import { type IDelta } from "@tsparticles/engine";
3
- import type { IInteractivityData } from "./IInteractivityData.js";
4
- import type { IParticlesInteractor } from "./IParticlesInteractor.js";
5
- import { InteractorType } from "./InteractorType.js";
3
+ import type { IInteractivityData } from "../Interfaces/IInteractivityData.js";
4
+ import type { IParticlesInteractor } from "../Interfaces/IParticlesInteractor.js";
5
+ import { InteractorType } from "../Enums/InteractorType.js";
6
6
  export declare abstract class ParticlesInteractorBase<TContainer extends InteractivityContainer = InteractivityContainer, TParticle extends InteractivityParticle = InteractivityParticle> implements IParticlesInteractor<TParticle> {
7
7
  type: InteractorType;
8
8
  protected readonly container: TContainer;
@@ -1,5 +1,5 @@
1
1
  import { type Container, type IDelta, type Particle } from "@tsparticles/engine";
2
- import type { IInteractivityData } from "./IInteractivityData.js";
2
+ import type { IInteractivityData } from "./Interfaces/IInteractivityData.js";
3
3
  import type { InteractivityEngine } from "./types.js";
4
4
  export declare class InteractionManager {
5
5
  private readonly container;
@@ -17,7 +17,8 @@ export declare class InteractionManager {
17
17
  clearClickHandlers(): void;
18
18
  externalInteract(delta: IDelta): void;
19
19
  handleClickMode(mode: string): void;
20
- init(): Promise<void>;
20
+ init(): void;
21
+ initInteractors(): Promise<void>;
21
22
  particlesInteract(particle: Particle, delta: IDelta): void;
22
23
  removeListeners(): void;
23
24
  reset(particle: Particle): void;
@@ -1,9 +1,9 @@
1
1
  import type { IDelta, Particle, RecursivePartial } from "@tsparticles/engine";
2
2
  import type { IInteractivityData } from "./IInteractivityData.js";
3
- import type { IInteractor } from "./IInteractor.js";
4
- import type { IModes } from "./Options/Interfaces/Modes/IModes.js";
5
- import type { Modes } from "./Options/Classes/Modes/Modes.js";
6
- export interface IExternalInteractor<TParticle extends Particle = Particle> extends IInteractor<TParticle> {
3
+ import type { IModes } from "../Options/Interfaces/Modes/IModes.js";
4
+ import type { IParticleInteractorBase } from "./IParticleInteractorBase.js";
5
+ import type { Modes } from "../Options/Classes/Modes/Modes.js";
6
+ export interface IExternalInteractor<TParticle extends Particle = Particle> extends IParticleInteractorBase<TParticle> {
7
7
  handleClickMode?: (mode: string, interactivityData: IInteractivityData) => void;
8
8
  loadModeOptions?: (options: Modes, ...sources: RecursivePartial<IModes | undefined>[]) => void;
9
9
  interact(interactivityData: IInteractivityData, delta: IDelta): void;
@@ -0,0 +1,7 @@
1
+ import type { ISourceOptions, Options } from "@tsparticles/engine";
2
+ import type { InteractorType } from "../Enums/InteractorType.js";
3
+ export interface IInteractor {
4
+ loadOptions?: (options: Options, ...sources: (ISourceOptions | undefined)[]) => void;
5
+ type: InteractorType;
6
+ init(): void;
7
+ }
@@ -1,12 +1,9 @@
1
- import type { IDelta, ISourceOptions, Options, Particle, RecursivePartial } from "@tsparticles/engine";
2
- import type { IInteractivityParticlesOptions, InteractivityParticlesOptions } from "./types.js";
1
+ import type { IDelta, Particle, RecursivePartial } from "@tsparticles/engine";
2
+ import type { IInteractivityParticlesOptions, InteractivityParticlesOptions } from "../types.js";
3
3
  import type { IInteractivityData } from "./IInteractivityData.js";
4
- import type { InteractorType } from "./InteractorType.js";
5
- export interface IInteractor<TParticle extends Particle = Particle> {
6
- loadOptions?: (options: Options, ...sources: (ISourceOptions | undefined)[]) => void;
4
+ import type { IInteractor } from "./IInteractor.js";
5
+ export interface IParticleInteractorBase<TParticle extends Particle = Particle> extends IInteractor {
7
6
  loadParticlesOptions?: (options: InteractivityParticlesOptions, ...sources: (RecursivePartial<IInteractivityParticlesOptions> | undefined)[]) => void;
8
- type: InteractorType;
9
7
  clear(particle: TParticle, delta: IDelta): void;
10
- init(): void;
11
8
  reset(interactivityData: IInteractivityData, particle: TParticle): void;
12
9
  }
@@ -1,7 +1,7 @@
1
1
  import type { IDelta, Particle } from "@tsparticles/engine";
2
2
  import type { IInteractivityData } from "./IInteractivityData.js";
3
- import type { IInteractor } from "./IInteractor.js";
4
- export interface IParticlesInteractor<TParticle extends Particle = Particle> extends IInteractor<TParticle> {
3
+ import type { IParticleInteractorBase } from "./IParticleInteractorBase.js";
4
+ export interface IParticlesInteractor<TParticle extends Particle = Particle> extends IParticleInteractorBase<TParticle> {
5
5
  interact(particle: TParticle, interactivityData: IInteractivityData, delta: IDelta): void;
6
6
  isEnabled(particle: TParticle, interactivityData: IInteractivityData): boolean;
7
7
  }
@@ -1,5 +1,5 @@
1
1
  import { type IOptionLoader, type RecursivePartial, type SingleOrMultiple } from "@tsparticles/engine";
2
- import { DivType } from "../../../DivType.js";
2
+ import { DivType } from "../../../Enums/DivType.js";
3
3
  import type { IDivEvent } from "../../Interfaces/Events/IDivEvent.js";
4
4
  export declare class DivEvent implements IDivEvent, IOptionLoader<IDivEvent> {
5
5
  enable: boolean;
@@ -1,7 +1,7 @@
1
1
  import { type Container, type IOptionLoader, type RecursivePartial } from "@tsparticles/engine";
2
2
  import { Events } from "./Events/Events.js";
3
3
  import type { IInteractivity } from "../Interfaces/IInteractivity.js";
4
- import { InteractivityDetect } from "../../InteractivityDetect.js";
4
+ import { InteractivityDetect } from "../../Enums/InteractivityDetect.js";
5
5
  import type { InteractivityEngine } from "../../types.js";
6
6
  import { Modes } from "./Modes/Modes.js";
7
7
  export declare class Interactivity implements IInteractivity, IOptionLoader<IInteractivity> {
@@ -1,4 +1,4 @@
1
- import type { DivType } from "../../../DivType.js";
1
+ import type { DivType } from "../../../Enums/DivType.js";
2
2
  import type { SingleOrMultiple } from "@tsparticles/engine";
3
3
  export interface IDivEvent {
4
4
  enable: boolean;
@@ -1,6 +1,6 @@
1
1
  import type { IEvents } from "./Events/IEvents.js";
2
2
  import type { IModes } from "./Modes/IModes.js";
3
- import type { InteractivityDetect } from "../../InteractivityDetect.js";
3
+ import type { InteractivityDetect } from "../../Enums/InteractivityDetect.js";
4
4
  export interface IInteractivity {
5
5
  [name: string]: unknown;
6
6
  detectsOn: InteractivityDetect | keyof typeof InteractivityDetect;
package/types/index.d.ts CHANGED
@@ -2,16 +2,17 @@ import { type Engine } from "@tsparticles/engine";
2
2
  import { type InteractivityEngine } from "./types.js";
3
3
  export declare function loadInteractivityPlugin(engine: Engine): Promise<void>;
4
4
  export declare function ensureInteractivityPluginLoaded(e: InteractivityEngine): void;
5
- export * from "./DivType.js";
6
- export * from "./ExternalInteractorBase.js";
7
- export type * from "./IExternalInteractor.js";
8
- export type * from "./IInteractivityData.js";
9
- export type * from "./IInteractor.js";
5
+ export * from "./BaseClasses/ExternalInteractorBase.js";
6
+ export * from "./BaseClasses/ParticlesInteractorBase.js";
7
+ export type * from "./Interfaces/IExternalInteractor.js";
8
+ export type * from "./Interfaces/IInteractivityData.js";
9
+ export type * from "./Interfaces/IInteractor.js";
10
+ export type * from "./Interfaces/IParticleInteractorBase.js";
11
+ export type * from "./Interfaces/IParticlesInteractor.js";
10
12
  export * from "./InteractivityConstants.js";
11
- export * from "./InteractivityDetect.js";
12
- export * from "./InteractorType.js";
13
- export type * from "./IParticlesInteractor.js";
14
- export * from "./ParticlesInteractorBase.js";
13
+ export * from "./Enums/DivType.js";
14
+ export * from "./Enums/InteractivityDetect.js";
15
+ export * from "./Enums/InteractorType.js";
15
16
  export type * from "./types.js";
16
17
  export * from "./utils.js";
17
18
  export type * from "./Options/Interfaces/Events/IDivEvent.js";
package/types/types.d.ts CHANGED
@@ -1,6 +1,6 @@
1
1
  import type { Container, Engine, GenericInitializer, IOptions, IParticlesOptions, Options, Particle, ParticlesOptions, RecursivePartial } from "@tsparticles/engine";
2
2
  import type { IInteractivity } from "./Options/Interfaces/IInteractivity.js";
3
- import type { IInteractor } from "./IInteractor.js";
3
+ import type { IInteractor } from "./Interfaces/IInteractor.js";
4
4
  import type { Interactivity } from "./Options/Classes/Interactivity.js";
5
5
  export type IInteractivityOptions = IOptions & {
6
6
  interactivity?: IInteractivity;