@tsparticles/pjs 3.0.0-alpha.0 → 3.0.0-alpha.1
Sign up to get free protection for your applications and to get access to all the features.
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@tsparticles/pjs",
|
3
|
-
"version": "3.0.0-alpha.
|
3
|
+
"version": "3.0.0-alpha.1",
|
4
4
|
"description": "Easily create highly customizable particle animations and use them as animated backgrounds for your website. Ready to use components available also for React, Vue.js (2.x and 3.x), Angular, Svelte, jQuery, Preact, Riot.js, Inferno.",
|
5
5
|
"homepage": "https://particles.js.org",
|
6
6
|
"repository": {
|
@@ -79,6 +79,6 @@
|
|
79
79
|
"access": "public"
|
80
80
|
},
|
81
81
|
"dependencies": {
|
82
|
-
"@tsparticles/engine": "^3.0.0-alpha.
|
82
|
+
"@tsparticles/engine": "^3.0.0-alpha.1"
|
83
83
|
}
|
84
84
|
}
|
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/pjs [
|
6
|
+
<title>@tsparticles/pjs [26 Jan 2023 at 11:12]</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>
|
@@ -31,7 +31,7 @@
|
|
31
31
|
<body>
|
32
32
|
<div id="app"></div>
|
33
33
|
<script>
|
34
|
-
window.chartData = [{"label":"tsparticles.pjs.bundle.js","isAsset":true,"statSize":163887,"parsedSize":162376,"gzipSize":30546,"groups":[{"label":"dist/browser","path":"./dist/browser","statSize":163887,"groups":[{"id":305,"label":"bundle.js + 80 modules (concatenated)","path":"./dist/browser/bundle.js + 80 modules (concatenated)","statSize":163887,"parsedSize":162376,"gzipSize":30546,"concatenated":true,"groups":[{"label":"dist/browser","path":"./dist/browser/bundle.js + 80 modules (concatenated)/dist/browser","statSize":815,"groups":[{"id":null,"label":"bundle.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/dist/browser/bundle.js","statSize":206,"parsedSize":204,"gzipSize":38,"inaccurateSizes":true},{"id":null,"label":"index.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/dist/browser/index.js","statSize":609,"parsedSize":603,"gzipSize":113,"inaccurateSizes":true}],"parsedSize":807,"gzipSize":151,"inaccurateSizes":true},{"label":"../engine/dist/esm","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm","statSize":163072,"groups":[{"id":null,"label":"index.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/index.js","statSize":10810,"parsedSize":10710,"gzipSize":2014,"inaccurateSizes":true},{"id":null,"label":"engine.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/engine.js","statSize":5337,"parsedSize":5287,"gzipSize":994,"inaccurateSizes":true},{"label":"Utils","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Utils","statSize":31037,"groups":[{"id":null,"label":"Utils.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Utils/Utils.js","statSize":8661,"parsedSize":8581,"gzipSize":1614,"inaccurateSizes":true},{"id":null,"label":"NumberUtils.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Utils/NumberUtils.js","statSize":5298,"parsedSize":5249,"gzipSize":987,"inaccurateSizes":true},{"id":null,"label":"CanvasUtils.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Utils/CanvasUtils.js","statSize":5032,"parsedSize":4985,"gzipSize":937,"inaccurateSizes":true},{"id":null,"label":"ColorUtils.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Utils/ColorUtils.js","statSize":8091,"parsedSize":8016,"gzipSize":1508,"inaccurateSizes":true},{"id":null,"label":"OptionsUtils.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Utils/OptionsUtils.js","statSize":433,"parsedSize":429,"gzipSize":80,"inaccurateSizes":true},{"id":null,"label":"HslColorManager.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Utils/HslColorManager.js","statSize":1307,"parsedSize":1294,"gzipSize":243,"inaccurateSizes":true},{"id":null,"label":"RgbColorManager.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Utils/RgbColorManager.js","statSize":1148,"parsedSize":1137,"gzipSize":213,"inaccurateSizes":true},{"id":null,"label":"EventDispatcher.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Utils/EventDispatcher.js","statSize":1067,"parsedSize":1057,"gzipSize":198,"inaccurateSizes":true}],"parsedSize":30750,"gzipSize":5784,"inaccurateSizes":true},{"label":"Core","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core","statSize":75434,"groups":[{"label":"Utils","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils","statSize":25239,"groups":[{"id":null,"label":"Vector.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/Vector.js","statSize":333,"parsedSize":329,"gzipSize":62,"inaccurateSizes":true},{"id":null,"label":"Vector3d.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/Vector3d.js","statSize":2202,"parsedSize":2181,"gzipSize":410,"inaccurateSizes":true},{"id":null,"label":"Constants.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/Constants.js","statSize":537,"parsedSize":532,"gzipSize":100,"inaccurateSizes":true},{"id":null,"label":"Circle.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/Circle.js","statSize":1015,"parsedSize":1005,"gzipSize":189,"inaccurateSizes":true},{"id":null,"label":"Range.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/Range.js","statSize":100,"parsedSize":99,"gzipSize":18,"inaccurateSizes":true},{"id":null,"label":"Rectangle.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/Rectangle.js","statSize":907,"parsedSize":898,"gzipSize":169,"inaccurateSizes":true},{"id":null,"label":"Point.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/Point.js","statSize":122,"parsedSize":120,"gzipSize":22,"inaccurateSizes":true},{"id":null,"label":"ExternalInteractorBase.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/ExternalInteractorBase.js","statSize":130,"parsedSize":128,"gzipSize":24,"inaccurateSizes":true},{"id":null,"label":"ParticlesInteractorBase.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/ParticlesInteractorBase.js","statSize":132,"parsedSize":130,"gzipSize":24,"inaccurateSizes":true},{"id":null,"label":"Plugins.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/Plugins.js","statSize":3224,"parsedSize":3194,"gzipSize":600,"inaccurateSizes":true},{"id":null,"label":"EventListeners.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/EventListeners.js","statSize":10959,"parsedSize":10857,"gzipSize":2042,"inaccurateSizes":true},{"id":null,"label":"FrameManager.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/FrameManager.js","statSize":1257,"parsedSize":1245,"gzipSize":234,"inaccurateSizes":true},{"id":null,"label":"QuadTree.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/QuadTree.js","statSize":2599,"parsedSize":2575,"gzipSize":484,"inaccurateSizes":true},{"id":null,"label":"InteractionManager.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/InteractionManager.js","statSize":1722,"parsedSize":1706,"gzipSize":320,"inaccurateSizes":true}],"parsedSize":25006,"gzipSize":4704,"inaccurateSizes":true},{"id":null,"label":"Container.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Container.js","statSize":13211,"parsedSize":13089,"gzipSize":2462,"inaccurateSizes":true},{"id":null,"label":"Canvas.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Canvas.js","statSize":13156,"parsedSize":13034,"gzipSize":2452,"inaccurateSizes":true},{"id":null,"label":"Particles.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Particles.js","statSize":9416,"parsedSize":9329,"gzipSize":1754,"inaccurateSizes":true},{"id":null,"label":"Retina.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Retina.js","statSize":1740,"parsedSize":1723,"gzipSize":324,"inaccurateSizes":true},{"id":null,"label":"Particle.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Particle.js","statSize":12672,"parsedSize":12555,"gzipSize":2361,"inaccurateSizes":true}],"parsedSize":74738,"gzipSize":14059,"inaccurateSizes":true},{"label":"Options/Classes","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes","statSize":40454,"groups":[{"id":null,"label":"Options.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Options.js","statSize":6104,"parsedSize":6047,"gzipSize":1137,"inaccurateSizes":true},{"label":"Interactivity","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Interactivity","statSize":5107,"groups":[{"id":null,"label":"Interactivity.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Interactivity/Interactivity.js","statSize":672,"parsedSize":665,"gzipSize":125,"inaccurateSizes":true},{"label":"Events","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Interactivity/Events","statSize":3945,"groups":[{"id":null,"label":"Events.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Interactivity/Events/Events.js","statSize":1380,"parsedSize":1367,"gzipSize":257,"inaccurateSizes":true},{"id":null,"label":"DivEvent.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Interactivity/Events/DivEvent.js","statSize":1150,"parsedSize":1139,"gzipSize":214,"inaccurateSizes":true},{"id":null,"label":"ClickEvent.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Interactivity/Events/ClickEvent.js","statSize":296,"parsedSize":293,"gzipSize":55,"inaccurateSizes":true},{"id":null,"label":"HoverEvent.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Interactivity/Events/HoverEvent.js","statSize":410,"parsedSize":406,"gzipSize":76,"inaccurateSizes":true},{"id":null,"label":"Parallax.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Interactivity/Events/Parallax.js","statSize":395,"parsedSize":391,"gzipSize":73,"inaccurateSizes":true},{"id":null,"label":"ResizeEvent.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Interactivity/Events/ResizeEvent.js","statSize":314,"parsedSize":311,"gzipSize":58,"inaccurateSizes":true}],"parsedSize":3908,"gzipSize":735,"inaccurateSizes":true},{"label":"Modes","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Interactivity/Modes","statSize":490,"groups":[{"id":null,"label":"Modes.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Interactivity/Modes/Modes.js","statSize":490,"parsedSize":485,"gzipSize":91,"inaccurateSizes":true}],"parsedSize":485,"gzipSize":91,"inaccurateSizes":true}],"parsedSize":5059,"gzipSize":951,"inaccurateSizes":true},{"id":null,"label":"ManualParticle.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/ManualParticle.js","statSize":465,"parsedSize":460,"gzipSize":86,"inaccurateSizes":true},{"id":null,"label":"Responsive.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Responsive.js","statSize":569,"parsedSize":563,"gzipSize":106,"inaccurateSizes":true},{"label":"Theme","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Theme","statSize":849,"groups":[{"id":null,"label":"Theme.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Theme/Theme.js","statSize":459,"parsedSize":454,"gzipSize":85,"inaccurateSizes":true},{"id":null,"label":"ThemeDefault.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Theme/ThemeDefault.js","statSize":390,"parsedSize":386,"gzipSize":72,"inaccurateSizes":true}],"parsedSize":841,"gzipSize":158,"inaccurateSizes":true},{"label":"Particles","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles","statSize":19590,"groups":[{"id":null,"label":"ParticlesOptions.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/ParticlesOptions.js","statSize":3201,"parsedSize":3171,"gzipSize":596,"inaccurateSizes":true},{"label":"Collisions","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Collisions","statSize":1226,"groups":[{"id":null,"label":"Collisions.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Collisions/Collisions.js","statSize":709,"parsedSize":702,"gzipSize":132,"inaccurateSizes":true},{"id":null,"label":"CollisionsAbsorb.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Collisions/CollisionsAbsorb.js","statSize":204,"parsedSize":202,"gzipSize":38,"inaccurateSizes":true},{"id":null,"label":"CollisionsOverlap.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Collisions/CollisionsOverlap.js","statSize":313,"parsedSize":310,"gzipSize":58,"inaccurateSizes":true}],"parsedSize":1214,"gzipSize":228,"inaccurateSizes":true},{"label":"Bounce","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Bounce","statSize":567,"groups":[{"id":null,"label":"ParticlesBounce.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Bounce/ParticlesBounce.js","statSize":357,"parsedSize":353,"gzipSize":66,"inaccurateSizes":true},{"id":null,"label":"ParticlesBounceFactor.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Bounce/ParticlesBounceFactor.js","statSize":210,"parsedSize":208,"gzipSize":39,"inaccurateSizes":true}],"parsedSize":561,"gzipSize":105,"inaccurateSizes":true},{"label":"Move","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Move","statSize":8533,"groups":[{"id":null,"label":"Move.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Move/Move.js","statSize":3257,"parsedSize":3226,"gzipSize":607,"inaccurateSizes":true},{"id":null,"label":"MoveAngle.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Move/MoveAngle.js","statSize":388,"parsedSize":384,"gzipSize":72,"inaccurateSizes":true},{"id":null,"label":"MoveAttract.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Move/MoveAttract.js","statSize":1086,"parsedSize":1075,"gzipSize":202,"inaccurateSizes":true},{"id":null,"label":"MoveGravity.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Move/MoveGravity.js","statSize":635,"parsedSize":629,"gzipSize":118,"inaccurateSizes":true},{"label":"Path","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Move/Path","statSize":641,"groups":[{"id":null,"label":"MovePath.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Move/Path/MovePath.js","statSize":641,"parsedSize":635,"gzipSize":119,"inaccurateSizes":true}],"parsedSize":635,"gzipSize":119,"inaccurateSizes":true},{"id":null,"label":"Spin.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Move/Spin.js","statSize":532,"parsedSize":527,"gzipSize":99,"inaccurateSizes":true},{"id":null,"label":"MoveCenter.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Move/MoveCenter.js","statSize":455,"parsedSize":450,"gzipSize":84,"inaccurateSizes":true},{"id":null,"label":"OutModes.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Move/OutModes.js","statSize":556,"parsedSize":550,"gzipSize":103,"inaccurateSizes":true},{"id":null,"label":"MoveTrail.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Move/MoveTrail.js","statSize":667,"parsedSize":660,"gzipSize":124,"inaccurateSizes":true},{"id":null,"label":"MoveTrailFill.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Move/MoveTrailFill.js","statSize":316,"parsedSize":313,"gzipSize":58,"inaccurateSizes":true}],"parsedSize":8454,"gzipSize":1590,"inaccurateSizes":true},{"label":"Opacity","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Opacity","statSize":1083,"groups":[{"id":null,"label":"Opacity.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Opacity/Opacity.js","statSize":424,"parsedSize":420,"gzipSize":79,"inaccurateSizes":true},{"id":null,"label":"OpacityAnimation.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Opacity/OpacityAnimation.js","statSize":659,"parsedSize":652,"gzipSize":122,"inaccurateSizes":true}],"parsedSize":1073,"gzipSize":201,"inaccurateSizes":true},{"label":"Shape","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Shape","statSize":584,"groups":[{"id":null,"label":"Shape.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Shape/Shape.js","statSize":584,"parsedSize":578,"gzipSize":108,"inaccurateSizes":true}],"parsedSize":578,"gzipSize":108,"inaccurateSizes":true},{"label":"Size","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Size","statSize":1054,"groups":[{"id":null,"label":"Size.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Size/Size.js","statSize":410,"parsedSize":406,"gzipSize":76,"inaccurateSizes":true},{"id":null,"label":"SizeAnimation.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Size/SizeAnimation.js","statSize":644,"parsedSize":638,"gzipSize":120,"inaccurateSizes":true}],"parsedSize":1044,"gzipSize":196,"inaccurateSizes":true},{"id":null,"label":"Stroke.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Stroke.js","statSize":526,"parsedSize":521,"gzipSize":98,"inaccurateSizes":true},{"label":"ZIndex","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/ZIndex","statSize":560,"groups":[{"id":null,"label":"ZIndex.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/ZIndex/ZIndex.js","statSize":560,"parsedSize":554,"gzipSize":104,"inaccurateSizes":true}],"parsedSize":554,"gzipSize":104,"inaccurateSizes":true},{"label":"Number","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Number","statSize":1516,"groups":[{"id":null,"label":"ParticlesNumber.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Number/ParticlesNumber.js","statSize":602,"parsedSize":596,"gzipSize":112,"inaccurateSizes":true},{"id":null,"label":"ParticlesDensity.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Number/ParticlesDensity.js","statSize":914,"parsedSize":905,"gzipSize":170,"inaccurateSizes":true}],"parsedSize":1502,"gzipSize":282,"inaccurateSizes":true},{"id":null,"label":"Shadow.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Shadow.js","statSize":740,"parsedSize":733,"gzipSize":137,"inaccurateSizes":true}],"parsedSize":19409,"gzipSize":3651,"inaccurateSizes":true},{"id":null,"label":"AnimatableColor.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/AnimatableColor.js","statSize":876,"parsedSize":867,"gzipSize":163,"inaccurateSizes":true},{"id":null,"label":"HslAnimation.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/HslAnimation.js","statSize":338,"parsedSize":334,"gzipSize":62,"inaccurateSizes":true},{"id":null,"label":"ColorAnimation.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/ColorAnimation.js","statSize":795,"parsedSize":787,"gzipSize":148,"inaccurateSizes":true},{"id":null,"label":"OptionsColor.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/OptionsColor.js","statSize":541,"parsedSize":536,"gzipSize":100,"inaccurateSizes":true},{"id":null,"label":"ValueWithRandom.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/ValueWithRandom.js","statSize":1560,"parsedSize":1545,"gzipSize":290,"inaccurateSizes":true},{"id":null,"label":"AnimationOptions.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/AnimationOptions.js","statSize":1078,"parsedSize":1068,"gzipSize":200,"inaccurateSizes":true},{"label":"Background","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Background","statSize":812,"groups":[{"id":null,"label":"Background.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Background/Background.js","statSize":812,"parsedSize":804,"gzipSize":151,"inaccurateSizes":true}],"parsedSize":804,"gzipSize":151,"inaccurateSizes":true},{"label":"BackgroundMask","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/BackgroundMask","statSize":1145,"groups":[{"id":null,"label":"BackgroundMask.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/BackgroundMask/BackgroundMask.js","statSize":708,"parsedSize":701,"gzipSize":131,"inaccurateSizes":true},{"id":null,"label":"BackgroundMaskCover.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/BackgroundMask/BackgroundMaskCover.js","statSize":437,"parsedSize":432,"gzipSize":81,"inaccurateSizes":true}],"parsedSize":1134,"gzipSize":213,"inaccurateSizes":true},{"label":"FullScreen","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/FullScreen","statSize":302,"groups":[{"id":null,"label":"FullScreen.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/FullScreen/FullScreen.js","statSize":302,"parsedSize":299,"gzipSize":56,"inaccurateSizes":true}],"parsedSize":299,"gzipSize":56,"inaccurateSizes":true},{"id":null,"label":"Random.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Random.js","statSize":323,"parsedSize":320,"gzipSize":60,"inaccurateSizes":true}],"parsedSize":40081,"gzipSize":7539,"inaccurateSizes":true}],"parsedSize":161568,"gzipSize":30394,"inaccurateSizes":true}]}],"parsedSize":162376,"gzipSize":30546}],"isInitialByEntrypoint":{"tsparticles.pjs.bundle":true}}];
|
34
|
+
window.chartData = [{"label":"tsparticles.pjs.bundle.js","isAsset":true,"statSize":165463,"parsedSize":163908,"gzipSize":30809,"groups":[{"label":"dist/browser","path":"./dist/browser","statSize":165463,"groups":[{"id":305,"label":"bundle.js + 80 modules (concatenated)","path":"./dist/browser/bundle.js + 80 modules (concatenated)","statSize":165463,"parsedSize":163908,"gzipSize":30809,"concatenated":true,"groups":[{"label":"dist/browser","path":"./dist/browser/bundle.js + 80 modules (concatenated)/dist/browser","statSize":815,"groups":[{"id":null,"label":"bundle.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/dist/browser/bundle.js","statSize":206,"parsedSize":204,"gzipSize":38,"inaccurateSizes":true},{"id":null,"label":"index.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/dist/browser/index.js","statSize":609,"parsedSize":603,"gzipSize":113,"inaccurateSizes":true}],"parsedSize":807,"gzipSize":151,"inaccurateSizes":true},{"label":"../engine/dist/esm","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm","statSize":164648,"groups":[{"id":null,"label":"index.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/index.js","statSize":10855,"parsedSize":10752,"gzipSize":2021,"inaccurateSizes":true},{"id":null,"label":"engine.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/engine.js","statSize":5337,"parsedSize":5286,"gzipSize":993,"inaccurateSizes":true},{"label":"Utils","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Utils","statSize":31505,"groups":[{"id":null,"label":"Utils.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Utils/Utils.js","statSize":9129,"parsedSize":9043,"gzipSize":1699,"inaccurateSizes":true},{"id":null,"label":"NumberUtils.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Utils/NumberUtils.js","statSize":5298,"parsedSize":5248,"gzipSize":986,"inaccurateSizes":true},{"id":null,"label":"CanvasUtils.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Utils/CanvasUtils.js","statSize":5032,"parsedSize":4984,"gzipSize":936,"inaccurateSizes":true},{"id":null,"label":"ColorUtils.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Utils/ColorUtils.js","statSize":8091,"parsedSize":8014,"gzipSize":1506,"inaccurateSizes":true},{"id":null,"label":"OptionsUtils.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Utils/OptionsUtils.js","statSize":433,"parsedSize":428,"gzipSize":80,"inaccurateSizes":true},{"id":null,"label":"HslColorManager.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Utils/HslColorManager.js","statSize":1307,"parsedSize":1294,"gzipSize":243,"inaccurateSizes":true},{"id":null,"label":"RgbColorManager.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Utils/RgbColorManager.js","statSize":1148,"parsedSize":1137,"gzipSize":213,"inaccurateSizes":true},{"id":null,"label":"EventDispatcher.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Utils/EventDispatcher.js","statSize":1067,"parsedSize":1056,"gzipSize":198,"inaccurateSizes":true}],"parsedSize":31208,"gzipSize":5866,"inaccurateSizes":true},{"label":"Core","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core","statSize":76127,"groups":[{"label":"Utils","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils","statSize":25654,"groups":[{"id":null,"label":"Vector.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/Vector.js","statSize":333,"parsedSize":329,"gzipSize":62,"inaccurateSizes":true},{"id":null,"label":"Vector3d.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/Vector3d.js","statSize":2202,"parsedSize":2181,"gzipSize":410,"inaccurateSizes":true},{"id":null,"label":"Constants.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/Constants.js","statSize":537,"parsedSize":531,"gzipSize":99,"inaccurateSizes":true},{"id":null,"label":"Circle.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/Circle.js","statSize":1015,"parsedSize":1005,"gzipSize":188,"inaccurateSizes":true},{"id":null,"label":"Range.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/Range.js","statSize":100,"parsedSize":99,"gzipSize":18,"inaccurateSizes":true},{"id":null,"label":"Rectangle.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/Rectangle.js","statSize":907,"parsedSize":898,"gzipSize":168,"inaccurateSizes":true},{"id":null,"label":"Point.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/Point.js","statSize":122,"parsedSize":120,"gzipSize":22,"inaccurateSizes":true},{"id":null,"label":"ExternalInteractorBase.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/ExternalInteractorBase.js","statSize":130,"parsedSize":128,"gzipSize":24,"inaccurateSizes":true},{"id":null,"label":"ParticlesInteractorBase.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/ParticlesInteractorBase.js","statSize":132,"parsedSize":130,"gzipSize":24,"inaccurateSizes":true},{"id":null,"label":"Plugins.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/Plugins.js","statSize":3224,"parsedSize":3193,"gzipSize":600,"inaccurateSizes":true},{"id":null,"label":"EventListeners.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/EventListeners.js","statSize":11374,"parsedSize":11267,"gzipSize":2117,"inaccurateSizes":true},{"id":null,"label":"FrameManager.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/FrameManager.js","statSize":1257,"parsedSize":1245,"gzipSize":234,"inaccurateSizes":true},{"id":null,"label":"QuadTree.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/QuadTree.js","statSize":2599,"parsedSize":2574,"gzipSize":483,"inaccurateSizes":true},{"id":null,"label":"InteractionManager.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Utils/InteractionManager.js","statSize":1722,"parsedSize":1705,"gzipSize":320,"inaccurateSizes":true}],"parsedSize":25412,"gzipSize":4776,"inaccurateSizes":true},{"id":null,"label":"Container.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Container.js","statSize":13211,"parsedSize":13086,"gzipSize":2459,"inaccurateSizes":true},{"id":null,"label":"Canvas.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Canvas.js","statSize":13156,"parsedSize":13032,"gzipSize":2449,"inaccurateSizes":true},{"id":null,"label":"Particles.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Particles.js","statSize":9620,"parsedSize":9529,"gzipSize":1791,"inaccurateSizes":true},{"id":null,"label":"Retina.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Retina.js","statSize":1740,"parsedSize":1723,"gzipSize":323,"inaccurateSizes":true},{"id":null,"label":"Particle.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Core/Particle.js","statSize":12746,"parsedSize":12626,"gzipSize":2373,"inaccurateSizes":true}],"parsedSize":75411,"gzipSize":14174,"inaccurateSizes":true},{"label":"Options/Classes","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes","statSize":40824,"groups":[{"id":null,"label":"Options.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Options.js","statSize":6104,"parsedSize":6046,"gzipSize":1136,"inaccurateSizes":true},{"label":"Interactivity","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Interactivity","statSize":5107,"groups":[{"id":null,"label":"Interactivity.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Interactivity/Interactivity.js","statSize":672,"parsedSize":665,"gzipSize":125,"inaccurateSizes":true},{"label":"Events","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Interactivity/Events","statSize":3945,"groups":[{"id":null,"label":"Events.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Interactivity/Events/Events.js","statSize":1380,"parsedSize":1367,"gzipSize":256,"inaccurateSizes":true},{"id":null,"label":"DivEvent.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Interactivity/Events/DivEvent.js","statSize":1150,"parsedSize":1139,"gzipSize":214,"inaccurateSizes":true},{"id":null,"label":"ClickEvent.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Interactivity/Events/ClickEvent.js","statSize":296,"parsedSize":293,"gzipSize":55,"inaccurateSizes":true},{"id":null,"label":"HoverEvent.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Interactivity/Events/HoverEvent.js","statSize":410,"parsedSize":406,"gzipSize":76,"inaccurateSizes":true},{"id":null,"label":"Parallax.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Interactivity/Events/Parallax.js","statSize":395,"parsedSize":391,"gzipSize":73,"inaccurateSizes":true},{"id":null,"label":"ResizeEvent.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Interactivity/Events/ResizeEvent.js","statSize":314,"parsedSize":311,"gzipSize":58,"inaccurateSizes":true}],"parsedSize":3907,"gzipSize":734,"inaccurateSizes":true},{"label":"Modes","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Interactivity/Modes","statSize":490,"groups":[{"id":null,"label":"Modes.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Interactivity/Modes/Modes.js","statSize":490,"parsedSize":485,"gzipSize":91,"inaccurateSizes":true}],"parsedSize":485,"gzipSize":91,"inaccurateSizes":true}],"parsedSize":5059,"gzipSize":950,"inaccurateSizes":true},{"id":null,"label":"ManualParticle.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/ManualParticle.js","statSize":553,"parsedSize":547,"gzipSize":102,"inaccurateSizes":true},{"id":null,"label":"Responsive.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Responsive.js","statSize":569,"parsedSize":563,"gzipSize":105,"inaccurateSizes":true},{"label":"Theme","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Theme","statSize":849,"groups":[{"id":null,"label":"Theme.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Theme/Theme.js","statSize":459,"parsedSize":454,"gzipSize":85,"inaccurateSizes":true},{"id":null,"label":"ThemeDefault.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Theme/ThemeDefault.js","statSize":390,"parsedSize":386,"gzipSize":72,"inaccurateSizes":true}],"parsedSize":841,"gzipSize":158,"inaccurateSizes":true},{"label":"Particles","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles","statSize":19778,"groups":[{"id":null,"label":"ParticlesOptions.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/ParticlesOptions.js","statSize":3201,"parsedSize":3170,"gzipSize":596,"inaccurateSizes":true},{"label":"Collisions","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Collisions","statSize":1226,"groups":[{"id":null,"label":"Collisions.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Collisions/Collisions.js","statSize":709,"parsedSize":702,"gzipSize":132,"inaccurateSizes":true},{"id":null,"label":"CollisionsAbsorb.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Collisions/CollisionsAbsorb.js","statSize":204,"parsedSize":202,"gzipSize":37,"inaccurateSizes":true},{"id":null,"label":"CollisionsOverlap.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Collisions/CollisionsOverlap.js","statSize":313,"parsedSize":310,"gzipSize":58,"inaccurateSizes":true}],"parsedSize":1214,"gzipSize":228,"inaccurateSizes":true},{"label":"Bounce","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Bounce","statSize":567,"groups":[{"id":null,"label":"ParticlesBounce.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Bounce/ParticlesBounce.js","statSize":357,"parsedSize":353,"gzipSize":66,"inaccurateSizes":true},{"id":null,"label":"ParticlesBounceFactor.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Bounce/ParticlesBounceFactor.js","statSize":210,"parsedSize":208,"gzipSize":39,"inaccurateSizes":true}],"parsedSize":561,"gzipSize":105,"inaccurateSizes":true},{"label":"Move","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Move","statSize":8533,"groups":[{"id":null,"label":"Move.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Move/Move.js","statSize":3257,"parsedSize":3226,"gzipSize":606,"inaccurateSizes":true},{"id":null,"label":"MoveAngle.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Move/MoveAngle.js","statSize":388,"parsedSize":384,"gzipSize":72,"inaccurateSizes":true},{"id":null,"label":"MoveAttract.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Move/MoveAttract.js","statSize":1086,"parsedSize":1075,"gzipSize":202,"inaccurateSizes":true},{"id":null,"label":"MoveGravity.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Move/MoveGravity.js","statSize":635,"parsedSize":629,"gzipSize":118,"inaccurateSizes":true},{"label":"Path","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Move/Path","statSize":641,"groups":[{"id":null,"label":"MovePath.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Move/Path/MovePath.js","statSize":641,"parsedSize":634,"gzipSize":119,"inaccurateSizes":true}],"parsedSize":634,"gzipSize":119,"inaccurateSizes":true},{"id":null,"label":"Spin.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Move/Spin.js","statSize":532,"parsedSize":527,"gzipSize":99,"inaccurateSizes":true},{"id":null,"label":"MoveCenter.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Move/MoveCenter.js","statSize":455,"parsedSize":450,"gzipSize":84,"inaccurateSizes":true},{"id":null,"label":"OutModes.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Move/OutModes.js","statSize":556,"parsedSize":550,"gzipSize":103,"inaccurateSizes":true},{"id":null,"label":"MoveTrail.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Move/MoveTrail.js","statSize":667,"parsedSize":660,"gzipSize":124,"inaccurateSizes":true},{"id":null,"label":"MoveTrailFill.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Move/MoveTrailFill.js","statSize":316,"parsedSize":313,"gzipSize":58,"inaccurateSizes":true}],"parsedSize":8452,"gzipSize":1588,"inaccurateSizes":true},{"label":"Opacity","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Opacity","statSize":1083,"groups":[{"id":null,"label":"Opacity.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Opacity/Opacity.js","statSize":424,"parsedSize":420,"gzipSize":78,"inaccurateSizes":true},{"id":null,"label":"OpacityAnimation.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Opacity/OpacityAnimation.js","statSize":659,"parsedSize":652,"gzipSize":122,"inaccurateSizes":true}],"parsedSize":1072,"gzipSize":201,"inaccurateSizes":true},{"label":"Shape","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Shape","statSize":772,"groups":[{"id":null,"label":"Shape.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Shape/Shape.js","statSize":772,"parsedSize":764,"gzipSize":143,"inaccurateSizes":true}],"parsedSize":764,"gzipSize":143,"inaccurateSizes":true},{"label":"Size","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Size","statSize":1054,"groups":[{"id":null,"label":"Size.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Size/Size.js","statSize":410,"parsedSize":406,"gzipSize":76,"inaccurateSizes":true},{"id":null,"label":"SizeAnimation.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Size/SizeAnimation.js","statSize":644,"parsedSize":637,"gzipSize":119,"inaccurateSizes":true}],"parsedSize":1044,"gzipSize":196,"inaccurateSizes":true},{"id":null,"label":"Stroke.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Stroke.js","statSize":526,"parsedSize":521,"gzipSize":97,"inaccurateSizes":true},{"label":"ZIndex","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/ZIndex","statSize":560,"groups":[{"id":null,"label":"ZIndex.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/ZIndex/ZIndex.js","statSize":560,"parsedSize":554,"gzipSize":104,"inaccurateSizes":true}],"parsedSize":554,"gzipSize":104,"inaccurateSizes":true},{"label":"Number","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Number","statSize":1516,"groups":[{"id":null,"label":"ParticlesNumber.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Number/ParticlesNumber.js","statSize":602,"parsedSize":596,"gzipSize":112,"inaccurateSizes":true},{"id":null,"label":"ParticlesDensity.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Number/ParticlesDensity.js","statSize":914,"parsedSize":905,"gzipSize":170,"inaccurateSizes":true}],"parsedSize":1501,"gzipSize":282,"inaccurateSizes":true},{"id":null,"label":"Shadow.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Particles/Shadow.js","statSize":740,"parsedSize":733,"gzipSize":137,"inaccurateSizes":true}],"parsedSize":19592,"gzipSize":3682,"inaccurateSizes":true},{"id":null,"label":"AnimatableColor.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/AnimatableColor.js","statSize":876,"parsedSize":867,"gzipSize":163,"inaccurateSizes":true},{"id":null,"label":"HslAnimation.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/HslAnimation.js","statSize":338,"parsedSize":334,"gzipSize":62,"inaccurateSizes":true},{"id":null,"label":"ColorAnimation.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/ColorAnimation.js","statSize":795,"parsedSize":787,"gzipSize":148,"inaccurateSizes":true},{"id":null,"label":"OptionsColor.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/OptionsColor.js","statSize":541,"parsedSize":535,"gzipSize":100,"inaccurateSizes":true},{"id":null,"label":"ValueWithRandom.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/ValueWithRandom.js","statSize":1560,"parsedSize":1545,"gzipSize":290,"inaccurateSizes":true},{"id":null,"label":"AnimationOptions.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/AnimationOptions.js","statSize":1172,"parsedSize":1160,"gzipSize":218,"inaccurateSizes":true},{"label":"Background","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Background","statSize":812,"groups":[{"id":null,"label":"Background.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Background/Background.js","statSize":812,"parsedSize":804,"gzipSize":151,"inaccurateSizes":true}],"parsedSize":804,"gzipSize":151,"inaccurateSizes":true},{"label":"BackgroundMask","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/BackgroundMask","statSize":1145,"groups":[{"id":null,"label":"BackgroundMask.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/BackgroundMask/BackgroundMask.js","statSize":708,"parsedSize":701,"gzipSize":131,"inaccurateSizes":true},{"id":null,"label":"BackgroundMaskCover.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/BackgroundMask/BackgroundMaskCover.js","statSize":437,"parsedSize":432,"gzipSize":81,"inaccurateSizes":true}],"parsedSize":1134,"gzipSize":213,"inaccurateSizes":true},{"label":"FullScreen","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/FullScreen","statSize":302,"groups":[{"id":null,"label":"FullScreen.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/FullScreen/FullScreen.js","statSize":302,"parsedSize":299,"gzipSize":56,"inaccurateSizes":true}],"parsedSize":299,"gzipSize":56,"inaccurateSizes":true},{"id":null,"label":"Random.js","path":"./dist/browser/bundle.js + 80 modules (concatenated)/../engine/dist/esm/Options/Classes/Random.js","statSize":323,"parsedSize":319,"gzipSize":60,"inaccurateSizes":true}],"parsedSize":40440,"gzipSize":7601,"inaccurateSizes":true}],"parsedSize":163100,"gzipSize":30657,"inaccurateSizes":true}]}],"parsedSize":163908,"gzipSize":30809}],"isInitialByEntrypoint":{"tsparticles.pjs.bundle":true}}];
|
35
35
|
window.entrypoints = ["tsparticles.pjs.bundle","tsparticles.pjs.bundle.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.0-alpha.
|
7
|
+
* v3.0.0-alpha.1
|
8
8
|
*/
|
9
9
|
(function webpackUniversalModuleDefinition(root, factory) {
|
10
10
|
if(typeof exports === 'object' && typeof module === 'object')
|
@@ -754,21 +754,41 @@ function initParticleNumericAnimationValue(options, pxRatio) {
|
|
754
754
|
maxLoops: getRangeValue(options.animation.count)
|
755
755
|
};
|
756
756
|
if (animationOptions.enable) {
|
757
|
-
res.status = "increasing";
|
758
757
|
res.decay = 1 - getRangeValue(animationOptions.decay);
|
758
|
+
let autoStatus = false;
|
759
|
+
switch (animationOptions.mode) {
|
760
|
+
case "increase":
|
761
|
+
res.status = "increasing";
|
762
|
+
break;
|
763
|
+
case "decrease":
|
764
|
+
res.status = "decreasing";
|
765
|
+
break;
|
766
|
+
case "random":
|
767
|
+
res.status = getRandom() >= 0.5 ? "increasing" : "decreasing";
|
768
|
+
break;
|
769
|
+
case "auto":
|
770
|
+
autoStatus = true;
|
771
|
+
break;
|
772
|
+
}
|
759
773
|
switch (animationOptions.startValue) {
|
760
774
|
case "min":
|
761
775
|
res.value = res.min;
|
762
|
-
|
776
|
+
if (autoStatus) {
|
777
|
+
res.status = "increasing";
|
778
|
+
}
|
763
779
|
break;
|
764
780
|
case "random":
|
765
781
|
res.value = randomInRange(res);
|
766
|
-
|
782
|
+
if (autoStatus) {
|
783
|
+
res.status = getRandom() >= 0.5 ? "increasing" : "decreasing";
|
784
|
+
}
|
767
785
|
break;
|
768
786
|
case "max":
|
769
787
|
default:
|
770
788
|
res.value = res.max;
|
771
|
-
|
789
|
+
if (autoStatus) {
|
790
|
+
res.status = "decreasing";
|
791
|
+
}
|
772
792
|
break;
|
773
793
|
}
|
774
794
|
}
|
@@ -1671,28 +1691,28 @@ class EventListeners {
|
|
1671
1691
|
this.container = container;
|
1672
1692
|
this.canPush = true;
|
1673
1693
|
this.handlers = {
|
1674
|
-
mouseMove: e => this.
|
1675
|
-
touchStart: e => this.
|
1676
|
-
touchMove: e => this.
|
1677
|
-
touchEnd: () => this.
|
1678
|
-
mouseLeave: () => this.
|
1679
|
-
touchCancel: () => this.
|
1680
|
-
touchEndClick: e => this.
|
1681
|
-
mouseUp: e => this.
|
1682
|
-
mouseDown: () => this.
|
1683
|
-
visibilityChange: () => this.
|
1684
|
-
themeChange: e => this.
|
1685
|
-
oldThemeChange: e => this.
|
1686
|
-
resize: () => this.
|
1694
|
+
mouseMove: e => this._mouseTouchMove(e),
|
1695
|
+
touchStart: e => this._mouseTouchMove(e),
|
1696
|
+
touchMove: e => this._mouseTouchMove(e),
|
1697
|
+
touchEnd: () => this._mouseTouchFinish(),
|
1698
|
+
mouseLeave: () => this._mouseTouchFinish(),
|
1699
|
+
touchCancel: () => this._mouseTouchFinish(),
|
1700
|
+
touchEndClick: e => this._mouseTouchClick(e),
|
1701
|
+
mouseUp: e => this._mouseTouchClick(e),
|
1702
|
+
mouseDown: () => this._mouseDown(),
|
1703
|
+
visibilityChange: () => this._handleVisibilityChange(),
|
1704
|
+
themeChange: e => this._handleThemeChange(e),
|
1705
|
+
oldThemeChange: e => this._handleThemeChange(e),
|
1706
|
+
resize: () => this._handleWindowResize()
|
1687
1707
|
};
|
1688
1708
|
}
|
1689
1709
|
addListeners() {
|
1690
|
-
this.
|
1710
|
+
this._manageListeners(true);
|
1691
1711
|
}
|
1692
1712
|
removeListeners() {
|
1693
|
-
this.
|
1713
|
+
this._manageListeners(false);
|
1694
1714
|
}
|
1695
|
-
|
1715
|
+
_doMouseTouchClick(e) {
|
1696
1716
|
const container = this.container,
|
1697
1717
|
options = container.actualOptions;
|
1698
1718
|
if (this.canPush) {
|
@@ -1704,16 +1724,16 @@ class EventListeners {
|
|
1704
1724
|
mouseInteractivity.clickPosition = Object.assign({}, mousePos);
|
1705
1725
|
mouseInteractivity.clickTime = new Date().getTime();
|
1706
1726
|
const onClick = options.interactivity.events.onClick;
|
1707
|
-
executeOnSingleOrMultiple(onClick.mode, mode => this.
|
1727
|
+
executeOnSingleOrMultiple(onClick.mode, mode => this._handleClickMode(mode));
|
1708
1728
|
}
|
1709
1729
|
if (e.type === "touchend") {
|
1710
|
-
setTimeout(() => this.
|
1730
|
+
setTimeout(() => this._mouseTouchFinish(), 500);
|
1711
1731
|
}
|
1712
1732
|
}
|
1713
|
-
|
1733
|
+
_handleClickMode(mode) {
|
1714
1734
|
this.container.handleClickMode(mode);
|
1715
1735
|
}
|
1716
|
-
|
1736
|
+
_handleThemeChange(e) {
|
1717
1737
|
const mediaEvent = e,
|
1718
1738
|
container = this.container,
|
1719
1739
|
options = container.options,
|
@@ -1724,18 +1744,17 @@ class EventListeners {
|
|
1724
1744
|
container.loadTheme(themeName);
|
1725
1745
|
}
|
1726
1746
|
}
|
1727
|
-
|
1747
|
+
_handleVisibilityChange() {
|
1728
1748
|
const container = this.container,
|
1729
1749
|
options = container.actualOptions;
|
1730
|
-
this.
|
1750
|
+
this._mouseTouchFinish();
|
1731
1751
|
if (!options.pauseOnBlur) {
|
1732
1752
|
return;
|
1733
1753
|
}
|
1734
|
-
|
1735
|
-
|
1754
|
+
container.pageHidden = (document === null || document === void 0 ? void 0 : document.hidden) || false;
|
1755
|
+
if (container.pageHidden) {
|
1736
1756
|
container.pause();
|
1737
1757
|
} else {
|
1738
|
-
container.pageHidden = false;
|
1739
1758
|
if (container.getAnimationStatus()) {
|
1740
1759
|
container.play(true);
|
1741
1760
|
} else {
|
@@ -1743,7 +1762,7 @@ class EventListeners {
|
|
1743
1762
|
}
|
1744
1763
|
}
|
1745
1764
|
}
|
1746
|
-
|
1765
|
+
_handleWindowResize() {
|
1747
1766
|
if (this.resizeTimeout) {
|
1748
1767
|
clearTimeout(this.resizeTimeout);
|
1749
1768
|
delete this.resizeTimeout;
|
@@ -1753,7 +1772,7 @@ class EventListeners {
|
|
1753
1772
|
return (_a = this.container.canvas) === null || _a === void 0 ? void 0 : _a.windowResize();
|
1754
1773
|
}, this.container.actualOptions.interactivity.events.resize.delay * 1000);
|
1755
1774
|
}
|
1756
|
-
|
1775
|
+
_manageInteractivityEvents(add) {
|
1757
1776
|
var _a;
|
1758
1777
|
const handlers = this.handlers,
|
1759
1778
|
container = this.container,
|
@@ -1769,18 +1788,6 @@ class EventListeners {
|
|
1769
1788
|
} else {
|
1770
1789
|
container.interactivity.element = container.canvas.element;
|
1771
1790
|
}
|
1772
|
-
const mediaMatch = safeMatchMedia("(prefers-color-scheme: dark)");
|
1773
|
-
if (mediaMatch) {
|
1774
|
-
if (mediaMatch.addEventListener !== undefined) {
|
1775
|
-
manageListener(mediaMatch, "change", handlers.themeChange, add);
|
1776
|
-
} else if (mediaMatch.addListener !== undefined) {
|
1777
|
-
if (add) {
|
1778
|
-
mediaMatch.addListener(handlers.oldThemeChange);
|
1779
|
-
} else {
|
1780
|
-
mediaMatch.removeListener(handlers.oldThemeChange);
|
1781
|
-
}
|
1782
|
-
}
|
1783
|
-
}
|
1784
1791
|
const interactivityEl = container.interactivity.element;
|
1785
1792
|
if (!interactivityEl) {
|
1786
1793
|
return;
|
@@ -1803,33 +1810,66 @@ class EventListeners {
|
|
1803
1810
|
if (container.canvas.element) {
|
1804
1811
|
container.canvas.element.style.pointerEvents = html === container.canvas.element ? "initial" : "none";
|
1805
1812
|
}
|
1806
|
-
|
1807
|
-
|
1808
|
-
|
1809
|
-
|
1810
|
-
|
1811
|
-
|
1812
|
-
|
1813
|
-
|
1814
|
-
|
1815
|
-
|
1816
|
-
|
1817
|
-
|
1818
|
-
|
1819
|
-
|
1820
|
-
|
1821
|
-
|
1822
|
-
|
1823
|
-
|
1813
|
+
}
|
1814
|
+
_manageListeners(add) {
|
1815
|
+
this._manageMediaEvents(add);
|
1816
|
+
this._manageInteractivityEvents(add);
|
1817
|
+
this._manageResizeEvent(add);
|
1818
|
+
this._manageVisibilityEvent(add);
|
1819
|
+
}
|
1820
|
+
_manageMediaEvents(add) {
|
1821
|
+
const handlers = this.handlers,
|
1822
|
+
mediaMatch = safeMatchMedia("(prefers-color-scheme: dark)");
|
1823
|
+
if (!mediaMatch) {
|
1824
|
+
return;
|
1825
|
+
}
|
1826
|
+
if (mediaMatch.addEventListener !== undefined) {
|
1827
|
+
manageListener(mediaMatch, "change", handlers.themeChange, add);
|
1828
|
+
return;
|
1829
|
+
}
|
1830
|
+
if (mediaMatch.addListener !== undefined) {
|
1831
|
+
if (add) {
|
1832
|
+
mediaMatch.addListener(handlers.oldThemeChange);
|
1824
1833
|
} else {
|
1825
|
-
|
1834
|
+
mediaMatch.removeListener(handlers.oldThemeChange);
|
1835
|
+
}
|
1836
|
+
}
|
1837
|
+
}
|
1838
|
+
_manageResizeEvent(add) {
|
1839
|
+
const handlers = this.handlers,
|
1840
|
+
container = this.container,
|
1841
|
+
options = container.actualOptions;
|
1842
|
+
if (!options.interactivity.events.resize) {
|
1843
|
+
return;
|
1844
|
+
}
|
1845
|
+
if (typeof ResizeObserver === "undefined") {
|
1846
|
+
manageListener(window, resizeEvent, handlers.resize, add);
|
1847
|
+
return;
|
1848
|
+
}
|
1849
|
+
if (this.resizeObserver && !add) {
|
1850
|
+
if (container.canvas.element) {
|
1851
|
+
this.resizeObserver.unobserve(container.canvas.element);
|
1826
1852
|
}
|
1853
|
+
this.resizeObserver.disconnect();
|
1854
|
+
delete this.resizeObserver;
|
1855
|
+
} else if (!this.resizeObserver && add && container.canvas.element) {
|
1856
|
+
this.resizeObserver = new ResizeObserver(entries => {
|
1857
|
+
const entry = entries.find(e => e.target === container.canvas.element);
|
1858
|
+
if (!entry) {
|
1859
|
+
return;
|
1860
|
+
}
|
1861
|
+
this._handleWindowResize();
|
1862
|
+
});
|
1863
|
+
this.resizeObserver.observe(container.canvas.element);
|
1827
1864
|
}
|
1828
|
-
|
1829
|
-
|
1865
|
+
}
|
1866
|
+
_manageVisibilityEvent(add) {
|
1867
|
+
if (!document) {
|
1868
|
+
return;
|
1830
1869
|
}
|
1870
|
+
manageListener(document, visibilityChangeEvent, this.handlers.visibilityChange, add);
|
1831
1871
|
}
|
1832
|
-
|
1872
|
+
_mouseDown() {
|
1833
1873
|
const interactivity = this.container.interactivity;
|
1834
1874
|
if (interactivity) {
|
1835
1875
|
const mouse = interactivity.mouse;
|
@@ -1837,7 +1877,7 @@ class EventListeners {
|
|
1837
1877
|
mouse.downPosition = mouse.position;
|
1838
1878
|
}
|
1839
1879
|
}
|
1840
|
-
|
1880
|
+
_mouseTouchClick(e) {
|
1841
1881
|
const container = this.container,
|
1842
1882
|
options = container.actualOptions,
|
1843
1883
|
mouse = container.interactivity.mouse;
|
@@ -1857,11 +1897,11 @@ class EventListeners {
|
|
1857
1897
|
}
|
1858
1898
|
}
|
1859
1899
|
if (!handled) {
|
1860
|
-
this.
|
1900
|
+
this._doMouseTouchClick(e);
|
1861
1901
|
}
|
1862
1902
|
mouse.clicking = false;
|
1863
1903
|
}
|
1864
|
-
|
1904
|
+
_mouseTouchFinish() {
|
1865
1905
|
const interactivity = this.container.interactivity;
|
1866
1906
|
if (!interactivity) {
|
1867
1907
|
return;
|
@@ -1874,7 +1914,7 @@ class EventListeners {
|
|
1874
1914
|
mouse.inside = false;
|
1875
1915
|
mouse.clicking = false;
|
1876
1916
|
}
|
1877
|
-
|
1917
|
+
_mouseTouchMove(e) {
|
1878
1918
|
var _a, _b, _c, _d, _e, _f, _g;
|
1879
1919
|
const container = this.container,
|
1880
1920
|
options = container.actualOptions;
|
@@ -2343,14 +2383,15 @@ class Interactivity {
|
|
2343
2383
|
|
2344
2384
|
class ManualParticle {
|
2345
2385
|
load(data) {
|
2346
|
-
var _a, _b;
|
2386
|
+
var _a, _b, _c;
|
2347
2387
|
if (!data) {
|
2348
2388
|
return;
|
2349
2389
|
}
|
2350
2390
|
if (data.position !== undefined) {
|
2351
2391
|
this.position = {
|
2352
2392
|
x: (_a = data.position.x) !== null && _a !== void 0 ? _a : 50,
|
2353
|
-
y: (_b = data.position.y) !== null && _b !== void 0 ? _b : 50
|
2393
|
+
y: (_b = data.position.y) !== null && _b !== void 0 ? _b : 50,
|
2394
|
+
mode: (_c = data.position.mode) !== null && _c !== void 0 ? _c : "percent"
|
2354
2395
|
};
|
2355
2396
|
}
|
2356
2397
|
if (data.options !== undefined) {
|
@@ -2583,6 +2624,7 @@ class AnimationOptions {
|
|
2583
2624
|
class RangedAnimationOptions extends AnimationOptions {
|
2584
2625
|
constructor() {
|
2585
2626
|
super();
|
2627
|
+
this.mode = "auto";
|
2586
2628
|
this.startValue = "random";
|
2587
2629
|
}
|
2588
2630
|
load(data) {
|
@@ -2593,6 +2635,9 @@ class RangedAnimationOptions extends AnimationOptions {
|
|
2593
2635
|
if (data.minimumValue !== undefined) {
|
2594
2636
|
this.minimumValue = data.minimumValue;
|
2595
2637
|
}
|
2638
|
+
if (data.mode !== undefined) {
|
2639
|
+
this.mode = data.mode;
|
2640
|
+
}
|
2596
2641
|
if (data.startValue !== undefined) {
|
2597
2642
|
this.startValue = data.startValue;
|
2598
2643
|
}
|
@@ -3239,12 +3284,20 @@ class Shape {
|
|
3239
3284
|
constructor() {
|
3240
3285
|
this.options = {};
|
3241
3286
|
this.type = "circle";
|
3287
|
+
this.close = true;
|
3288
|
+
this.fill = true;
|
3242
3289
|
}
|
3243
3290
|
load(data) {
|
3244
3291
|
var _a;
|
3245
3292
|
if (!data) {
|
3246
3293
|
return;
|
3247
3294
|
}
|
3295
|
+
if (data.close !== undefined) {
|
3296
|
+
this.close = data.close;
|
3297
|
+
}
|
3298
|
+
if (data.fill !== undefined) {
|
3299
|
+
this.fill = data.fill;
|
3300
|
+
}
|
3248
3301
|
const options = data.options;
|
3249
3302
|
if (options !== undefined) {
|
3250
3303
|
for (const shape in options) {
|
@@ -4011,7 +4064,10 @@ class Particle {
|
|
4011
4064
|
_loadShapeData(shapeOptions, reduceDuplicates) {
|
4012
4065
|
const shapeData = shapeOptions.options[this.shape];
|
4013
4066
|
if (shapeData) {
|
4014
|
-
return deepExtend({
|
4067
|
+
return deepExtend({
|
4068
|
+
close: shapeOptions.close,
|
4069
|
+
fill: shapeOptions.fill
|
4070
|
+
}, itemFromSingleOrMultiple(shapeData, this.id, reduceDuplicates));
|
4015
4071
|
}
|
4016
4072
|
}
|
4017
4073
|
}
|
@@ -4194,10 +4250,10 @@ class Particles {
|
|
4194
4250
|
const container = this.container,
|
4195
4251
|
options = container.actualOptions;
|
4196
4252
|
for (const particle of options.manualParticles) {
|
4197
|
-
this.addParticle(calcPositionFromSize({
|
4253
|
+
this.addParticle(particle.position ? particle.position.mode === "precise" ? particle.position : calcPositionFromSize({
|
4198
4254
|
size: container.canvas.size,
|
4199
4255
|
position: particle.position
|
4200
|
-
}), particle.options);
|
4256
|
+
}) : undefined, particle.options);
|
4201
4257
|
}
|
4202
4258
|
}
|
4203
4259
|
addParticle(position, overrideOptions, group, initializer) {
|
@@ -4301,22 +4357,9 @@ class Particles {
|
|
4301
4357
|
}
|
4302
4358
|
let deleted = 0;
|
4303
4359
|
for (let i = index; deleted < quantity && i < this.count; i++) {
|
4304
|
-
|
4305
|
-
|
4306
|
-
continue;
|
4360
|
+
if (this._removeParticle(i--, group, override)) {
|
4361
|
+
deleted++;
|
4307
4362
|
}
|
4308
|
-
particle.destroy(override);
|
4309
|
-
this.array.splice(i--, 1);
|
4310
|
-
const idx = this.zArray.indexOf(particle);
|
4311
|
-
this.zArray.splice(idx, 1);
|
4312
|
-
this.pool.push(particle);
|
4313
|
-
deleted++;
|
4314
|
-
this._engine.dispatchEvent("particleRemoved", {
|
4315
|
-
container: this.container,
|
4316
|
-
data: {
|
4317
|
-
particle
|
4318
|
-
}
|
4319
|
-
});
|
4320
4363
|
}
|
4321
4364
|
}
|
4322
4365
|
removeQuantity(quantity, group) {
|
@@ -4437,6 +4480,24 @@ class Particles {
|
|
4437
4480
|
return;
|
4438
4481
|
}
|
4439
4482
|
}
|
4483
|
+
_removeParticle(index, group, override) {
|
4484
|
+
const particle = this.array[index];
|
4485
|
+
if (!particle || particle.group !== group) {
|
4486
|
+
return false;
|
4487
|
+
}
|
4488
|
+
particle.destroy(override);
|
4489
|
+
this.array.splice(index, 1);
|
4490
|
+
const zIdx = this.zArray.indexOf(particle);
|
4491
|
+
this.zArray.splice(zIdx, 1);
|
4492
|
+
this.pool.push(particle);
|
4493
|
+
this._engine.dispatchEvent("particleRemoved", {
|
4494
|
+
container: this.container,
|
4495
|
+
data: {
|
4496
|
+
particle
|
4497
|
+
}
|
4498
|
+
});
|
4499
|
+
return true;
|
4500
|
+
}
|
4440
4501
|
}
|
4441
4502
|
;// CONCATENATED MODULE: ../../engine/dist/esm/Core/Retina.js
|
4442
4503
|
|
@@ -5563,6 +5624,7 @@ const tsParticles = new Engine();
|
|
5563
5624
|
|
5564
5625
|
|
5565
5626
|
|
5627
|
+
|
5566
5628
|
|
5567
5629
|
|
5568
5630
|
;// CONCATENATED MODULE: ./dist/browser/bundle.js
|
@@ -1,2 +1,2 @@
|
|
1
1
|
/*! For license information please see tsparticles.pjs.bundle.min.js.LICENSE.txt */
|
2
|
-
!function(t,e){if("object"==typeof exports&&"object"==typeof module)module.exports=e();else if("function"==typeof define&&define.amd)define([],e);else{var i=e();for(var s in i)("object"==typeof exports?exports:t)[s]=i[s]}}(this,(()=>(()=>{"use strict";var t={d:(e,i)=>{for(var s in i)t.o(i,s)&&!t.o(e,s)&&Object.defineProperty(e,s,{enumerable:!0,get:i[s]})},o:(t,e)=>Object.prototype.hasOwnProperty.call(t,e),r:t=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})}},e={};t.r(e),t.d(e,{AnimatableColor:()=>be,AnimationOptions:()=>xe,AnimationValueWithRandom:()=>Oe,Background:()=>ee,BackgroundMask:()=>se,BackgroundMaskCover:()=>ie,Circle:()=>ai,ClickEvent:()=>oe,Collisions:()=>Re,CollisionsAbsorb:()=>we,CollisionsOverlap:()=>_e,ColorAnimation:()=>ge,DivEvent:()=>ae,Events:()=>ce,ExternalInteractorBase:()=>wi,FullScreen:()=>ne,HoverEvent:()=>le,HslAnimation:()=>ye,HslColorManager:()=>yi,Interactivity:()=>ue,ManualParticle:()=>pe,Modes:()=>de,Move:()=>Be,MoveAngle:()=>Te,MoveAttract:()=>Ie,MoveCenter:()=>Ee,MoveGravity:()=>De,MovePath:()=>Ae,MoveTrail:()=>Le,MoveTrailFill:()=>Fe,Opacity:()=>Ue,OpacityAnimation:()=>He,Options:()=>ti,OptionsColor:()=>te,OutModes:()=>Ve,Parallax:()=>re,ParticlesBounce:()=>Se,ParticlesBounceFactor:()=>Ce,ParticlesDensity:()=>qe,ParticlesInteractorBase:()=>_i,ParticlesNumber:()=>Ge,ParticlesOptions:()=>Ze,Point:()=>ni,Range:()=>oi,RangedAnimationOptions:()=>ze,RangedAnimationValueWithRandom:()=>ke,Rectangle:()=>ri,ResizeEvent:()=>he,Responsive:()=>ve,RgbColorManager:()=>bi,Shadow:()=>je,Shape:()=>$e,Size:()=>Xe,SizeAnimation:()=>Ne,Spin:()=>We,Stroke:()=>Ye,Theme:()=>me,ThemeDefault:()=>fe,ValueWithRandom:()=>Pe,Vector:()=>s,Vector3d:()=>i,ZIndex:()=>Je,addColorManager:()=>st,addEasing:()=>a,alterHsl:()=>Ft,animate:()=>E,areBoundsInside:()=>B,arrayRandomIndex:()=>L,calcExactPositionOrRandomFromSize:()=>O,calcExactPositionOrRandomFromSizeRanged:()=>k,calcPositionFromSize:()=>z,calcPositionOrRandomFromSize:()=>M,calcPositionOrRandomFromSizeRanged:()=>P,calculateBounds:()=>H,cancelAnimation:()=>D,circleBounce:()=>X,circleBounceDataFromParticle:()=>N,clamp:()=>c,clear:()=>Rt,clearCanvas:()=>Ot,collisionVelocity:()=>x,colorMix:()=>yt,colorToHsl:()=>lt,colorToRgb:()=>rt,deepExtend:()=>U,divMode:()=>$,divModeExecute:()=>G,drawLine:()=>Ct,drawParticle:()=>Tt,drawParticlePlugin:()=>At,drawPlugin:()=>Dt,drawShape:()=>It,drawShapeAfterEffect:()=>Et,drawTriangle:()=>St,executeOnSingleOrMultiple:()=>J,findItemFromSingleOrMultiple:()=>Q,generatedAttribute:()=>Lt,getContext:()=>Pt,getDistance:()=>b,getDistances:()=>y,getEasing:()=>r,getHslAnimationFromHsl:()=>xt,getHslFromAnimation:()=>_t,getLinkColor:()=>bt,getLinkRandomColor:()=>wt,getParticleBaseVelocity:()=>_,getParticleDirectionAngle:()=>w,getRandom:()=>h,getRandomRgbColor:()=>ft,getRangeMax:()=>f,getRangeMin:()=>v,getRangeValue:()=>p,getStyleFromHsl:()=>gt,getStyleFromRgb:()=>mt,getValue:()=>g,hasMatchMedia:()=>T,hslToRgb:()=>pt,hslaToRgba:()=>vt,initParticleNumericAnimationValue:()=>K,isDivModeEnabled:()=>q,isInArray:()=>A,isPointInside:()=>W,isSsr:()=>R,itemFromArray:()=>V,itemFromSingleOrMultiple:()=>Z,loadFont:()=>F,loadOptions:()=>Qe,loadParticlesOptions:()=>Ke,mix:()=>d,mouseDownEvent:()=>Wt,mouseLeaveEvent:()=>Gt,mouseMoveEvent:()=>Ht,mouseOutEvent:()=>jt,mouseUpEvent:()=>Bt,pJSDom:()=>Oi,paintCanvas:()=>kt,parseAlpha:()=>C,particlesJS:()=>Pi,randomInRange:()=>u,rangeColorToHsl:()=>ht,rangeColorToRgb:()=>at,rectBounce:()=>Y,resizeEvent:()=>Nt,rgbToHsl:()=>ct,safeMatchMedia:()=>I,setRandom:()=>l,setRangeValue:()=>m,singleDivModeExecute:()=>j,stringToAlpha:()=>dt,stringToRgb:()=>ut,touchCancelEvent:()=>$t,touchEndEvent:()=>Vt,touchMoveEvent:()=>qt,touchStartEvent:()=>Ut,tsParticles:()=>Mi,visibilityChangeEvent:()=>Xt});class i{constructor(t,e,i){if("number"!=typeof t&&t){this.x=t.x,this.y=t.y;const e=t;this.z=e.z?e.z:0}else{if(void 0===t||void 0===e)throw new Error("tsParticles - Vector3d not initialized correctly");this.x=t,this.y=e,this.z=null!=i?i:0}}static get origin(){return i.create(0,0,0)}get angle(){return Math.atan2(this.y,this.x)}set angle(t){this.updateFromAngle(t,this.length)}get length(){return Math.sqrt(this.getLengthSq())}set length(t){this.updateFromAngle(this.angle,t)}static clone(t){return i.create(t.x,t.y,t.z)}static create(t,e,s){return new i(t,e,s)}add(t){return i.create(this.x+t.x,this.y+t.y,this.z+t.z)}addTo(t){this.x+=t.x,this.y+=t.y,this.z+=t.z}copy(){return i.clone(this)}distanceTo(t){return this.sub(t).length}distanceToSq(t){return this.sub(t).getLengthSq()}div(t){return i.create(this.x/t,this.y/t,this.z/t)}divTo(t){this.x/=t,this.y/=t,this.z/=t}getLengthSq(){return this.x**2+this.y**2}mult(t){return i.create(this.x*t,this.y*t,this.z*t)}multTo(t){this.x*=t,this.y*=t,this.z*=t}rotate(t){return i.create(this.x*Math.cos(t)-this.y*Math.sin(t),this.x*Math.sin(t)+this.y*Math.cos(t),0)}setTo(t){this.x=t.x,this.y=t.y;const e=t;this.z=e.z?e.z:0}sub(t){return i.create(this.x-t.x,this.y-t.y,this.z-t.z)}subFrom(t){this.x-=t.x,this.y-=t.y,this.z-=t.z}updateFromAngle(t,e){this.x=Math.cos(t)*e,this.y=Math.sin(t)*e}}class s extends i{constructor(t,e){super(t,e,0)}static get origin(){return s.create(0,0)}static clone(t){return s.create(t.x,t.y)}static create(t,e){return new s(t,e)}}let n=Math.random;const o=new Map;function a(t,e){o.get(t)||o.set(t,e)}function r(t){return o.get(t)||(t=>t)}function l(t=Math.random){n=t}function h(){return c(n(),0,1-1e-16)}function c(t,e,i){return Math.min(Math.max(t,e),i)}function d(t,e,i,s){return Math.floor((t*i+e*s)/(i+s))}function u(t){const e=f(t);let i=v(t);return e===i&&(i=0),h()*(e-i)+i}function p(t){return"number"==typeof t?t:u(t)}function v(t){return"number"==typeof t?t:t.min}function f(t){return"number"==typeof t?t:t.max}function m(t,e){if(t===e||void 0===e&&"number"==typeof t)return t;const i=v(t),s=f(t);return void 0!==e?{min:Math.min(i,e),max:Math.max(s,e)}:m(i,s)}function g(t){const e=t.random,{enable:i,minimumValue:s}="boolean"==typeof e?{enable:e,minimumValue:0}:e;return p(i?m(t.value,s):t.value)}function y(t,e){const i=t.x-e.x,s=t.y-e.y;return{dx:i,dy:s,distance:Math.sqrt(i**2+s**2)}}function b(t,e){return y(t,e).distance}function w(t,e,i){if("number"==typeof t)return t*Math.PI/180;switch(t){case"top":return-Math.PI/2;case"top-right":return-Math.PI/4;case"right":return 0;case"bottom-right":return Math.PI/4;case"bottom":return Math.PI/2;case"bottom-left":return 3*Math.PI/4;case"left":return Math.PI;case"top-left":return-3*Math.PI/4;case"inside":return Math.atan2(i.y-e.y,i.x-e.x);case"outside":return Math.atan2(e.y-i.y,e.x-i.x);default:return h()*Math.PI*2}}function _(t){const e=s.origin;return e.length=1,e.angle=t,e}function x(t,e,i,n){return s.create(t.x*(i-n)/(i+n)+2*e.x*n/(i+n),t.y)}function z(t){return t.position&&void 0!==t.position.x&&void 0!==t.position.y?{x:t.position.x*t.size.width/100,y:t.position.y*t.size.height/100}:void 0}function M(t){var e,i,s,n;return{x:(null!==(i=null===(e=t.position)||void 0===e?void 0:e.x)&&void 0!==i?i:100*h())*t.size.width/100,y:(null!==(n=null===(s=t.position)||void 0===s?void 0:s.y)&&void 0!==n?n:100*h())*t.size.height/100}}function P(t){var e,i;const s={x:void 0!==(null===(e=t.position)||void 0===e?void 0:e.x)?p(t.position.x):void 0,y:void 0!==(null===(i=t.position)||void 0===i?void 0:i.y)?p(t.position.y):void 0};return M({size:t.size,position:s})}function O(t){var e,i,s,n;return{x:null!==(i=null===(e=t.position)||void 0===e?void 0:e.x)&&void 0!==i?i:h()*t.size.width,y:null!==(n=null===(s=t.position)||void 0===s?void 0:s.y)&&void 0!==n?n:h()*t.size.height}}function k(t){var e,i;const s={x:void 0!==(null===(e=t.position)||void 0===e?void 0:e.x)?p(t.position.x):void 0,y:void 0!==(null===(i=t.position)||void 0===i?void 0:i.y)?p(t.position.y):void 0};return O({size:t.size,position:s})}function C(t){return t?t.endsWith("%")?parseFloat(t)/100:parseFloat(t):1}function S(t,e,i,s,n,o){const a={bounced:!1};return e.min<s.min||e.min>s.max||e.max<s.min||e.max>s.max||(t.max>=i.min&&t.max<=(i.max+i.min)/2&&n>0||t.min<=i.max&&t.min>(i.max+i.min)/2&&n<0)&&(a.velocity=n*-o,a.bounced=!0),a}function R(){return"undefined"==typeof window||!window||void 0===window.document||!window.document}function T(){return!R()&&"undefined"!=typeof matchMedia}function I(t){if(T())return matchMedia(t)}function E(){return R()?t=>setTimeout(t):t=>(requestAnimationFrame||setTimeout)(t)}function D(){return R()?t=>clearTimeout(t):t=>(cancelAnimationFrame||clearTimeout)(t)}function A(t,e){return t===e||e instanceof Array&&e.indexOf(t)>-1}async function F(t,e){try{await document.fonts.load(`${null!=e?e:"400"} 36px '${null!=t?t:"Verdana"}'`)}catch(t){}}function L(t){return Math.floor(h()*t.length)}function V(t,e,i=!0){return t[void 0!==e&&i?e%t.length:L(t)]}function W(t,e,i,s,n){return B(H(t,null!=s?s:0),e,i,n)}function B(t,e,i,s){let n=!0;return s&&"bottom"!==s||(n=t.top<e.height+i.x),!n||s&&"left"!==s||(n=t.right>i.x),!n||s&&"right"!==s||(n=t.left<e.width+i.y),!n||s&&"top"!==s||(n=t.bottom>i.y),n}function H(t,e){return{bottom:t.y+e,left:t.x-e,right:t.x+e,top:t.y-e}}function U(t,...e){for(const i of e){if(null==i)continue;if("object"!=typeof i){t=i;continue}const e=Array.isArray(i);!e||"object"==typeof t&&t&&Array.isArray(t)?e||"object"==typeof t&&t&&!Array.isArray(t)||(t={}):t=[];for(const e in i){if("__proto__"===e)continue;const s=i[e],n="object"==typeof s,o=t;o[e]=n&&Array.isArray(s)?s.map((t=>U(o[e],t))):U(o[e],s)}}return t}function q(t,e){return!!Q(e,(e=>e.enable&&A(t,e.mode)))}function G(t,e,i){J(e,(e=>{const s=e.mode;e.enable&&A(t,s)&&j(e,i)}))}function j(t,e){J(t.selectors,(i=>{e(i,t)}))}function $(t,e){if(e&&t)return Q(t,(t=>function(t,e){const i=J(e,(e=>t.matches(e)));return i instanceof Array?i.some((t=>t)):i}(e,t.selectors)))}function N(t){return{position:t.getPosition(),radius:t.getRadius(),mass:t.getMass(),velocity:t.velocity,factor:s.create(g(t.options.bounce.horizontal),g(t.options.bounce.vertical))}}function X(t,e){const{x:i,y:s}=t.velocity.sub(e.velocity),[n,o]=[t.position,e.position],{dx:a,dy:r}=y(o,n);if(i*a+s*r<0)return;const l=-Math.atan2(r,a),h=t.mass,c=e.mass,d=t.velocity.rotate(l),u=e.velocity.rotate(l),p=x(d,u,h,c),v=x(u,d,h,c),f=p.rotate(-l),m=v.rotate(-l);t.velocity.x=f.x*t.factor.x,t.velocity.y=f.y*t.factor.y,e.velocity.x=m.x*e.factor.x,e.velocity.y=m.y*e.factor.y}function Y(t,e){const i=H(t.getPosition(),t.getRadius()),s=S({min:i.left,max:i.right},{min:i.top,max:i.bottom},{min:e.left,max:e.right},{min:e.top,max:e.bottom},t.velocity.x,g(t.options.bounce.horizontal));s.bounced&&(void 0!==s.velocity&&(t.velocity.x=s.velocity),void 0!==s.position&&(t.position.x=s.position));const n=S({min:i.top,max:i.bottom},{min:i.left,max:i.right},{min:e.top,max:e.bottom},{min:e.left,max:e.right},t.velocity.y,g(t.options.bounce.vertical));n.bounced&&(void 0!==n.velocity&&(t.velocity.y=n.velocity),void 0!==n.position&&(t.position.y=n.position))}function J(t,e){return t instanceof Array?t.map(((t,i)=>e(t,i))):e(t,0)}function Z(t,e,i){return t instanceof Array?V(t,e,i):t}function Q(t,e){return t instanceof Array?t.find(((t,i)=>e(t,i))):e(t,0)?t:void 0}function K(t,e){const i=t.value,s=t.animation,n={enable:t.animation.enable,value:p(t.value)*e,max:f(i)*e,min:v(i)*e,loops:0,maxLoops:p(t.animation.count)};if(s.enable)switch(n.status="increasing",n.decay=1-p(s.decay),s.startValue){case"min":n.value=n.min,n.status="increasing";break;case"random":n.value=u(n),n.status=h()>=.5?"increasing":"decreasing";break;default:n.value=n.max,n.status="decreasing"}return n.initialValue=n.value,n}const tt="random",et="mid",it=new Map;function st(t){it.set(t.key,t)}function nt(t,e,i){return i<0&&(i+=1),i>1&&(i-=1),i<1/6?t+6*(e-t)*i:i<.5?e:i<2/3?t+(e-t)*(2/3-i)*6:t}function ot(t){for(const[,e]of it)if(t.startsWith(e.stringPrefix))return e.parseString(t);const e=t.replace(/^#?([a-f\d])([a-f\d])([a-f\d])([a-f\d])?$/i,((t,e,i,s,n)=>e+e+i+i+s+s+(void 0!==n?n+n:""))),i=/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})?$/i.exec(e);return i?{a:void 0!==i[4]?parseInt(i[4],16)/255:1,b:parseInt(i[3],16),g:parseInt(i[2],16),r:parseInt(i[1],16)}:void 0}function at(t,e,i=!0){if(!t)return;const s="string"==typeof t?{value:t}:t;if("string"==typeof s.value)return rt(s.value,e,i);if(s.value instanceof Array)return at({value:V(s.value,e,i)});for(const[,t]of it){const e=t.handleRangeColor(s);if(e)return e}}function rt(t,e,i=!0){if(!t)return;const s="string"==typeof t?{value:t}:t;if("string"==typeof s.value)return s.value===tt?ft():ut(s.value);if(s.value instanceof Array)return rt({value:V(s.value,e,i)});for(const[,t]of it){const e=t.handleColor(s);if(e)return e}}function lt(t,e,i=!0){const s=rt(t,e,i);return s?ct(s):void 0}function ht(t,e,i=!0){const s=at(t,e,i);return s?ct(s):void 0}function ct(t){const e=t.r/255,i=t.g/255,s=t.b/255,n=Math.max(e,i,s),o=Math.min(e,i,s),a={h:0,l:(n+o)/2,s:0};return n!==o&&(a.s=a.l<.5?(n-o)/(n+o):(n-o)/(2-n-o),a.h=e===n?(i-s)/(n-o):a.h=i===n?2+(s-e)/(n-o):4+(e-i)/(n-o)),a.l*=100,a.s*=100,a.h*=60,a.h<0&&(a.h+=360),a.h>=360&&(a.h-=360),a}function dt(t){var e;return null===(e=ot(t))||void 0===e?void 0:e.a}function ut(t){return ot(t)}function pt(t){const e={b:0,g:0,r:0},i={h:t.h/360,l:t.l/100,s:t.s/100};if(i.s){const t=i.l<.5?i.l*(1+i.s):i.l+i.s-i.l*i.s,s=2*i.l-t;e.r=nt(s,t,i.h+1/3),e.g=nt(s,t,i.h),e.b=nt(s,t,i.h-1/3)}else e.b=i.l,e.g=i.l,e.r=i.l;return e.r=Math.floor(255*e.r),e.g=Math.floor(255*e.g),e.b=Math.floor(255*e.b),e}function vt(t){const e=pt(t);return{a:t.a,b:e.b,g:e.g,r:e.r}}function ft(t){const e=null!=t?t:0;return{b:Math.floor(u(m(e,256))),g:Math.floor(u(m(e,256))),r:Math.floor(u(m(e,256)))}}function mt(t,e){return`rgba(${t.r}, ${t.g}, ${t.b}, ${null!=e?e:1})`}function gt(t,e){return`hsla(${t.h}, ${t.s}%, ${t.l}%, ${null!=e?e:1})`}function yt(t,e,i,s){let n=t,o=e;return void 0===n.r&&(n=pt(t)),void 0===o.r&&(o=pt(e)),{b:d(n.b,o.b,i,s),g:d(n.g,o.g,i,s),r:d(n.r,o.r,i,s)}}function bt(t,e,i){var s,n;if(i===tt)return ft();if(i!==et)return i;{const i=null!==(s=t.getFillColor())&&void 0!==s?s:t.getStrokeColor(),o=null!==(n=null==e?void 0:e.getFillColor())&&void 0!==n?n:null==e?void 0:e.getStrokeColor();if(i&&o&&e)return yt(i,o,t.getRadius(),e.getRadius());{const t=null!=i?i:o;if(t)return pt(t)}}}function wt(t,e,i){const s="string"==typeof t?t:t.value;return s===tt?i?at({value:s}):e?tt:et:s===et?et:at({value:s})}function _t(t){return void 0!==t?{h:t.h.value,s:t.s.value,l:t.l.value}:void 0}function xt(t,e,i){const s={h:{enable:!1,value:t.h},s:{enable:!1,value:t.s},l:{enable:!1,value:t.l}};return e&&(zt(s.h,e.h,i),zt(s.s,e.s,i),zt(s.l,e.l,i)),s}function zt(t,e,i){t.enable=e.enable,t.enable?(t.velocity=p(e.speed)/100*i,t.decay=1-p(e.decay),t.status="increasing",t.loops=0,t.maxLoops=p(e.count),e.sync||(t.velocity*=h(),t.value*=h()),t.initialValue=t.value):t.velocity=0}function Mt(t,e,i){t.fillStyle=null!=i?i:"rgba(0,0,0,0)",t.fillRect(0,0,e.width,e.height)}function Pt(t){const e=t.getContext("2d");if(!e)throw new Error("Error tsParticles - No canvas context found");return e}function Ot(t,e,i,s,n){if(i.backgroundMask.enable)kt(t,e,i,n);else{const n=i.particles.move.trail;n.enable&&n.length>0&&s?s.color?Mt(t,e,mt(s.color,s.opacity)):s.image&&function(t,e,i,s){i&&(t.globalAlpha=s,t.drawImage(i,0,0,e.width,e.height),t.globalAlpha=1)}(t,e,s.image,s.opacity):Rt(t,e)}}function kt(t,e,i,s){i.backgroundMask.enable&&s?(Rt(t,e),Mt(t,e,s)):Mt(t,e)}function Ct(t,e,i){t.beginPath(),t.moveTo(e.x,e.y),t.lineTo(i.x,i.y),t.closePath()}function St(t,e,i,s){t.beginPath(),t.moveTo(e.x,e.y),t.lineTo(i.x,i.y),t.lineTo(s.x,s.y),t.closePath()}function Rt(t,e){t.clearRect(0,0,e.width,e.height)}function Tt(t){var e,i,s,n,o;const{container:a,context:r,particle:l,delta:h,colorStyles:c,backgroundMask:d,composite:u,radius:p,opacity:v,shadow:f,transform:m}=t,g=l.getPosition(),y=l.rotation+(l.pathRotation?l.velocity.angle:0),b=Math.sin(y),w=Math.cos(y),_={a:w*(null!==(e=m.a)&&void 0!==e?e:1),b:b*(null!==(i=m.b)&&void 0!==i?i:1),c:-b*(null!==(s=m.c)&&void 0!==s?s:1),d:w*(null!==(n=m.d)&&void 0!==n?n:1)};r.setTransform(_.a,_.b,_.c,_.d,g.x,g.y),r.beginPath(),d&&(r.globalCompositeOperation=u);const x=l.shadowColor;f.enable&&x&&(r.shadowBlur=f.blur,r.shadowColor=mt(x),r.shadowOffsetX=f.offset.x,r.shadowOffsetY=f.offset.y),c.fill&&(r.fillStyle=c.fill);const z=null!==(o=l.strokeWidth)&&void 0!==o?o:0;r.lineWidth=z,c.stroke&&(r.strokeStyle=c.stroke),It(a,r,l,p,v,h),z>0&&r.stroke(),l.close&&r.closePath(),l.fill&&r.fill(),Et(a,r,l,p,v,h),r.globalCompositeOperation="source-over",r.setTransform(1,0,0,1,0,0)}function It(t,e,i,s,n,o){if(!i.shape)return;const a=t.drawers.get(i.shape);a&&a.draw(e,i,s,n,o,t.retina.pixelRatio)}function Et(t,e,i,s,n,o){if(!i.shape)return;const a=t.drawers.get(i.shape);(null==a?void 0:a.afterEffect)&&a.afterEffect(e,i,s,n,o,t.retina.pixelRatio)}function Dt(t,e,i){e.draw&&e.draw(t,i)}function At(t,e,i,s){e.drawParticle&&e.drawParticle(t,i,s)}function Ft(t,e,i){return{h:t.h,s:t.s,l:t.l+("darken"===e?-1:1)*i}}const Lt="generated",Vt="touchend",Wt="pointerdown",Bt="pointerup",Ht="pointermove",Ut="touchstart",qt="touchmove",Gt="pointerleave",jt="pointerout",$t="touchcancel",Nt="resize",Xt="visibilitychange";function Yt(t,e,i){var s;const n=e[i];void 0!==n&&(t[i]=(null!==(s=t[i])&&void 0!==s?s:1)*n)}class Jt{constructor(t){this.container=t,this.size={height:0,width:0},this._context=null,this._generated=!1,this._preDrawUpdaters=[],this._postDrawUpdaters=[],this._resizePlugins=[],this._colorPlugins=[],this._mutationObserver=R()||"undefined"==typeof MutationObserver?void 0:new MutationObserver((t=>{for(const e of t)"attributes"===e.type&&"style"===e.attributeName&&this._repairStyle()}))}get _fullScreen(){return this.container.actualOptions.fullScreen.enable}clear(){this.draw((t=>{Ot(t,this.size,this.container.actualOptions,this._trailFill,this._coverColorStyle)}))}destroy(){var t,e;null===(t=this._mutationObserver)||void 0===t||t.disconnect(),this._generated?null===(e=this.element)||void 0===e||e.remove():this._resetOriginalStyle(),this.draw((t=>{Rt(t,this.size)})),this._preDrawUpdaters=[],this._postDrawUpdaters=[],this._resizePlugins=[],this._colorPlugins=[]}draw(t){if(this._context)return t(this._context)}drawParticle(t,e){var i;if(t.spawning||t.destroyed)return;const s=t.getRadius();if(s<=0)return;const n=t.getFillColor(),o=null!==(i=t.getStrokeColor())&&void 0!==i?i:n;let[a,r]=this._getPluginParticleColors(t);a||(a=n),r||(r=o),(a||r)&&this.draw((i=>{var n,o,l,h;const c=this.container.actualOptions,d=t.options.zIndex,u=(1-t.zIndexFactor)**d.opacityRate,p=null!==(l=null!==(n=t.bubble.opacity)&&void 0!==n?n:null===(o=t.opacity)||void 0===o?void 0:o.value)&&void 0!==l?l:1,v=p*u,f=(null!==(h=t.strokeOpacity)&&void 0!==h?h:p)*u,m={},g={fill:a?gt(a,v):void 0};g.stroke=r?gt(r,f):g.fill,this._applyPreDrawUpdaters(i,t,s,v,g,m),Tt({container:this.container,context:i,particle:t,delta:e,colorStyles:g,backgroundMask:c.backgroundMask.enable,composite:c.backgroundMask.composite,radius:s*(1-t.zIndexFactor)**d.sizeRate,opacity:v,shadow:t.options.shadow,transform:m}),this._applyPostDrawUpdaters(t)}))}drawParticlePlugin(t,e,i){this.draw((s=>{At(s,t,e,i)}))}drawPlugin(t,e){this.draw((i=>{Dt(i,t,e)}))}async init(){var t;this._resize(),this._initStyle(),this._initCover();try{await this._initTrail()}catch(t){console.error(t)}this._initBackground(),this.element&&(null===(t=this._mutationObserver)||void 0===t||t.observe(this.element,{attributes:!0})),this._initUpdaters(),this._initPlugins(),this._paint(),this.container.updateActualOptions(),this._resize(),this._initBackground()}loadCanvas(t){var e,i;this._generated&&(null===(e=this.element)||void 0===e||e.remove()),this._generated=t.dataset&&Lt in t.dataset?"true"===t.dataset[Lt]:this._generated,this.element=t,this.element.ariaHidden="true",this._originalStyle=U({},this.element.style),this.size.height=t.offsetHeight,this.size.width=t.offsetWidth,this._context=Pt(t),null===(i=this._mutationObserver)||void 0===i||i.observe(this.element,{attributes:!0}),this.container.retina.init(),this._initBackground()}async windowResize(){if(!this.element)return;this._resize();const t=this.container,e=t.updateActualOptions();t.particles.setDensity(),this._applyResizePlugins(),e&&await t.refresh()}_applyPostDrawUpdaters(t){var e;for(const i of this._postDrawUpdaters)null===(e=i.afterDraw)||void 0===e||e.call(i,t)}_applyPreDrawUpdaters(t,e,i,s,n,o){var a;for(const r of this._preDrawUpdaters){if(r.getColorStyles){const{fill:o,stroke:a}=r.getColorStyles(e,t,i,s);o&&(n.fill=o),a&&(n.stroke=a)}if(r.getTransformValues){const t=r.getTransformValues(e);for(const e in t)Yt(o,t,e)}null===(a=r.beforeDraw)||void 0===a||a.call(r,e)}}_applyResizePlugins(){for(const t of this._resizePlugins)t.resize&&t.resize()}_getPluginParticleColors(t){let e,i;for(const s of this._colorPlugins)if(!e&&s.particleFillColor&&(e=ht(s.particleFillColor(t))),!i&&s.particleStrokeColor&&(i=ht(s.particleStrokeColor(t))),e&&i)break;return[e,i]}_initBackground(){const t=this.container.actualOptions.background,e=this.element,i=null==e?void 0:e.style;if(i){if(t.color){const e=at(t.color);i.backgroundColor=e?mt(e,t.opacity):""}else i.backgroundColor="";i.backgroundImage=t.image||"",i.backgroundPosition=t.position||"",i.backgroundRepeat=t.repeat||"",i.backgroundSize=t.size||""}}_initCover(){const t=this.container.actualOptions.backgroundMask.cover,e=at(t.color);if(e){const i={r:e.r,g:e.g,b:e.b,a:t.opacity};this._coverColorStyle=mt(i,i.a)}}_initPlugins(){this._resizePlugins=[];for(const[,t]of this.container.plugins)t.resize&&this._resizePlugins.push(t),(t.particleFillColor||t.particleStrokeColor)&&this._colorPlugins.push(t)}_initStyle(){const t=this.element,e=this.container.actualOptions;if(t){this._fullScreen?(this._originalStyle=U({},t.style),this._setFullScreenStyle()):this._resetOriginalStyle();for(const i in e.style){if(!i||!e.style)continue;const s=e.style[i];s&&t.style.setProperty(i,s,"important")}}}async _initTrail(){const t=this.container.actualOptions,e=t.particles.move.trail,i=e.fill;if(e.enable)if(i.color){const e=at(i.color);if(!e)return;const s=t.particles.move.trail;this._trailFill={color:Object.assign({},e),opacity:1/s.length}}else await new Promise(((t,s)=>{if(!i.image)return;const n=document.createElement("img");n.addEventListener("load",(()=>{this._trailFill={image:n,opacity:1/e.length},t()})),n.addEventListener("error",(t=>{s(t.error)})),n.src=i.image}))}_initUpdaters(){this._preDrawUpdaters=[],this._postDrawUpdaters=[];for(const t of this.container.particles.updaters)t.afterDraw&&this._postDrawUpdaters.push(t),(t.getColorStyles||t.getTransformValues||t.beforeDraw)&&this._preDrawUpdaters.push(t)}_paint(){this.draw((t=>{kt(t,this.size,this.container.actualOptions,this._coverColorStyle)}))}_repairStyle(){var t,e;const i=this.element;i&&(null===(t=this._mutationObserver)||void 0===t||t.disconnect(),this._initStyle(),this._initBackground(),null===(e=this._mutationObserver)||void 0===e||e.observe(i,{attributes:!0}))}_resetOriginalStyle(){const t=this.element,e=this._originalStyle;t&&e&&(t.style.position=e.position,t.style.zIndex=e.zIndex,t.style.top=e.top,t.style.left=e.left,t.style.width=e.width,t.style.height=e.height)}_resize(){if(!this.element)return;const t=this.container,e=t.retina.pixelRatio,i=t.canvas.size,s=this.element.offsetWidth*e,n=this.element.offsetHeight*e;if(n===i.height&&s===i.width&&n===this.element.height&&s===this.element.width)return;const o=Object.assign({},i);this.element.width=i.width=this.element.offsetWidth*e,this.element.height=i.height=this.element.offsetHeight*e,this.container.started&&(this.resizeFactor={width:i.width/o.width,height:i.height/o.height})}_setFullScreenStyle(){const t=this.element;if(!t)return;const e="important";t.style.setProperty("position","fixed",e),t.style.setProperty("z-index",this.container.actualOptions.fullScreen.zIndex.toString(10),e),t.style.setProperty("top","0",e),t.style.setProperty("left","0",e),t.style.setProperty("width","100%",e),t.style.setProperty("height","100%",e)}}function Zt(t,e,i,s,n){if(s){let s={passive:!0};"boolean"==typeof n?s.capture=n:void 0!==n&&(s=n),t.addEventListener(e,i,s)}else{const s=n;t.removeEventListener(e,i,s)}}class Qt{constructor(t){this.container=t,this.canPush=!0,this.handlers={mouseMove:t=>this.mouseTouchMove(t),touchStart:t=>this.mouseTouchMove(t),touchMove:t=>this.mouseTouchMove(t),touchEnd:()=>this.mouseTouchFinish(),mouseLeave:()=>this.mouseTouchFinish(),touchCancel:()=>this.mouseTouchFinish(),touchEndClick:t=>this.mouseTouchClick(t),mouseUp:t=>this.mouseTouchClick(t),mouseDown:()=>this.mouseDown(),visibilityChange:()=>this.handleVisibilityChange(),themeChange:t=>this.handleThemeChange(t),oldThemeChange:t=>this.handleThemeChange(t),resize:()=>this.handleWindowResize()}}addListeners(){this.manageListeners(!0)}removeListeners(){this.manageListeners(!1)}doMouseTouchClick(t){const e=this.container,i=e.actualOptions;if(this.canPush){const t=e.interactivity.mouse,s=t.position;if(!s)return;t.clickPosition=Object.assign({},s),t.clickTime=(new Date).getTime();J(i.interactivity.events.onClick.mode,(t=>this.handleClickMode(t)))}"touchend"===t.type&&setTimeout((()=>this.mouseTouchFinish()),500)}handleClickMode(t){this.container.handleClickMode(t)}handleThemeChange(t){const e=t,i=this.container,s=i.options,n=s.defaultThemes,o=e.matches?n.dark:n.light,a=s.themes.find((t=>t.name===o));a&&a.default.auto&&i.loadTheme(o)}handleVisibilityChange(){const t=this.container,e=t.actualOptions;this.mouseTouchFinish(),e.pauseOnBlur&&((null===document||void 0===document?void 0:document.hidden)?(t.pageHidden=!0,t.pause()):(t.pageHidden=!1,t.getAnimationStatus()?t.play(!0):t.draw(!0)))}handleWindowResize(){this.resizeTimeout&&(clearTimeout(this.resizeTimeout),delete this.resizeTimeout),this.resizeTimeout=setTimeout((async()=>{var t;return null===(t=this.container.canvas)||void 0===t?void 0:t.windowResize()}),1e3*this.container.actualOptions.interactivity.events.resize.delay)}manageListeners(t){var e;const i=this.handlers,s=this.container,n=s.actualOptions,o=n.interactivity.detectsOn;let a=Gt;if("window"===o)s.interactivity.element=window,a=jt;else if("parent"===o&&s.canvas.element){const t=s.canvas.element;s.interactivity.element=null!==(e=t.parentElement)&&void 0!==e?e:t.parentNode}else s.interactivity.element=s.canvas.element;const r=I("(prefers-color-scheme: dark)");r&&(void 0!==r.addEventListener?Zt(r,"change",i.themeChange,t):void 0!==r.addListener&&(t?r.addListener(i.oldThemeChange):r.removeListener(i.oldThemeChange)));const l=s.interactivity.element;if(!l)return;const h=l;(n.interactivity.events.onHover.enable||n.interactivity.events.onClick.enable)&&(Zt(l,Ht,i.mouseMove,t),Zt(l,Ut,i.touchStart,t),Zt(l,qt,i.touchMove,t),n.interactivity.events.onClick.enable?(Zt(l,Vt,i.touchEndClick,t),Zt(l,Bt,i.mouseUp,t),Zt(l,Wt,i.mouseDown,t)):Zt(l,Vt,i.touchEnd,t),Zt(l,a,i.mouseLeave,t),Zt(l,$t,i.touchCancel,t)),s.canvas.element&&(s.canvas.element.style.pointerEvents=h===s.canvas.element?"initial":"none"),n.interactivity.events.resize&&("undefined"!=typeof ResizeObserver?this.resizeObserver&&!t?(s.canvas.element&&this.resizeObserver.unobserve(s.canvas.element),this.resizeObserver.disconnect(),delete this.resizeObserver):!this.resizeObserver&&t&&s.canvas.element&&(this.resizeObserver=new ResizeObserver((t=>{t.find((t=>t.target===s.canvas.element))&&this.handleWindowResize()})),this.resizeObserver.observe(s.canvas.element)):Zt(window,Nt,i.resize,t)),document&&Zt(document,Xt,i.visibilityChange,t,!1)}mouseDown(){const t=this.container.interactivity;if(t){const e=t.mouse;e.clicking=!0,e.downPosition=e.position}}mouseTouchClick(t){const e=this.container,i=e.actualOptions,s=e.interactivity.mouse;s.inside=!0;let n=!1;const o=s.position;if(o&&i.interactivity.events.onClick.enable){for(const[,t]of e.plugins)if(t.clickPositionValid&&(n=t.clickPositionValid(o),n))break;n||this.doMouseTouchClick(t),s.clicking=!1}}mouseTouchFinish(){const t=this.container.interactivity;if(!t)return;const e=t.mouse;delete e.position,delete e.clickPosition,delete e.downPosition,t.status=Gt,e.inside=!1,e.clicking=!1}mouseTouchMove(t){var e,i,s,n,o,a,r;const l=this.container,h=l.actualOptions;if(!(null===(e=l.interactivity)||void 0===e?void 0:e.element))return;let c;l.interactivity.mouse.inside=!0;const d=l.canvas.element;if(t.type.startsWith("pointer")){this.canPush=!0;const e=t;if(l.interactivity.element===window){if(d){const t=d.getBoundingClientRect();c={x:e.clientX-t.left,y:e.clientY-t.top}}}else if("parent"===h.interactivity.detectsOn){const t=e.target,n=e.currentTarget,o=l.canvas.element;if(t&&n&&o){const i=t.getBoundingClientRect(),s=n.getBoundingClientRect(),a=o.getBoundingClientRect();c={x:e.offsetX+2*i.left-(s.left+a.left),y:e.offsetY+2*i.top-(s.top+a.top)}}else c={x:null!==(i=e.offsetX)&&void 0!==i?i:e.clientX,y:null!==(s=e.offsetY)&&void 0!==s?s:e.clientY}}else e.target===l.canvas.element&&(c={x:null!==(n=e.offsetX)&&void 0!==n?n:e.clientX,y:null!==(o=e.offsetY)&&void 0!==o?o:e.clientY})}else{this.canPush="touchmove"!==t.type;const e=t,i=e.touches[e.touches.length-1],s=null==d?void 0:d.getBoundingClientRect();c={x:i.clientX-(null!==(a=null==s?void 0:s.left)&&void 0!==a?a:0),y:i.clientY-(null!==(r=null==s?void 0:s.top)&&void 0!==r?r:0)}}const u=l.retina.pixelRatio;c&&(c.x*=u,c.y*=u),l.interactivity.mouse.position=c,l.interactivity.status=Ht}}class Kt{constructor(t){this.container=t}async nextFrame(t){var e;try{const i=this.container;if(!i.smooth&&void 0!==i.lastFrameTime&&t<i.lastFrameTime+1e3/i.fpsLimit)return void i.draw(!1);null!==(e=i.lastFrameTime)&&void 0!==e||(i.lastFrameTime=t);const s=function(t,e=60,i=!1){return{value:t,factor:i?60/e:60*t/1e3}}(t-i.lastFrameTime,i.fpsLimit,i.smooth);if(i.lifeTime+=s.value,i.lastFrameTime=t,s.value>1e3)return void i.draw(!1);if(await i.particles.draw(s),i.duration>0&&i.lifeTime>i.duration)return void i.destroy();i.getAnimationStatus()&&i.draw(!1)}catch(t){console.error("tsParticles error in animation loop",t)}}}class te{constructor(){this.value=""}static create(t,e){const i=new te;return i.load(t),void 0!==e&&("string"==typeof e||e instanceof Array?i.load({value:e}):i.load(e)),i}load(t){void 0!==(null==t?void 0:t.value)&&(this.value=t.value)}}class ee{constructor(){this.color=new te,this.color.value="",this.image="",this.position="",this.repeat="",this.size="",this.opacity=1}load(t){t&&(void 0!==t.color&&(this.color=te.create(this.color,t.color)),void 0!==t.image&&(this.image=t.image),void 0!==t.position&&(this.position=t.position),void 0!==t.repeat&&(this.repeat=t.repeat),void 0!==t.size&&(this.size=t.size),void 0!==t.opacity&&(this.opacity=t.opacity))}}class ie{constructor(){this.color=new te,this.color.value="#fff",this.opacity=1}load(t){t&&(void 0!==t.color&&(this.color=te.create(this.color,t.color)),void 0!==t.opacity&&(this.opacity=t.opacity))}}class se{constructor(){this.composite="destination-out",this.cover=new ie,this.enable=!1}load(t){if(t){if(void 0!==t.composite&&(this.composite=t.composite),void 0!==t.cover){const e=t.cover,i="string"==typeof t.cover?{color:t.cover}:t.cover;this.cover.load(void 0!==e.color?e:{color:i})}void 0!==t.enable&&(this.enable=t.enable)}}}class ne{constructor(){this.enable=!0,this.zIndex=0}load(t){t&&(void 0!==t.enable&&(this.enable=t.enable),void 0!==t.zIndex&&(this.zIndex=t.zIndex))}}class oe{constructor(){this.enable=!1,this.mode=[]}load(t){t&&(void 0!==t.enable&&(this.enable=t.enable),void 0!==t.mode&&(this.mode=t.mode))}}class ae{constructor(){this.selectors=[],this.enable=!1,this.mode=[],this.type="circle"}get el(){return this.elementId}set el(t){this.elementId=t}get elementId(){return this.ids}set elementId(t){this.ids=t}get ids(){return J(this.selectors,(t=>t.replace("#","")))}set ids(t){this.selectors=J(t,(t=>`#${t}`))}load(t){var e,i;if(!t)return;const s=null!==(i=null!==(e=t.ids)&&void 0!==e?e:t.elementId)&&void 0!==i?i:t.el;void 0!==s&&(this.ids=s),void 0!==t.selectors&&(this.selectors=t.selectors),void 0!==t.enable&&(this.enable=t.enable),void 0!==t.mode&&(this.mode=t.mode),void 0!==t.type&&(this.type=t.type)}}class re{constructor(){this.enable=!1,this.force=2,this.smooth=10}load(t){t&&(void 0!==t.enable&&(this.enable=t.enable),void 0!==t.force&&(this.force=t.force),void 0!==t.smooth&&(this.smooth=t.smooth))}}class le{constructor(){this.enable=!1,this.mode=[],this.parallax=new re}load(t){t&&(void 0!==t.enable&&(this.enable=t.enable),void 0!==t.mode&&(this.mode=t.mode),this.parallax.load(t.parallax))}}class he{constructor(){this.delay=.5,this.enable=!0}load(t){void 0!==t&&(void 0!==t.delay&&(this.delay=t.delay),void 0!==t.enable&&(this.enable=t.enable))}}class ce{constructor(){this.onClick=new oe,this.onDiv=new ae,this.onHover=new le,this.resize=new he}get onclick(){return this.onClick}set onclick(t){this.onClick=t}get ondiv(){return this.onDiv}set ondiv(t){this.onDiv=t}get onhover(){return this.onHover}set onhover(t){this.onHover=t}load(t){var e,i,s;if(!t)return;this.onClick.load(null!==(e=t.onClick)&&void 0!==e?e:t.onclick);const n=null!==(i=t.onDiv)&&void 0!==i?i:t.ondiv;void 0!==n&&(this.onDiv=J(n,(t=>{const e=new ae;return e.load(t),e}))),this.onHover.load(null!==(s=t.onHover)&&void 0!==s?s:t.onhover),"boolean"==typeof t.resize?this.resize.enable=t.resize:this.resize.load(t.resize)}}class de{constructor(t,e){this._engine=t,this._container=e}load(t){if(t&&this._container){const e=this._engine.plugins.interactors.get(this._container);if(e)for(const i of e)i.loadModeOptions&&i.loadModeOptions(this,t)}}}class ue{constructor(t,e){this.detectsOn="window",this.events=new ce,this.modes=new de(t,e)}get detect_on(){return this.detectsOn}set detect_on(t){this.detectsOn=t}load(t){var e;if(!t)return;const i=null!==(e=t.detectsOn)&&void 0!==e?e:t.detect_on;void 0!==i&&(this.detectsOn=i),this.events.load(t.events),this.modes.load(t.modes)}}class pe{load(t){var e,i;t&&(void 0!==t.position&&(this.position={x:null!==(e=t.position.x)&&void 0!==e?e:50,y:null!==(i=t.position.y)&&void 0!==i?i:50}),void 0!==t.options&&(this.options=U({},t.options)))}}class ve{constructor(){this.maxWidth=1/0,this.options={},this.mode="canvas"}load(t){t&&(void 0!==t.maxWidth&&(this.maxWidth=t.maxWidth),void 0!==t.mode&&("screen"===t.mode?this.mode="screen":this.mode="canvas"),void 0!==t.options&&(this.options=U({},t.options)))}}class fe{constructor(){this.auto=!1,this.mode="any",this.value=!1}load(t){t&&(void 0!==t.auto&&(this.auto=t.auto),void 0!==t.mode&&(this.mode=t.mode),void 0!==t.value&&(this.value=t.value))}}class me{constructor(){this.name="",this.default=new fe}load(t){t&&(void 0!==t.name&&(this.name=t.name),this.default.load(t.default),void 0!==t.options&&(this.options=U({},t.options)))}}class ge{constructor(){this.count=0,this.enable=!1,this.offset=0,this.speed=1,this.decay=0,this.sync=!0}load(t){t&&(void 0!==t.count&&(this.count=m(t.count)),void 0!==t.enable&&(this.enable=t.enable),void 0!==t.offset&&(this.offset=m(t.offset)),void 0!==t.speed&&(this.speed=m(t.speed)),void 0!==t.decay&&(this.decay=m(t.decay)),void 0!==t.sync&&(this.sync=t.sync))}}class ye{constructor(){this.h=new ge,this.s=new ge,this.l=new ge}load(t){t&&(this.h.load(t.h),this.s.load(t.s),this.l.load(t.l))}}class be extends te{constructor(){super(),this.animation=new ye}static create(t,e){const i=new be;return i.load(t),void 0!==e&&("string"==typeof e||e instanceof Array?i.load({value:e}):i.load(e)),i}load(t){if(super.load(t),!t)return;const e=t.animation;void 0!==e&&(void 0!==e.enable?this.animation.h.load(e):this.animation.load(t.animation))}}class we{constructor(){this.speed=2}load(t){t&&void 0!==t.speed&&(this.speed=t.speed)}}class _e{constructor(){this.enable=!0,this.retries=0}load(t){t&&(void 0!==t.enable&&(this.enable=t.enable),void 0!==t.retries&&(this.retries=t.retries))}}class xe{constructor(){this.count=0,this.enable=!1,this.speed=1,this.decay=0,this.sync=!1}load(t){t&&(void 0!==t.count&&(this.count=m(t.count)),void 0!==t.enable&&(this.enable=t.enable),void 0!==t.speed&&(this.speed=m(t.speed)),void 0!==t.decay&&(this.decay=m(t.decay)),void 0!==t.sync&&(this.sync=t.sync))}}class ze extends xe{constructor(){super(),this.startValue="random"}load(t){super.load(t),t&&(void 0!==t.minimumValue&&(this.minimumValue=t.minimumValue),void 0!==t.startValue&&(this.startValue=t.startValue))}}class Me{constructor(){this.enable=!1,this.minimumValue=0}load(t){t&&(void 0!==t.enable&&(this.enable=t.enable),void 0!==t.minimumValue&&(this.minimumValue=t.minimumValue))}}class Pe{constructor(){this.random=new Me,this.value=0}load(t){t&&("boolean"==typeof t.random?this.random.enable=t.random:this.random.load(t.random),void 0!==t.value&&(this.value=m(t.value,this.random.enable?this.random.minimumValue:void 0)))}}class Oe extends Pe{constructor(){super(),this.animation=new xe}get anim(){return this.animation}set anim(t){this.animation=t}load(t){var e;if(super.load(t),!t)return;const i=null!==(e=t.animation)&&void 0!==e?e:t.anim;void 0!==i&&this.animation.load(i)}}class ke extends Oe{constructor(){super(),this.animation=new ze}load(t){super.load(t),t&&void 0!==t.animation&&(this.value=m(this.value,this.animation.enable?this.animation.minimumValue:void 0))}}class Ce extends Pe{constructor(){super(),this.random.minimumValue=.1,this.value=1}}class Se{constructor(){this.horizontal=new Ce,this.vertical=new Ce}load(t){t&&(this.horizontal.load(t.horizontal),this.vertical.load(t.vertical))}}class Re{constructor(){this.absorb=new we,this.bounce=new Se,this.enable=!1,this.mode="bounce",this.overlap=new _e}load(t){t&&(this.absorb.load(t.absorb),this.bounce.load(t.bounce),void 0!==t.enable&&(this.enable=t.enable),void 0!==t.mode&&(this.mode=t.mode),this.overlap.load(t.overlap))}}class Te{constructor(){this.offset=0,this.value=90}load(t){t&&(void 0!==t.offset&&(this.offset=m(t.offset)),void 0!==t.value&&(this.value=m(t.value)))}}class Ie{constructor(){this.distance=200,this.enable=!1,this.rotate={x:3e3,y:3e3}}get rotateX(){return this.rotate.x}set rotateX(t){this.rotate.x=t}get rotateY(){return this.rotate.y}set rotateY(t){this.rotate.y=t}load(t){var e,i,s,n;if(!t)return;void 0!==t.distance&&(this.distance=m(t.distance)),void 0!==t.enable&&(this.enable=t.enable);const o=null!==(i=null===(e=t.rotate)||void 0===e?void 0:e.x)&&void 0!==i?i:t.rotateX;void 0!==o&&(this.rotate.x=o);const a=null!==(n=null===(s=t.rotate)||void 0===s?void 0:s.y)&&void 0!==n?n:t.rotateY;void 0!==a&&(this.rotate.y=a)}}class Ee{constructor(){this.x=50,this.y=50,this.mode="percent",this.radius=0}load(t){t&&(void 0!==t.x&&(this.x=t.x),void 0!==t.y&&(this.y=t.y),void 0!==t.mode&&(this.mode=t.mode),void 0!==t.radius&&(this.radius=t.radius))}}class De{constructor(){this.acceleration=9.81,this.enable=!1,this.inverse=!1,this.maxSpeed=50}load(t){t&&(void 0!==t.acceleration&&(this.acceleration=m(t.acceleration)),void 0!==t.enable&&(this.enable=t.enable),void 0!==t.inverse&&(this.inverse=t.inverse),void 0!==t.maxSpeed&&(this.maxSpeed=m(t.maxSpeed)))}}class Ae{constructor(){this.clamp=!0,this.delay=new Pe,this.enable=!1,this.options={}}load(t){t&&(void 0!==t.clamp&&(this.clamp=t.clamp),this.delay.load(t.delay),void 0!==t.enable&&(this.enable=t.enable),this.generator=t.generator,t.options&&(this.options=U(this.options,t.options)))}}class Fe{load(t){t&&(void 0!==t.color&&(this.color=te.create(this.color,t.color)),void 0!==t.image&&(this.image=t.image))}}class Le{constructor(){this.enable=!1,this.length=10,this.fill=new Fe}get fillColor(){return this.fill.color}set fillColor(t){this.fill.load({color:t})}load(t){t&&(void 0!==t.enable&&(this.enable=t.enable),void 0===t.fill&&void 0===t.fillColor||this.fill.load(t.fill||{color:t.fillColor}),void 0!==t.length&&(this.length=t.length))}}class Ve{constructor(){this.default="out"}load(t){var e,i,s,n;t&&(void 0!==t.default&&(this.default=t.default),this.bottom=null!==(e=t.bottom)&&void 0!==e?e:t.default,this.left=null!==(i=t.left)&&void 0!==i?i:t.default,this.right=null!==(s=t.right)&&void 0!==s?s:t.default,this.top=null!==(n=t.top)&&void 0!==n?n:t.default)}}class We{constructor(){this.acceleration=0,this.enable=!1}load(t){t&&(void 0!==t.acceleration&&(this.acceleration=m(t.acceleration)),void 0!==t.enable&&(this.enable=t.enable),this.position=t.position?U({},t.position):void 0)}}class Be{constructor(){this.angle=new Te,this.attract=new Ie,this.center=new Ee,this.decay=0,this.distance={},this.direction="none",this.drift=0,this.enable=!1,this.gravity=new De,this.path=new Ae,this.outModes=new Ve,this.random=!1,this.size=!1,this.speed=2,this.spin=new We,this.straight=!1,this.trail=new Le,this.vibrate=!1,this.warp=!1}get bounce(){return this.collisions}set bounce(t){this.collisions=t}get collisions(){return!1}set collisions(t){}get noise(){return this.path}set noise(t){this.path=t}get outMode(){return this.outModes.default}set outMode(t){this.outModes.default=t}get out_mode(){return this.outMode}set out_mode(t){this.outMode=t}load(t){var e,i,s;if(!t)return;this.angle.load("number"==typeof t.angle?{value:t.angle}:t.angle),this.attract.load(t.attract),this.center.load(t.center),void 0!==t.decay&&(this.decay=m(t.decay)),void 0!==t.direction&&(this.direction=t.direction),void 0!==t.distance&&(this.distance="number"==typeof t.distance?{horizontal:t.distance,vertical:t.distance}:Object.assign({},t.distance)),void 0!==t.drift&&(this.drift=m(t.drift)),void 0!==t.enable&&(this.enable=t.enable),this.gravity.load(t.gravity);const n=null!==(i=null!==(e=t.outModes)&&void 0!==e?e:t.outMode)&&void 0!==i?i:t.out_mode;void 0!==n&&("object"==typeof n?this.outModes.load(n):this.outModes.load({default:n})),this.path.load(null!==(s=t.path)&&void 0!==s?s:t.noise),void 0!==t.random&&(this.random=t.random),void 0!==t.size&&(this.size=t.size),void 0!==t.speed&&(this.speed=m(t.speed)),this.spin.load(t.spin),void 0!==t.straight&&(this.straight=t.straight),this.trail.load(t.trail),void 0!==t.vibrate&&(this.vibrate=t.vibrate),void 0!==t.warp&&(this.warp=t.warp)}}class He extends ze{constructor(){super(),this.destroy="none",this.speed=2}get opacity_min(){return this.minimumValue}set opacity_min(t){this.minimumValue=t}load(t){void 0!==(null==t?void 0:t.opacity_min)&&void 0===t.minimumValue&&(t.minimumValue=t.opacity_min),super.load(t),t&&void 0!==t.destroy&&(this.destroy=t.destroy)}}class Ue extends ke{constructor(){super(),this.animation=new He,this.random.minimumValue=.1,this.value=1}get anim(){return this.animation}set anim(t){this.animation=t}}class qe{constructor(){this.enable=!1,this.width=1920,this.height=1080}get area(){return this.width}set area(t){this.width=t}get factor(){return this.height}set factor(t){this.height=t}get value_area(){return this.area}set value_area(t){this.area=t}load(t){var e,i,s;if(!t)return;void 0!==t.enable&&(this.enable=t.enable);const n=null!==(i=null!==(e=t.width)&&void 0!==e?e:t.area)&&void 0!==i?i:t.value_area;void 0!==n&&(this.width=n);const o=null!==(s=t.height)&&void 0!==s?s:t.factor;void 0!==o&&(this.height=o)}}class Ge{constructor(){this.density=new qe,this.limit=0,this.value=100}get max(){return this.limit}set max(t){this.limit=t}load(t){var e;if(!t)return;this.density.load(t.density);const i=null!==(e=t.limit)&&void 0!==e?e:t.max;void 0!==i&&(this.limit=i),void 0!==t.value&&(this.value=t.value)}}class je{constructor(){this.blur=0,this.color=new te,this.enable=!1,this.offset={x:0,y:0},this.color.value="#000"}load(t){t&&(void 0!==t.blur&&(this.blur=t.blur),this.color=te.create(this.color,t.color),void 0!==t.enable&&(this.enable=t.enable),void 0!==t.offset&&(void 0!==t.offset.x&&(this.offset.x=t.offset.x),void 0!==t.offset.y&&(this.offset.y=t.offset.y)))}}class $e{constructor(){this.options={},this.type="circle"}load(t){var e;if(!t)return;const i=t.options;if(void 0!==i)for(const t in i){const s=i[t];s&&(this.options[t]=U(null!==(e=this.options[t])&&void 0!==e?e:{},s))}void 0!==t.type&&(this.type=t.type)}}class Ne extends ze{constructor(){super(),this.destroy="none",this.speed=5}get size_min(){return this.minimumValue}set size_min(t){this.minimumValue=t}load(t){void 0!==(null==t?void 0:t.size_min)&&void 0===t.minimumValue&&(t.minimumValue=t.size_min),super.load(t),t&&void 0!==t.destroy&&(this.destroy=t.destroy)}}class Xe extends ke{constructor(){super(),this.animation=new Ne,this.random.minimumValue=1,this.value=3}get anim(){return this.animation}set anim(t){this.animation=t}}class Ye{constructor(){this.width=0}load(t){t&&(void 0!==t.color&&(this.color=be.create(this.color,t.color)),void 0!==t.width&&(this.width=m(t.width)),void 0!==t.opacity&&(this.opacity=m(t.opacity)))}}class Je extends Pe{constructor(){super(),this.opacityRate=1,this.sizeRate=1,this.velocityRate=1}load(t){super.load(t),t&&(void 0!==t.opacityRate&&(this.opacityRate=t.opacityRate),void 0!==t.sizeRate&&(this.sizeRate=t.sizeRate),void 0!==t.velocityRate&&(this.velocityRate=t.velocityRate))}}class Ze{constructor(t,e){this._engine=t,this._container=e,this.bounce=new Se,this.collisions=new Re,this.color=new be,this.color.value="#fff",this.groups={},this.move=new Be,this.number=new Ge,this.opacity=new Ue,this.reduceDuplicates=!1,this.shadow=new je,this.shape=new $e,this.size=new Xe,this.stroke=new Ye,this.zIndex=new Je}load(t){var e,i,s,n;if(!t)return;if(this.bounce.load(t.bounce),this.color.load(be.create(this.color,t.color)),void 0!==t.groups)for(const i in t.groups){const s=t.groups[i];void 0!==s&&(this.groups[i]=U(null!==(e=this.groups[i])&&void 0!==e?e:{},s))}this.move.load(t.move),this.number.load(t.number),this.opacity.load(t.opacity),void 0!==t.reduceDuplicates&&(this.reduceDuplicates=t.reduceDuplicates),this.shape.load(t.shape),this.size.load(t.size),this.shadow.load(t.shadow),this.zIndex.load(t.zIndex);const o=null!==(s=null===(i=t.move)||void 0===i?void 0:i.collisions)&&void 0!==s?s:null===(n=t.move)||void 0===n?void 0:n.bounce;void 0!==o&&(this.collisions.enable=o),this.collisions.load(t.collisions),void 0!==t.interactivity&&(this.interactivity=U({},t.interactivity));const a=t.stroke;if(a&&(this.stroke=J(a,(t=>{const e=new Ye;return e.load(t),e}))),this._container){const e=this._engine.plugins.updaters.get(this._container);if(e)for(const i of e)i.loadOptions&&i.loadOptions(this,t);const i=this._engine.plugins.interactors.get(this._container);if(i)for(const e of i)e.loadParticlesOptions&&e.loadParticlesOptions(this,t)}}}function Qe(t,...e){for(const i of e)t.load(i)}function Ke(t,e,...i){const s=new Ze(t,e);return Qe(s,...i),s}class ti{constructor(t,e){this._engine=t,this._container=e,this.autoPlay=!0,this.background=new ee,this.backgroundMask=new se,this.defaultThemes={},this.delay=0,this.fullScreen=new ne,this.detectRetina=!0,this.duration=0,this.fpsLimit=120,this.interactivity=new ue(t,e),this.manualParticles=[],this.name="default",this.particles=Ke(this._engine,this._container),this.pauseOnBlur=!0,this.pauseOnOutsideViewport=!0,this.responsive=[],this.smooth=!1,this.style={},this.themes=[],this.zLayers=100}get backgroundMode(){return this.fullScreen}set backgroundMode(t){this.fullScreen.load(t)}get fps_limit(){return this.fpsLimit}set fps_limit(t){this.fpsLimit=t}get retina_detect(){return this.detectRetina}set retina_detect(t){this.detectRetina=t}load(t){var e,i,s,n,o;if(!t)return;void 0!==t.preset&&J(t.preset,(t=>this._importPreset(t))),void 0!==t.autoPlay&&(this.autoPlay=t.autoPlay),void 0!==t.delay&&(this.delay=m(t.delay));const a=null!==(e=t.detectRetina)&&void 0!==e?e:t.retina_detect;void 0!==a&&(this.detectRetina=a),void 0!==t.duration&&(this.duration=m(t.duration));const r=null!==(i=t.fpsLimit)&&void 0!==i?i:t.fps_limit;void 0!==r&&(this.fpsLimit=r),void 0!==t.pauseOnBlur&&(this.pauseOnBlur=t.pauseOnBlur),void 0!==t.pauseOnOutsideViewport&&(this.pauseOnOutsideViewport=t.pauseOnOutsideViewport),void 0!==t.zLayers&&(this.zLayers=t.zLayers),this.background.load(t.background);const l=null!==(s=t.fullScreen)&&void 0!==s?s:t.backgroundMode;"boolean"==typeof l?this.fullScreen.enable=l:this.fullScreen.load(l),this.backgroundMask.load(t.backgroundMask),this.interactivity.load(t.interactivity),void 0!==t.manualParticles&&(this.manualParticles=t.manualParticles.map((t=>{const e=new pe;return e.load(t),e}))),this.particles.load(t.particles),this.style=U(this.style,t.style),this._engine.plugins.loadOptions(this,t),void 0!==t.smooth&&(this.smooth=t.smooth);const h=this._engine.plugins.interactors.get(this._container);if(h)for(const e of h)e.loadOptions&&e.loadOptions(this,t);if(void 0!==t.responsive)for(const e of t.responsive){const t=new ve;t.load(e),this.responsive.push(t)}if(this.responsive.sort(((t,e)=>t.maxWidth-e.maxWidth)),void 0!==t.themes)for(const e of t.themes){const t=this.themes.find((t=>t.name===e.name));if(t)t.load(e);else{const t=new me;t.load(e),this.themes.push(t)}}this.defaultThemes.dark=null===(n=this._findDefaultTheme("dark"))||void 0===n?void 0:n.name,this.defaultThemes.light=null===(o=this._findDefaultTheme("light"))||void 0===o?void 0:o.name}setResponsive(t,e,i){this.load(i);const s=this.responsive.find((i=>"screen"===i.mode&&screen?i.maxWidth>screen.availWidth:i.maxWidth*e>t));return this.load(null==s?void 0:s.options),null==s?void 0:s.maxWidth}setTheme(t){if(t){const e=this.themes.find((e=>e.name===t));e&&this.load(e.options)}else{const t=I("(prefers-color-scheme: dark)"),e=t&&t.matches,i=this._findDefaultTheme(e?"dark":"light");i&&this.load(i.options)}}_findDefaultTheme(t){var e;return null!==(e=this.themes.find((e=>e.default.value&&e.default.mode===t)))&&void 0!==e?e:this.themes.find((t=>t.default.value&&"any"===t.default.mode))}_importPreset(t){this.load(this._engine.plugins.getPreset(t))}}class ei{constructor(t,e){this.container=e,this._engine=t,this._interactors=this._engine.plugins.getInteractors(this.container,!0),this._externalInteractors=[],this._particleInteractors=[]}async externalInteract(t){for(const e of this._externalInteractors)e.isEnabled()&&await e.interact(t)}handleClickMode(t){for(const e of this._externalInteractors)e.handleClickMode&&e.handleClickMode(t)}init(){this._externalInteractors=[],this._particleInteractors=[];for(const t of this._interactors){switch(t.type){case"external":this._externalInteractors.push(t);break;case"particles":this._particleInteractors.push(t)}t.init()}}async particlesInteract(t,e){for(const i of this._externalInteractors)i.clear(t,e);for(const i of this._particleInteractors)i.isEnabled(t)&&await i.interact(t,e)}async reset(t){for(const e of this._externalInteractors)e.isEnabled()&&await e.reset(t);for(const e of this._particleInteractors)e.isEnabled(t)&&await e.reset(t)}}const ii=t=>{A(t.outMode,t.checkModes)&&(t.coord>t.maxCoord-2*t.radius?t.setCb(-t.radius):t.coord<2*t.radius&&t.setCb(t.radius))};class si{constructor(t,e,i,s,n,o){this.container=i,this._engine=t,this.init(e,s,n,o)}destroy(t){var e;if(!this.unbreakable&&!this.destroyed){this.destroyed=!0,this.bubble.inRange=!1,this.slow.inRange=!1;for(const[,e]of this.container.plugins)e.particleDestroyed&&e.particleDestroyed(this,t);for(const e of this.container.particles.updaters)e.particleDestroyed&&e.particleDestroyed(this,t);null===(e=this.pathGenerator)||void 0===e||e.reset(this)}}draw(t){const e=this.container;for(const[,i]of e.plugins)e.canvas.drawParticlePlugin(i,this,t);e.canvas.drawParticle(this,t)}getFillColor(){var t;return this._getRollColor(null!==(t=this.bubble.color)&&void 0!==t?t:_t(this.color))}getMass(){return this.getRadius()**2*Math.PI/2}getPosition(){return{x:this.position.x+this.offset.x,y:this.position.y+this.offset.y,z:this.position.z}}getRadius(){var t;return null!==(t=this.bubble.radius)&&void 0!==t?t:this.size.value}getStrokeColor(){var t;return this._getRollColor(null!==(t=this.bubble.color)&&void 0!==t?t:_t(this.strokeColor))}init(t,e,i,s){var n,o,a,r,l,h,c;const d=this.container,u=this._engine;this.id=t,this.group=s,this.fill=!0,this.pathRotation=!1,this.close=!0,this.lastPathTime=0,this.destroyed=!1,this.unbreakable=!1,this.rotation=0,this.misplaced=!1,this.retina={maxDistance:{}},this.outType="normal",this.ignoresResizeRatio=!0;const v=d.retina.pixelRatio,f=d.actualOptions,m=Ke(this._engine,d,f.particles),y=m.shape.type,{reduceDuplicates:b}=m;this.shape=Z(y,this.id,b);const w=m.shape;if(i&&i.shape&&i.shape.type){const t=Z(i.shape.type,this.id,b);t&&(this.shape=t,w.load(i.shape))}this.shapeData=this._loadShapeData(w,b),m.load(i),m.load(null===(n=this.shapeData)||void 0===n?void 0:n.particles),this.interactivity=new ue(u,d),this.interactivity.load(d.actualOptions.interactivity),this.interactivity.load(m.interactivity),this.fill=null!==(a=null===(o=this.shapeData)||void 0===o?void 0:o.fill)&&void 0!==a?a:this.fill,this.close=null!==(l=null===(r=this.shapeData)||void 0===r?void 0:r.close)&&void 0!==l?l:this.close,this.options=m;const _=this.options.move.path;this.pathDelay=1e3*g(_.delay),_.generator&&(this.pathGenerator=this._engine.plugins.getPathGenerator(_.generator),this.pathGenerator&&d.addPath(_.generator,this.pathGenerator)&&this.pathGenerator.init(d)),d.retina.initParticle(this),this.size=K(this.options.size,v),this.bubble={inRange:!1},this.slow={inRange:!1,factor:1},this._initPosition(e),this.initialVelocity=this._calculateVelocity(),this.velocity=this.initialVelocity.copy(),this.moveDecay=1-p(this.options.move.decay);const x=d.particles;x.needsSort=x.needsSort||x.lastZIndex<this.position.z,x.lastZIndex=this.position.z,this.zIndexFactor=this.position.z/d.zLayers,this.sides=24;let z=d.drawers.get(this.shape);z||(z=this._engine.plugins.getShapeDrawer(this.shape),z&&d.drawers.set(this.shape,z)),(null==z?void 0:z.loadShape)&&(null==z||z.loadShape(this));const M=null==z?void 0:z.getSidesCount;M&&(this.sides=M(this)),this.spawning=!1,this.shadowColor=at(this.options.shadow.color);for(const t of d.particles.updaters)t.init(this);for(const t of d.particles.movers)null===(h=t.init)||void 0===h||h.call(t,this);(null==z?void 0:z.particleInit)&&z.particleInit(d,this);for(const[,t]of d.plugins)null===(c=t.particleCreated)||void 0===c||c.call(t,this)}isInsideCanvas(){const t=this.getRadius(),e=this.container.canvas.size;return this.position.x>=-t&&this.position.y>=-t&&this.position.y<=e.height+t&&this.position.x<=e.width+t}isVisible(){return!this.destroyed&&!this.spawning&&this.isInsideCanvas()}reset(){var t;for(const e of this.container.particles.updaters)null===(t=e.reset)||void 0===t||t.call(e,this)}_calcPosition(t,e,s,n=0){var o,a,r,l;for(const[,n]of t.plugins){const t=void 0!==n.particlePosition?n.particlePosition(e,this):void 0;if(void 0!==t)return i.create(t.x,t.y,s)}const h=O({size:t.canvas.size,position:e}),c=i.create(h.x,h.y,s),d=this.getRadius(),u=this.options.move.outModes,p=e=>{ii({outMode:e,checkModes:["bounce","bounce-horizontal"],coord:c.x,maxCoord:t.canvas.size.width,setCb:t=>c.x+=t,radius:d})},v=e=>{ii({outMode:e,checkModes:["bounce","bounce-vertical"],coord:c.y,maxCoord:t.canvas.size.height,setCb:t=>c.y+=t,radius:d})};return p(null!==(o=u.left)&&void 0!==o?o:u.default),p(null!==(a=u.right)&&void 0!==a?a:u.default),v(null!==(r=u.top)&&void 0!==r?r:u.default),v(null!==(l=u.bottom)&&void 0!==l?l:u.default),this._checkOverlap(c,n)?this._calcPosition(t,void 0,s,n+1):c}_calculateVelocity(){const t=_(this.direction).copy(),e=this.options.move;if("inside"===e.direction||"outside"===e.direction)return t;const i=Math.PI/180*p(e.angle.value),s=Math.PI/180*p(e.angle.offset),n={left:s-i/2,right:s+i/2};return e.straight||(t.angle+=u(m(n.left,n.right))),e.random&&"number"==typeof e.speed&&(t.length*=h()),t}_checkOverlap(t,e=0){const i=this.options.collisions,s=this.getRadius();if(!i.enable)return!1;const n=i.overlap;if(n.enable)return!1;const o=n.retries;if(o>=0&&e>o)throw new Error("Particle is overlapping and can't be placed");let a=!1;for(const e of this.container.particles.array)if(b(t,e.position)<s+e.getRadius()){a=!0;break}return a}_getRollColor(t){var e;if(!t||!this.roll||!this.backColor&&!this.roll.alter)return t;const i=this.roll.horizontal&&this.roll.vertical?2:1,s=this.roll.horizontal?Math.PI/2:0;return Math.floor(((null!==(e=this.roll.angle)&&void 0!==e?e:0)+s)/(Math.PI/i))%2?this.backColor?this.backColor:this.roll.alter?Ft(t,this.roll.alter.type,this.roll.alter.value):t:t}_initPosition(t){var e,i;const n=this.container,o=p(this.options.zIndex.value);this.position=this._calcPosition(n,t,c(o,0,n.zLayers)),this.initialPosition=this.position.copy();const a=n.canvas.size,r=Object.assign({},this.options.move.center),l="percent"===r.mode;switch(this.moveCenter={x:r.x*(l?a.width/100:1),y:r.y*(l?a.height/100:1),radius:null!==(e=this.options.move.center.radius)&&void 0!==e?e:0,mode:null!==(i=this.options.move.center.mode)&&void 0!==i?i:"percent"},this.direction=w(this.options.move.direction,this.position,this.moveCenter),this.options.move.direction){case"inside":this.outType="inside";break;case"outside":this.outType="outside"}this.offset=s.origin}_loadShapeData(t,e){const i=t.options[this.shape];if(i)return U({},Z(i,this.id,e))}}class ni{constructor(t,e){this.position=t,this.particle=e}}class oi{constructor(t,e){this.position={x:t,y:e}}}class ai extends oi{constructor(t,e,i){super(t,e),this.radius=i}contains(t){return b(t,this.position)<=this.radius}intersects(t){const e=t,i=t,s=this.position,n=t.position,o=Math.abs(n.x-s.x),a=Math.abs(n.y-s.y),r=this.radius;if(void 0!==i.radius){return r+i.radius>Math.sqrt(o**2+a**2)}if(void 0!==e.size){const t=e.size.width,i=e.size.height;return Math.pow(o-t,2)+Math.pow(a-i,2)<=r**2||o<=r+t&&a<=r+i||o<=t||a<=i}return!1}}class ri extends oi{constructor(t,e,i,s){super(t,e),this.size={height:s,width:i}}contains(t){const e=this.size.width,i=this.size.height,s=this.position;return t.x>=s.x&&t.x<=s.x+e&&t.y>=s.y&&t.y<=s.y+i}intersects(t){t instanceof ai&&t.intersects(this);const e=this.size.width,i=this.size.height,s=this.position,n=t.position,o=t instanceof ri?t.size:{width:0,height:0},a=o.width,r=o.height;return n.x<s.x+e&&n.x+a>s.x&&n.y<s.y+i&&n.y+r>s.y}}class li{constructor(t,e){this.rectangle=t,this.capacity=e,this._points=[],this._divided=!1}insert(t){var e,i,s,n,o;return!!this.rectangle.contains(t.position)&&(this._points.length<this.capacity?(this._points.push(t),!0):(this._divided||this.subdivide(),null!==(o=(null===(e=this._NE)||void 0===e?void 0:e.insert(t))||(null===(i=this._NW)||void 0===i?void 0:i.insert(t))||(null===(s=this._SE)||void 0===s?void 0:s.insert(t))||(null===(n=this._SW)||void 0===n?void 0:n.insert(t)))&&void 0!==o&&o))}query(t,e,i){var s,n,o,a;const r=null!=i?i:[];if(!t.intersects(this.rectangle))return[];for(const i of this._points)!t.contains(i.position)&&b(t.position,i.position)>i.particle.getRadius()&&(!e||e(i.particle))||r.push(i.particle);return this._divided&&(null===(s=this._NE)||void 0===s||s.query(t,e,r),null===(n=this._NW)||void 0===n||n.query(t,e,r),null===(o=this._SE)||void 0===o||o.query(t,e,r),null===(a=this._SW)||void 0===a||a.query(t,e,r)),r}queryCircle(t,e,i){return this.query(new ai(t.x,t.y,e),i)}queryRectangle(t,e,i){return this.query(new ri(t.x,t.y,e.width,e.height),i)}subdivide(){const t=this.rectangle.position.x,e=this.rectangle.position.y,i=this.rectangle.size.width,s=this.rectangle.size.height,n=this.capacity;this._NE=new li(new ri(t,e,i/2,s/2),n),this._NW=new li(new ri(t+i/2,e,i/2,s/2),n),this._SE=new li(new ri(t,e+s/2,i/2,s/2),n),this._SW=new li(new ri(t+i/2,e+s/2,i/2,s/2),n),this._divided=!0}}class hi{constructor(t,e){this.container=e,this._engine=t,this.nextId=0,this.array=[],this.zArray=[],this.pool=[],this.limit=0,this.needsSort=!1,this.lastZIndex=0,this.interactionManager=new ei(this._engine,e);const i=this.container.canvas.size;this.quadTree=new li(new ri(-i.width/4,-i.height/4,3*i.width/2,3*i.height/2),4),this.movers=this._engine.plugins.getMovers(e,!0),this.updaters=this._engine.plugins.getUpdaters(e,!0)}get count(){return this.array.length}addManualParticles(){const t=this.container,e=t.actualOptions;for(const i of e.manualParticles)this.addParticle(z({size:t.canvas.size,position:i.position}),i.options)}addParticle(t,e,i,s){const n=this.container.actualOptions.particles.number.limit;if(n>0){const t=this.count+1-n;t>0&&this.removeQuantity(t)}return this._pushParticle(t,e,i,s)}clear(){this.array=[],this.zArray=[]}destroy(){this.array=[],this.zArray=[],this.movers=[],this.updaters=[]}async draw(t){const e=this.container,i=this.container.canvas.size;this.quadTree=new li(new ri(-i.width/4,-i.height/4,3*i.width/2,3*i.height/2),4),e.canvas.clear(),await this.update(t),this.needsSort&&(this.zArray.sort(((t,e)=>e.position.z-t.position.z||t.id-e.id)),this.lastZIndex=this.zArray[this.zArray.length-1].position.z,this.needsSort=!1);for(const[,i]of e.plugins)e.canvas.drawPlugin(i,t);for(const e of this.zArray)e.draw(t)}handleClickMode(t){this.interactionManager.handleClickMode(t)}init(){var t;const e=this.container,i=e.actualOptions;this.lastZIndex=0,this.needsSort=!1;let s=!1;this.updaters=this._engine.plugins.getUpdaters(e,!0),this.interactionManager.init();for(const[,t]of e.plugins)if(void 0!==t.particlesInitialization&&(s=t.particlesInitialization()),s)break;this.interactionManager.init();for(const[,t]of e.pathGenerators)t.init(e);if(this.addManualParticles(),!s){for(const e in i.particles.groups){const s=i.particles.groups[e];for(let n=this.count,o=0;o<(null===(t=s.number)||void 0===t?void 0:t.value)&&n<i.particles.number.value;n++,o++)this.addParticle(void 0,s,e)}for(let t=this.count;t<i.particles.number.value;t++)this.addParticle()}}push(t,e,i,s){this.pushing=!0;for(let n=0;n<t;n++)this.addParticle(null==e?void 0:e.position,i,s);this.pushing=!1}async redraw(){this.clear(),this.init(),await this.draw({value:0,factor:0})}remove(t,e,i){this.removeAt(this.array.indexOf(t),void 0,e,i)}removeAt(t,e=1,i,s){if(t<0||t>this.count)return;let n=0;for(let o=t;n<e&&o<this.count;o++){const t=this.array[o];if(!t||t.group!==i)continue;t.destroy(s),this.array.splice(o--,1);const e=this.zArray.indexOf(t);this.zArray.splice(e,1),this.pool.push(t),n++,this._engine.dispatchEvent("particleRemoved",{container:this.container,data:{particle:t}})}}removeQuantity(t,e){this.removeAt(0,t,e)}setDensity(){const t=this.container.actualOptions;for(const e in t.particles.groups)this._applyDensity(t.particles.groups[e],0,e);this._applyDensity(t.particles,t.manualParticles.length)}async update(t){var e,i;const s=this.container,n=[];for(const[,t]of s.pathGenerators)t.update();for(const[,i]of s.plugins)null===(e=i.update)||void 0===e||e.call(i,t);for(const e of this.array){const o=s.canvas.resizeFactor;o&&!e.ignoresResizeRatio&&(e.position.x*=o.width,e.position.y*=o.height,e.initialPosition.x*=o.width,e.initialPosition.y*=o.height),e.ignoresResizeRatio=!1,await this.interactionManager.reset(e);for(const[,s]of this.container.plugins){if(e.destroyed)break;null===(i=s.particleUpdate)||void 0===i||i.call(s,e,t)}for(const i of this.movers)i.isEnabled(e)&&i.move(e,t);e.destroyed?n.push(e):this.quadTree.insert(new ni(e.getPosition(),e))}for(const t of n)this.remove(t);await this.interactionManager.externalInteract(t);for(const e of this.array){for(const i of this.updaters)i.update(e,t);e.destroyed||e.spawning||await this.interactionManager.particlesInteract(e,t)}delete s.canvas.resizeFactor}_applyDensity(t,e,i){var s;if(!(null===(s=t.number.density)||void 0===s?void 0:s.enable))return;const n=t.number,o=this._initDensityFactor(n.density),a=n.value,r=n.limit>0?n.limit:a,l=Math.min(a,r)*o+e,h=Math.min(this.count,this.array.filter((t=>t.group===i)).length);this.limit=n.limit*o,h<l?this.push(Math.abs(l-h),void 0,t,i):h>l&&this.removeQuantity(h-l,i)}_initDensityFactor(t){const e=this.container;if(!e.canvas.element||!t.enable)return 1;const i=e.canvas.element,s=e.retina.pixelRatio;return i.width*i.height/(t.factor*s**2*t.area)}_pushParticle(t,e,i,s){try{let n=this.pool.pop();n?n.init(this.nextId,t,e,i):n=new si(this._engine,this.nextId,this.container,t,e,i);let o=!0;if(s&&(o=s(n)),!o)return;return this.array.push(n),this.zArray.push(n),this.nextId++,this._engine.dispatchEvent("particleAdded",{container:this.container,data:{particle:n}}),n}catch(t){return void console.warn(`error adding particle: ${t}`)}}}class ci{constructor(t){this.container=t}init(){const t=this.container,e=t.actualOptions;this.pixelRatio=!e.detectRetina||R()?1:window.devicePixelRatio,this.reduceFactor=1;const i=this.pixelRatio;if(t.canvas.element){const e=t.canvas.element;t.canvas.size.width=e.offsetWidth*i,t.canvas.size.height=e.offsetHeight*i}const s=e.particles;this.attractDistance=p(s.move.attract.distance)*i,this.sizeAnimationSpeed=p(s.size.animation.speed)*i,this.maxSpeed=p(s.move.gravity.maxSpeed)*i}initParticle(t){const e=t.options,i=this.pixelRatio,s=e.move.distance,n=t.retina;n.attractDistance=p(e.move.attract.distance)*i,n.moveDrift=p(e.move.drift)*i,n.moveSpeed=p(e.move.speed)*i,n.sizeAnimationSpeed=p(e.size.animation.speed)*i;const o=n.maxDistance;o.horizontal=void 0!==s.horizontal?s.horizontal*i:void 0,o.vertical=void 0!==s.vertical?s.vertical*i:void 0,n.maxSpeed=p(e.move.gravity.maxSpeed)*i}}function di(t){return t&&!t.destroyed}function ui(t,e,...i){const s=new ti(t,e);return Qe(s,...i),s}const pi={generate:t=>{const e=t.velocity.copy();return e.angle+=e.length*Math.PI/180,e},init:()=>{},update:()=>{},reset:()=>{}};class vi{constructor(t,e,i){this.id=e,this._engine=t,this.fpsLimit=120,this.smooth=!1,this._delay=0,this.duration=0,this.lifeTime=0,this._firstStart=!0,this.started=!1,this.destroyed=!1,this._paused=!0,this.lastFrameTime=0,this.zLayers=100,this.pageHidden=!1,this._sourceOptions=i,this._initialSourceOptions=i,this.retina=new ci(this),this.canvas=new Jt(this),this.particles=new hi(this._engine,this),this.frameManager=new Kt(this),this.pathGenerators=new Map,this.interactivity={mouse:{clicking:!1,inside:!1}},this.plugins=new Map,this.drawers=new Map,this._options=ui(this._engine,this),this.actualOptions=ui(this._engine,this),this._eventListeners=new Qt(this),"undefined"!=typeof IntersectionObserver&&IntersectionObserver&&(this._intersectionObserver=new IntersectionObserver((t=>this._intersectionManager(t)))),this._engine.dispatchEvent("containerBuilt",{container:this})}get options(){return this._options}get sourceOptions(){return this._sourceOptions}addClickHandler(t){if(!di(this))return;const e=this.interactivity.element;if(!e)return;const i=(e,i,s)=>{if(!di(this))return;const n=this.retina.pixelRatio,o={x:i.x*n,y:i.y*n},a=this.particles.quadTree.queryCircle(o,s*n);t(e,a)};let s=!1,n=!1;e.addEventListener("click",(t=>{if(!di(this))return;const e=t,s={x:e.offsetX||e.clientX,y:e.offsetY||e.clientY};i(t,s,1)})),e.addEventListener("touchstart",(()=>{di(this)&&(s=!0,n=!1)})),e.addEventListener("touchmove",(()=>{di(this)&&(n=!0)})),e.addEventListener("touchend",(t=>{if(di(this)){if(s&&!n){const e=t;let s=e.touches[e.touches.length-1];if(!s&&(s=e.changedTouches[e.changedTouches.length-1],!s))return;const n=this.canvas.element,o=n?n.getBoundingClientRect():void 0,a={x:s.clientX-(o?o.left:0),y:s.clientY-(o?o.top:0)};i(t,a,Math.max(s.radiusX,s.radiusY))}s=!1,n=!1}})),e.addEventListener("touchcancel",(()=>{di(this)&&(s=!1,n=!1)}))}addPath(t,e,i=!1){return!(!di(this)||!i&&this.pathGenerators.has(t))&&(this.pathGenerators.set(t,null!=e?e:pi),!0)}destroy(){if(!di(this))return;this.stop(),this.particles.destroy(),this.canvas.destroy();for(const[,t]of this.drawers)t.destroy&&t.destroy(this);for(const t of this.drawers.keys())this.drawers.delete(t);this._engine.plugins.destroy(this),this.destroyed=!0;const t=this._engine.dom(),e=t.findIndex((t=>t===this));e>=0&&t.splice(e,1),this._engine.dispatchEvent("containerDestroyed",{container:this})}draw(t){if(!di(this))return;let e=t;this._drawAnimationFrame=E()((async t=>{e&&(this.lastFrameTime=void 0,e=!1),await this.frameManager.nextFrame(t)}))}exportConfiguration(){return JSON.stringify(this.actualOptions,((t,e)=>{if("_engine"!==t&&"_container"!==t)return e}),2)}exportImage(t,e,i){const s=this.canvas.element;s&&s.toBlob(t,null!=e?e:"image/png",i)}exportImg(t){this.exportImage(t)}getAnimationStatus(){return!this._paused&&!this.pageHidden&&di(this)}handleClickMode(t){if(di(this)){this.particles.handleClickMode(t);for(const[,e]of this.plugins)e.handleClickMode&&e.handleClickMode(t)}}async init(){if(!di(this))return;const t=this._engine.plugins.getSupportedShapes();for(const e of t){const t=this._engine.plugins.getShapeDrawer(e);t&&this.drawers.set(e,t)}this._options=ui(this._engine,this,this._initialSourceOptions,this.sourceOptions),this.actualOptions=ui(this._engine,this,this._options);const e=this._engine.plugins.getAvailablePlugins(this);for(const[t,i]of e)this.plugins.set(t,i);this.retina.init(),await this.canvas.init(),this.zLayers=this.actualOptions.zLayers,this.duration=1e3*p(this.actualOptions.duration),this._delay=1e3*p(this.actualOptions.delay),this.lifeTime=0,this.fpsLimit=this.actualOptions.fpsLimit>0?this.actualOptions.fpsLimit:120,this.smooth=this.actualOptions.smooth;for(const[,t]of this.drawers)t.init&&await t.init(this);for(const[,t]of this.plugins)t.init&&await t.init();this._engine.dispatchEvent("containerInit",{container:this}),this.particles.init(),this.particles.setDensity();for(const[,t]of this.plugins)t.particlesSetup&&t.particlesSetup();this._engine.dispatchEvent("particlesSetup",{container:this})}async loadTheme(t){di(this)&&(this._currentTheme=t,await this.refresh())}pause(){if(di(this)&&(void 0!==this._drawAnimationFrame&&(D()(this._drawAnimationFrame),delete this._drawAnimationFrame),!this._paused)){for(const[,t]of this.plugins)t.pause&&t.pause();this.pageHidden||(this._paused=!0),this._engine.dispatchEvent("containerPaused",{container:this})}}play(t){if(!di(this))return;const e=this._paused||t;if(!this._firstStart||this.actualOptions.autoPlay){if(this._paused&&(this._paused=!1),e)for(const[,t]of this.plugins)t.play&&t.play();this._engine.dispatchEvent("containerPlay",{container:this}),this.draw(e||!1)}else this._firstStart=!1}async refresh(){if(di(this))return this.stop(),this.start()}async reset(){if(di(this))return this._options=ui(this._engine,this),this.refresh()}setNoise(t,e,i){di(this)&&this.setPath(t,e,i)}setPath(t,e,i){if(!t||!di(this))return;const s=Object.assign({},pi);if("function"==typeof t)s.generate=t,e&&(s.init=e),i&&(s.update=i);else{const e=s;s.generate=t.generate||e.generate,s.init=t.init||e.init,s.update=t.update||e.update}this.addPath("default",s,!0)}async start(){di(this)&&!this.started&&(await this.init(),this.started=!0,await new Promise((t=>{this._delayTimeout=setTimeout((async()=>{this._eventListeners.addListeners(),this.interactivity.element instanceof HTMLElement&&this._intersectionObserver&&this._intersectionObserver.observe(this.interactivity.element);for(const[,t]of this.plugins)t.start&&await t.start();this._engine.dispatchEvent("containerStarted",{container:this}),this.play(),t()}),this._delay)})))}stop(){if(di(this)&&this.started){this._delayTimeout&&(clearTimeout(this._delayTimeout),delete this._delayTimeout),this._firstStart=!0,this.started=!1,this._eventListeners.removeListeners(),this.pause(),this.particles.clear(),this.canvas.clear(),this.interactivity.element instanceof HTMLElement&&this._intersectionObserver&&this._intersectionObserver.unobserve(this.interactivity.element);for(const[,t]of this.plugins)t.stop&&t.stop();for(const t of this.plugins.keys())this.plugins.delete(t);this._sourceOptions=this._options,this._engine.dispatchEvent("containerStopped",{container:this})}}updateActualOptions(){this.actualOptions.responsive=[];const t=this.actualOptions.setResponsive(this.canvas.size.width,this.retina.pixelRatio,this._options);return this.actualOptions.setTheme(this._currentTheme),this.responsiveMaxWidth!==t&&(this.responsiveMaxWidth=t,!0)}_intersectionManager(t){if(di(this)&&this.actualOptions.pauseOnOutsideViewport)for(const e of t)e.target===this.interactivity.element&&(e.isIntersecting?this.play:this.pause)()}}class fi{constructor(){this._listeners=new Map}addEventListener(t,e){var i;this.removeEventListener(t,e),this._listeners.get(t)||this._listeners.set(t,[]),null===(i=this._listeners.get(t))||void 0===i||i.push(e)}dispatchEvent(t,e){var i;null===(i=this._listeners.get(t))||void 0===i||i.forEach((t=>t(e)))}hasEventListener(t){return!!this._listeners.get(t)}removeAllEventListeners(t){t?this._listeners.delete(t):this._listeners=new Map}removeEventListener(t,e){const i=this._listeners.get(t);if(!i)return;const s=i.length,n=i.indexOf(e);n<0||(1===s?this._listeners.delete(t):i.splice(n,1))}}function mi(t,e,i,s=!1){let n=e.get(t);return n&&!s||(n=[...i.values()].map((e=>e(t))),e.set(t,n)),n}class gi{constructor(t){this._engine=t,this.plugins=[],this._initializers={interactors:new Map,movers:new Map,updaters:new Map},this.interactors=new Map,this.movers=new Map,this.updaters=new Map,this.presets=new Map,this.drawers=new Map,this.pathGenerators=new Map}addInteractor(t,e){this._initializers.interactors.set(t,e)}addParticleMover(t,e){this._initializers.movers.set(t,e)}addParticleUpdater(t,e){this._initializers.updaters.set(t,e)}addPathGenerator(t,e){this.getPathGenerator(t)||this.pathGenerators.set(t,e)}addPlugin(t){this.getPlugin(t.id)||this.plugins.push(t)}addPreset(t,e,i=!1){!i&&this.getPreset(t)||this.presets.set(t,e)}addShapeDrawer(t,e){J(t,(t=>{this.getShapeDrawer(t)||this.drawers.set(t,e)}))}destroy(t){this.updaters.delete(t),this.movers.delete(t),this.interactors.delete(t)}getAvailablePlugins(t){const e=new Map;for(const i of this.plugins)i.needsPlugin(t.actualOptions)&&e.set(i.id,i.getPlugin(t));return e}getInteractors(t,e=!1){return mi(t,this.interactors,this._initializers.interactors,e)}getMovers(t,e=!1){return mi(t,this.movers,this._initializers.movers,e)}getPathGenerator(t){return this.pathGenerators.get(t)}getPlugin(t){return this.plugins.find((e=>e.id===t))}getPreset(t){return this.presets.get(t)}getShapeDrawer(t){return this.drawers.get(t)}getSupportedShapes(){return this.drawers.keys()}getUpdaters(t,e=!1){return mi(t,this.updaters,this._initializers.updaters,e)}loadOptions(t,e){for(const i of this.plugins)i.loadOptions(t,e)}loadParticlesOptions(t,e,...i){const s=this.updaters.get(t);if(s)for(const t of s)t.loadOptions&&t.loadOptions(e,...i)}}class yi{constructor(){this.key="hsl",this.stringPrefix="hsl"}handleColor(t){var e;const i=null!==(e=t.value.hsl)&&void 0!==e?e:t.value;if(void 0!==i.h&&void 0!==i.s&&void 0!==i.l)return pt(i)}handleRangeColor(t){var e;const i=null!==(e=t.value.hsl)&&void 0!==e?e:t.value;if(void 0!==i.h&&void 0!==i.l)return pt({h:p(i.h),l:p(i.l),s:p(i.s)})}parseString(t){if(!t.startsWith("hsl"))return;const e=/hsla?\(\s*(\d+)\s*,\s*(\d+)%\s*,\s*(\d+)%\s*(,\s*([\d.%]+)\s*)?\)/i.exec(t);return e?vt({a:e.length>4?C(e[5]):1,h:parseInt(e[1],10),l:parseInt(e[3],10),s:parseInt(e[2],10)}):void 0}}class bi{constructor(){this.key="rgb",this.stringPrefix="rgb"}handleColor(t){var e;const i=null!==(e=t.value.rgb)&&void 0!==e?e:t.value;if(void 0!==i.r)return i}handleRangeColor(t){var e;const i=null!==(e=t.value.rgb)&&void 0!==e?e:t.value;if(void 0!==i.r)return{r:p(i.r),g:p(i.g),b:p(i.b)}}parseString(t){if(!t.startsWith(this.stringPrefix))return;const e=/rgba?\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*(,\s*([\d.%]+)\s*)?\)/i.exec(t);return e?{a:e.length>4?C(e[5]):1,b:parseInt(e[3],10),g:parseInt(e[2],10),r:parseInt(e[1],10)}:void 0}}class wi{constructor(t){this.container=t,this.type="external"}}class _i{constructor(t){this.container=t,this.type="particles"}}const xi=new bi,zi=new yi;st(xi),st(zi);const Mi=new class{constructor(){this._configs=new Map,this._domArray=[],this._eventDispatcher=new fi,this.plugins=new gi(this)}get configs(){const t={};for(const[e,i]of this._configs)t[e]=i;return t}addConfig(t,e){var i;"string"==typeof t?e&&(e.name=t,this._configs.set(t,e)):this._configs.set(null!==(i=t.name)&&void 0!==i?i:"default",t)}addEventListener(t,e){this._eventDispatcher.addEventListener(t,e)}async addInteractor(t,e){this.plugins.addInteractor(t,e),await this.refresh()}async addMover(t,e){this.plugins.addParticleMover(t,e),await this.refresh()}async addParticleUpdater(t,e){this.plugins.addParticleUpdater(t,e),await this.refresh()}async addPathGenerator(t,e){this.plugins.addPathGenerator(t,e),await this.refresh()}async addPlugin(t){this.plugins.addPlugin(t),await this.refresh()}async addPreset(t,e,i=!1){this.plugins.addPreset(t,e,i),await this.refresh()}async addShape(t,e,i,s,n){let o;o="function"==typeof e?{afterEffect:s,destroy:n,draw:e,init:i}:e,this.plugins.addShapeDrawer(t,o),await this.refresh()}dispatchEvent(t,e){this._eventDispatcher.dispatchEvent(t,e)}dom(){return this._domArray}domItem(t){const e=this.dom(),i=e[t];if(i&&!i.destroyed)return i;e.splice(t,1)}async load(t){var e,i,s;const n=null!==(e=t.id)&&void 0!==e?e:`tsparticles${Math.floor(1e4*h())}`,{index:o,url:a}=t,r=a?await async function(t){const e=Z(t.url,t.index);if(!e)return t.fallback;const i=await fetch(e);return i.ok?i.json():(console.error(`tsParticles - Error ${i.status} while retrieving config file`),t.fallback)}({fallback:t.options,index:o,url:a}):t.options;let l=null!==(i=t.element)&&void 0!==i?i:document.getElementById(n);l||(l=document.createElement("div"),l.id=n,null===(s=document.querySelector("body"))||void 0===s||s.append(l));const c=Z(r,o),d=this.dom(),u=d.findIndex((t=>t.id===n));if(u>=0){const t=this.domItem(u);t&&!t.destroyed&&(t.destroy(),d.splice(u,1))}let p;if("canvas"===l.tagName.toLowerCase())p=l,p.dataset[Lt]="false";else{const t=l.getElementsByTagName("canvas");t.length?(p=t[0],p.dataset[Lt]="false"):(p=document.createElement("canvas"),p.dataset[Lt]="true",l.appendChild(p))}p.style.width||(p.style.width="100%"),p.style.height||(p.style.height="100%");const v=new vi(this,n,c);return u>=0?d.splice(u,0,v):d.push(v),v.canvas.loadCanvas(p),await v.start(),v}async refresh(){for(const t of this.dom())await t.refresh()}removeEventListener(t,e){this._eventDispatcher.removeEventListener(t,e)}setOnClickHandler(t){const e=this.dom();if(!e.length)throw new Error("Can only set click handlers after calling tsParticles.load()");for(const i of e)i.addClickHandler(t)}},{particlesJS:Pi,pJSDom:Oi}=(t=>{const e=(e,i)=>t.load({id:e,options:i});e.load=(e,i,s)=>{t.load({id:e,url:i}).then((t=>{t&&s(t)})).catch((()=>{s(void 0)}))},e.setOnClickHandler=e=>{t.setOnClickHandler(e)};return{particlesJS:e,pJSDom:t.dom()}})(Mi);return e})()));
|
2
|
+
!function(t,e){if("object"==typeof exports&&"object"==typeof module)module.exports=e();else if("function"==typeof define&&define.amd)define([],e);else{var i=e();for(var s in i)("object"==typeof exports?exports:t)[s]=i[s]}}(this,(()=>(()=>{"use strict";var t={d:(e,i)=>{for(var s in i)t.o(i,s)&&!t.o(e,s)&&Object.defineProperty(e,s,{enumerable:!0,get:i[s]})},o:(t,e)=>Object.prototype.hasOwnProperty.call(t,e),r:t=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})}},e={};t.r(e),t.d(e,{AnimatableColor:()=>be,AnimationOptions:()=>xe,AnimationValueWithRandom:()=>Oe,Background:()=>ee,BackgroundMask:()=>se,BackgroundMaskCover:()=>ie,Circle:()=>ai,ClickEvent:()=>oe,Collisions:()=>Re,CollisionsAbsorb:()=>we,CollisionsOverlap:()=>_e,ColorAnimation:()=>ge,DivEvent:()=>ae,Events:()=>ce,ExternalInteractorBase:()=>wi,FullScreen:()=>ne,HoverEvent:()=>le,HslAnimation:()=>ye,HslColorManager:()=>yi,Interactivity:()=>ue,ManualParticle:()=>pe,Modes:()=>de,Move:()=>Be,MoveAngle:()=>Te,MoveAttract:()=>Ie,MoveCenter:()=>Ee,MoveGravity:()=>De,MovePath:()=>Ae,MoveTrail:()=>Le,MoveTrailFill:()=>Fe,Opacity:()=>Ue,OpacityAnimation:()=>He,Options:()=>ti,OptionsColor:()=>te,OutModes:()=>Ve,Parallax:()=>re,ParticlesBounce:()=>Se,ParticlesBounceFactor:()=>Ce,ParticlesDensity:()=>qe,ParticlesInteractorBase:()=>_i,ParticlesNumber:()=>Ge,ParticlesOptions:()=>Ze,Point:()=>ni,Range:()=>oi,RangedAnimationOptions:()=>ze,RangedAnimationValueWithRandom:()=>ke,Rectangle:()=>ri,ResizeEvent:()=>he,Responsive:()=>ve,RgbColorManager:()=>bi,Shadow:()=>je,Shape:()=>$e,Size:()=>Xe,SizeAnimation:()=>Ne,Spin:()=>We,Stroke:()=>Ye,Theme:()=>me,ThemeDefault:()=>fe,ValueWithRandom:()=>Pe,Vector:()=>s,Vector3d:()=>i,ZIndex:()=>Je,addColorManager:()=>st,addEasing:()=>a,alterHsl:()=>Ft,animate:()=>E,areBoundsInside:()=>B,arrayRandomIndex:()=>L,calcExactPositionOrRandomFromSize:()=>O,calcExactPositionOrRandomFromSizeRanged:()=>k,calcPositionFromSize:()=>z,calcPositionOrRandomFromSize:()=>M,calcPositionOrRandomFromSizeRanged:()=>P,calculateBounds:()=>H,cancelAnimation:()=>D,circleBounce:()=>X,circleBounceDataFromParticle:()=>N,clamp:()=>c,clear:()=>Rt,clearCanvas:()=>Ot,collisionVelocity:()=>x,colorMix:()=>yt,colorToHsl:()=>lt,colorToRgb:()=>rt,deepExtend:()=>U,divMode:()=>$,divModeExecute:()=>G,drawLine:()=>Ct,drawParticle:()=>Tt,drawParticlePlugin:()=>At,drawPlugin:()=>Dt,drawShape:()=>It,drawShapeAfterEffect:()=>Et,drawTriangle:()=>St,executeOnSingleOrMultiple:()=>J,findItemFromSingleOrMultiple:()=>Q,generatedAttribute:()=>Lt,getContext:()=>Pt,getDistance:()=>b,getDistances:()=>y,getEasing:()=>r,getHslAnimationFromHsl:()=>xt,getHslFromAnimation:()=>_t,getLinkColor:()=>bt,getLinkRandomColor:()=>wt,getParticleBaseVelocity:()=>_,getParticleDirectionAngle:()=>w,getRandom:()=>h,getRandomRgbColor:()=>ft,getRangeMax:()=>f,getRangeMin:()=>v,getRangeValue:()=>p,getStyleFromHsl:()=>gt,getStyleFromRgb:()=>mt,getValue:()=>g,hasMatchMedia:()=>T,hslToRgb:()=>pt,hslaToRgba:()=>vt,initParticleNumericAnimationValue:()=>K,isDivModeEnabled:()=>q,isInArray:()=>A,isPointInside:()=>W,isSsr:()=>R,itemFromArray:()=>V,itemFromSingleOrMultiple:()=>Z,loadFont:()=>F,loadOptions:()=>Qe,loadParticlesOptions:()=>Ke,mix:()=>d,mouseDownEvent:()=>Wt,mouseLeaveEvent:()=>Gt,mouseMoveEvent:()=>Ht,mouseOutEvent:()=>jt,mouseUpEvent:()=>Bt,pJSDom:()=>Oi,paintCanvas:()=>kt,parseAlpha:()=>C,particlesJS:()=>Pi,randomInRange:()=>u,rangeColorToHsl:()=>ht,rangeColorToRgb:()=>at,rectBounce:()=>Y,resizeEvent:()=>Nt,rgbToHsl:()=>ct,safeMatchMedia:()=>I,setRandom:()=>l,setRangeValue:()=>m,singleDivModeExecute:()=>j,stringToAlpha:()=>dt,stringToRgb:()=>ut,touchCancelEvent:()=>$t,touchEndEvent:()=>Vt,touchMoveEvent:()=>qt,touchStartEvent:()=>Ut,tsParticles:()=>Mi,visibilityChangeEvent:()=>Xt});class i{constructor(t,e,i){if("number"!=typeof t&&t){this.x=t.x,this.y=t.y;const e=t;this.z=e.z?e.z:0}else{if(void 0===t||void 0===e)throw new Error("tsParticles - Vector3d not initialized correctly");this.x=t,this.y=e,this.z=null!=i?i:0}}static get origin(){return i.create(0,0,0)}get angle(){return Math.atan2(this.y,this.x)}set angle(t){this.updateFromAngle(t,this.length)}get length(){return Math.sqrt(this.getLengthSq())}set length(t){this.updateFromAngle(this.angle,t)}static clone(t){return i.create(t.x,t.y,t.z)}static create(t,e,s){return new i(t,e,s)}add(t){return i.create(this.x+t.x,this.y+t.y,this.z+t.z)}addTo(t){this.x+=t.x,this.y+=t.y,this.z+=t.z}copy(){return i.clone(this)}distanceTo(t){return this.sub(t).length}distanceToSq(t){return this.sub(t).getLengthSq()}div(t){return i.create(this.x/t,this.y/t,this.z/t)}divTo(t){this.x/=t,this.y/=t,this.z/=t}getLengthSq(){return this.x**2+this.y**2}mult(t){return i.create(this.x*t,this.y*t,this.z*t)}multTo(t){this.x*=t,this.y*=t,this.z*=t}rotate(t){return i.create(this.x*Math.cos(t)-this.y*Math.sin(t),this.x*Math.sin(t)+this.y*Math.cos(t),0)}setTo(t){this.x=t.x,this.y=t.y;const e=t;this.z=e.z?e.z:0}sub(t){return i.create(this.x-t.x,this.y-t.y,this.z-t.z)}subFrom(t){this.x-=t.x,this.y-=t.y,this.z-=t.z}updateFromAngle(t,e){this.x=Math.cos(t)*e,this.y=Math.sin(t)*e}}class s extends i{constructor(t,e){super(t,e,0)}static get origin(){return s.create(0,0)}static clone(t){return s.create(t.x,t.y)}static create(t,e){return new s(t,e)}}let n=Math.random;const o=new Map;function a(t,e){o.get(t)||o.set(t,e)}function r(t){return o.get(t)||(t=>t)}function l(t=Math.random){n=t}function h(){return c(n(),0,1-1e-16)}function c(t,e,i){return Math.min(Math.max(t,e),i)}function d(t,e,i,s){return Math.floor((t*i+e*s)/(i+s))}function u(t){const e=f(t);let i=v(t);return e===i&&(i=0),h()*(e-i)+i}function p(t){return"number"==typeof t?t:u(t)}function v(t){return"number"==typeof t?t:t.min}function f(t){return"number"==typeof t?t:t.max}function m(t,e){if(t===e||void 0===e&&"number"==typeof t)return t;const i=v(t),s=f(t);return void 0!==e?{min:Math.min(i,e),max:Math.max(s,e)}:m(i,s)}function g(t){const e=t.random,{enable:i,minimumValue:s}="boolean"==typeof e?{enable:e,minimumValue:0}:e;return p(i?m(t.value,s):t.value)}function y(t,e){const i=t.x-e.x,s=t.y-e.y;return{dx:i,dy:s,distance:Math.sqrt(i**2+s**2)}}function b(t,e){return y(t,e).distance}function w(t,e,i){if("number"==typeof t)return t*Math.PI/180;switch(t){case"top":return-Math.PI/2;case"top-right":return-Math.PI/4;case"right":return 0;case"bottom-right":return Math.PI/4;case"bottom":return Math.PI/2;case"bottom-left":return 3*Math.PI/4;case"left":return Math.PI;case"top-left":return-3*Math.PI/4;case"inside":return Math.atan2(i.y-e.y,i.x-e.x);case"outside":return Math.atan2(e.y-i.y,e.x-i.x);default:return h()*Math.PI*2}}function _(t){const e=s.origin;return e.length=1,e.angle=t,e}function x(t,e,i,n){return s.create(t.x*(i-n)/(i+n)+2*e.x*n/(i+n),t.y)}function z(t){return t.position&&void 0!==t.position.x&&void 0!==t.position.y?{x:t.position.x*t.size.width/100,y:t.position.y*t.size.height/100}:void 0}function M(t){var e,i,s,n;return{x:(null!==(i=null===(e=t.position)||void 0===e?void 0:e.x)&&void 0!==i?i:100*h())*t.size.width/100,y:(null!==(n=null===(s=t.position)||void 0===s?void 0:s.y)&&void 0!==n?n:100*h())*t.size.height/100}}function P(t){var e,i;const s={x:void 0!==(null===(e=t.position)||void 0===e?void 0:e.x)?p(t.position.x):void 0,y:void 0!==(null===(i=t.position)||void 0===i?void 0:i.y)?p(t.position.y):void 0};return M({size:t.size,position:s})}function O(t){var e,i,s,n;return{x:null!==(i=null===(e=t.position)||void 0===e?void 0:e.x)&&void 0!==i?i:h()*t.size.width,y:null!==(n=null===(s=t.position)||void 0===s?void 0:s.y)&&void 0!==n?n:h()*t.size.height}}function k(t){var e,i;const s={x:void 0!==(null===(e=t.position)||void 0===e?void 0:e.x)?p(t.position.x):void 0,y:void 0!==(null===(i=t.position)||void 0===i?void 0:i.y)?p(t.position.y):void 0};return O({size:t.size,position:s})}function C(t){return t?t.endsWith("%")?parseFloat(t)/100:parseFloat(t):1}function S(t,e,i,s,n,o){const a={bounced:!1};return e.min<s.min||e.min>s.max||e.max<s.min||e.max>s.max||(t.max>=i.min&&t.max<=(i.max+i.min)/2&&n>0||t.min<=i.max&&t.min>(i.max+i.min)/2&&n<0)&&(a.velocity=n*-o,a.bounced=!0),a}function R(){return"undefined"==typeof window||!window||void 0===window.document||!window.document}function T(){return!R()&&"undefined"!=typeof matchMedia}function I(t){if(T())return matchMedia(t)}function E(){return R()?t=>setTimeout(t):t=>(requestAnimationFrame||setTimeout)(t)}function D(){return R()?t=>clearTimeout(t):t=>(cancelAnimationFrame||clearTimeout)(t)}function A(t,e){return t===e||e instanceof Array&&e.indexOf(t)>-1}async function F(t,e){try{await document.fonts.load(`${null!=e?e:"400"} 36px '${null!=t?t:"Verdana"}'`)}catch(t){}}function L(t){return Math.floor(h()*t.length)}function V(t,e,i=!0){return t[void 0!==e&&i?e%t.length:L(t)]}function W(t,e,i,s,n){return B(H(t,null!=s?s:0),e,i,n)}function B(t,e,i,s){let n=!0;return s&&"bottom"!==s||(n=t.top<e.height+i.x),!n||s&&"left"!==s||(n=t.right>i.x),!n||s&&"right"!==s||(n=t.left<e.width+i.y),!n||s&&"top"!==s||(n=t.bottom>i.y),n}function H(t,e){return{bottom:t.y+e,left:t.x-e,right:t.x+e,top:t.y-e}}function U(t,...e){for(const i of e){if(null==i)continue;if("object"!=typeof i){t=i;continue}const e=Array.isArray(i);!e||"object"==typeof t&&t&&Array.isArray(t)?e||"object"==typeof t&&t&&!Array.isArray(t)||(t={}):t=[];for(const e in i){if("__proto__"===e)continue;const s=i[e],n="object"==typeof s,o=t;o[e]=n&&Array.isArray(s)?s.map((t=>U(o[e],t))):U(o[e],s)}}return t}function q(t,e){return!!Q(e,(e=>e.enable&&A(t,e.mode)))}function G(t,e,i){J(e,(e=>{const s=e.mode;e.enable&&A(t,s)&&j(e,i)}))}function j(t,e){J(t.selectors,(i=>{e(i,t)}))}function $(t,e){if(e&&t)return Q(t,(t=>function(t,e){const i=J(e,(e=>t.matches(e)));return i instanceof Array?i.some((t=>t)):i}(e,t.selectors)))}function N(t){return{position:t.getPosition(),radius:t.getRadius(),mass:t.getMass(),velocity:t.velocity,factor:s.create(g(t.options.bounce.horizontal),g(t.options.bounce.vertical))}}function X(t,e){const{x:i,y:s}=t.velocity.sub(e.velocity),[n,o]=[t.position,e.position],{dx:a,dy:r}=y(o,n);if(i*a+s*r<0)return;const l=-Math.atan2(r,a),h=t.mass,c=e.mass,d=t.velocity.rotate(l),u=e.velocity.rotate(l),p=x(d,u,h,c),v=x(u,d,h,c),f=p.rotate(-l),m=v.rotate(-l);t.velocity.x=f.x*t.factor.x,t.velocity.y=f.y*t.factor.y,e.velocity.x=m.x*e.factor.x,e.velocity.y=m.y*e.factor.y}function Y(t,e){const i=H(t.getPosition(),t.getRadius()),s=S({min:i.left,max:i.right},{min:i.top,max:i.bottom},{min:e.left,max:e.right},{min:e.top,max:e.bottom},t.velocity.x,g(t.options.bounce.horizontal));s.bounced&&(void 0!==s.velocity&&(t.velocity.x=s.velocity),void 0!==s.position&&(t.position.x=s.position));const n=S({min:i.top,max:i.bottom},{min:i.left,max:i.right},{min:e.top,max:e.bottom},{min:e.left,max:e.right},t.velocity.y,g(t.options.bounce.vertical));n.bounced&&(void 0!==n.velocity&&(t.velocity.y=n.velocity),void 0!==n.position&&(t.position.y=n.position))}function J(t,e){return t instanceof Array?t.map(((t,i)=>e(t,i))):e(t,0)}function Z(t,e,i){return t instanceof Array?V(t,e,i):t}function Q(t,e){return t instanceof Array?t.find(((t,i)=>e(t,i))):e(t,0)?t:void 0}function K(t,e){const i=t.value,s=t.animation,n={enable:t.animation.enable,value:p(t.value)*e,max:f(i)*e,min:v(i)*e,loops:0,maxLoops:p(t.animation.count)};if(s.enable){n.decay=1-p(s.decay);let t=!1;switch(s.mode){case"increase":n.status="increasing";break;case"decrease":n.status="decreasing";break;case"random":n.status=h()>=.5?"increasing":"decreasing";break;case"auto":t=!0}switch(s.startValue){case"min":n.value=n.min,t&&(n.status="increasing");break;case"random":n.value=u(n),t&&(n.status=h()>=.5?"increasing":"decreasing");break;default:n.value=n.max,t&&(n.status="decreasing")}}return n.initialValue=n.value,n}const tt="random",et="mid",it=new Map;function st(t){it.set(t.key,t)}function nt(t,e,i){return i<0&&(i+=1),i>1&&(i-=1),i<1/6?t+6*(e-t)*i:i<.5?e:i<2/3?t+(e-t)*(2/3-i)*6:t}function ot(t){for(const[,e]of it)if(t.startsWith(e.stringPrefix))return e.parseString(t);const e=t.replace(/^#?([a-f\d])([a-f\d])([a-f\d])([a-f\d])?$/i,((t,e,i,s,n)=>e+e+i+i+s+s+(void 0!==n?n+n:""))),i=/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})?$/i.exec(e);return i?{a:void 0!==i[4]?parseInt(i[4],16)/255:1,b:parseInt(i[3],16),g:parseInt(i[2],16),r:parseInt(i[1],16)}:void 0}function at(t,e,i=!0){if(!t)return;const s="string"==typeof t?{value:t}:t;if("string"==typeof s.value)return rt(s.value,e,i);if(s.value instanceof Array)return at({value:V(s.value,e,i)});for(const[,t]of it){const e=t.handleRangeColor(s);if(e)return e}}function rt(t,e,i=!0){if(!t)return;const s="string"==typeof t?{value:t}:t;if("string"==typeof s.value)return s.value===tt?ft():ut(s.value);if(s.value instanceof Array)return rt({value:V(s.value,e,i)});for(const[,t]of it){const e=t.handleColor(s);if(e)return e}}function lt(t,e,i=!0){const s=rt(t,e,i);return s?ct(s):void 0}function ht(t,e,i=!0){const s=at(t,e,i);return s?ct(s):void 0}function ct(t){const e=t.r/255,i=t.g/255,s=t.b/255,n=Math.max(e,i,s),o=Math.min(e,i,s),a={h:0,l:(n+o)/2,s:0};return n!==o&&(a.s=a.l<.5?(n-o)/(n+o):(n-o)/(2-n-o),a.h=e===n?(i-s)/(n-o):a.h=i===n?2+(s-e)/(n-o):4+(e-i)/(n-o)),a.l*=100,a.s*=100,a.h*=60,a.h<0&&(a.h+=360),a.h>=360&&(a.h-=360),a}function dt(t){var e;return null===(e=ot(t))||void 0===e?void 0:e.a}function ut(t){return ot(t)}function pt(t){const e={b:0,g:0,r:0},i={h:t.h/360,l:t.l/100,s:t.s/100};if(i.s){const t=i.l<.5?i.l*(1+i.s):i.l+i.s-i.l*i.s,s=2*i.l-t;e.r=nt(s,t,i.h+1/3),e.g=nt(s,t,i.h),e.b=nt(s,t,i.h-1/3)}else e.b=i.l,e.g=i.l,e.r=i.l;return e.r=Math.floor(255*e.r),e.g=Math.floor(255*e.g),e.b=Math.floor(255*e.b),e}function vt(t){const e=pt(t);return{a:t.a,b:e.b,g:e.g,r:e.r}}function ft(t){const e=null!=t?t:0;return{b:Math.floor(u(m(e,256))),g:Math.floor(u(m(e,256))),r:Math.floor(u(m(e,256)))}}function mt(t,e){return`rgba(${t.r}, ${t.g}, ${t.b}, ${null!=e?e:1})`}function gt(t,e){return`hsla(${t.h}, ${t.s}%, ${t.l}%, ${null!=e?e:1})`}function yt(t,e,i,s){let n=t,o=e;return void 0===n.r&&(n=pt(t)),void 0===o.r&&(o=pt(e)),{b:d(n.b,o.b,i,s),g:d(n.g,o.g,i,s),r:d(n.r,o.r,i,s)}}function bt(t,e,i){var s,n;if(i===tt)return ft();if(i!==et)return i;{const i=null!==(s=t.getFillColor())&&void 0!==s?s:t.getStrokeColor(),o=null!==(n=null==e?void 0:e.getFillColor())&&void 0!==n?n:null==e?void 0:e.getStrokeColor();if(i&&o&&e)return yt(i,o,t.getRadius(),e.getRadius());{const t=null!=i?i:o;if(t)return pt(t)}}}function wt(t,e,i){const s="string"==typeof t?t:t.value;return s===tt?i?at({value:s}):e?tt:et:s===et?et:at({value:s})}function _t(t){return void 0!==t?{h:t.h.value,s:t.s.value,l:t.l.value}:void 0}function xt(t,e,i){const s={h:{enable:!1,value:t.h},s:{enable:!1,value:t.s},l:{enable:!1,value:t.l}};return e&&(zt(s.h,e.h,i),zt(s.s,e.s,i),zt(s.l,e.l,i)),s}function zt(t,e,i){t.enable=e.enable,t.enable?(t.velocity=p(e.speed)/100*i,t.decay=1-p(e.decay),t.status="increasing",t.loops=0,t.maxLoops=p(e.count),e.sync||(t.velocity*=h(),t.value*=h()),t.initialValue=t.value):t.velocity=0}function Mt(t,e,i){t.fillStyle=null!=i?i:"rgba(0,0,0,0)",t.fillRect(0,0,e.width,e.height)}function Pt(t){const e=t.getContext("2d");if(!e)throw new Error("Error tsParticles - No canvas context found");return e}function Ot(t,e,i,s,n){if(i.backgroundMask.enable)kt(t,e,i,n);else{const n=i.particles.move.trail;n.enable&&n.length>0&&s?s.color?Mt(t,e,mt(s.color,s.opacity)):s.image&&function(t,e,i,s){i&&(t.globalAlpha=s,t.drawImage(i,0,0,e.width,e.height),t.globalAlpha=1)}(t,e,s.image,s.opacity):Rt(t,e)}}function kt(t,e,i,s){i.backgroundMask.enable&&s?(Rt(t,e),Mt(t,e,s)):Mt(t,e)}function Ct(t,e,i){t.beginPath(),t.moveTo(e.x,e.y),t.lineTo(i.x,i.y),t.closePath()}function St(t,e,i,s){t.beginPath(),t.moveTo(e.x,e.y),t.lineTo(i.x,i.y),t.lineTo(s.x,s.y),t.closePath()}function Rt(t,e){t.clearRect(0,0,e.width,e.height)}function Tt(t){var e,i,s,n,o;const{container:a,context:r,particle:l,delta:h,colorStyles:c,backgroundMask:d,composite:u,radius:p,opacity:v,shadow:f,transform:m}=t,g=l.getPosition(),y=l.rotation+(l.pathRotation?l.velocity.angle:0),b=Math.sin(y),w=Math.cos(y),_={a:w*(null!==(e=m.a)&&void 0!==e?e:1),b:b*(null!==(i=m.b)&&void 0!==i?i:1),c:-b*(null!==(s=m.c)&&void 0!==s?s:1),d:w*(null!==(n=m.d)&&void 0!==n?n:1)};r.setTransform(_.a,_.b,_.c,_.d,g.x,g.y),r.beginPath(),d&&(r.globalCompositeOperation=u);const x=l.shadowColor;f.enable&&x&&(r.shadowBlur=f.blur,r.shadowColor=mt(x),r.shadowOffsetX=f.offset.x,r.shadowOffsetY=f.offset.y),c.fill&&(r.fillStyle=c.fill);const z=null!==(o=l.strokeWidth)&&void 0!==o?o:0;r.lineWidth=z,c.stroke&&(r.strokeStyle=c.stroke),It(a,r,l,p,v,h),z>0&&r.stroke(),l.close&&r.closePath(),l.fill&&r.fill(),Et(a,r,l,p,v,h),r.globalCompositeOperation="source-over",r.setTransform(1,0,0,1,0,0)}function It(t,e,i,s,n,o){if(!i.shape)return;const a=t.drawers.get(i.shape);a&&a.draw(e,i,s,n,o,t.retina.pixelRatio)}function Et(t,e,i,s,n,o){if(!i.shape)return;const a=t.drawers.get(i.shape);(null==a?void 0:a.afterEffect)&&a.afterEffect(e,i,s,n,o,t.retina.pixelRatio)}function Dt(t,e,i){e.draw&&e.draw(t,i)}function At(t,e,i,s){e.drawParticle&&e.drawParticle(t,i,s)}function Ft(t,e,i){return{h:t.h,s:t.s,l:t.l+("darken"===e?-1:1)*i}}const Lt="generated",Vt="touchend",Wt="pointerdown",Bt="pointerup",Ht="pointermove",Ut="touchstart",qt="touchmove",Gt="pointerleave",jt="pointerout",$t="touchcancel",Nt="resize",Xt="visibilitychange";function Yt(t,e,i){var s;const n=e[i];void 0!==n&&(t[i]=(null!==(s=t[i])&&void 0!==s?s:1)*n)}class Jt{constructor(t){this.container=t,this.size={height:0,width:0},this._context=null,this._generated=!1,this._preDrawUpdaters=[],this._postDrawUpdaters=[],this._resizePlugins=[],this._colorPlugins=[],this._mutationObserver=R()||"undefined"==typeof MutationObserver?void 0:new MutationObserver((t=>{for(const e of t)"attributes"===e.type&&"style"===e.attributeName&&this._repairStyle()}))}get _fullScreen(){return this.container.actualOptions.fullScreen.enable}clear(){this.draw((t=>{Ot(t,this.size,this.container.actualOptions,this._trailFill,this._coverColorStyle)}))}destroy(){var t,e;null===(t=this._mutationObserver)||void 0===t||t.disconnect(),this._generated?null===(e=this.element)||void 0===e||e.remove():this._resetOriginalStyle(),this.draw((t=>{Rt(t,this.size)})),this._preDrawUpdaters=[],this._postDrawUpdaters=[],this._resizePlugins=[],this._colorPlugins=[]}draw(t){if(this._context)return t(this._context)}drawParticle(t,e){var i;if(t.spawning||t.destroyed)return;const s=t.getRadius();if(s<=0)return;const n=t.getFillColor(),o=null!==(i=t.getStrokeColor())&&void 0!==i?i:n;let[a,r]=this._getPluginParticleColors(t);a||(a=n),r||(r=o),(a||r)&&this.draw((i=>{var n,o,l,h;const c=this.container.actualOptions,d=t.options.zIndex,u=(1-t.zIndexFactor)**d.opacityRate,p=null!==(l=null!==(n=t.bubble.opacity)&&void 0!==n?n:null===(o=t.opacity)||void 0===o?void 0:o.value)&&void 0!==l?l:1,v=p*u,f=(null!==(h=t.strokeOpacity)&&void 0!==h?h:p)*u,m={},g={fill:a?gt(a,v):void 0};g.stroke=r?gt(r,f):g.fill,this._applyPreDrawUpdaters(i,t,s,v,g,m),Tt({container:this.container,context:i,particle:t,delta:e,colorStyles:g,backgroundMask:c.backgroundMask.enable,composite:c.backgroundMask.composite,radius:s*(1-t.zIndexFactor)**d.sizeRate,opacity:v,shadow:t.options.shadow,transform:m}),this._applyPostDrawUpdaters(t)}))}drawParticlePlugin(t,e,i){this.draw((s=>{At(s,t,e,i)}))}drawPlugin(t,e){this.draw((i=>{Dt(i,t,e)}))}async init(){var t;this._resize(),this._initStyle(),this._initCover();try{await this._initTrail()}catch(t){console.error(t)}this._initBackground(),this.element&&(null===(t=this._mutationObserver)||void 0===t||t.observe(this.element,{attributes:!0})),this._initUpdaters(),this._initPlugins(),this._paint(),this.container.updateActualOptions(),this._resize(),this._initBackground()}loadCanvas(t){var e,i;this._generated&&(null===(e=this.element)||void 0===e||e.remove()),this._generated=t.dataset&&Lt in t.dataset?"true"===t.dataset[Lt]:this._generated,this.element=t,this.element.ariaHidden="true",this._originalStyle=U({},this.element.style),this.size.height=t.offsetHeight,this.size.width=t.offsetWidth,this._context=Pt(t),null===(i=this._mutationObserver)||void 0===i||i.observe(this.element,{attributes:!0}),this.container.retina.init(),this._initBackground()}async windowResize(){if(!this.element)return;this._resize();const t=this.container,e=t.updateActualOptions();t.particles.setDensity(),this._applyResizePlugins(),e&&await t.refresh()}_applyPostDrawUpdaters(t){var e;for(const i of this._postDrawUpdaters)null===(e=i.afterDraw)||void 0===e||e.call(i,t)}_applyPreDrawUpdaters(t,e,i,s,n,o){var a;for(const r of this._preDrawUpdaters){if(r.getColorStyles){const{fill:o,stroke:a}=r.getColorStyles(e,t,i,s);o&&(n.fill=o),a&&(n.stroke=a)}if(r.getTransformValues){const t=r.getTransformValues(e);for(const e in t)Yt(o,t,e)}null===(a=r.beforeDraw)||void 0===a||a.call(r,e)}}_applyResizePlugins(){for(const t of this._resizePlugins)t.resize&&t.resize()}_getPluginParticleColors(t){let e,i;for(const s of this._colorPlugins)if(!e&&s.particleFillColor&&(e=ht(s.particleFillColor(t))),!i&&s.particleStrokeColor&&(i=ht(s.particleStrokeColor(t))),e&&i)break;return[e,i]}_initBackground(){const t=this.container.actualOptions.background,e=this.element,i=null==e?void 0:e.style;if(i){if(t.color){const e=at(t.color);i.backgroundColor=e?mt(e,t.opacity):""}else i.backgroundColor="";i.backgroundImage=t.image||"",i.backgroundPosition=t.position||"",i.backgroundRepeat=t.repeat||"",i.backgroundSize=t.size||""}}_initCover(){const t=this.container.actualOptions.backgroundMask.cover,e=at(t.color);if(e){const i={r:e.r,g:e.g,b:e.b,a:t.opacity};this._coverColorStyle=mt(i,i.a)}}_initPlugins(){this._resizePlugins=[];for(const[,t]of this.container.plugins)t.resize&&this._resizePlugins.push(t),(t.particleFillColor||t.particleStrokeColor)&&this._colorPlugins.push(t)}_initStyle(){const t=this.element,e=this.container.actualOptions;if(t){this._fullScreen?(this._originalStyle=U({},t.style),this._setFullScreenStyle()):this._resetOriginalStyle();for(const i in e.style){if(!i||!e.style)continue;const s=e.style[i];s&&t.style.setProperty(i,s,"important")}}}async _initTrail(){const t=this.container.actualOptions,e=t.particles.move.trail,i=e.fill;if(e.enable)if(i.color){const e=at(i.color);if(!e)return;const s=t.particles.move.trail;this._trailFill={color:Object.assign({},e),opacity:1/s.length}}else await new Promise(((t,s)=>{if(!i.image)return;const n=document.createElement("img");n.addEventListener("load",(()=>{this._trailFill={image:n,opacity:1/e.length},t()})),n.addEventListener("error",(t=>{s(t.error)})),n.src=i.image}))}_initUpdaters(){this._preDrawUpdaters=[],this._postDrawUpdaters=[];for(const t of this.container.particles.updaters)t.afterDraw&&this._postDrawUpdaters.push(t),(t.getColorStyles||t.getTransformValues||t.beforeDraw)&&this._preDrawUpdaters.push(t)}_paint(){this.draw((t=>{kt(t,this.size,this.container.actualOptions,this._coverColorStyle)}))}_repairStyle(){var t,e;const i=this.element;i&&(null===(t=this._mutationObserver)||void 0===t||t.disconnect(),this._initStyle(),this._initBackground(),null===(e=this._mutationObserver)||void 0===e||e.observe(i,{attributes:!0}))}_resetOriginalStyle(){const t=this.element,e=this._originalStyle;t&&e&&(t.style.position=e.position,t.style.zIndex=e.zIndex,t.style.top=e.top,t.style.left=e.left,t.style.width=e.width,t.style.height=e.height)}_resize(){if(!this.element)return;const t=this.container,e=t.retina.pixelRatio,i=t.canvas.size,s=this.element.offsetWidth*e,n=this.element.offsetHeight*e;if(n===i.height&&s===i.width&&n===this.element.height&&s===this.element.width)return;const o=Object.assign({},i);this.element.width=i.width=this.element.offsetWidth*e,this.element.height=i.height=this.element.offsetHeight*e,this.container.started&&(this.resizeFactor={width:i.width/o.width,height:i.height/o.height})}_setFullScreenStyle(){const t=this.element;if(!t)return;const e="important";t.style.setProperty("position","fixed",e),t.style.setProperty("z-index",this.container.actualOptions.fullScreen.zIndex.toString(10),e),t.style.setProperty("top","0",e),t.style.setProperty("left","0",e),t.style.setProperty("width","100%",e),t.style.setProperty("height","100%",e)}}function Zt(t,e,i,s,n){if(s){let s={passive:!0};"boolean"==typeof n?s.capture=n:void 0!==n&&(s=n),t.addEventListener(e,i,s)}else{const s=n;t.removeEventListener(e,i,s)}}class Qt{constructor(t){this.container=t,this.canPush=!0,this.handlers={mouseMove:t=>this._mouseTouchMove(t),touchStart:t=>this._mouseTouchMove(t),touchMove:t=>this._mouseTouchMove(t),touchEnd:()=>this._mouseTouchFinish(),mouseLeave:()=>this._mouseTouchFinish(),touchCancel:()=>this._mouseTouchFinish(),touchEndClick:t=>this._mouseTouchClick(t),mouseUp:t=>this._mouseTouchClick(t),mouseDown:()=>this._mouseDown(),visibilityChange:()=>this._handleVisibilityChange(),themeChange:t=>this._handleThemeChange(t),oldThemeChange:t=>this._handleThemeChange(t),resize:()=>this._handleWindowResize()}}addListeners(){this._manageListeners(!0)}removeListeners(){this._manageListeners(!1)}_doMouseTouchClick(t){const e=this.container,i=e.actualOptions;if(this.canPush){const t=e.interactivity.mouse,s=t.position;if(!s)return;t.clickPosition=Object.assign({},s),t.clickTime=(new Date).getTime();J(i.interactivity.events.onClick.mode,(t=>this._handleClickMode(t)))}"touchend"===t.type&&setTimeout((()=>this._mouseTouchFinish()),500)}_handleClickMode(t){this.container.handleClickMode(t)}_handleThemeChange(t){const e=t,i=this.container,s=i.options,n=s.defaultThemes,o=e.matches?n.dark:n.light,a=s.themes.find((t=>t.name===o));a&&a.default.auto&&i.loadTheme(o)}_handleVisibilityChange(){const t=this.container,e=t.actualOptions;this._mouseTouchFinish(),e.pauseOnBlur&&(t.pageHidden=(null===document||void 0===document?void 0:document.hidden)||!1,t.pageHidden?t.pause():t.getAnimationStatus()?t.play(!0):t.draw(!0))}_handleWindowResize(){this.resizeTimeout&&(clearTimeout(this.resizeTimeout),delete this.resizeTimeout),this.resizeTimeout=setTimeout((async()=>{var t;return null===(t=this.container.canvas)||void 0===t?void 0:t.windowResize()}),1e3*this.container.actualOptions.interactivity.events.resize.delay)}_manageInteractivityEvents(t){var e;const i=this.handlers,s=this.container,n=s.actualOptions,o=n.interactivity.detectsOn;let a=Gt;if("window"===o)s.interactivity.element=window,a=jt;else if("parent"===o&&s.canvas.element){const t=s.canvas.element;s.interactivity.element=null!==(e=t.parentElement)&&void 0!==e?e:t.parentNode}else s.interactivity.element=s.canvas.element;const r=s.interactivity.element;if(!r)return;const l=r;(n.interactivity.events.onHover.enable||n.interactivity.events.onClick.enable)&&(Zt(r,Ht,i.mouseMove,t),Zt(r,Ut,i.touchStart,t),Zt(r,qt,i.touchMove,t),n.interactivity.events.onClick.enable?(Zt(r,Vt,i.touchEndClick,t),Zt(r,Bt,i.mouseUp,t),Zt(r,Wt,i.mouseDown,t)):Zt(r,Vt,i.touchEnd,t),Zt(r,a,i.mouseLeave,t),Zt(r,$t,i.touchCancel,t)),s.canvas.element&&(s.canvas.element.style.pointerEvents=l===s.canvas.element?"initial":"none")}_manageListeners(t){this._manageMediaEvents(t),this._manageInteractivityEvents(t),this._manageResizeEvent(t),this._manageVisibilityEvent(t)}_manageMediaEvents(t){const e=this.handlers,i=I("(prefers-color-scheme: dark)");i&&(void 0===i.addEventListener?void 0!==i.addListener&&(t?i.addListener(e.oldThemeChange):i.removeListener(e.oldThemeChange)):Zt(i,"change",e.themeChange,t))}_manageResizeEvent(t){const e=this.handlers,i=this.container;i.actualOptions.interactivity.events.resize&&("undefined"!=typeof ResizeObserver?this.resizeObserver&&!t?(i.canvas.element&&this.resizeObserver.unobserve(i.canvas.element),this.resizeObserver.disconnect(),delete this.resizeObserver):!this.resizeObserver&&t&&i.canvas.element&&(this.resizeObserver=new ResizeObserver((t=>{t.find((t=>t.target===i.canvas.element))&&this._handleWindowResize()})),this.resizeObserver.observe(i.canvas.element)):Zt(window,Nt,e.resize,t))}_manageVisibilityEvent(t){document&&Zt(document,Xt,this.handlers.visibilityChange,t)}_mouseDown(){const t=this.container.interactivity;if(t){const e=t.mouse;e.clicking=!0,e.downPosition=e.position}}_mouseTouchClick(t){const e=this.container,i=e.actualOptions,s=e.interactivity.mouse;s.inside=!0;let n=!1;const o=s.position;if(o&&i.interactivity.events.onClick.enable){for(const[,t]of e.plugins)if(t.clickPositionValid&&(n=t.clickPositionValid(o),n))break;n||this._doMouseTouchClick(t),s.clicking=!1}}_mouseTouchFinish(){const t=this.container.interactivity;if(!t)return;const e=t.mouse;delete e.position,delete e.clickPosition,delete e.downPosition,t.status=Gt,e.inside=!1,e.clicking=!1}_mouseTouchMove(t){var e,i,s,n,o,a,r;const l=this.container,h=l.actualOptions;if(!(null===(e=l.interactivity)||void 0===e?void 0:e.element))return;let c;l.interactivity.mouse.inside=!0;const d=l.canvas.element;if(t.type.startsWith("pointer")){this.canPush=!0;const e=t;if(l.interactivity.element===window){if(d){const t=d.getBoundingClientRect();c={x:e.clientX-t.left,y:e.clientY-t.top}}}else if("parent"===h.interactivity.detectsOn){const t=e.target,n=e.currentTarget,o=l.canvas.element;if(t&&n&&o){const i=t.getBoundingClientRect(),s=n.getBoundingClientRect(),a=o.getBoundingClientRect();c={x:e.offsetX+2*i.left-(s.left+a.left),y:e.offsetY+2*i.top-(s.top+a.top)}}else c={x:null!==(i=e.offsetX)&&void 0!==i?i:e.clientX,y:null!==(s=e.offsetY)&&void 0!==s?s:e.clientY}}else e.target===l.canvas.element&&(c={x:null!==(n=e.offsetX)&&void 0!==n?n:e.clientX,y:null!==(o=e.offsetY)&&void 0!==o?o:e.clientY})}else{this.canPush="touchmove"!==t.type;const e=t,i=e.touches[e.touches.length-1],s=null==d?void 0:d.getBoundingClientRect();c={x:i.clientX-(null!==(a=null==s?void 0:s.left)&&void 0!==a?a:0),y:i.clientY-(null!==(r=null==s?void 0:s.top)&&void 0!==r?r:0)}}const u=l.retina.pixelRatio;c&&(c.x*=u,c.y*=u),l.interactivity.mouse.position=c,l.interactivity.status=Ht}}class Kt{constructor(t){this.container=t}async nextFrame(t){var e;try{const i=this.container;if(!i.smooth&&void 0!==i.lastFrameTime&&t<i.lastFrameTime+1e3/i.fpsLimit)return void i.draw(!1);null!==(e=i.lastFrameTime)&&void 0!==e||(i.lastFrameTime=t);const s=function(t,e=60,i=!1){return{value:t,factor:i?60/e:60*t/1e3}}(t-i.lastFrameTime,i.fpsLimit,i.smooth);if(i.lifeTime+=s.value,i.lastFrameTime=t,s.value>1e3)return void i.draw(!1);if(await i.particles.draw(s),i.duration>0&&i.lifeTime>i.duration)return void i.destroy();i.getAnimationStatus()&&i.draw(!1)}catch(t){console.error("tsParticles error in animation loop",t)}}}class te{constructor(){this.value=""}static create(t,e){const i=new te;return i.load(t),void 0!==e&&("string"==typeof e||e instanceof Array?i.load({value:e}):i.load(e)),i}load(t){void 0!==(null==t?void 0:t.value)&&(this.value=t.value)}}class ee{constructor(){this.color=new te,this.color.value="",this.image="",this.position="",this.repeat="",this.size="",this.opacity=1}load(t){t&&(void 0!==t.color&&(this.color=te.create(this.color,t.color)),void 0!==t.image&&(this.image=t.image),void 0!==t.position&&(this.position=t.position),void 0!==t.repeat&&(this.repeat=t.repeat),void 0!==t.size&&(this.size=t.size),void 0!==t.opacity&&(this.opacity=t.opacity))}}class ie{constructor(){this.color=new te,this.color.value="#fff",this.opacity=1}load(t){t&&(void 0!==t.color&&(this.color=te.create(this.color,t.color)),void 0!==t.opacity&&(this.opacity=t.opacity))}}class se{constructor(){this.composite="destination-out",this.cover=new ie,this.enable=!1}load(t){if(t){if(void 0!==t.composite&&(this.composite=t.composite),void 0!==t.cover){const e=t.cover,i="string"==typeof t.cover?{color:t.cover}:t.cover;this.cover.load(void 0!==e.color?e:{color:i})}void 0!==t.enable&&(this.enable=t.enable)}}}class ne{constructor(){this.enable=!0,this.zIndex=0}load(t){t&&(void 0!==t.enable&&(this.enable=t.enable),void 0!==t.zIndex&&(this.zIndex=t.zIndex))}}class oe{constructor(){this.enable=!1,this.mode=[]}load(t){t&&(void 0!==t.enable&&(this.enable=t.enable),void 0!==t.mode&&(this.mode=t.mode))}}class ae{constructor(){this.selectors=[],this.enable=!1,this.mode=[],this.type="circle"}get el(){return this.elementId}set el(t){this.elementId=t}get elementId(){return this.ids}set elementId(t){this.ids=t}get ids(){return J(this.selectors,(t=>t.replace("#","")))}set ids(t){this.selectors=J(t,(t=>`#${t}`))}load(t){var e,i;if(!t)return;const s=null!==(i=null!==(e=t.ids)&&void 0!==e?e:t.elementId)&&void 0!==i?i:t.el;void 0!==s&&(this.ids=s),void 0!==t.selectors&&(this.selectors=t.selectors),void 0!==t.enable&&(this.enable=t.enable),void 0!==t.mode&&(this.mode=t.mode),void 0!==t.type&&(this.type=t.type)}}class re{constructor(){this.enable=!1,this.force=2,this.smooth=10}load(t){t&&(void 0!==t.enable&&(this.enable=t.enable),void 0!==t.force&&(this.force=t.force),void 0!==t.smooth&&(this.smooth=t.smooth))}}class le{constructor(){this.enable=!1,this.mode=[],this.parallax=new re}load(t){t&&(void 0!==t.enable&&(this.enable=t.enable),void 0!==t.mode&&(this.mode=t.mode),this.parallax.load(t.parallax))}}class he{constructor(){this.delay=.5,this.enable=!0}load(t){void 0!==t&&(void 0!==t.delay&&(this.delay=t.delay),void 0!==t.enable&&(this.enable=t.enable))}}class ce{constructor(){this.onClick=new oe,this.onDiv=new ae,this.onHover=new le,this.resize=new he}get onclick(){return this.onClick}set onclick(t){this.onClick=t}get ondiv(){return this.onDiv}set ondiv(t){this.onDiv=t}get onhover(){return this.onHover}set onhover(t){this.onHover=t}load(t){var e,i,s;if(!t)return;this.onClick.load(null!==(e=t.onClick)&&void 0!==e?e:t.onclick);const n=null!==(i=t.onDiv)&&void 0!==i?i:t.ondiv;void 0!==n&&(this.onDiv=J(n,(t=>{const e=new ae;return e.load(t),e}))),this.onHover.load(null!==(s=t.onHover)&&void 0!==s?s:t.onhover),"boolean"==typeof t.resize?this.resize.enable=t.resize:this.resize.load(t.resize)}}class de{constructor(t,e){this._engine=t,this._container=e}load(t){if(t&&this._container){const e=this._engine.plugins.interactors.get(this._container);if(e)for(const i of e)i.loadModeOptions&&i.loadModeOptions(this,t)}}}class ue{constructor(t,e){this.detectsOn="window",this.events=new ce,this.modes=new de(t,e)}get detect_on(){return this.detectsOn}set detect_on(t){this.detectsOn=t}load(t){var e;if(!t)return;const i=null!==(e=t.detectsOn)&&void 0!==e?e:t.detect_on;void 0!==i&&(this.detectsOn=i),this.events.load(t.events),this.modes.load(t.modes)}}class pe{load(t){var e,i,s;t&&(void 0!==t.position&&(this.position={x:null!==(e=t.position.x)&&void 0!==e?e:50,y:null!==(i=t.position.y)&&void 0!==i?i:50,mode:null!==(s=t.position.mode)&&void 0!==s?s:"percent"}),void 0!==t.options&&(this.options=U({},t.options)))}}class ve{constructor(){this.maxWidth=1/0,this.options={},this.mode="canvas"}load(t){t&&(void 0!==t.maxWidth&&(this.maxWidth=t.maxWidth),void 0!==t.mode&&("screen"===t.mode?this.mode="screen":this.mode="canvas"),void 0!==t.options&&(this.options=U({},t.options)))}}class fe{constructor(){this.auto=!1,this.mode="any",this.value=!1}load(t){t&&(void 0!==t.auto&&(this.auto=t.auto),void 0!==t.mode&&(this.mode=t.mode),void 0!==t.value&&(this.value=t.value))}}class me{constructor(){this.name="",this.default=new fe}load(t){t&&(void 0!==t.name&&(this.name=t.name),this.default.load(t.default),void 0!==t.options&&(this.options=U({},t.options)))}}class ge{constructor(){this.count=0,this.enable=!1,this.offset=0,this.speed=1,this.decay=0,this.sync=!0}load(t){t&&(void 0!==t.count&&(this.count=m(t.count)),void 0!==t.enable&&(this.enable=t.enable),void 0!==t.offset&&(this.offset=m(t.offset)),void 0!==t.speed&&(this.speed=m(t.speed)),void 0!==t.decay&&(this.decay=m(t.decay)),void 0!==t.sync&&(this.sync=t.sync))}}class ye{constructor(){this.h=new ge,this.s=new ge,this.l=new ge}load(t){t&&(this.h.load(t.h),this.s.load(t.s),this.l.load(t.l))}}class be extends te{constructor(){super(),this.animation=new ye}static create(t,e){const i=new be;return i.load(t),void 0!==e&&("string"==typeof e||e instanceof Array?i.load({value:e}):i.load(e)),i}load(t){if(super.load(t),!t)return;const e=t.animation;void 0!==e&&(void 0!==e.enable?this.animation.h.load(e):this.animation.load(t.animation))}}class we{constructor(){this.speed=2}load(t){t&&void 0!==t.speed&&(this.speed=t.speed)}}class _e{constructor(){this.enable=!0,this.retries=0}load(t){t&&(void 0!==t.enable&&(this.enable=t.enable),void 0!==t.retries&&(this.retries=t.retries))}}class xe{constructor(){this.count=0,this.enable=!1,this.speed=1,this.decay=0,this.sync=!1}load(t){t&&(void 0!==t.count&&(this.count=m(t.count)),void 0!==t.enable&&(this.enable=t.enable),void 0!==t.speed&&(this.speed=m(t.speed)),void 0!==t.decay&&(this.decay=m(t.decay)),void 0!==t.sync&&(this.sync=t.sync))}}class ze extends xe{constructor(){super(),this.mode="auto",this.startValue="random"}load(t){super.load(t),t&&(void 0!==t.minimumValue&&(this.minimumValue=t.minimumValue),void 0!==t.mode&&(this.mode=t.mode),void 0!==t.startValue&&(this.startValue=t.startValue))}}class Me{constructor(){this.enable=!1,this.minimumValue=0}load(t){t&&(void 0!==t.enable&&(this.enable=t.enable),void 0!==t.minimumValue&&(this.minimumValue=t.minimumValue))}}class Pe{constructor(){this.random=new Me,this.value=0}load(t){t&&("boolean"==typeof t.random?this.random.enable=t.random:this.random.load(t.random),void 0!==t.value&&(this.value=m(t.value,this.random.enable?this.random.minimumValue:void 0)))}}class Oe extends Pe{constructor(){super(),this.animation=new xe}get anim(){return this.animation}set anim(t){this.animation=t}load(t){var e;if(super.load(t),!t)return;const i=null!==(e=t.animation)&&void 0!==e?e:t.anim;void 0!==i&&this.animation.load(i)}}class ke extends Oe{constructor(){super(),this.animation=new ze}load(t){super.load(t),t&&void 0!==t.animation&&(this.value=m(this.value,this.animation.enable?this.animation.minimumValue:void 0))}}class Ce extends Pe{constructor(){super(),this.random.minimumValue=.1,this.value=1}}class Se{constructor(){this.horizontal=new Ce,this.vertical=new Ce}load(t){t&&(this.horizontal.load(t.horizontal),this.vertical.load(t.vertical))}}class Re{constructor(){this.absorb=new we,this.bounce=new Se,this.enable=!1,this.mode="bounce",this.overlap=new _e}load(t){t&&(this.absorb.load(t.absorb),this.bounce.load(t.bounce),void 0!==t.enable&&(this.enable=t.enable),void 0!==t.mode&&(this.mode=t.mode),this.overlap.load(t.overlap))}}class Te{constructor(){this.offset=0,this.value=90}load(t){t&&(void 0!==t.offset&&(this.offset=m(t.offset)),void 0!==t.value&&(this.value=m(t.value)))}}class Ie{constructor(){this.distance=200,this.enable=!1,this.rotate={x:3e3,y:3e3}}get rotateX(){return this.rotate.x}set rotateX(t){this.rotate.x=t}get rotateY(){return this.rotate.y}set rotateY(t){this.rotate.y=t}load(t){var e,i,s,n;if(!t)return;void 0!==t.distance&&(this.distance=m(t.distance)),void 0!==t.enable&&(this.enable=t.enable);const o=null!==(i=null===(e=t.rotate)||void 0===e?void 0:e.x)&&void 0!==i?i:t.rotateX;void 0!==o&&(this.rotate.x=o);const a=null!==(n=null===(s=t.rotate)||void 0===s?void 0:s.y)&&void 0!==n?n:t.rotateY;void 0!==a&&(this.rotate.y=a)}}class Ee{constructor(){this.x=50,this.y=50,this.mode="percent",this.radius=0}load(t){t&&(void 0!==t.x&&(this.x=t.x),void 0!==t.y&&(this.y=t.y),void 0!==t.mode&&(this.mode=t.mode),void 0!==t.radius&&(this.radius=t.radius))}}class De{constructor(){this.acceleration=9.81,this.enable=!1,this.inverse=!1,this.maxSpeed=50}load(t){t&&(void 0!==t.acceleration&&(this.acceleration=m(t.acceleration)),void 0!==t.enable&&(this.enable=t.enable),void 0!==t.inverse&&(this.inverse=t.inverse),void 0!==t.maxSpeed&&(this.maxSpeed=m(t.maxSpeed)))}}class Ae{constructor(){this.clamp=!0,this.delay=new Pe,this.enable=!1,this.options={}}load(t){t&&(void 0!==t.clamp&&(this.clamp=t.clamp),this.delay.load(t.delay),void 0!==t.enable&&(this.enable=t.enable),this.generator=t.generator,t.options&&(this.options=U(this.options,t.options)))}}class Fe{load(t){t&&(void 0!==t.color&&(this.color=te.create(this.color,t.color)),void 0!==t.image&&(this.image=t.image))}}class Le{constructor(){this.enable=!1,this.length=10,this.fill=new Fe}get fillColor(){return this.fill.color}set fillColor(t){this.fill.load({color:t})}load(t){t&&(void 0!==t.enable&&(this.enable=t.enable),void 0===t.fill&&void 0===t.fillColor||this.fill.load(t.fill||{color:t.fillColor}),void 0!==t.length&&(this.length=t.length))}}class Ve{constructor(){this.default="out"}load(t){var e,i,s,n;t&&(void 0!==t.default&&(this.default=t.default),this.bottom=null!==(e=t.bottom)&&void 0!==e?e:t.default,this.left=null!==(i=t.left)&&void 0!==i?i:t.default,this.right=null!==(s=t.right)&&void 0!==s?s:t.default,this.top=null!==(n=t.top)&&void 0!==n?n:t.default)}}class We{constructor(){this.acceleration=0,this.enable=!1}load(t){t&&(void 0!==t.acceleration&&(this.acceleration=m(t.acceleration)),void 0!==t.enable&&(this.enable=t.enable),this.position=t.position?U({},t.position):void 0)}}class Be{constructor(){this.angle=new Te,this.attract=new Ie,this.center=new Ee,this.decay=0,this.distance={},this.direction="none",this.drift=0,this.enable=!1,this.gravity=new De,this.path=new Ae,this.outModes=new Ve,this.random=!1,this.size=!1,this.speed=2,this.spin=new We,this.straight=!1,this.trail=new Le,this.vibrate=!1,this.warp=!1}get bounce(){return this.collisions}set bounce(t){this.collisions=t}get collisions(){return!1}set collisions(t){}get noise(){return this.path}set noise(t){this.path=t}get outMode(){return this.outModes.default}set outMode(t){this.outModes.default=t}get out_mode(){return this.outMode}set out_mode(t){this.outMode=t}load(t){var e,i,s;if(!t)return;this.angle.load("number"==typeof t.angle?{value:t.angle}:t.angle),this.attract.load(t.attract),this.center.load(t.center),void 0!==t.decay&&(this.decay=m(t.decay)),void 0!==t.direction&&(this.direction=t.direction),void 0!==t.distance&&(this.distance="number"==typeof t.distance?{horizontal:t.distance,vertical:t.distance}:Object.assign({},t.distance)),void 0!==t.drift&&(this.drift=m(t.drift)),void 0!==t.enable&&(this.enable=t.enable),this.gravity.load(t.gravity);const n=null!==(i=null!==(e=t.outModes)&&void 0!==e?e:t.outMode)&&void 0!==i?i:t.out_mode;void 0!==n&&("object"==typeof n?this.outModes.load(n):this.outModes.load({default:n})),this.path.load(null!==(s=t.path)&&void 0!==s?s:t.noise),void 0!==t.random&&(this.random=t.random),void 0!==t.size&&(this.size=t.size),void 0!==t.speed&&(this.speed=m(t.speed)),this.spin.load(t.spin),void 0!==t.straight&&(this.straight=t.straight),this.trail.load(t.trail),void 0!==t.vibrate&&(this.vibrate=t.vibrate),void 0!==t.warp&&(this.warp=t.warp)}}class He extends ze{constructor(){super(),this.destroy="none",this.speed=2}get opacity_min(){return this.minimumValue}set opacity_min(t){this.minimumValue=t}load(t){void 0!==(null==t?void 0:t.opacity_min)&&void 0===t.minimumValue&&(t.minimumValue=t.opacity_min),super.load(t),t&&void 0!==t.destroy&&(this.destroy=t.destroy)}}class Ue extends ke{constructor(){super(),this.animation=new He,this.random.minimumValue=.1,this.value=1}get anim(){return this.animation}set anim(t){this.animation=t}}class qe{constructor(){this.enable=!1,this.width=1920,this.height=1080}get area(){return this.width}set area(t){this.width=t}get factor(){return this.height}set factor(t){this.height=t}get value_area(){return this.area}set value_area(t){this.area=t}load(t){var e,i,s;if(!t)return;void 0!==t.enable&&(this.enable=t.enable);const n=null!==(i=null!==(e=t.width)&&void 0!==e?e:t.area)&&void 0!==i?i:t.value_area;void 0!==n&&(this.width=n);const o=null!==(s=t.height)&&void 0!==s?s:t.factor;void 0!==o&&(this.height=o)}}class Ge{constructor(){this.density=new qe,this.limit=0,this.value=100}get max(){return this.limit}set max(t){this.limit=t}load(t){var e;if(!t)return;this.density.load(t.density);const i=null!==(e=t.limit)&&void 0!==e?e:t.max;void 0!==i&&(this.limit=i),void 0!==t.value&&(this.value=t.value)}}class je{constructor(){this.blur=0,this.color=new te,this.enable=!1,this.offset={x:0,y:0},this.color.value="#000"}load(t){t&&(void 0!==t.blur&&(this.blur=t.blur),this.color=te.create(this.color,t.color),void 0!==t.enable&&(this.enable=t.enable),void 0!==t.offset&&(void 0!==t.offset.x&&(this.offset.x=t.offset.x),void 0!==t.offset.y&&(this.offset.y=t.offset.y)))}}class $e{constructor(){this.options={},this.type="circle",this.close=!0,this.fill=!0}load(t){var e;if(!t)return;void 0!==t.close&&(this.close=t.close),void 0!==t.fill&&(this.fill=t.fill);const i=t.options;if(void 0!==i)for(const t in i){const s=i[t];s&&(this.options[t]=U(null!==(e=this.options[t])&&void 0!==e?e:{},s))}void 0!==t.type&&(this.type=t.type)}}class Ne extends ze{constructor(){super(),this.destroy="none",this.speed=5}get size_min(){return this.minimumValue}set size_min(t){this.minimumValue=t}load(t){void 0!==(null==t?void 0:t.size_min)&&void 0===t.minimumValue&&(t.minimumValue=t.size_min),super.load(t),t&&void 0!==t.destroy&&(this.destroy=t.destroy)}}class Xe extends ke{constructor(){super(),this.animation=new Ne,this.random.minimumValue=1,this.value=3}get anim(){return this.animation}set anim(t){this.animation=t}}class Ye{constructor(){this.width=0}load(t){t&&(void 0!==t.color&&(this.color=be.create(this.color,t.color)),void 0!==t.width&&(this.width=m(t.width)),void 0!==t.opacity&&(this.opacity=m(t.opacity)))}}class Je extends Pe{constructor(){super(),this.opacityRate=1,this.sizeRate=1,this.velocityRate=1}load(t){super.load(t),t&&(void 0!==t.opacityRate&&(this.opacityRate=t.opacityRate),void 0!==t.sizeRate&&(this.sizeRate=t.sizeRate),void 0!==t.velocityRate&&(this.velocityRate=t.velocityRate))}}class Ze{constructor(t,e){this._engine=t,this._container=e,this.bounce=new Se,this.collisions=new Re,this.color=new be,this.color.value="#fff",this.groups={},this.move=new Be,this.number=new Ge,this.opacity=new Ue,this.reduceDuplicates=!1,this.shadow=new je,this.shape=new $e,this.size=new Xe,this.stroke=new Ye,this.zIndex=new Je}load(t){var e,i,s,n;if(!t)return;if(this.bounce.load(t.bounce),this.color.load(be.create(this.color,t.color)),void 0!==t.groups)for(const i in t.groups){const s=t.groups[i];void 0!==s&&(this.groups[i]=U(null!==(e=this.groups[i])&&void 0!==e?e:{},s))}this.move.load(t.move),this.number.load(t.number),this.opacity.load(t.opacity),void 0!==t.reduceDuplicates&&(this.reduceDuplicates=t.reduceDuplicates),this.shape.load(t.shape),this.size.load(t.size),this.shadow.load(t.shadow),this.zIndex.load(t.zIndex);const o=null!==(s=null===(i=t.move)||void 0===i?void 0:i.collisions)&&void 0!==s?s:null===(n=t.move)||void 0===n?void 0:n.bounce;void 0!==o&&(this.collisions.enable=o),this.collisions.load(t.collisions),void 0!==t.interactivity&&(this.interactivity=U({},t.interactivity));const a=t.stroke;if(a&&(this.stroke=J(a,(t=>{const e=new Ye;return e.load(t),e}))),this._container){const e=this._engine.plugins.updaters.get(this._container);if(e)for(const i of e)i.loadOptions&&i.loadOptions(this,t);const i=this._engine.plugins.interactors.get(this._container);if(i)for(const e of i)e.loadParticlesOptions&&e.loadParticlesOptions(this,t)}}}function Qe(t,...e){for(const i of e)t.load(i)}function Ke(t,e,...i){const s=new Ze(t,e);return Qe(s,...i),s}class ti{constructor(t,e){this._engine=t,this._container=e,this.autoPlay=!0,this.background=new ee,this.backgroundMask=new se,this.defaultThemes={},this.delay=0,this.fullScreen=new ne,this.detectRetina=!0,this.duration=0,this.fpsLimit=120,this.interactivity=new ue(t,e),this.manualParticles=[],this.name="default",this.particles=Ke(this._engine,this._container),this.pauseOnBlur=!0,this.pauseOnOutsideViewport=!0,this.responsive=[],this.smooth=!1,this.style={},this.themes=[],this.zLayers=100}get backgroundMode(){return this.fullScreen}set backgroundMode(t){this.fullScreen.load(t)}get fps_limit(){return this.fpsLimit}set fps_limit(t){this.fpsLimit=t}get retina_detect(){return this.detectRetina}set retina_detect(t){this.detectRetina=t}load(t){var e,i,s,n,o;if(!t)return;void 0!==t.preset&&J(t.preset,(t=>this._importPreset(t))),void 0!==t.autoPlay&&(this.autoPlay=t.autoPlay),void 0!==t.delay&&(this.delay=m(t.delay));const a=null!==(e=t.detectRetina)&&void 0!==e?e:t.retina_detect;void 0!==a&&(this.detectRetina=a),void 0!==t.duration&&(this.duration=m(t.duration));const r=null!==(i=t.fpsLimit)&&void 0!==i?i:t.fps_limit;void 0!==r&&(this.fpsLimit=r),void 0!==t.pauseOnBlur&&(this.pauseOnBlur=t.pauseOnBlur),void 0!==t.pauseOnOutsideViewport&&(this.pauseOnOutsideViewport=t.pauseOnOutsideViewport),void 0!==t.zLayers&&(this.zLayers=t.zLayers),this.background.load(t.background);const l=null!==(s=t.fullScreen)&&void 0!==s?s:t.backgroundMode;"boolean"==typeof l?this.fullScreen.enable=l:this.fullScreen.load(l),this.backgroundMask.load(t.backgroundMask),this.interactivity.load(t.interactivity),void 0!==t.manualParticles&&(this.manualParticles=t.manualParticles.map((t=>{const e=new pe;return e.load(t),e}))),this.particles.load(t.particles),this.style=U(this.style,t.style),this._engine.plugins.loadOptions(this,t),void 0!==t.smooth&&(this.smooth=t.smooth);const h=this._engine.plugins.interactors.get(this._container);if(h)for(const e of h)e.loadOptions&&e.loadOptions(this,t);if(void 0!==t.responsive)for(const e of t.responsive){const t=new ve;t.load(e),this.responsive.push(t)}if(this.responsive.sort(((t,e)=>t.maxWidth-e.maxWidth)),void 0!==t.themes)for(const e of t.themes){const t=this.themes.find((t=>t.name===e.name));if(t)t.load(e);else{const t=new me;t.load(e),this.themes.push(t)}}this.defaultThemes.dark=null===(n=this._findDefaultTheme("dark"))||void 0===n?void 0:n.name,this.defaultThemes.light=null===(o=this._findDefaultTheme("light"))||void 0===o?void 0:o.name}setResponsive(t,e,i){this.load(i);const s=this.responsive.find((i=>"screen"===i.mode&&screen?i.maxWidth>screen.availWidth:i.maxWidth*e>t));return this.load(null==s?void 0:s.options),null==s?void 0:s.maxWidth}setTheme(t){if(t){const e=this.themes.find((e=>e.name===t));e&&this.load(e.options)}else{const t=I("(prefers-color-scheme: dark)"),e=t&&t.matches,i=this._findDefaultTheme(e?"dark":"light");i&&this.load(i.options)}}_findDefaultTheme(t){var e;return null!==(e=this.themes.find((e=>e.default.value&&e.default.mode===t)))&&void 0!==e?e:this.themes.find((t=>t.default.value&&"any"===t.default.mode))}_importPreset(t){this.load(this._engine.plugins.getPreset(t))}}class ei{constructor(t,e){this.container=e,this._engine=t,this._interactors=this._engine.plugins.getInteractors(this.container,!0),this._externalInteractors=[],this._particleInteractors=[]}async externalInteract(t){for(const e of this._externalInteractors)e.isEnabled()&&await e.interact(t)}handleClickMode(t){for(const e of this._externalInteractors)e.handleClickMode&&e.handleClickMode(t)}init(){this._externalInteractors=[],this._particleInteractors=[];for(const t of this._interactors){switch(t.type){case"external":this._externalInteractors.push(t);break;case"particles":this._particleInteractors.push(t)}t.init()}}async particlesInteract(t,e){for(const i of this._externalInteractors)i.clear(t,e);for(const i of this._particleInteractors)i.isEnabled(t)&&await i.interact(t,e)}async reset(t){for(const e of this._externalInteractors)e.isEnabled()&&await e.reset(t);for(const e of this._particleInteractors)e.isEnabled(t)&&await e.reset(t)}}const ii=t=>{A(t.outMode,t.checkModes)&&(t.coord>t.maxCoord-2*t.radius?t.setCb(-t.radius):t.coord<2*t.radius&&t.setCb(t.radius))};class si{constructor(t,e,i,s,n,o){this.container=i,this._engine=t,this.init(e,s,n,o)}destroy(t){var e;if(!this.unbreakable&&!this.destroyed){this.destroyed=!0,this.bubble.inRange=!1,this.slow.inRange=!1;for(const[,e]of this.container.plugins)e.particleDestroyed&&e.particleDestroyed(this,t);for(const e of this.container.particles.updaters)e.particleDestroyed&&e.particleDestroyed(this,t);null===(e=this.pathGenerator)||void 0===e||e.reset(this)}}draw(t){const e=this.container;for(const[,i]of e.plugins)e.canvas.drawParticlePlugin(i,this,t);e.canvas.drawParticle(this,t)}getFillColor(){var t;return this._getRollColor(null!==(t=this.bubble.color)&&void 0!==t?t:_t(this.color))}getMass(){return this.getRadius()**2*Math.PI/2}getPosition(){return{x:this.position.x+this.offset.x,y:this.position.y+this.offset.y,z:this.position.z}}getRadius(){var t;return null!==(t=this.bubble.radius)&&void 0!==t?t:this.size.value}getStrokeColor(){var t;return this._getRollColor(null!==(t=this.bubble.color)&&void 0!==t?t:_t(this.strokeColor))}init(t,e,i,s){var n,o,a,r,l,h,c;const d=this.container,u=this._engine;this.id=t,this.group=s,this.fill=!0,this.pathRotation=!1,this.close=!0,this.lastPathTime=0,this.destroyed=!1,this.unbreakable=!1,this.rotation=0,this.misplaced=!1,this.retina={maxDistance:{}},this.outType="normal",this.ignoresResizeRatio=!0;const v=d.retina.pixelRatio,f=d.actualOptions,m=Ke(this._engine,d,f.particles),y=m.shape.type,{reduceDuplicates:b}=m;this.shape=Z(y,this.id,b);const w=m.shape;if(i&&i.shape&&i.shape.type){const t=Z(i.shape.type,this.id,b);t&&(this.shape=t,w.load(i.shape))}this.shapeData=this._loadShapeData(w,b),m.load(i),m.load(null===(n=this.shapeData)||void 0===n?void 0:n.particles),this.interactivity=new ue(u,d),this.interactivity.load(d.actualOptions.interactivity),this.interactivity.load(m.interactivity),this.fill=null!==(a=null===(o=this.shapeData)||void 0===o?void 0:o.fill)&&void 0!==a?a:this.fill,this.close=null!==(l=null===(r=this.shapeData)||void 0===r?void 0:r.close)&&void 0!==l?l:this.close,this.options=m;const _=this.options.move.path;this.pathDelay=1e3*g(_.delay),_.generator&&(this.pathGenerator=this._engine.plugins.getPathGenerator(_.generator),this.pathGenerator&&d.addPath(_.generator,this.pathGenerator)&&this.pathGenerator.init(d)),d.retina.initParticle(this),this.size=K(this.options.size,v),this.bubble={inRange:!1},this.slow={inRange:!1,factor:1},this._initPosition(e),this.initialVelocity=this._calculateVelocity(),this.velocity=this.initialVelocity.copy(),this.moveDecay=1-p(this.options.move.decay);const x=d.particles;x.needsSort=x.needsSort||x.lastZIndex<this.position.z,x.lastZIndex=this.position.z,this.zIndexFactor=this.position.z/d.zLayers,this.sides=24;let z=d.drawers.get(this.shape);z||(z=this._engine.plugins.getShapeDrawer(this.shape),z&&d.drawers.set(this.shape,z)),(null==z?void 0:z.loadShape)&&(null==z||z.loadShape(this));const M=null==z?void 0:z.getSidesCount;M&&(this.sides=M(this)),this.spawning=!1,this.shadowColor=at(this.options.shadow.color);for(const t of d.particles.updaters)t.init(this);for(const t of d.particles.movers)null===(h=t.init)||void 0===h||h.call(t,this);(null==z?void 0:z.particleInit)&&z.particleInit(d,this);for(const[,t]of d.plugins)null===(c=t.particleCreated)||void 0===c||c.call(t,this)}isInsideCanvas(){const t=this.getRadius(),e=this.container.canvas.size;return this.position.x>=-t&&this.position.y>=-t&&this.position.y<=e.height+t&&this.position.x<=e.width+t}isVisible(){return!this.destroyed&&!this.spawning&&this.isInsideCanvas()}reset(){var t;for(const e of this.container.particles.updaters)null===(t=e.reset)||void 0===t||t.call(e,this)}_calcPosition(t,e,s,n=0){var o,a,r,l;for(const[,n]of t.plugins){const t=void 0!==n.particlePosition?n.particlePosition(e,this):void 0;if(void 0!==t)return i.create(t.x,t.y,s)}const h=O({size:t.canvas.size,position:e}),c=i.create(h.x,h.y,s),d=this.getRadius(),u=this.options.move.outModes,p=e=>{ii({outMode:e,checkModes:["bounce","bounce-horizontal"],coord:c.x,maxCoord:t.canvas.size.width,setCb:t=>c.x+=t,radius:d})},v=e=>{ii({outMode:e,checkModes:["bounce","bounce-vertical"],coord:c.y,maxCoord:t.canvas.size.height,setCb:t=>c.y+=t,radius:d})};return p(null!==(o=u.left)&&void 0!==o?o:u.default),p(null!==(a=u.right)&&void 0!==a?a:u.default),v(null!==(r=u.top)&&void 0!==r?r:u.default),v(null!==(l=u.bottom)&&void 0!==l?l:u.default),this._checkOverlap(c,n)?this._calcPosition(t,void 0,s,n+1):c}_calculateVelocity(){const t=_(this.direction).copy(),e=this.options.move;if("inside"===e.direction||"outside"===e.direction)return t;const i=Math.PI/180*p(e.angle.value),s=Math.PI/180*p(e.angle.offset),n={left:s-i/2,right:s+i/2};return e.straight||(t.angle+=u(m(n.left,n.right))),e.random&&"number"==typeof e.speed&&(t.length*=h()),t}_checkOverlap(t,e=0){const i=this.options.collisions,s=this.getRadius();if(!i.enable)return!1;const n=i.overlap;if(n.enable)return!1;const o=n.retries;if(o>=0&&e>o)throw new Error("Particle is overlapping and can't be placed");let a=!1;for(const e of this.container.particles.array)if(b(t,e.position)<s+e.getRadius()){a=!0;break}return a}_getRollColor(t){var e;if(!t||!this.roll||!this.backColor&&!this.roll.alter)return t;const i=this.roll.horizontal&&this.roll.vertical?2:1,s=this.roll.horizontal?Math.PI/2:0;return Math.floor(((null!==(e=this.roll.angle)&&void 0!==e?e:0)+s)/(Math.PI/i))%2?this.backColor?this.backColor:this.roll.alter?Ft(t,this.roll.alter.type,this.roll.alter.value):t:t}_initPosition(t){var e,i;const n=this.container,o=p(this.options.zIndex.value);this.position=this._calcPosition(n,t,c(o,0,n.zLayers)),this.initialPosition=this.position.copy();const a=n.canvas.size,r=Object.assign({},this.options.move.center),l="percent"===r.mode;switch(this.moveCenter={x:r.x*(l?a.width/100:1),y:r.y*(l?a.height/100:1),radius:null!==(e=this.options.move.center.radius)&&void 0!==e?e:0,mode:null!==(i=this.options.move.center.mode)&&void 0!==i?i:"percent"},this.direction=w(this.options.move.direction,this.position,this.moveCenter),this.options.move.direction){case"inside":this.outType="inside";break;case"outside":this.outType="outside"}this.offset=s.origin}_loadShapeData(t,e){const i=t.options[this.shape];if(i)return U({close:t.close,fill:t.fill},Z(i,this.id,e))}}class ni{constructor(t,e){this.position=t,this.particle=e}}class oi{constructor(t,e){this.position={x:t,y:e}}}class ai extends oi{constructor(t,e,i){super(t,e),this.radius=i}contains(t){return b(t,this.position)<=this.radius}intersects(t){const e=t,i=t,s=this.position,n=t.position,o=Math.abs(n.x-s.x),a=Math.abs(n.y-s.y),r=this.radius;if(void 0!==i.radius){return r+i.radius>Math.sqrt(o**2+a**2)}if(void 0!==e.size){const t=e.size.width,i=e.size.height;return Math.pow(o-t,2)+Math.pow(a-i,2)<=r**2||o<=r+t&&a<=r+i||o<=t||a<=i}return!1}}class ri extends oi{constructor(t,e,i,s){super(t,e),this.size={height:s,width:i}}contains(t){const e=this.size.width,i=this.size.height,s=this.position;return t.x>=s.x&&t.x<=s.x+e&&t.y>=s.y&&t.y<=s.y+i}intersects(t){t instanceof ai&&t.intersects(this);const e=this.size.width,i=this.size.height,s=this.position,n=t.position,o=t instanceof ri?t.size:{width:0,height:0},a=o.width,r=o.height;return n.x<s.x+e&&n.x+a>s.x&&n.y<s.y+i&&n.y+r>s.y}}class li{constructor(t,e){this.rectangle=t,this.capacity=e,this._points=[],this._divided=!1}insert(t){var e,i,s,n,o;return!!this.rectangle.contains(t.position)&&(this._points.length<this.capacity?(this._points.push(t),!0):(this._divided||this.subdivide(),null!==(o=(null===(e=this._NE)||void 0===e?void 0:e.insert(t))||(null===(i=this._NW)||void 0===i?void 0:i.insert(t))||(null===(s=this._SE)||void 0===s?void 0:s.insert(t))||(null===(n=this._SW)||void 0===n?void 0:n.insert(t)))&&void 0!==o&&o))}query(t,e,i){var s,n,o,a;const r=null!=i?i:[];if(!t.intersects(this.rectangle))return[];for(const i of this._points)!t.contains(i.position)&&b(t.position,i.position)>i.particle.getRadius()&&(!e||e(i.particle))||r.push(i.particle);return this._divided&&(null===(s=this._NE)||void 0===s||s.query(t,e,r),null===(n=this._NW)||void 0===n||n.query(t,e,r),null===(o=this._SE)||void 0===o||o.query(t,e,r),null===(a=this._SW)||void 0===a||a.query(t,e,r)),r}queryCircle(t,e,i){return this.query(new ai(t.x,t.y,e),i)}queryRectangle(t,e,i){return this.query(new ri(t.x,t.y,e.width,e.height),i)}subdivide(){const t=this.rectangle.position.x,e=this.rectangle.position.y,i=this.rectangle.size.width,s=this.rectangle.size.height,n=this.capacity;this._NE=new li(new ri(t,e,i/2,s/2),n),this._NW=new li(new ri(t+i/2,e,i/2,s/2),n),this._SE=new li(new ri(t,e+s/2,i/2,s/2),n),this._SW=new li(new ri(t+i/2,e+s/2,i/2,s/2),n),this._divided=!0}}class hi{constructor(t,e){this.container=e,this._engine=t,this.nextId=0,this.array=[],this.zArray=[],this.pool=[],this.limit=0,this.needsSort=!1,this.lastZIndex=0,this.interactionManager=new ei(this._engine,e);const i=this.container.canvas.size;this.quadTree=new li(new ri(-i.width/4,-i.height/4,3*i.width/2,3*i.height/2),4),this.movers=this._engine.plugins.getMovers(e,!0),this.updaters=this._engine.plugins.getUpdaters(e,!0)}get count(){return this.array.length}addManualParticles(){const t=this.container,e=t.actualOptions;for(const i of e.manualParticles)this.addParticle(i.position?"precise"===i.position.mode?i.position:z({size:t.canvas.size,position:i.position}):void 0,i.options)}addParticle(t,e,i,s){const n=this.container.actualOptions.particles.number.limit;if(n>0){const t=this.count+1-n;t>0&&this.removeQuantity(t)}return this._pushParticle(t,e,i,s)}clear(){this.array=[],this.zArray=[]}destroy(){this.array=[],this.zArray=[],this.movers=[],this.updaters=[]}async draw(t){const e=this.container,i=this.container.canvas.size;this.quadTree=new li(new ri(-i.width/4,-i.height/4,3*i.width/2,3*i.height/2),4),e.canvas.clear(),await this.update(t),this.needsSort&&(this.zArray.sort(((t,e)=>e.position.z-t.position.z||t.id-e.id)),this.lastZIndex=this.zArray[this.zArray.length-1].position.z,this.needsSort=!1);for(const[,i]of e.plugins)e.canvas.drawPlugin(i,t);for(const e of this.zArray)e.draw(t)}handleClickMode(t){this.interactionManager.handleClickMode(t)}init(){var t;const e=this.container,i=e.actualOptions;this.lastZIndex=0,this.needsSort=!1;let s=!1;this.updaters=this._engine.plugins.getUpdaters(e,!0),this.interactionManager.init();for(const[,t]of e.plugins)if(void 0!==t.particlesInitialization&&(s=t.particlesInitialization()),s)break;this.interactionManager.init();for(const[,t]of e.pathGenerators)t.init(e);if(this.addManualParticles(),!s){for(const e in i.particles.groups){const s=i.particles.groups[e];for(let n=this.count,o=0;o<(null===(t=s.number)||void 0===t?void 0:t.value)&&n<i.particles.number.value;n++,o++)this.addParticle(void 0,s,e)}for(let t=this.count;t<i.particles.number.value;t++)this.addParticle()}}push(t,e,i,s){this.pushing=!0;for(let n=0;n<t;n++)this.addParticle(null==e?void 0:e.position,i,s);this.pushing=!1}async redraw(){this.clear(),this.init(),await this.draw({value:0,factor:0})}remove(t,e,i){this.removeAt(this.array.indexOf(t),void 0,e,i)}removeAt(t,e=1,i,s){if(t<0||t>this.count)return;let n=0;for(let o=t;n<e&&o<this.count;o++)this._removeParticle(o--,i,s)&&n++}removeQuantity(t,e){this.removeAt(0,t,e)}setDensity(){const t=this.container.actualOptions;for(const e in t.particles.groups)this._applyDensity(t.particles.groups[e],0,e);this._applyDensity(t.particles,t.manualParticles.length)}async update(t){var e,i;const s=this.container,n=[];for(const[,t]of s.pathGenerators)t.update();for(const[,i]of s.plugins)null===(e=i.update)||void 0===e||e.call(i,t);for(const e of this.array){const o=s.canvas.resizeFactor;o&&!e.ignoresResizeRatio&&(e.position.x*=o.width,e.position.y*=o.height,e.initialPosition.x*=o.width,e.initialPosition.y*=o.height),e.ignoresResizeRatio=!1,await this.interactionManager.reset(e);for(const[,s]of this.container.plugins){if(e.destroyed)break;null===(i=s.particleUpdate)||void 0===i||i.call(s,e,t)}for(const i of this.movers)i.isEnabled(e)&&i.move(e,t);e.destroyed?n.push(e):this.quadTree.insert(new ni(e.getPosition(),e))}for(const t of n)this.remove(t);await this.interactionManager.externalInteract(t);for(const e of this.array){for(const i of this.updaters)i.update(e,t);e.destroyed||e.spawning||await this.interactionManager.particlesInteract(e,t)}delete s.canvas.resizeFactor}_applyDensity(t,e,i){var s;if(!(null===(s=t.number.density)||void 0===s?void 0:s.enable))return;const n=t.number,o=this._initDensityFactor(n.density),a=n.value,r=n.limit>0?n.limit:a,l=Math.min(a,r)*o+e,h=Math.min(this.count,this.array.filter((t=>t.group===i)).length);this.limit=n.limit*o,h<l?this.push(Math.abs(l-h),void 0,t,i):h>l&&this.removeQuantity(h-l,i)}_initDensityFactor(t){const e=this.container;if(!e.canvas.element||!t.enable)return 1;const i=e.canvas.element,s=e.retina.pixelRatio;return i.width*i.height/(t.factor*s**2*t.area)}_pushParticle(t,e,i,s){try{let n=this.pool.pop();n?n.init(this.nextId,t,e,i):n=new si(this._engine,this.nextId,this.container,t,e,i);let o=!0;if(s&&(o=s(n)),!o)return;return this.array.push(n),this.zArray.push(n),this.nextId++,this._engine.dispatchEvent("particleAdded",{container:this.container,data:{particle:n}}),n}catch(t){return void console.warn(`error adding particle: ${t}`)}}_removeParticle(t,e,i){const s=this.array[t];if(!s||s.group!==e)return!1;s.destroy(i),this.array.splice(t,1);const n=this.zArray.indexOf(s);return this.zArray.splice(n,1),this.pool.push(s),this._engine.dispatchEvent("particleRemoved",{container:this.container,data:{particle:s}}),!0}}class ci{constructor(t){this.container=t}init(){const t=this.container,e=t.actualOptions;this.pixelRatio=!e.detectRetina||R()?1:window.devicePixelRatio,this.reduceFactor=1;const i=this.pixelRatio;if(t.canvas.element){const e=t.canvas.element;t.canvas.size.width=e.offsetWidth*i,t.canvas.size.height=e.offsetHeight*i}const s=e.particles;this.attractDistance=p(s.move.attract.distance)*i,this.sizeAnimationSpeed=p(s.size.animation.speed)*i,this.maxSpeed=p(s.move.gravity.maxSpeed)*i}initParticle(t){const e=t.options,i=this.pixelRatio,s=e.move.distance,n=t.retina;n.attractDistance=p(e.move.attract.distance)*i,n.moveDrift=p(e.move.drift)*i,n.moveSpeed=p(e.move.speed)*i,n.sizeAnimationSpeed=p(e.size.animation.speed)*i;const o=n.maxDistance;o.horizontal=void 0!==s.horizontal?s.horizontal*i:void 0,o.vertical=void 0!==s.vertical?s.vertical*i:void 0,n.maxSpeed=p(e.move.gravity.maxSpeed)*i}}function di(t){return t&&!t.destroyed}function ui(t,e,...i){const s=new ti(t,e);return Qe(s,...i),s}const pi={generate:t=>{const e=t.velocity.copy();return e.angle+=e.length*Math.PI/180,e},init:()=>{},update:()=>{},reset:()=>{}};class vi{constructor(t,e,i){this.id=e,this._engine=t,this.fpsLimit=120,this.smooth=!1,this._delay=0,this.duration=0,this.lifeTime=0,this._firstStart=!0,this.started=!1,this.destroyed=!1,this._paused=!0,this.lastFrameTime=0,this.zLayers=100,this.pageHidden=!1,this._sourceOptions=i,this._initialSourceOptions=i,this.retina=new ci(this),this.canvas=new Jt(this),this.particles=new hi(this._engine,this),this.frameManager=new Kt(this),this.pathGenerators=new Map,this.interactivity={mouse:{clicking:!1,inside:!1}},this.plugins=new Map,this.drawers=new Map,this._options=ui(this._engine,this),this.actualOptions=ui(this._engine,this),this._eventListeners=new Qt(this),"undefined"!=typeof IntersectionObserver&&IntersectionObserver&&(this._intersectionObserver=new IntersectionObserver((t=>this._intersectionManager(t)))),this._engine.dispatchEvent("containerBuilt",{container:this})}get options(){return this._options}get sourceOptions(){return this._sourceOptions}addClickHandler(t){if(!di(this))return;const e=this.interactivity.element;if(!e)return;const i=(e,i,s)=>{if(!di(this))return;const n=this.retina.pixelRatio,o={x:i.x*n,y:i.y*n},a=this.particles.quadTree.queryCircle(o,s*n);t(e,a)};let s=!1,n=!1;e.addEventListener("click",(t=>{if(!di(this))return;const e=t,s={x:e.offsetX||e.clientX,y:e.offsetY||e.clientY};i(t,s,1)})),e.addEventListener("touchstart",(()=>{di(this)&&(s=!0,n=!1)})),e.addEventListener("touchmove",(()=>{di(this)&&(n=!0)})),e.addEventListener("touchend",(t=>{if(di(this)){if(s&&!n){const e=t;let s=e.touches[e.touches.length-1];if(!s&&(s=e.changedTouches[e.changedTouches.length-1],!s))return;const n=this.canvas.element,o=n?n.getBoundingClientRect():void 0,a={x:s.clientX-(o?o.left:0),y:s.clientY-(o?o.top:0)};i(t,a,Math.max(s.radiusX,s.radiusY))}s=!1,n=!1}})),e.addEventListener("touchcancel",(()=>{di(this)&&(s=!1,n=!1)}))}addPath(t,e,i=!1){return!(!di(this)||!i&&this.pathGenerators.has(t))&&(this.pathGenerators.set(t,null!=e?e:pi),!0)}destroy(){if(!di(this))return;this.stop(),this.particles.destroy(),this.canvas.destroy();for(const[,t]of this.drawers)t.destroy&&t.destroy(this);for(const t of this.drawers.keys())this.drawers.delete(t);this._engine.plugins.destroy(this),this.destroyed=!0;const t=this._engine.dom(),e=t.findIndex((t=>t===this));e>=0&&t.splice(e,1),this._engine.dispatchEvent("containerDestroyed",{container:this})}draw(t){if(!di(this))return;let e=t;this._drawAnimationFrame=E()((async t=>{e&&(this.lastFrameTime=void 0,e=!1),await this.frameManager.nextFrame(t)}))}exportConfiguration(){return JSON.stringify(this.actualOptions,((t,e)=>{if("_engine"!==t&&"_container"!==t)return e}),2)}exportImage(t,e,i){const s=this.canvas.element;s&&s.toBlob(t,null!=e?e:"image/png",i)}exportImg(t){this.exportImage(t)}getAnimationStatus(){return!this._paused&&!this.pageHidden&&di(this)}handleClickMode(t){if(di(this)){this.particles.handleClickMode(t);for(const[,e]of this.plugins)e.handleClickMode&&e.handleClickMode(t)}}async init(){if(!di(this))return;const t=this._engine.plugins.getSupportedShapes();for(const e of t){const t=this._engine.plugins.getShapeDrawer(e);t&&this.drawers.set(e,t)}this._options=ui(this._engine,this,this._initialSourceOptions,this.sourceOptions),this.actualOptions=ui(this._engine,this,this._options);const e=this._engine.plugins.getAvailablePlugins(this);for(const[t,i]of e)this.plugins.set(t,i);this.retina.init(),await this.canvas.init(),this.zLayers=this.actualOptions.zLayers,this.duration=1e3*p(this.actualOptions.duration),this._delay=1e3*p(this.actualOptions.delay),this.lifeTime=0,this.fpsLimit=this.actualOptions.fpsLimit>0?this.actualOptions.fpsLimit:120,this.smooth=this.actualOptions.smooth;for(const[,t]of this.drawers)t.init&&await t.init(this);for(const[,t]of this.plugins)t.init&&await t.init();this._engine.dispatchEvent("containerInit",{container:this}),this.particles.init(),this.particles.setDensity();for(const[,t]of this.plugins)t.particlesSetup&&t.particlesSetup();this._engine.dispatchEvent("particlesSetup",{container:this})}async loadTheme(t){di(this)&&(this._currentTheme=t,await this.refresh())}pause(){if(di(this)&&(void 0!==this._drawAnimationFrame&&(D()(this._drawAnimationFrame),delete this._drawAnimationFrame),!this._paused)){for(const[,t]of this.plugins)t.pause&&t.pause();this.pageHidden||(this._paused=!0),this._engine.dispatchEvent("containerPaused",{container:this})}}play(t){if(!di(this))return;const e=this._paused||t;if(!this._firstStart||this.actualOptions.autoPlay){if(this._paused&&(this._paused=!1),e)for(const[,t]of this.plugins)t.play&&t.play();this._engine.dispatchEvent("containerPlay",{container:this}),this.draw(e||!1)}else this._firstStart=!1}async refresh(){if(di(this))return this.stop(),this.start()}async reset(){if(di(this))return this._options=ui(this._engine,this),this.refresh()}setNoise(t,e,i){di(this)&&this.setPath(t,e,i)}setPath(t,e,i){if(!t||!di(this))return;const s=Object.assign({},pi);if("function"==typeof t)s.generate=t,e&&(s.init=e),i&&(s.update=i);else{const e=s;s.generate=t.generate||e.generate,s.init=t.init||e.init,s.update=t.update||e.update}this.addPath("default",s,!0)}async start(){di(this)&&!this.started&&(await this.init(),this.started=!0,await new Promise((t=>{this._delayTimeout=setTimeout((async()=>{this._eventListeners.addListeners(),this.interactivity.element instanceof HTMLElement&&this._intersectionObserver&&this._intersectionObserver.observe(this.interactivity.element);for(const[,t]of this.plugins)t.start&&await t.start();this._engine.dispatchEvent("containerStarted",{container:this}),this.play(),t()}),this._delay)})))}stop(){if(di(this)&&this.started){this._delayTimeout&&(clearTimeout(this._delayTimeout),delete this._delayTimeout),this._firstStart=!0,this.started=!1,this._eventListeners.removeListeners(),this.pause(),this.particles.clear(),this.canvas.clear(),this.interactivity.element instanceof HTMLElement&&this._intersectionObserver&&this._intersectionObserver.unobserve(this.interactivity.element);for(const[,t]of this.plugins)t.stop&&t.stop();for(const t of this.plugins.keys())this.plugins.delete(t);this._sourceOptions=this._options,this._engine.dispatchEvent("containerStopped",{container:this})}}updateActualOptions(){this.actualOptions.responsive=[];const t=this.actualOptions.setResponsive(this.canvas.size.width,this.retina.pixelRatio,this._options);return this.actualOptions.setTheme(this._currentTheme),this.responsiveMaxWidth!==t&&(this.responsiveMaxWidth=t,!0)}_intersectionManager(t){if(di(this)&&this.actualOptions.pauseOnOutsideViewport)for(const e of t)e.target===this.interactivity.element&&(e.isIntersecting?this.play:this.pause)()}}class fi{constructor(){this._listeners=new Map}addEventListener(t,e){var i;this.removeEventListener(t,e),this._listeners.get(t)||this._listeners.set(t,[]),null===(i=this._listeners.get(t))||void 0===i||i.push(e)}dispatchEvent(t,e){var i;null===(i=this._listeners.get(t))||void 0===i||i.forEach((t=>t(e)))}hasEventListener(t){return!!this._listeners.get(t)}removeAllEventListeners(t){t?this._listeners.delete(t):this._listeners=new Map}removeEventListener(t,e){const i=this._listeners.get(t);if(!i)return;const s=i.length,n=i.indexOf(e);n<0||(1===s?this._listeners.delete(t):i.splice(n,1))}}function mi(t,e,i,s=!1){let n=e.get(t);return n&&!s||(n=[...i.values()].map((e=>e(t))),e.set(t,n)),n}class gi{constructor(t){this._engine=t,this.plugins=[],this._initializers={interactors:new Map,movers:new Map,updaters:new Map},this.interactors=new Map,this.movers=new Map,this.updaters=new Map,this.presets=new Map,this.drawers=new Map,this.pathGenerators=new Map}addInteractor(t,e){this._initializers.interactors.set(t,e)}addParticleMover(t,e){this._initializers.movers.set(t,e)}addParticleUpdater(t,e){this._initializers.updaters.set(t,e)}addPathGenerator(t,e){this.getPathGenerator(t)||this.pathGenerators.set(t,e)}addPlugin(t){this.getPlugin(t.id)||this.plugins.push(t)}addPreset(t,e,i=!1){!i&&this.getPreset(t)||this.presets.set(t,e)}addShapeDrawer(t,e){J(t,(t=>{this.getShapeDrawer(t)||this.drawers.set(t,e)}))}destroy(t){this.updaters.delete(t),this.movers.delete(t),this.interactors.delete(t)}getAvailablePlugins(t){const e=new Map;for(const i of this.plugins)i.needsPlugin(t.actualOptions)&&e.set(i.id,i.getPlugin(t));return e}getInteractors(t,e=!1){return mi(t,this.interactors,this._initializers.interactors,e)}getMovers(t,e=!1){return mi(t,this.movers,this._initializers.movers,e)}getPathGenerator(t){return this.pathGenerators.get(t)}getPlugin(t){return this.plugins.find((e=>e.id===t))}getPreset(t){return this.presets.get(t)}getShapeDrawer(t){return this.drawers.get(t)}getSupportedShapes(){return this.drawers.keys()}getUpdaters(t,e=!1){return mi(t,this.updaters,this._initializers.updaters,e)}loadOptions(t,e){for(const i of this.plugins)i.loadOptions(t,e)}loadParticlesOptions(t,e,...i){const s=this.updaters.get(t);if(s)for(const t of s)t.loadOptions&&t.loadOptions(e,...i)}}class yi{constructor(){this.key="hsl",this.stringPrefix="hsl"}handleColor(t){var e;const i=null!==(e=t.value.hsl)&&void 0!==e?e:t.value;if(void 0!==i.h&&void 0!==i.s&&void 0!==i.l)return pt(i)}handleRangeColor(t){var e;const i=null!==(e=t.value.hsl)&&void 0!==e?e:t.value;if(void 0!==i.h&&void 0!==i.l)return pt({h:p(i.h),l:p(i.l),s:p(i.s)})}parseString(t){if(!t.startsWith("hsl"))return;const e=/hsla?\(\s*(\d+)\s*,\s*(\d+)%\s*,\s*(\d+)%\s*(,\s*([\d.%]+)\s*)?\)/i.exec(t);return e?vt({a:e.length>4?C(e[5]):1,h:parseInt(e[1],10),l:parseInt(e[3],10),s:parseInt(e[2],10)}):void 0}}class bi{constructor(){this.key="rgb",this.stringPrefix="rgb"}handleColor(t){var e;const i=null!==(e=t.value.rgb)&&void 0!==e?e:t.value;if(void 0!==i.r)return i}handleRangeColor(t){var e;const i=null!==(e=t.value.rgb)&&void 0!==e?e:t.value;if(void 0!==i.r)return{r:p(i.r),g:p(i.g),b:p(i.b)}}parseString(t){if(!t.startsWith(this.stringPrefix))return;const e=/rgba?\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*(,\s*([\d.%]+)\s*)?\)/i.exec(t);return e?{a:e.length>4?C(e[5]):1,b:parseInt(e[3],10),g:parseInt(e[2],10),r:parseInt(e[1],10)}:void 0}}class wi{constructor(t){this.container=t,this.type="external"}}class _i{constructor(t){this.container=t,this.type="particles"}}const xi=new bi,zi=new yi;st(xi),st(zi);const Mi=new class{constructor(){this._configs=new Map,this._domArray=[],this._eventDispatcher=new fi,this.plugins=new gi(this)}get configs(){const t={};for(const[e,i]of this._configs)t[e]=i;return t}addConfig(t,e){var i;"string"==typeof t?e&&(e.name=t,this._configs.set(t,e)):this._configs.set(null!==(i=t.name)&&void 0!==i?i:"default",t)}addEventListener(t,e){this._eventDispatcher.addEventListener(t,e)}async addInteractor(t,e){this.plugins.addInteractor(t,e),await this.refresh()}async addMover(t,e){this.plugins.addParticleMover(t,e),await this.refresh()}async addParticleUpdater(t,e){this.plugins.addParticleUpdater(t,e),await this.refresh()}async addPathGenerator(t,e){this.plugins.addPathGenerator(t,e),await this.refresh()}async addPlugin(t){this.plugins.addPlugin(t),await this.refresh()}async addPreset(t,e,i=!1){this.plugins.addPreset(t,e,i),await this.refresh()}async addShape(t,e,i,s,n){let o;o="function"==typeof e?{afterEffect:s,destroy:n,draw:e,init:i}:e,this.plugins.addShapeDrawer(t,o),await this.refresh()}dispatchEvent(t,e){this._eventDispatcher.dispatchEvent(t,e)}dom(){return this._domArray}domItem(t){const e=this.dom(),i=e[t];if(i&&!i.destroyed)return i;e.splice(t,1)}async load(t){var e,i,s;const n=null!==(e=t.id)&&void 0!==e?e:`tsparticles${Math.floor(1e4*h())}`,{index:o,url:a}=t,r=a?await async function(t){const e=Z(t.url,t.index);if(!e)return t.fallback;const i=await fetch(e);return i.ok?i.json():(console.error(`tsParticles - Error ${i.status} while retrieving config file`),t.fallback)}({fallback:t.options,index:o,url:a}):t.options;let l=null!==(i=t.element)&&void 0!==i?i:document.getElementById(n);l||(l=document.createElement("div"),l.id=n,null===(s=document.querySelector("body"))||void 0===s||s.append(l));const c=Z(r,o),d=this.dom(),u=d.findIndex((t=>t.id===n));if(u>=0){const t=this.domItem(u);t&&!t.destroyed&&(t.destroy(),d.splice(u,1))}let p;if("canvas"===l.tagName.toLowerCase())p=l,p.dataset[Lt]="false";else{const t=l.getElementsByTagName("canvas");t.length?(p=t[0],p.dataset[Lt]="false"):(p=document.createElement("canvas"),p.dataset[Lt]="true",l.appendChild(p))}p.style.width||(p.style.width="100%"),p.style.height||(p.style.height="100%");const v=new vi(this,n,c);return u>=0?d.splice(u,0,v):d.push(v),v.canvas.loadCanvas(p),await v.start(),v}async refresh(){for(const t of this.dom())await t.refresh()}removeEventListener(t,e){this._eventDispatcher.removeEventListener(t,e)}setOnClickHandler(t){const e=this.dom();if(!e.length)throw new Error("Can only set click handlers after calling tsParticles.load()");for(const i of e)i.addClickHandler(t)}},{particlesJS:Pi,pJSDom:Oi}=(t=>{const e=(e,i)=>t.load({id:e,options:i});e.load=(e,i,s)=>{t.load({id:e,url:i}).then((t=>{t&&s(t)})).catch((()=>{s(void 0)}))},e.setOnClickHandler=e=>{t.setOnClickHandler(e)};return{particlesJS:e,pJSDom:t.dom()}})(Mi);return e})()));
|
package/tsparticles.pjs.js
CHANGED
@@ -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.0-alpha.
|
7
|
+
* v3.0.0-alpha.1
|
8
8
|
*/
|
9
9
|
(function webpackUniversalModuleDefinition(root, factory) {
|
10
10
|
if(typeof exports === 'object' && typeof module === 'object')
|