@tsparticles/preset-fire 4.0.0-alpha.5 → 4.0.0-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/{731.min.js → 153.min.js} +1 -1
- package/{730.min.js → 172.min.js} +1 -1
- package/188.min.js +1 -0
- package/{270.min.js → 220.min.js} +1 -1
- package/{834.min.js → 260.min.js} +1 -1
- package/304.min.js +1 -0
- package/361.min.js +1 -0
- package/392.min.js +1 -0
- package/404.min.js +1 -0
- package/467.min.js +1 -0
- package/48.min.js +1 -0
- package/508.min.js +1 -1
- package/592.min.js +1 -0
- package/63.min.js +1 -0
- package/632.min.js +1 -0
- package/659.min.js +1 -0
- package/700.min.js +1 -0
- package/{844.min.js → 714.min.js} +1 -1
- package/719.min.js +1 -0
- package/72.min.js +1 -0
- package/74.min.js +1 -0
- package/{596.min.js → 750.min.js} +1 -1
- package/857.min.js +1 -0
- package/86.min.js +1 -0
- package/892.min.js +1 -0
- package/{231.min.js → 957.min.js} +1 -1
- package/959.min.js +1 -0
- package/README.md +32 -1
- package/browser/options.js +6 -4
- package/cjs/options.js +6 -4
- package/dist_browser_options_js.js +2 -2
- package/esm/options.js +6 -4
- package/node_modules_pnpm_tsparticles_basic_4_0_0-beta_11_node_modules_tsparticles_basic_browser_index_js.js +30 -0
- package/node_modules_pnpm_tsparticles_interaction-external-push_4_0_0-beta_11__tsparticles_engine_4_0-5dceb7.js +130 -0
- package/node_modules_pnpm_tsparticles_interaction-external-push_4_0_0-beta_11__tsparticles_engine_4_0-a32864.js +40 -0
- package/{node_modules_pnpm_tsparticles_plugin-hex-color_4_0_0-beta_1_node_modules_tsparticles_plugin-h-a0aea9.js → node_modules_pnpm_tsparticles_plugin-hex-color_4_0_0-beta_11__tsparticles_engine_4_0_0-beta_1-5e0ff2.js} +7 -7
- package/{node_modules_pnpm_tsparticles_plugin-hex-color_4_0_0-beta_1_node_modules_tsparticles_plugin-h-8932d7.js → node_modules_pnpm_tsparticles_plugin-hex-color_4_0_0-beta_11__tsparticles_engine_4_0_0-beta_1-b0d0ee.js} +7 -7
- package/node_modules_pnpm_tsparticles_plugin-hsl-color_4_0_0-beta_11__tsparticles_engine_4_0_0-beta_1-060416.js +30 -0
- package/{node_modules_pnpm_tsparticles_plugin-hsl-color_4_0_0-beta_1_node_modules_tsparticles_plugin-h-1737bf.js → node_modules_pnpm_tsparticles_plugin-hsl-color_4_0_0-beta_11__tsparticles_engine_4_0_0-beta_1-a6d106.js} +7 -7
- package/node_modules_pnpm_tsparticles_plugin-interactivity_4_0_0-beta_11__tsparticles_engine_4_0_0-be-47e198.js +120 -0
- package/node_modules_pnpm_tsparticles_plugin-interactivity_4_0_0-beta_11__tsparticles_engine_4_0_0-be-710e43.js +70 -0
- package/{node_modules_pnpm_tsparticles_plugin-move_4_0_0-beta_1_node_modules_tsparticles_plugin-move_b-c23e73.js → node_modules_pnpm_tsparticles_plugin-move_4_0_0-beta_11__tsparticles_engine_4_0_0-beta_11_nod-3a792b.js} +7 -7
- package/node_modules_pnpm_tsparticles_plugin-move_4_0_0-beta_11__tsparticles_engine_4_0_0-beta_11_nod-e1bc4b.js +30 -0
- package/node_modules_pnpm_tsparticles_plugin-rgb-color_4_0_0-beta_11__tsparticles_engine_4_0_0-beta_1-d9836d.js +30 -0
- package/{node_modules_pnpm_tsparticles_plugin-rgb-color_4_0_0-beta_1_node_modules_tsparticles_plugin-r-ae3d6b.js → node_modules_pnpm_tsparticles_plugin-rgb-color_4_0_0-beta_11__tsparticles_engine_4_0_0-beta_1-f22022.js} +7 -7
- package/node_modules_pnpm_tsparticles_shape-circle_4_0_0-beta_11__tsparticles_engine_4_0_0-beta_11_no-7552ae.js +40 -0
- package/{node_modules_pnpm_tsparticles_shape-circle_4_0_0-beta_1_node_modules_tsparticles_shape-circle-c2187f.js → node_modules_pnpm_tsparticles_shape-circle_4_0_0-beta_11__tsparticles_engine_4_0_0-beta_11_no-b06fc7.js} +7 -7
- package/node_modules_pnpm_tsparticles_updater-opacity_4_0_0-beta_11__tsparticles_engine_4_0_0-beta_11-8f9e09.js +30 -0
- package/{node_modules_pnpm_tsparticles_updater-opacity_4_0_0-beta_1_node_modules_tsparticles_updater-o-8a311f.js → node_modules_pnpm_tsparticles_updater-opacity_4_0_0-beta_11__tsparticles_engine_4_0_0-beta_11-da77ce.js} +7 -7
- package/{node_modules_pnpm_tsparticles_updater-out-modes_4_0_0-beta_1_node_modules_tsparticles_updater-265a6a.js → node_modules_pnpm_tsparticles_updater-out-modes_4_0_0-beta_11__tsparticles_engine_4_0_0-beta_-df7144.js} +7 -7
- package/node_modules_pnpm_tsparticles_updater-paint_4_0_0-beta_11__tsparticles_engine_4_0_0-beta_11_n-589482.js +30 -0
- package/node_modules_pnpm_tsparticles_updater-paint_4_0_0-beta_11__tsparticles_engine_4_0_0-beta_11_n-b1f330.js +30 -0
- package/node_modules_pnpm_tsparticles_updater-size_4_0_0-beta_11__tsparticles_engine_4_0_0-beta_11_no-a47b81.js +30 -0
- package/{node_modules_pnpm_tsparticles_updater-size_4_0_0-beta_1_node_modules_tsparticles_updater-size-124f3f.js → node_modules_pnpm_tsparticles_updater-size_4_0_0-beta_11__tsparticles_engine_4_0_0-beta_11_no-d2508a.js} +7 -7
- package/package.json +5 -5
- package/report.html +1 -1
- package/tsparticles.preset.fire.bundle.js +323 -313
- package/tsparticles.preset.fire.bundle.min.js +2 -2
- package/tsparticles.preset.fire.js +1 -1
- package/tsparticles.preset.fire.min.js +1 -1
- package/vendors-node_modules_pnpm_tsparticles_engine_4_0_0-beta_11_node_modules_tsparticles_engine_br-ca098e.js +100 -0
- package/vendors-node_modules_pnpm_tsparticles_plugin-interactivity_4_0_0-beta_11__tsparticles_engine_-32e86c.js +50 -0
- package/vendors-node_modules_pnpm_tsparticles_plugin-move_4_0_0-beta_11__tsparticles_engine_4_0_0-bet-5f2b78.js +40 -0
- package/vendors-node_modules_pnpm_tsparticles_updater-out-modes_4_0_0-beta_11__tsparticles_engine_4_0-09fa1a.js +80 -0
- package/126.min.js +0 -1
- package/182.min.js +0 -1
- package/204.min.js +0 -1
- package/278.min.js +0 -1
- package/28.min.js +0 -1
- package/3.min.js +0 -1
- package/302.min.js +0 -1
- package/316.min.js +0 -1
- package/337.min.js +0 -1
- package/382.min.js +0 -1
- package/398.min.js +0 -1
- package/406.min.js +0 -1
- package/463.min.js +0 -1
- package/530.min.js +0 -1
- package/646.min.js +0 -1
- package/830.min.js +0 -1
- package/85.min.js +0 -1
- package/922.min.js +0 -1
- package/930.min.js +0 -1
- package/node_modules_pnpm_tsparticles_basic_4_0_0-beta_1_node_modules_tsparticles_basic_browser_index_js.js +0 -30
- package/node_modules_pnpm_tsparticles_interaction-external-push_4_0_0-beta_1_node_modules_tsparticles-26affc.js +0 -130
- package/node_modules_pnpm_tsparticles_interaction-external-push_4_0_0-beta_1_node_modules_tsparticles-d5f96b.js +0 -40
- package/node_modules_pnpm_tsparticles_plugin-hsl-color_4_0_0-beta_1_node_modules_tsparticles_plugin-h-1179c3.js +0 -30
- package/node_modules_pnpm_tsparticles_plugin-interactivity_4_0_0-beta_1_node_modules_tsparticles_plug-908f96.js +0 -120
- package/node_modules_pnpm_tsparticles_plugin-interactivity_4_0_0-beta_1_node_modules_tsparticles_plug-d6e6b1.js +0 -70
- package/node_modules_pnpm_tsparticles_plugin-move_4_0_0-beta_1_node_modules_tsparticles_plugin-move_b-aa7108.js +0 -30
- package/node_modules_pnpm_tsparticles_plugin-rgb-color_4_0_0-beta_1_node_modules_tsparticles_plugin-r-0f881a.js +0 -30
- package/node_modules_pnpm_tsparticles_shape-circle_4_0_0-beta_1_node_modules_tsparticles_shape-circle-07826a.js +0 -40
- package/node_modules_pnpm_tsparticles_updater-fill-color_4_0_0-beta_1_node_modules_tsparticles_update-75868d.js +0 -30
- package/node_modules_pnpm_tsparticles_updater-fill-color_4_0_0-beta_1_node_modules_tsparticles_update-7cca03.js +0 -30
- package/node_modules_pnpm_tsparticles_updater-opacity_4_0_0-beta_1_node_modules_tsparticles_updater-o-138fb5.js +0 -30
- package/node_modules_pnpm_tsparticles_updater-size_4_0_0-beta_1_node_modules_tsparticles_updater-size-cbf46f.js +0 -30
- package/umd/bundle.js +0 -17
- package/umd/index.js +0 -66
- package/umd/options.js +0 -53
- package/vendors-node_modules_pnpm_tsparticles_engine_4_0_0-beta_1_node_modules_tsparticles_engine_bro-0bb20b.js +0 -100
- package/vendors-node_modules_pnpm_tsparticles_plugin-interactivity_4_0_0-beta_1_node_modules_tspartic-d557a0.js +0 -50
- package/vendors-node_modules_pnpm_tsparticles_plugin-move_4_0_0-beta_1_node_modules_tsparticles_plugi-2dea06.js +0 -40
- package/vendors-node_modules_pnpm_tsparticles_updater-out-modes_4_0_0-beta_1_node_modules_tsparticles-a5ec2f.js +0 -80
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
!function(e,t){if("object"==typeof exports&&"object"==typeof module)module.exports=t();else if("function"==typeof define&&define.amd)define([],t);else{var i=t();for(var a in i)("object"==typeof exports?exports:e)[a]=i[a]}}(this,()=>(()=>{"use strict";var e,t,i,a={6027(e,t,i){i.d(t,{$G:()=>D,$_:()=>E,$v:()=>B,$x:()=>z,BF:()=>ep,DN:()=>H,D_:()=>er,Dv:()=>eo,Eo:()=>U,Fl:()=>ev,Ie:()=>R,JC:()=>G,K3:()=>ei,L1:()=>T,LD:()=>es,MX:()=>l,NF:()=>n,Nu:()=>eu,Nx:()=>j,PZ:()=>X,Pf:()=>em,R1:()=>v,RF:()=>m,RV:()=>Z,Rq:()=>A,U0:()=>I,Ug:()=>c,WH:()=>J,X$:()=>y,X_:()=>Q,Xu:()=>d,Zp:()=>k,a5:()=>o,aE:()=>eh,bo:()=>u,ce:()=>g,dm:()=>w,dv:()=>K,eb:()=>a,eu:()=>O,gd:()=>p,hB:()=>S,hK:()=>eg,hv:()=>V,i8:()=>q,iU:()=>el,iX:()=>x,jn:()=>ef,lA:()=>ea,mR:()=>h,nK:()=>r,nq:()=>W,oi:()=>_,ou:()=>Y,rq:()=>b,tA:()=>en,tR:()=>ey,vF:()=>C,vS:()=>P,vd:()=>ed,w2:()=>F,wM:()=>ee,xH:()=>N,xd:()=>M,yj:()=>s,yx:()=>L,z$:()=>f,z9:()=>et,zg:()=>ec,zs:()=>$});let a="generated",s="source-over",n="resize",r="visibilitychange",o=100,l=.5,d=1e3,u={x:0,y:0,z:0},c={a:1,b:0,c:0,d:1},h="random",p=2,v=2*Math.PI,f=60,g="true",y="false",m="canvas",b=0,w=2,x=100,M=1,z=1,k=1,S=1,_=255,P=360,O=100,E=100,T=0,L=0,I=60,R=0,D=.25,A=.75,$=1,F=0,Z=1,V=1,G=1,C=0,q=120,H=0,j=0,B=1e4,X=0,N=1,K=0,J=1,U=1,Q=0,Y=0,W=1,ee=0,et=0,ei=1,ea=1,es=1,en=0,er=1,eo=0,el=1,ed=0,eu=3,ec=6,eh=1,ep=1,ev=0,ef=0,eg=0,ey=0,em=1},2130(e,t,i){i.d(t,{jl:()=>l,M_:()=>d}),(a=s||(s={})).circle="circle",a.rectangle="rectangle";var a,s,n=i(1451),r=i(6027);class o{position;type;constructor(e,t,i){this.position={x:e,y:t},this.type=i}_resetPosition(e,t){this.position.x=e,this.position.y=t}}class l extends o{radius;constructor(e,t,i){super(e,t,s.circle),this.radius=i}contains(e){return(0,n.gp)(e,this.position,this.radius)}intersects(e){let t=this.position,i=e.position,a=this.radius,n=Math.abs(i.x-t.x),o=Math.abs(i.y-t.y);if(e instanceof l||e.type===s.circle)return a+e.radius>Math.hypot(n,o);if(e instanceof d||e.type===s.rectangle){let{width:t,height:i}=e.size;return Math.pow(n-t,r.dm)+Math.pow(o-i,r.dm)<=a**r.dm||n<=a+t&&o<=a+i||n<=t||o<=i}return!1}reset(e,t,i){return this._resetPosition(e,t),this.radius=i,this}}class d extends o{size;constructor(e,t,i,a){super(e,t,s.rectangle),this.size={height:a,width:i}}contains(e){let t=this.size.width,i=this.size.height,a=this.position;return e.x>=a.x&&e.x<=a.x+t&&e.y>=a.y&&e.y<=a.y+i}intersects(e){if(e instanceof l)return e.intersects(this);if(!(e instanceof d))return!1;let t=this.size.width,i=this.size.height,a=this.position,s=e.position,n=e.size,r=n.width,o=n.height;return s.x<a.x+t&&s.x+r>a.x&&s.y<a.y+i&&s.y+o>a.y}reset(e,t,i,a){return this._resetPosition(e,t),this.size.width=i,this.size.height=a,this}}},5186(e,t,i){i.d(t,{M:()=>r,p:()=>n});var a=i(6027);function s(e){return"z"in e?e.z:a.bo.z}class n{x;y;z;constructor(e=a.bo.x,t=a.bo.y,i=a.bo.z){this.x=e,this.y=t,this.z=i}static get origin(){return n.create(a.bo.x,a.bo.y,a.bo.z)}get angle(){return Math.atan2(this.y,this.x)}set angle(e){this._updateFromAngle(e,this.length)}get length(){return Math.sqrt(this.getLengthSq())}set length(e){this._updateFromAngle(this.angle,e)}static clone(e){return n.create(e.x,e.y,s(e))}static create(e,t,i){return"number"==typeof e?new n(e,t??a.bo.y,i??a.bo.z):new n(e.x,e.y,s(e))}add(e){return n.create(this.x+e.x,this.y+e.y,this.z+s(e))}addTo(e){this.x+=e.x,this.y+=e.y,this.z+=s(e)}copy(){return n.clone(this)}div(e){return n.create(this.x/e,this.y/e,this.z/e)}divTo(e){this.x/=e,this.y/=e,this.z/=e}getLengthSq(){return this.x**a.dm+this.y**a.dm}mult(e){return n.create(this.x*e,this.y*e,this.z*e)}multTo(e){this.x*=e,this.y*=e,this.z*=e}normalize(){let e=this.length;e!=a.dv&&this.multTo(a.hB/e)}rotate(e){return n.create(this.x*Math.cos(e)-this.y*Math.sin(e),this.x*Math.sin(e)+this.y*Math.cos(e),a.bo.z)}setTo(e){this.x=e.x,this.y=e.y,this.z=s(e)}sub(e){return n.create(this.x-e.x,this.y-e.y,this.z-s(e))}subFrom(e){this.x-=e.x,this.y-=e.y,this.z-=s(e)}_updateFromAngle(e,t){this.x=Math.cos(e)*t,this.y=Math.sin(e)*t}}class r extends n{constructor(e=a.bo.x,t=a.bo.y){super(e,t,a.bo.z)}static get origin(){return r.create(a.bo.x,a.bo.y)}static clone(e){return r.create(e.x,e.y)}static create(e,t){return"number"==typeof e?new r(e,t??a.bo.y):new r(e.x,e.y)}}},1187(e,t,i){var a,s;i.d(t,{H:()=>a}),(s=a||(a={})).increasing="increasing",s.decreasing="decreasing"},4840(e,t,i){var a,s;i.d(t,{F:()=>a}),(s=a||(a={})).bottom="bottom",s.bottomLeft="bottom-left",s.bottomRight="bottom-right",s.left="left",s.none="none",s.right="right",s.top="top",s.topLeft="top-left",s.topRight="top-right",s.outside="outside",s.inside="inside"},5248(e,t,i){var a,s;i.d(t,{v:()=>a}),(s=a||(a={})).bottom="bottom",s.left="left",s.right="right",s.top="top"},9993(e,t,i){var a,s;i.d(t,{g:()=>a}),(s=a||(a={})).auto="auto",s.increase="increase",s.decrease="decrease",s.random="random"},6192(e,t,i){var a,s;i.d(t,{d:()=>a}),(s=a||(a={})).delete="delete",s.wait="wait"},4435(e,t,i){var a,s;i.d(t,{Y:()=>a}),(s=a||(a={})).bounce="bounce",s.none="none",s.out="out",s.destroy="destroy",s.split="split"},9563(e,t,i){var a,s;i.d(t,{q:()=>a}),(s=a||(a={})).precise="precise",s.percent="percent"},4393(e,t,i){var a,s;i.d(t,{H:()=>a}),(s=a||(a={})).darken="darken",s.enlighten="enlighten"},9319(e,t,i){var a,s;i.d(t,{V:()=>a}),(s=a||(a={})).none="none",s.max="max",s.min="min"},4085(e,t,i){var a,s;i.d(t,{B:()=>a}),(s=a||(a={})).configAdded="configAdded",s.containerInit="containerInit",s.particlesSetup="particlesSetup",s.containerStarted="containerStarted",s.containerStopped="containerStopped",s.containerDestroyed="containerDestroyed",s.containerPaused="containerPaused",s.containerPlay="containerPlay",s.containerBuilt="containerBuilt",s.particleAdded="particleAdded",s.particleDestroyed="particleDestroyed",s.particleRemoved="particleRemoved"},9827(e,t,i){var a,s;i.d(t,{x:()=>a}),(s=a||(a={})).normal="normal",s.inside="inside",s.outside="outside"},1004(e,t,i){var a,s;i.d(t,{S:()=>a}),(s=a||(a={})).max="max",s.min="min",s.random="random"},4179(e,t,i){i.d(t,{A:()=>r});var a=i(3829),s=i(5365),n=i(4899);class r extends n.O{animation;constructor(){super(),this.animation=new s.i}static create(e,t){let i=new r;return i.load(e),void 0!==t&&((0,a.Kg)(t)||(0,a.cy)(t)?i.load({value:t}):i.load(t)),i}load(e){if(super.load(e),(0,a.kZ)(e))return;let t=e.animation;void 0!==t&&(void 0===t.enable?this.animation.load(e.animation):this.animation.h.load(t))}}},4570(e,t,i){i.d(t,{Q:()=>l,p:()=>o});var a=i(9993),s=i(1004),n=i(3829),r=i(1451);class o{count;decay;delay;enable;speed;sync;constructor(){this.count=0,this.enable=!1,this.speed=1,this.decay=0,this.delay=0,this.sync=!1}load(e){(0,n.kZ)(e)||(void 0!==e.count&&(this.count=(0,r.DT)(e.count)),void 0!==e.enable&&(this.enable=e.enable),void 0!==e.speed&&(this.speed=(0,r.DT)(e.speed)),void 0!==e.decay&&(this.decay=(0,r.DT)(e.decay)),void 0!==e.delay&&(this.delay=(0,r.DT)(e.delay)),void 0!==e.sync&&(this.sync=e.sync))}}class l extends o{mode;startValue;constructor(){super(),this.mode=a.g.auto,this.startValue=s.S.random}load(e){super.load(e),(0,n.kZ)(e)||(void 0!==e.mode&&(this.mode=e.mode),void 0!==e.startValue&&(this.startValue=e.startValue))}}},2845(e,t,i){i.d(t,{e:()=>r});var a=i(4570),s=i(3829),n=i(1451);class r extends a.p{max;min;offset;constructor(e,t){super(),this.min=e,this.max=t,this.offset=0,this.sync=!0}load(e){super.load(e),(0,s.kZ)(e)||(void 0!==e.max&&(this.max=e.max),void 0!==e.min&&(this.min=e.min),void 0!==e.offset&&(this.offset=(0,n.DT)(e.offset)))}}},5365(e,t,i){i.d(t,{i:()=>r});var a=i(6027),s=i(2845),n=i(3829);class r{h=new s.e(a.L1,a.vS);l=new s.e(a.vd,a.$_);s=new s.e(a.yx,a.eu);load(e){(0,n.kZ)(e)||(this.h.load(e.h),this.s.load(e.s),this.l.load(e.l))}}},4757(e,t,i){i.d(t,{J:()=>c});var a=i(4477),s=i(3829),n=i(4899);class r{color;image;opacity;position;repeat;size;constructor(){this.color=new n.O,this.color.value="",this.image="",this.position="",this.repeat="",this.size="",this.opacity=1}load(e){(0,s.kZ)(e)||(void 0!==e.color&&(this.color=n.O.create(this.color,e.color)),void 0!==e.image&&(this.image=e.image),void 0!==e.position&&(this.position=e.position),void 0!==e.repeat&&(this.repeat=e.repeat),void 0!==e.size&&(this.size=e.size),void 0!==e.opacity&&(this.opacity=e.opacity))}}class o{enable;zIndex;constructor(){this.enable=!0,this.zIndex=0}load(e){(0,s.kZ)(e)||(void 0!==e.enable&&(this.enable=e.enable),void 0!==e.zIndex&&(this.zIndex=e.zIndex))}}class l{delay;enable;constructor(){this.delay=.5,this.enable=!0}load(e){(0,s.kZ)(e)||(void 0!==e.delay&&(this.delay=e.delay),void 0!==e.enable&&(this.enable=e.enable))}}var d=i(9725),u=i(1451);class c{autoPlay;background;clear;defaultThemes;delay;detectRetina;duration;fpsLimit;fullScreen;hdr;key;name;palette;particles;pauseOnBlur;pauseOnOutsideViewport;preset;resize;smooth;style;zLayers;_container;_pluginManager;constructor(e,t){this._pluginManager=e,this._container=t,this.autoPlay=!0,this.background=new r,this.clear=!0,this.defaultThemes={},this.delay=0,this.fullScreen=new o,this.detectRetina=!0,this.duration=0,this.fpsLimit=120,this.hdr=!0,this.particles=(0,d.y)(this._pluginManager,this._container),this.pauseOnBlur=!0,this.pauseOnOutsideViewport=!0,this.resize=new l,this.smooth=!1,this.style={},this.zLayers=100}load(e){if((0,s.kZ)(e))return;void 0!==e.preset&&(this.preset=e.preset,(0,a.wJ)(this.preset,e=>{this._importPreset(e)})),void 0!==e.palette&&(this.palette=e.palette,this._importPalette(this.palette)),void 0!==e.autoPlay&&(this.autoPlay=e.autoPlay),void 0!==e.clear&&(this.clear=e.clear),void 0!==e.key&&(this.key=e.key),void 0!==e.name&&(this.name=e.name),void 0!==e.delay&&(this.delay=(0,u.DT)(e.delay));let t=e.detectRetina;void 0!==t&&(this.detectRetina=t),void 0!==e.duration&&(this.duration=(0,u.DT)(e.duration));let i=e.fpsLimit;void 0!==i&&(this.fpsLimit=i),void 0!==e.hdr&&(this.hdr=e.hdr),void 0!==e.pauseOnBlur&&(this.pauseOnBlur=e.pauseOnBlur),void 0!==e.pauseOnOutsideViewport&&(this.pauseOnOutsideViewport=e.pauseOnOutsideViewport),void 0!==e.zLayers&&(this.zLayers=e.zLayers),this.background.load(e.background);let n=e.fullScreen;(0,s.Lm)(n)?this.fullScreen.enable=n:this.fullScreen.load(n),this.particles.load(e.particles),this.resize.load(e.resize),this.style=(0,a.zw)(this.style,e.style),void 0!==e.smooth&&(this.smooth=e.smooth),this._pluginManager.plugins.forEach(t=>{t.loadOptions(this._container,this,e)})}_importPalette=e=>{let t=this._pluginManager.getPalette(e);t&&this.load({background:{color:t.background},blend:{enable:!0,mode:t.blendMode},particles:{fill:{color:t.fill?{value:t.colors}:void 0,enable:t.fill},stroke:t.fill?void 0:t.colors.map(e=>({color:{value:e},width:1}))}})};_importPreset=e=>{this.load(this._pluginManager.getPreset(e))}}},4899(e,t,i){i.d(t,{O:()=>s});var a=i(3829);class s{value;constructor(){this.value=""}static create(e,t){let i=new s;return i.load(e),void 0!==t&&((0,a.Kg)(t)||(0,a.cy)(t)?i.load({value:t}):i.load(t)),i}load(e){!(0,a.kZ)(e)&&((0,a.kZ)(e.value)||(this.value=e.value))}}},5122(e,t,i){i.d(t,{w:()=>n});var a=i(2109),s=i(3829);class n{horizontal;vertical;constructor(){this.horizontal=new a.F,this.vertical=new a.F}load(e){(0,s.kZ)(e)||(this.horizontal.load(e.horizontal),this.vertical.load(e.vertical))}}},2109(e,t,i){i.d(t,{F:()=>s});var a=i(598);class s extends a.PV{constructor(){super(),this.value=1}}},3823(e,t,i){i.d(t,{S:()=>r});var a=i(4179),s=i(3829),n=i(1451);class r{color;enable;opacity;constructor(){this.enable=!0,this.color=new a.A,this.color.value="#fff",this.opacity=1}load(e){(0,s.kZ)(e)||(void 0!==e.color&&(this.color=a.A.create(this.color,e.color)),void 0!==e.enable&&(this.enable=e.enable),void 0!==e.opacity&&(this.opacity=(0,n.DT)(e.opacity)))}}},3551(e,t,i){i.d(t,{y:()=>h});var a=i(4840),s=i(3829),n=i(704),r=i(7602),o=i(4809),l=i(4238),d=i(4110),u=i(454),c=i(1451);class h{angle;center;decay;direction;distance;drift;enable;gravity;outModes;path;random;size;speed;spin;straight;vibrate;warp;constructor(){this.angle=new n.h,this.center=new r.Z,this.decay=0,this.distance={},this.direction=a.F.none,this.drift=0,this.enable=!1,this.gravity=new o.y,this.path=new l.v,this.outModes=new d.j,this.random=!1,this.size=!1,this.speed=2,this.spin=new u.t,this.straight=!1,this.vibrate=!1,this.warp=!1}load(e){if((0,s.kZ)(e))return;this.angle.load((0,s.Et)(e.angle)?{value:e.angle}:e.angle),this.center.load(e.center),void 0!==e.decay&&(this.decay=(0,c.DT)(e.decay)),void 0!==e.direction&&(this.direction=e.direction),void 0!==e.distance&&(this.distance=(0,s.Et)(e.distance)?{horizontal:e.distance,vertical:e.distance}:{...e.distance}),void 0!==e.drift&&(this.drift=(0,c.DT)(e.drift)),void 0!==e.enable&&(this.enable=e.enable),this.gravity.load(e.gravity);let t=e.outModes;void 0!==t&&((0,s.Gv)(t)?this.outModes.load(t):this.outModes.load({default:t})),this.path.load(e.path),void 0!==e.random&&(this.random=e.random),void 0!==e.size&&(this.size=e.size),void 0!==e.speed&&(this.speed=(0,c.DT)(e.speed)),this.spin.load(e.spin),void 0!==e.straight&&(this.straight=e.straight),void 0!==e.vibrate&&(this.vibrate=e.vibrate),void 0!==e.warp&&(this.warp=e.warp)}}},704(e,t,i){i.d(t,{h:()=>n});var a=i(3829),s=i(1451);class n{offset;value;constructor(){this.offset=0,this.value=90}load(e){(0,a.kZ)(e)||(void 0!==e.offset&&(this.offset=(0,s.DT)(e.offset)),void 0!==e.value&&(this.value=(0,s.DT)(e.value)))}}},7602(e,t,i){i.d(t,{Z:()=>n});var a=i(9563),s=i(3829);class n{mode;radius;x;y;constructor(){this.x=50,this.y=50,this.mode=a.q.percent,this.radius=0}load(e){(0,s.kZ)(e)||(void 0!==e.x&&(this.x=e.x),void 0!==e.y&&(this.y=e.y),void 0!==e.mode&&(this.mode=e.mode),void 0!==e.radius&&(this.radius=e.radius))}}},4809(e,t,i){i.d(t,{y:()=>n});var a=i(3829),s=i(1451);class n{acceleration;enable;inverse;maxSpeed;constructor(){this.acceleration=9.81,this.enable=!1,this.inverse=!1,this.maxSpeed=50}load(e){(0,a.kZ)(e)||(void 0!==e.acceleration&&(this.acceleration=(0,s.DT)(e.acceleration)),void 0!==e.enable&&(this.enable=e.enable),void 0!==e.inverse&&(this.inverse=e.inverse),void 0!==e.maxSpeed&&(this.maxSpeed=(0,s.DT)(e.maxSpeed)))}}},4110(e,t,i){i.d(t,{j:()=>n});var a=i(4435),s=i(3829);class n{bottom;default;left;right;top;constructor(){this.default=a.Y.out}load(e){(0,s.kZ)(e)||(void 0!==e.default&&(this.default=e.default),this.bottom=e.bottom??e.default,this.left=e.left??e.default,this.right=e.right??e.default,this.top=e.top??e.default)}}},4238(e,t,i){i.d(t,{v:()=>r});var a=i(598),s=i(4477),n=i(3829);class r{clamp;delay;enable;generator;options;constructor(){this.clamp=!0,this.delay=new a.PV,this.enable=!1,this.options={}}load(e){!(0,n.kZ)(e)&&(void 0!==e.clamp&&(this.clamp=e.clamp),this.delay.load(e.delay),void 0!==e.enable&&(this.enable=e.enable),this.generator=e.generator,e.options&&(this.options=(0,s.zw)(this.options,e.options)))}}},454(e,t,i){i.d(t,{t:()=>r});var a=i(4477),s=i(3829),n=i(1451);class r{acceleration;enable;position;constructor(){this.acceleration=0,this.enable=!1}load(e){!(0,s.kZ)(e)&&(void 0!==e.acceleration&&(this.acceleration=(0,n.DT)(e.acceleration)),void 0!==e.enable&&(this.enable=e.enable),e.position&&(this.position=(0,a.zw)({},e.position)))}}},3432(e,t,i){i.d(t,{N:()=>r});var a=i(3829);class s{enable;height;width;constructor(){this.enable=!1,this.width=1920,this.height=1080}load(e){if((0,a.kZ)(e))return;void 0!==e.enable&&(this.enable=e.enable);let t=e.width;void 0!==t&&(this.width=t);let i=e.height;void 0!==i&&(this.height=i)}}var n=i(547);class r{density;limit;value;constructor(){this.density=new s,this.limit=new n.A,this.value=0}load(e){(0,a.kZ)(e)||(this.density.load(e.density),this.limit.load(e.limit),void 0!==e.value&&(this.value=e.value))}}},547(e,t,i){i.d(t,{A:()=>n});var a=i(6192),s=i(3829);class n{mode;value;constructor(){this.mode=a.d.delete,this.value=0}load(e){(0,s.kZ)(e)||(void 0!==e.mode&&(this.mode=e.mode),void 0!==e.value&&(this.value=e.value))}}},6575(e,t,i){i.d(t,{Y:()=>r});var a=i(2921),s=i(598),n=i(3829);class r extends s.AI{animation;constructor(){super(),this.animation=new a.I,this.value=1}load(e){if((0,n.kZ)(e))return;super.load(e);let t=e.animation;void 0!==t&&this.animation.load(t)}}},2921(e,t,i){i.d(t,{I:()=>r});var a=i(9319),s=i(4570),n=i(3829);class r extends s.Q{destroy;constructor(){super(),this.destroy=a.V.none,this.speed=2}load(e){super.load(e),(0,n.kZ)(e)||void 0!==e.destroy&&(this.destroy=e.destroy)}}},6951(e,t,i){i.d(t,{U:()=>f});var a=i(4477),s=i(3829);class n{close;options;type;constructor(){this.close=!0,this.options={},this.type=[]}load(e){if((0,s.kZ)(e))return;let t=e.options;if(void 0!==t)for(let e in t){let i=t[e];i&&(this.options[e]=(0,a.zw)(this.options[e]??{},i))}void 0!==e.close&&(this.close=e.close),void 0!==e.type&&(this.type=e.type)}}var r=i(3823),o=i(3551),l=i(6575),d=i(5122),u=i(3432),c=i(2827),h=i(1415),p=i(6078),v=i(2617);class f{bounce;effect;fill;groups;move;number;opacity;reduceDuplicates;shape;size;stroke;zIndex;_container;_pluginManager;constructor(e,t){this._pluginManager=e,this._container=t,this.bounce=new d.w,this.effect=new n,this.fill=new r.S,this.groups={},this.move=new o.y,this.number=new u.N,this.opacity=new l.Y,this.reduceDuplicates=!1,this.shape=new c.y,this.size=new h.o,this.stroke=new p.t,this.zIndex=new v.P}load(e){if((0,s.kZ)(e))return;if(void 0!==e.groups)for(let t of Object.keys(e.groups)){if(!(t in e.groups))continue;let i=e.groups[t];void 0!==i&&(this.groups[t]=(0,a.zw)(this.groups[t]??{},i))}void 0!==e.reduceDuplicates&&(this.reduceDuplicates=e.reduceDuplicates),this.bounce.load(e.bounce),this.effect.load(e.effect),this.move.load(e.move),this.number.load(e.number),this.opacity.load(e.opacity),this.shape.load(e.shape),this.size.load(e.size),this.zIndex.load(e.zIndex);let t=e.fill;t&&(this.fill=(0,a.wJ)(t,e=>{let t=new r.S;return t.load(e),t}));let i=e.stroke;if(i&&(this.stroke=(0,a.wJ)(i,e=>{let t=new p.t;return t.load(e),t})),this._container){for(let t of this._pluginManager.plugins)t.loadParticlesOptions&&t.loadParticlesOptions(this._container,this,e);let t=this._pluginManager.updaters.get(this._container);if(t)for(let i of t)i.loadOptions&&i.loadOptions(this,e)}}}},2827(e,t,i){i.d(t,{y:()=>n});var a=i(4477),s=i(3829);class n{close;options;type;constructor(){this.close=!0,this.options={},this.type="circle"}load(e){if((0,s.kZ)(e))return;let t=e.options;if(void 0!==t)for(let e in t){let i=t[e];i&&(this.options[e]=(0,a.zw)(this.options[e]??{},i))}void 0!==e.close&&(this.close=e.close),void 0!==e.type&&(this.type=e.type)}}},1415(e,t,i){i.d(t,{o:()=>r});var a=i(598),s=i(6305),n=i(3829);class r extends a.AI{animation;constructor(){super(),this.animation=new s.q,this.value=3}load(e){if(super.load(e),(0,n.kZ)(e))return;let t=e.animation;void 0!==t&&this.animation.load(t)}}},6305(e,t,i){i.d(t,{q:()=>r});var a=i(9319),s=i(4570),n=i(3829);class r extends s.Q{destroy;constructor(){super(),this.destroy=a.V.none,this.speed=5}load(e){super.load(e),(0,n.kZ)(e)||void 0!==e.destroy&&(this.destroy=e.destroy)}}},6078(e,t,i){i.d(t,{t:()=>r});var a=i(4179),s=i(3829),n=i(1451);class r{color;opacity;width;constructor(){this.width=0}load(e){(0,s.kZ)(e)||(void 0!==e.color&&(this.color=a.A.create(this.color,e.color)),void 0!==e.width&&(this.width=(0,n.DT)(e.width)),void 0!==e.opacity&&(this.opacity=(0,n.DT)(e.opacity)))}}},2617(e,t,i){i.d(t,{P:()=>n});var a=i(598),s=i(3829);class n extends a.PV{opacityRate;sizeRate;velocityRate;constructor(){super(),this.opacityRate=1,this.sizeRate=1,this.velocityRate=1}load(e){super.load(e),(0,s.kZ)(e)||(void 0!==e.opacityRate&&(this.opacityRate=e.opacityRate),void 0!==e.sizeRate&&(this.sizeRate=e.sizeRate),void 0!==e.velocityRate&&(this.velocityRate=e.velocityRate))}}},598(e,t,i){i.d(t,{AI:()=>l,PV:()=>r});var a=i(4570),s=i(3829),n=i(1451);class r{value;constructor(){this.value=0}load(e){!(0,s.kZ)(e)&&((0,s.kZ)(e.value)||(this.value=(0,n.DT)(e.value)))}}class o extends r{animation=new a.p;load(e){if(super.load(e),(0,s.kZ)(e))return;let t=e.animation;void 0!==t&&this.animation.load(t)}}class l extends o{animation;constructor(){super(),this.animation=new a.Q}load(e){super.load(e)}}},9297(e,t,i){i.d(t,{IU:()=>r,Md:()=>n,Sn:()=>s,Wb:()=>l,p0:()=>o});var a=i(6027);function s(e,t,i){e.fillStyle=i??"rgba(0,0,0,0)",e.fillRect(a.bo.x,a.bo.y,t.width,t.height)}function n(e,t,i,s){if(!i)return;let n=e.globalAlpha;e.globalAlpha=s,e.drawImage(i,a.bo.x,a.bo.y,t.width,t.height),e.globalAlpha=n}function r(e,t){e.clearRect(a.bo.x,a.bo.y,t.width,t.height)}function o(e){let{container:t,context:i,particle:s,delta:n,colorStyles:r,radius:o,opacity:l,transform:d}=e,{effectDrawers:u,shapeDrawers:c}=t,h=s.getPosition(),p=s.getTransformData(d),v=a.Pf,f={x:h.x,y:h.y};i.setTransform(p.a,p.b,p.c,p.d,h.x,h.y),r.fill&&(i.fillStyle=r.fill);let g=!!s.fillEnabled,y=s.strokeWidth??a.Dv;i.lineWidth=y,r.stroke&&(i.strokeStyle=r.stroke);let m={context:i,particle:s,radius:o,drawRadius:o*v,opacity:l,delta:n,pixelRatio:t.retina.pixelRatio,fill:g,stroke:y>a.Dv,transformData:p,position:{...h},drawPosition:f,drawScale:v};for(let e of t.plugins)e.drawParticleTransform?.(m);let b=s.effect?u.get(s.effect):void 0,w=s.shape?c.get(s.shape):void 0;(function(e,t){if(!e?.drawBefore)return;let{particle:i}=t;i.effect&&e.drawBefore(t)})(b,m),function(e,t){if(!e?.beforeDraw)return;let{particle:i}=t;i.shape&&e.beforeDraw(t)}(w,m),function(e,t){if(!e)return;let{context:i,fill:a,particle:s,stroke:n}=t;s.shape&&(i.beginPath(),e.draw(t),s.shapeClose&&i.closePath(),n&&i.stroke(),a&&i.fill())}(w,m),function(e,t){if(!e?.afterDraw)return;let{particle:i}=t;i.shape&&e.afterDraw(t)}(w,m),function(e,t){if(!e?.drawAfter)return;let{particle:i}=t;i.effect&&e.drawAfter(t)}(b,m),i.resetTransform()}function l(e,t,i,a){t.drawParticle&&t.drawParticle(e,i,a)}},5482(e,t,i){i.d(t,{BN:()=>c,Jv:()=>M,LC:()=>y,O_:()=>m,R5:()=>h,YL:()=>p,ay:()=>v,pz:()=>b,xx:()=>f,yx:()=>z});var a=i(1451),s=i(6027),n=i(3829),r=i(4393),o=i(1187),l=i(4477);let d=new Map;function u(e,t){let i=d.get(e);return i||(i=t(),d.size>=1e3&&[...d.keys()].slice(0,1e3*s.MX).forEach(e=>d.delete(e)),d.set(e,i)),i}function c(e,t,i,r=!0){if(!t)return;let o=(0,n.Kg)(t)?{value:t}:t;if((0,n.Kg)(o.value))return function e(t,i,r,o=!0){if(!i)return;let d=(0,n.Kg)(i)?{value:i}:i;if((0,n.Kg)(d.value)){let e,i,n;return d.value===s.mR?(e=(void 0)??s.Fl,i=s.oi+s.D_,{b:(n=()=>Math.floor((0,a.e4)(e,i)))(),g:n(),r:n()}):function(e,t){if(t){for(let i of e.colorManagers.values())if(i.accepts(t))return i.parseString(t)}}(t,d.value)}if((0,n.cy)(d.value)){let i=(0,l.Vh)(d.value,r,o);if(!i)return;return e(t,{value:i})}for(let e of t.colorManagers.values()){let t=e.handleColor(d);if(t)return t}}(e,o.value,i,r);if((0,n.cy)(o.value)){let t=(0,l.Vh)(o.value,i,r);if(!t)return;return c(e,{value:t})}for(let t of e.colorManagers.values()){let e=t.handleRangeColor(o);if(e)return e}}function h(e,t,i,a=!0){var n;let r,o,l,d,u,p,v=c(e,t,i,a);return v?(r=(n=v).r/s.oi,o=n.g/s.oi,d=Math.max(r,o,l=n.b/s.oi),u=Math.min(r,o,l),p={h:s.L1,l:(d+u)*s.MX,s:s.yx},d!==u&&(p.s=p.l<s.MX?(d-u)/(d+u):(d-u)/(s.gd-d-u),r===d?p.h=(o-l)/(d-u):o===d?p.h=s.gd+(l-r)/(d-u):p.h=s.gd*s.gd+(r-o)/(d-u)),p.l*=s.$_,p.s*=s.eu,p.h*=s.U0,p.h<s.L1&&(p.h+=s.vS),p.h>=s.vS&&(p.h-=s.vS),p):void 0}function p(e){let t=(e.h%s.vS+s.vS)%s.vS,i=Math.max(s.yx,Math.min(s.eu,e.s)),a=Math.max(s.vd,Math.min(s.$_,e.l)),n=t/s.vS,r=i/s.eu,o=a/s.$_;if(i===s.yx){let e=Math.round(o*s.oi);return{r:e,g:e,b:e}}let l=(e,t,i)=>(i<0&&i++,i>1&&i--,i*s.zg<1)?e+(t-e)*s.zg*i:i*s.gd<1?t:i*s.Nu<+s.gd?e+(t-e)*(s.gd/s.Nu-i)*s.zg:e,d=o<s.MX?o*(s.aE+r):o+r-o*r,u=s.gd*o-d,c=s.BF/s.Nu;return{r:Math.round(Math.min(s.oi,s.oi*l(u,d,n+c))),g:Math.round(Math.min(s.oi,s.oi*l(u,d,n))),b:Math.round(Math.min(s.oi,s.oi*l(u,d,n-c)))}}function v(e){let t=p(e);return{a:e.a,b:t.b,g:t.g,r:t.r}}function f(e,t,i){let a=i??s.hv;return u(`rgb-${e.r.toFixed(2)}-${e.g.toFixed(2)}-${e.b.toFixed(2)}-${t?"hdr":"sdr"}-${a.toString()}`,()=>{var a,n;return t?g(e,i):(a=e,n=i,`rgba(${a.r.toString()}, ${a.g.toString()}, ${a.b.toString()}, ${(n??s.hv).toString()})`)})}function g(e,t){return`color(display-p3 ${(e.r/s.oi).toString()} ${(e.g/s.oi).toString()} ${(e.b/s.oi).toString()} / ${(t??s.hv).toString()})`}function y(e,t,i){let a=i??s.hv;return u(`hsl-${e.h.toFixed(2)}-${e.s.toFixed(2)}-${e.l.toFixed(2)}-${t?"hdr":"sdr"}-${a.toString()}`,()=>{var a,n,r,o;return t?(a=e,n=i,g(p(a),n)):(r=e,o=i,`hsla(${r.h.toString()}, ${r.s.toString()}%, ${r.l.toString()}%, ${(o??s.hv).toString()})`)})}function m(e){return void 0===e?void 0:{h:e.h.value,s:e.s.value,l:e.l.value}}function b(e,t,i){let a={h:{enable:!1,value:e.h,min:s.L1,max:s.vS},s:{enable:!1,value:e.s,min:s.yx,max:s.eu},l:{enable:!1,value:e.l,min:s.vd,max:s.$_}};return t&&(w(a.h,t.h,i),w(a.s,t.s,i),w(a.l,t.l,i)),a}function w(e,t,i){e.enable=t.enable,e.min=t.min,e.max=t.max,e.enable?(e.velocity=(0,a.VG)(t.speed)/s.a5*i,e.decay=s.WH-(0,a.VG)(t.decay),e.status=o.H.increasing,e.loops=s.hK,e.maxLoops=(0,a.VG)(t.count),e.time=s.tR,e.delayTime=(0,a.VG)(t.delay)*s.Xu,t.sync||(e.velocity*=(0,a.G0)(),e.value*=(0,a.G0)()),e.initialValue=e.value,e.offset=(0,a.DT)(t.offset)):e.velocity=s.jn}function x(e,t,i){if(!e.enable||(e.maxLoops??0)>0&&(e.loops??0)>(e.maxLoops??0)||(e.time??=0,(e.delayTime??0)>0&&e.time<(e.delayTime??0)&&(e.time+=i.value),(e.delayTime??0)>0&&e.time<(e.delayTime??0)))return;let s=e.offset?(0,a.vE)(e.offset):0,n=(e.velocity??0)*i.factor+3.6*s,r=e.decay??1,l=e.max,d=e.min;t&&e.status!==o.H.increasing?(e.value-=n,e.value<d&&(e.loops??=0,e.loops++,e.status=o.H.increasing)):(e.value+=n,e.value>l&&(e.loops??=0,e.loops++,t?e.status=o.H.decreasing:e.value-=l)),e.velocity&&1!==r&&(e.velocity*=r),e.value=(0,a.qE)(e.value,d,l)}function M(e,t){if(!e)return;let{h:i,s:a,l:s}=e;x(i,!1,t),x(a,!0,t),x(s,!0,t)}function z(e,t,i){return{h:e.h,s:e.s,l:e.l+(t===r.H.darken?-s.iU:s.iU)*i}}},9281(e,t,i){i.d(t,{t:()=>s});let a={debug:console.debug,error:(e,t)=>{console.error(`tsParticles - Error - ${e}`,t)},info:console.info,log:console.log,trace:console.trace,verbose:console.log,warning:console.warn};function s(){return a}},1451(e,t,i){i.d(t,{$m:()=>k,DT:()=>function e(t,i){if(t===i||void 0===i&&(0,r.Et)(t))return t;let a=g(t),s=y(t);return void 0!==i?{min:Math.min(a,i),max:Math.max(s,i)}:e(a,s)},G0:()=>d,JY:()=>z,M3:()=>_,Nx:()=>S,Sg:()=>g,VG:()=>f,W9:()=>y,Yf:()=>w,e4:()=>u,gp:()=>x,i0:()=>c,pu:()=>M,px:()=>h,qE:()=>p,vE:()=>v,vr:()=>m});var a=i(4840),s=i(6027),n=i(5186),r=i(3829);let o=Math.PI/180,l=Math.random;function d(){return p(l(),0,1-Number.EPSILON)}function u(e,t){return d()*(t-e)+e}function c(e){return requestAnimationFrame(e)}function h(e){cancelAnimationFrame(e)}function p(e,t,i){return Math.min(Math.max(e,t),i)}function v(e){let t=y(e),i=g(e);return t===i&&(i=0),u(i,t)}function f(e){return(0,r.Et)(e)?e:v(e)}function g(e){return(0,r.Et)(e)?e:e.min}function y(e){return(0,r.Et)(e)?e:e.max}function m(e,t){let i=e.x-t.x,a=e.y-t.y;return{dx:i,dy:a,distance:Math.hypot(i,a)}}function b(e,t){let i=e.x-t.x,a=e.y-t.y;return i*i+a*a}function w(e,t){return Math.sqrt(b(e,t))}function x(e,t,i){return b(e,t)<=i*i}function M(e){return e*o}function z(e,t,i){if((0,r.Et)(e))return e*o;switch(e){case a.F.top:return-Math.PI*s.MX;case a.F.topRight:return-Math.PI*s.$G;case a.F.right:return s.Ie;case a.F.bottomRight:return Math.PI*s.$G;case a.F.bottom:return Math.PI*s.MX;case a.F.bottomLeft:return Math.PI*s.Rq;case a.F.left:return Math.PI;case a.F.topLeft:return-Math.PI*s.Rq;case a.F.inside:return Math.atan2(i.y-t.y,i.x-t.x);case a.F.outside:return Math.atan2(t.y-i.y,t.x-i.x);default:return d()*s.R1}}function k(e){let t=n.M.origin;return t.length=1,t.angle=e,t}function S(e){let{position:t,size:i}=e;return{x:t?.x??d()*i.width,y:t?.y??d()*i.height}}function _(e){return e?e.endsWith("%")?parseFloat(e)/s.a5:parseFloat(e):1}},9725(e,t,i){i.d(t,{Z:()=>s,y:()=>n});var a=i(6951);function s(e,...t){for(let i of t)e.load(i)}function n(e,t,...i){let r=new a.U(e,t);return s(r,...i),r}},3829(e,t,i){function a(e){return"boolean"==typeof e}function s(e){return"string"==typeof e}function n(e){return"number"==typeof e}function r(e){return"object"==typeof e&&null!==e}function o(e){return Array.isArray(e)}function l(e){return null==e}i.d(t,{Et:()=>n,Gv:()=>r,Kg:()=>s,Lm:()=>a,cy:()=>o,kZ:()=>l})},4477(e,t,i){let a,s,n,r,o;i.d(t,{AE:()=>S,BR:()=>w,E9:()=>T,HQ:()=>A,Kp:()=>D,Ot:()=>$,T5:()=>m,TA:()=>P,Tj:()=>k,UC:()=>L,Vh:()=>z,Xs:()=>E,hJ:()=>R,hn:()=>M,lV:()=>b,tG:()=>x,td:()=>I,w3:()=>O,wJ:()=>_,zw:()=>function e(t,...i){for(let a of i){if((0,c.kZ)(a))continue;if(!(0,c.Gv)(a)){t=a;continue}Array.isArray(a)?Array.isArray(t)||(t=[]):(!(0,c.Gv)(t)||Array.isArray(t))&&(t={});let i=Object.keys(a),s=new Set(["__proto__","constructor","prototype"]);if(!i.some(e=>{let t=a[e];return(0,c.Gv)(t)||Array.isArray(t)})){let e=t;for(let t of i)if(!s.has(t)&&t in a){let i=a[t];void 0!==i&&(e[t]=i)}continue}for(let n of i){if(s.has(n))continue;let i=t,r=a[n];i[n]=Array.isArray(r)?r.map(t=>e(void 0,t)):e(i[n],r)}}return t}});var l,d=i(1451),u=i(6027),c=i(3829),h=i(9993),p=i(1187),v=i(9319),f=i(5248),g=i(9563),y=i(1004);function m(){return globalThis.document}function b(e){if("u">typeof matchMedia)return matchMedia(e)}function w(e){if("u">typeof IntersectionObserver)return new IntersectionObserver(e)}function x(e){if("u">typeof MutationObserver)return new MutationObserver(e)}function M(e,t){return e===t||(0,c.cy)(t)&&t.includes(e)}function z(e,t,i=!0){return e[void 0!==t&&i?t%e.length:Math.floor((0,d.G0)()*e.length)]}function k(e,t,i,a,s){var n,r,o,l;let d;return n=S(e,a??0),r=t,o=i,d=!0,(l=s)&&l!==f.v.bottom||(d=n.top<r.height+o.x),d&&(!l||l===f.v.left)&&(d=n.right>o.x),d&&(!l||l===f.v.right)&&(d=n.left<r.width+o.y),d&&(!l||l===f.v.top)&&(d=n.bottom>o.y),d}function S(e,t){return{bottom:e.y+t,left:e.x-t,right:e.x+t,top:e.y-t}}function _(e,t){return(0,c.cy)(e)?e.map((e,i)=>t(e,i)):t(e,0)}function P(e,t,i){return(0,c.cy)(e)?z(e,t,i):e}function O(e,t){return(0,c.cy)(e)?e.find((e,i)=>t(e,i)):t(e,0)?e:void 0}function E(e,t){let i=e.value,a=e.animation,s={delayTime:(0,d.VG)(a.delay)*u.Xu,enable:a.enable,value:(0,d.VG)(e.value)*t,max:(0,d.W9)(i)*t,min:(0,d.Sg)(i)*t,loops:0,maxLoops:(0,d.VG)(a.count),time:0};if(a.enable){switch(s.decay=1-(0,d.VG)(a.decay),a.mode){case h.g.increase:s.status=p.H.increasing;break;case h.g.decrease:s.status=p.H.decreasing;break;case h.g.random:s.status=(0,d.G0)()>=u.MX?p.H.increasing:p.H.decreasing}let e=a.mode===h.g.auto;switch(a.startValue){case y.S.min:s.value=s.min,e&&(s.status=p.H.increasing);break;case y.S.max:s.value=s.max,e&&(s.status=p.H.decreasing);break;case y.S.random:default:s.value=(0,d.vE)(s),e&&(s.status=(0,d.G0)()>=u.MX?p.H.increasing:p.H.decreasing)}}return s.initialValue=s.value,s}function T(e,t){return function(e,t){if(e.mode!==g.q.percent){let{mode:t,...i}=e;return i}return"x"in e?{x:e.x/u.a5*t.width,y:e.y/u.a5*t.height}:{width:e.width/u.a5*t.width,height:e.height/u.a5*t.height}}(e,t)}function L(e,t,i,a,s){if(e.destroyed||!t.enable||(t.maxLoops??0)>0&&(t.loops??0)>(t.maxLoops??0))return;let n=(t.velocity??0)*s.factor,r=t.min,o=t.max,l=t.decay??1;if(t.time??=0,(t.delayTime??0)>0&&t.time<(t.delayTime??0)&&(t.time+=s.value),!((t.delayTime??0)>0)||!(t.time<(t.delayTime??0))){switch(t.status){case p.H.increasing:t.value>=o?(i?t.status=p.H.decreasing:t.value-=o,t.loops??=0,t.loops++):t.value+=n;break;case p.H.decreasing:t.value<=r?(i?t.status=p.H.increasing:t.value+=o,t.loops??=0,t.loops++):t.value-=n}t.velocity&&1!==l&&(t.velocity*=l);var u=t.value;switch(a){case v.V.max:u>=o&&e.destroy();break;case v.V.min:u<=r&&e.destroy()}t.value=(0,d.qE)(t.value,r,o)}}function I(e){let t=m().createElement("div").style;for(let i in e){let a=e[i];if(!(i in e)||(0,c.kZ)(a))continue;let s=e.getPropertyValue?.(a);if(!s)continue;let n=e.getPropertyPriority?.(a);n?t.setProperty(a,s,n):t.setProperty(a,s)}return t}i(5186);let R=(l=function(e){let t=m().createElement("div").style,i={width:"100%",height:"100%",margin:"0",padding:"0",borderWidth:"0",position:"fixed",zIndex:e.toString(10),"z-index":e.toString(10),top:"0",left:"0"};for(let e in i){let a=i[e];void 0!==a&&t.setProperty(e,a)}return t},a=new Map,s=void 0,n=void 0,r=void 0,o=(e,t=new WeakSet)=>{if(null===e)return"null";let i=typeof e;if("undefined"===i)return"undefined";if("number"===i||"boolean"===i||"string"===i)return JSON.stringify(e);if("function"===i)try{return e.toString()}catch{return'"[Function]"'}if("symbol"===i)try{return e.toString()}catch{return'"[Symbol]"'}if(Array.isArray(e))return`[${e.map(e=>o(e,t)).join(",")}]`;if(t.has(e))return'"[Circular]"';t.add(e);let a=Object.keys(e).sort();return`{${a.map(i=>`${JSON.stringify(i)}:${o(e[i],t)}`).join(",")}}`},(...e)=>{let t,i=(t=e,r?r(t):o(t)),d=Date.now(),u=a.get(i);if(void 0!==u)if(!n||!(d-u.ts>n))return a.delete(i),a.set(i,{value:u.value,ts:u.ts}),u.value;else a.delete(i);let c=l(...e);if(a.set(i,{value:c,ts:d}),"number"==typeof s&&s>=0)for(;a.size>s;){let e=a.keys().next().value;if(void 0===e)break;a.delete(e)}return c});function D(e,t,i,a,s){if(a){let a={passive:!0};(0,c.Lm)(s)?a.capture=s:void 0!==s&&(a=s),e.addEventListener(t,i,a)}else e.removeEventListener(t,i,s)}async function A(e,t,i,a=!1){let s=t.get(e);return(!s||a)&&(s=await Promise.all([...i.values()].map(t=>t(e))),t.set(e,s)),s}async function $(e,t,i,a=!1){let s=t.get(e);return(!s||a)&&(s=new Map(await Promise.all([...i.entries()].map(([t,i])=>i(e).then(e=>[t,e])))),t.set(e,s)),s}},3360(e,t,i){i.d(t,{Yzx:()=>x.Y,v5k:()=>w.v,x_I:()=>M.x,pTR:()=>r,Miz:()=>b.M,AEc:()=>u.AE,qE8:()=>f.qE,WH8:()=>d.WH,zwS:()=>u.zw,puj:()=>f.pu,gdl:()=>d.gd,R1e:()=>d.R1,wJ2:()=>u.wJ,w3Z:()=>u.w3,YfF:()=>f.Yf,vrU:()=>f.vr,pzy:()=>z.pz,OtU:()=>u.Ot,HQK:()=>u.HQ,G0i:()=>f.G0,W9e:()=>f.W9,VGA:()=>f.VG,MXx:()=>d.MX,YLU:()=>z.YL,ayx:()=>z.ay,XsS:()=>u.Xs,cyL:()=>k.cy,hnD:()=>u.hn,kZJ:()=>k.kZ,Gvm:()=>k.Gv,Tj8:()=>u.Tj,Vh1:()=>u.Vh,TA3:()=>u.TA,K3:()=>d.K3,KpY:()=>u.Kp,XuV:()=>d.Xu,boI:()=>d.bo,M3Y:()=>f.M3,a56:()=>d.a5,vEz:()=>f.vE,R5R:()=>z.R5,T5G:()=>u.T5,BRq:()=>u.BR,DT4:()=>f.DT,$k3:()=>S,UC0:()=>u.UC,JvX:()=>z.Jv,nKi:()=>d.nK});var a,s,n,r,o,l,d=i(6027),u=i(4477);class c{_listeners;constructor(){this._listeners=new Map}addEventListener(e,t){this.removeEventListener(e,t);let i=this._listeners.get(e);i||(i=[],this._listeners.set(e,i)),i.push(t)}dispatchEvent(e,t){let i=this._listeners.get(e);i?.forEach(e=>{e(t)})}hasEventListener(e){return!!this._listeners.get(e)}removeAllEventListeners(e){e?this._listeners.delete(e):this._listeners=new Map}removeEventListener(e,t){let i=this._listeners.get(e);if(!i)return;let a=i.length,s=i.indexOf(t);s<d.z9||(a===d.LD?this._listeners.delete(e):i.splice(s,d.LD))}}var h=i(4085);class p{colorManagers=new Map;easingFunctions=new Map;effectDrawers=new Map;initializers={effects:new Map,shapes:new Map,updaters:new Map};palettes=new Map;plugins=[];presets=new Map;shapeDrawers=new Map;updaters=new Map;_allLoadersSet=new Set;_configs=new Map;_engine;_executedSet=new Set;_initialized=!1;_isRunningLoaders=!1;_loadPromises=new Set;constructor(e){this._engine=e}get configs(){let e={};for(let[t,i]of this._configs)e[t]=i;return e}addColorManager(e,t){this.colorManagers.set(e,t)}addConfig(e){let t=e.key??e.name??"default";this._configs.set(t,e),this._engine.dispatchEvent(h.B.configAdded,{data:{name:t,config:e}})}addEasing(e,t){this.easingFunctions.get(e)||this.easingFunctions.set(e,t)}addEffect(e,t){this.initializers.effects.set(e,t)}addPalette(e,t){this.palettes.set(e,t)}addParticleUpdater(e,t){this.initializers.updaters.set(e,t)}addPlugin(e){this.getPlugin(e.id)||this.plugins.push(e)}addPreset(e,t,i=!1){(i||!this.getPreset(e))&&this.presets.set(e,t)}addShape(e,t){for(let i of e)this.initializers.shapes.set(i,t)}clearPlugins(e){this.effectDrawers.delete(e),this.shapeDrawers.delete(e),this.updaters.delete(e)}getEasing(e){return this.easingFunctions.get(e)??(e=>e)}getEffectDrawers(e,t=!1){return(0,u.Ot)(e,this.effectDrawers,this.initializers.effects,t)}getPalette(e){return this.palettes.get(e)}getPlugin(e){return this.plugins.find(t=>t.id===e)}getPreset(e){return this.presets.get(e)}async getShapeDrawers(e,t=!1){return(0,u.Ot)(e,this.shapeDrawers,this.initializers.shapes,t)}async getUpdaters(e,t=!1){return(0,u.HQ)(e,this.updaters,this.initializers.updaters,t)}async init(){if(!this._initialized&&!this._isRunningLoaders){this._isRunningLoaders=!0,this._executedSet=new Set,this._allLoadersSet=new Set(this._loadPromises);try{for(let e of this._allLoadersSet)await this._runLoader(e,this._executedSet,this._allLoadersSet)}finally{this._loadPromises.clear(),this._isRunningLoaders=!1,this._initialized=!0}}}loadParticlesOptions(e,t,...i){let a=this.updaters.get(e);a&&a.forEach(e=>e.loadOptions?.(t,...i))}async register(...e){if(this._initialized)throw Error("Register plugins can only be done before calling tsParticles.load()");for(let t of e)this._isRunningLoaders?await this._runLoader(t,this._executedSet,this._allLoadersSet):this._loadPromises.add(t)}async _runLoader(e,t,i){t.has(e)||(t.add(e),i.add(e),await e(this._engine))}}var v=i(9281),f=i(1451);let g="100%";async function y(e){let t=(0,u.TA)(e.url,e.index);if(!t)return e.fallback;let i=await fetch(t);return i.ok?await i.json():((0,v.t)().error(`${i.status.toString()} while retrieving config file`),e.fallback)}class m{pluginManager=new p(this);_domArray=[];_eventDispatcher=new c;_initialized=!1;get items(){return this._domArray}get version(){return"4.0.0-beta.1"}addEventListener(e,t){this._eventDispatcher.addEventListener(e,t)}checkVersion(e){if(this.version!==e)throw Error(`The tsParticles version is different from the loaded plugins version. Engine version: ${this.version}. Plugin version: ${e}`)}dispatchEvent(e,t){this._eventDispatcher.dispatchEvent(e,t)}async init(){this._initialized||(await this.pluginManager.init(),this._initialized=!0)}item(e){let{items:t}=this,i=t[e];return i?.destroyed?void t.splice(e,d.JC):i}async load(e){var t;let a,s;await this.init();let{Container:n}=await i.e(930).then(i.bind(i,4930)),r=e.id??e.element?.id??`tsparticles${Math.floor((0,f.G0)()*d.$v).toString()}`,{index:o,url:l}=e,c=l?await y({fallback:e.options,url:l,index:o}):e.options,h=(0,u.TA)(c,o),{items:p}=this,v=p.findIndex(e=>e.id.description===r),m=new n({dispatchCallback:(e,t)=>{this.dispatchEvent(e,t)},id:r,onDestroy:e=>{if(!e)return;let t=this.items,i=t.indexOf(m);i>=d.vF&&t.splice(i,d.JC)},pluginManager:this.pluginManager,sourceOptions:h});if(v>=d.PZ){let e=this.item(v),t=e?d.xH:d.dv;e&&!e.destroyed&&e.destroy(!1),p.splice(v,t,m)}else p.push(m);let b=(e=>{let t,i=(0,u.T5)();if(e instanceof HTMLCanvasElement||e.tagName.toLowerCase()===d.RF)t=e,t.dataset[d.eb]??=d.X$;else{let a=e.getElementsByTagName(d.RF)[d.Nx];a?(t=a).dataset[d.eb]=d.X$:((t=i.createElement(d.RF)).dataset[d.eb]=d.ce,e.appendChild(t))}return t.style.width||=g,t.style.height||=g,t})((t=e.element,a=(0,u.T5)(),(s=t??a.getElementById(r))||((s=a.createElement("canvas")).id=r,s.dataset[d.eb]=d.ce,a.body.append(s)),s));return m.canvas.loadCanvas(b),await m.start(),m}async refresh(e=!0){e&&await Promise.all(this.items.map(e=>e.refresh()))}removeEventListener(e,t){this._eventDispatcher.removeEventListener(e,t)}}i(2130);var b=i(5186);i(4840),(a=r||(r={})).clockwise="clockwise",a.counterClockwise="counter-clockwise",a.random="random";var w=i(5248);i(9993),i(6192);var x=i(4435);i(9563),i(4393),i(9319),(s=o||(o={})).linear="linear",s.radial="radial",s.random="random";var M=i(9827);i(1004),(n=l||(l={})).easeInBack="ease-in-back",n.easeInBounce="ease-in-bounce",n.easeInCirc="ease-in-circ",n.easeInCubic="ease-in-cubic",n.easeInElastic="ease-in-elastic",n.easeInExpo="ease-in-expo",n.easeInGaussian="ease-in-gaussian",n.easeInLinear="ease-in-linear",n.easeInQuad="ease-in-quad",n.easeInQuart="ease-in-quart",n.easeInQuint="ease-in-quint",n.easeInSigmoid="ease-in-sigmoid",n.easeInSine="ease-in-sine",n.easeInSmoothstep="ease-in-smoothstep",n.easeOutBack="ease-out-back",n.easeOutBounce="ease-out-bounce",n.easeOutCirc="ease-out-circ",n.easeOutCubic="ease-out-cubic",n.easeOutElastic="ease-out-elastic",n.easeOutExpo="ease-out-expo",n.easeOutGaussian="ease-out-gaussian",n.easeOutLinear="ease-out-linear",n.easeOutQuad="ease-out-quad",n.easeOutQuart="ease-out-quart",n.easeOutQuint="ease-out-quint",n.easeOutSigmoid="ease-out-sigmoid",n.easeOutSine="ease-out-sine",n.easeOutSmoothstep="ease-out-smoothstep",n.easeInOutBack="ease-in-out-back",n.easeInOutBounce="ease-in-out-bounce",n.easeInOutCirc="ease-in-out-circ",n.easeInOutCubic="ease-in-out-cubic",n.easeInOutElastic="ease-in-out-elastic",n.easeInOutExpo="ease-in-out-expo",n.easeInOutGaussian="ease-in-out-gaussian",n.easeInOutLinear="ease-in-out-linear",n.easeInOutQuad="ease-in-out-quad",n.easeInOutQuart="ease-in-out-quart",n.easeInOutQuint="ease-in-out-quint",n.easeInOutSigmoid="ease-in-out-sigmoid",n.easeInOutSine="ease-in-out-sine",n.easeInOutSmoothstep="ease-in-out-smoothstep",i(1187),i(4179),i(4570),i(2845),i(5365),i(4757),i(5122),i(2109),i(6951),i(3823),i(6078),i(3551),i(704),i(7602),i(4809),i(4110),i(4238),i(454),i(3432),i(547),i(6575),i(2921),i(2827),i(1415),i(6305),i(2617),i(598),i(9297);var z=i(5482);i(9725);var k=i(3829);let S=new m;globalThis.tsParticles=S}},s={};function n(e){var t=s[e];if(void 0!==t)return t.exports;var i=s[e]={exports:{}};return a[e](i,i.exports,n),i.exports}n.m=a,n.d=(e,t)=>{for(var i in t)n.o(t,i)&&!n.o(e,i)&&Object.defineProperty(e,i,{enumerable:!0,get:t[i]})},n.f={},n.e=e=>Promise.all(Object.keys(n.f).reduce((t,i)=>(n.f[i](e,t),t),[])),n.u=e=>""+e+".min.js",n.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||Function("return this")()}catch(e){if("object"==typeof window)return window}}(),n.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),r={},n.l=(e,t,i,a)=>{if(r[e])return void r[e].push(t);if(void 0!==i)for(var s,o,l=document.getElementsByTagName("script"),d=0;d<l.length;d++){var u=l[d];if(u.getAttribute("src")==e||u.getAttribute("data-webpack")=="@tsparticles/preset-fire:"+i){s=u;break}}s||(o=!0,(s=document.createElement("script")).charset="utf-8",n.nc&&s.setAttribute("nonce",n.nc),s.setAttribute("data-webpack","@tsparticles/preset-fire:"+i),s.src=e),r[e]=[t];var c=(t,i)=>{s.onerror=s.onload=null,clearTimeout(h);var a=r[e];if(delete r[e],s.parentNode&&s.parentNode.removeChild(s),a&&a.forEach(e=>e(i)),t)return t(i)},h=setTimeout(c.bind(null,void 0,{type:"timeout",target:s}),12e4);s.onerror=c.bind(null,s.onerror),s.onload=c.bind(null,s.onload),o&&document.head.appendChild(s)},n.r=e=>{"u">typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},n.g.importScripts&&(o=n.g.location+"");var r,o,l=n.g.document;if(!o&&l&&(l.currentScript&&"SCRIPT"===l.currentScript.tagName.toUpperCase()&&(o=l.currentScript.src),!o)){var d=l.getElementsByTagName("script");if(d.length)for(var u=d.length-1;u>-1&&(!o||!/^http(s?):/.test(o));)o=d[u--].src}if(!o)throw Error("Automatic publicPath is not supported in this browser");n.p=o=o.replace(/^blob:/,"").replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),e={178:0},n.f.j=(t,i)=>{var a=n.o(e,t)?e[t]:void 0;if(0!==a)if(a)i.push(a[2]);else{var s=new Promise((i,s)=>a=e[t]=[i,s]);i.push(a[2]=s);var r=n.p+n.u(t),o=Error();n.l(r,i=>{if(n.o(e,t)&&(0!==(a=e[t])&&(e[t]=void 0),a)){var s=i&&("load"===i.type?"missing":i.type),r=i&&i.target&&i.target.src;o.message="Loading chunk "+t+` failed.
|
|
2
|
-
(`+s+": "+r+")",o.name="ChunkLoadError",o.type=s,o.request=r,a[1](o)}},"chunk-"+t,t)}},t=(t,i)=>{var a,s,[r,o,l]=i,d=0;if(r.some(t=>0!==e[t])){for(a in o)n.o(o,a)&&(n.m[a]=o[a]);l&&l(n)}for(t&&t(i);d<r.length;d++)s=r[d],n.o(e,s)&&e[s]&&e[s][0](),e[s]=0},(i=this.webpackChunk_tsparticles_preset_fire=this.webpackChunk_tsparticles_preset_fire||[]).forEach(t.bind(null,0)),i.push=t.bind(null,i.push.bind(i));var c={};async function h(e){await e.pluginManager.register(async e=>{let[{loadBasic:t},{loadInteractivityPlugin:i},{loadExternalPushInteraction:a},{options:s}]=await Promise.all([n.e(
|
|
1
|
+
!function(e,t){if("object"==typeof exports&&"object"==typeof module)module.exports=t();else if("function"==typeof define&&define.amd)define([],t);else{var i=t();for(var a in i)("object"==typeof exports?exports:e)[a]=i[a]}}(this,()=>(()=>{"use strict";var e,t,i,a={8660(e,t,i){i.d(t,{$G:()=>D,$_:()=>E,$v:()=>B,$x:()=>z,BF:()=>ep,DN:()=>q,D_:()=>er,Dv:()=>eo,Eo:()=>J,Fl:()=>ev,Ie:()=>R,JC:()=>G,K3:()=>ei,L1:()=>T,LD:()=>es,MX:()=>l,NF:()=>n,Nu:()=>eu,Nx:()=>j,PZ:()=>X,Pf:()=>em,R1:()=>v,RF:()=>m,RV:()=>Z,Rq:()=>A,U0:()=>I,Ug:()=>c,WH:()=>U,X$:()=>y,X_:()=>Q,Xu:()=>d,Zp:()=>k,a5:()=>o,aE:()=>eh,bo:()=>u,ce:()=>g,dm:()=>w,dv:()=>K,eb:()=>a,eu:()=>O,gd:()=>p,hB:()=>_,hK:()=>eg,hv:()=>V,i8:()=>H,iU:()=>el,iX:()=>x,jn:()=>ef,lA:()=>ea,mR:()=>h,nK:()=>r,nq:()=>W,oi:()=>S,ou:()=>Y,rq:()=>b,tA:()=>en,tR:()=>ey,vF:()=>C,vS:()=>P,vd:()=>ed,w2:()=>F,wM:()=>ee,xH:()=>N,xd:()=>M,yj:()=>s,yx:()=>L,z$:()=>f,z9:()=>et,zg:()=>ec,zs:()=>$});let a="generated",s="source-over",n="resize",r="visibilitychange",o=100,l=.5,d=1e3,u={x:0,y:0,z:0},c={a:1,b:0,c:0,d:1},h="random",p=2,v=2*Math.PI,f=60,g="true",y="false",m="canvas",b=0,w=2,x=100,M=1,z=1,k=1,_=1,S=255,P=360,O=100,E=100,T=0,L=0,I=60,R=0,D=.25,A=.75,$=1,F=0,Z=1,V=1,G=1,C=0,H=120,q=0,j=0,B=1e4,X=0,N=1,K=0,U=1,J=1,Q=0,Y=0,W=1,ee=0,et=0,ei=1,ea=1,es=1,en=0,er=1,eo=0,el=1,ed=0,eu=3,ec=6,eh=1,ep=1,ev=0,ef=0,eg=0,ey=0,em=1},6197(e,t,i){i.d(t,{jl:()=>l,M_:()=>d}),(a=s||(s={})).circle="circle",a.rectangle="rectangle";var a,s,n=i(8770),r=i(8660);class o{position;type;constructor(e,t,i){this.position={x:e,y:t},this.type=i}_resetPosition(e,t){this.position.x=e,this.position.y=t}}class l extends o{radius;constructor(e,t,i){super(e,t,s.circle),this.radius=i}contains(e){return(0,n.gp)(e,this.position,this.radius)}intersects(e){let t=this.position,i=e.position,a=this.radius,n=Math.abs(i.x-t.x),o=Math.abs(i.y-t.y);if(e instanceof l||e.type===s.circle)return a+e.radius>Math.hypot(n,o);if(e instanceof d||e.type===s.rectangle){let{width:t,height:i}=e.size;return Math.pow(n-t,r.dm)+Math.pow(o-i,r.dm)<=a**r.dm||n<=a+t&&o<=a+i||n<=t||o<=i}return!1}reset(e,t,i){return this._resetPosition(e,t),this.radius=i,this}}class d extends o{size;constructor(e,t,i,a){super(e,t,s.rectangle),this.size={height:a,width:i}}contains(e){let t=this.size.width,i=this.size.height,a=this.position;return e.x>=a.x&&e.x<=a.x+t&&e.y>=a.y&&e.y<=a.y+i}intersects(e){if(e instanceof l)return e.intersects(this);if(!(e instanceof d))return!1;let t=this.size.width,i=this.size.height,a=this.position,s=e.position,n=e.size,r=n.width,o=n.height;return s.x<a.x+t&&s.x+r>a.x&&s.y<a.y+i&&s.y+o>a.y}reset(e,t,i,a){return this._resetPosition(e,t),this.size.width=i,this.size.height=a,this}}},4037(e,t,i){i.d(t,{M:()=>r,p:()=>n});var a=i(8660);function s(e){return"z"in e?e.z:a.bo.z}class n{x;y;z;constructor(e=a.bo.x,t=a.bo.y,i=a.bo.z){this.x=e,this.y=t,this.z=i}static get origin(){return n.create(a.bo.x,a.bo.y,a.bo.z)}get angle(){return Math.atan2(this.y,this.x)}set angle(e){this._updateFromAngle(e,this.length)}get length(){return Math.sqrt(this.getLengthSq())}set length(e){this._updateFromAngle(this.angle,e)}static clone(e){return n.create(e.x,e.y,s(e))}static create(e,t,i){return"number"==typeof e?new n(e,t??a.bo.y,i??a.bo.z):new n(e.x,e.y,s(e))}add(e){return n.create(this.x+e.x,this.y+e.y,this.z+s(e))}addTo(e){this.x+=e.x,this.y+=e.y,this.z+=s(e)}copy(){return n.clone(this)}div(e){return n.create(this.x/e,this.y/e,this.z/e)}divTo(e){this.x/=e,this.y/=e,this.z/=e}getLengthSq(){return this.x**a.dm+this.y**a.dm}mult(e){return n.create(this.x*e,this.y*e,this.z*e)}multTo(e){this.x*=e,this.y*=e,this.z*=e}normalize(){let e=this.length;e!=a.dv&&this.multTo(a.hB/e)}rotate(e){return n.create(this.x*Math.cos(e)-this.y*Math.sin(e),this.x*Math.sin(e)+this.y*Math.cos(e),a.bo.z)}setTo(e){this.x=e.x,this.y=e.y,this.z=s(e)}sub(e){return n.create(this.x-e.x,this.y-e.y,this.z-s(e))}subFrom(e){this.x-=e.x,this.y-=e.y,this.z-=s(e)}_updateFromAngle(e,t){this.x=Math.cos(e)*t,this.y=Math.sin(e)*t}}class r extends n{constructor(e=a.bo.x,t=a.bo.y){super(e,t,a.bo.z)}static get origin(){return r.create(a.bo.x,a.bo.y)}static clone(e){return r.create(e.x,e.y)}static create(e,t){return"number"==typeof e?new r(e,t??a.bo.y):new r(e.x,e.y)}}},2314(e,t,i){var a,s;i.d(t,{H:()=>a}),(s=a||(a={})).increasing="increasing",s.decreasing="decreasing"},5327(e,t,i){var a,s;i.d(t,{F:()=>a}),(s=a||(a={})).bottom="bottom",s.bottomLeft="bottom-left",s.bottomRight="bottom-right",s.left="left",s.none="none",s.right="right",s.top="top",s.topLeft="top-left",s.topRight="top-right",s.outside="outside",s.inside="inside"},7341(e,t,i){var a,s;i.d(t,{v:()=>a}),(s=a||(a={})).bottom="bottom",s.left="left",s.right="right",s.top="top"},4992(e,t,i){var a,s;i.d(t,{g:()=>a}),(s=a||(a={})).auto="auto",s.increase="increase",s.decrease="decrease",s.random="random"},7345(e,t,i){var a,s;i.d(t,{d:()=>a}),(s=a||(a={})).delete="delete",s.wait="wait"},3942(e,t,i){var a,s;i.d(t,{Y:()=>a}),(s=a||(a={})).bounce="bounce",s.none="none",s.out="out",s.destroy="destroy",s.split="split"},2702(e,t,i){var a,s;i.d(t,{q:()=>a}),(s=a||(a={})).precise="precise",s.percent="percent"},6932(e,t,i){var a,s;i.d(t,{H:()=>a}),(s=a||(a={})).darken="darken",s.enlighten="enlighten"},202(e,t,i){var a,s;i.d(t,{V:()=>a}),(s=a||(a={})).none="none",s.max="max",s.min="min"},6128(e,t,i){var a,s;i.d(t,{B:()=>a}),(s=a||(a={})).configAdded="configAdded",s.containerInit="containerInit",s.particlesSetup="particlesSetup",s.containerStarted="containerStarted",s.containerStopped="containerStopped",s.containerDestroyed="containerDestroyed",s.containerPaused="containerPaused",s.containerPlay="containerPlay",s.containerBuilt="containerBuilt",s.particleAdded="particleAdded",s.particleDestroyed="particleDestroyed",s.particleRemoved="particleRemoved"},510(e,t,i){var a,s;i.d(t,{x:()=>a}),(s=a||(a={})).normal="normal",s.inside="inside",s.outside="outside"},9983(e,t,i){var a,s;i.d(t,{S:()=>a}),(s=a||(a={})).max="max",s.min="min",s.random="random"},2078(e,t,i){i.d(t,{A:()=>r});var a=i(4920),s=i(3410),n=i(9744);class r extends n.O{animation;constructor(){super(),this.animation=new s.i}static create(e,t){let i=new r;return i.load(e),void 0!==t&&((0,a.Kg)(t)||(0,a.cy)(t)?i.load({value:t}):i.load(t)),i}load(e){if(super.load(e),(0,a.kZ)(e))return;let t=e.animation;void 0!==t&&(void 0===t.enable?this.animation.load(e.animation):this.animation.h.load(t))}}},6753(e,t,i){i.d(t,{Q:()=>l,p:()=>o});var a=i(4992),s=i(9983),n=i(4920),r=i(8770);class o{count;decay;delay;enable;speed;sync;constructor(){this.count=0,this.enable=!1,this.speed=1,this.decay=0,this.delay=0,this.sync=!1}load(e){(0,n.kZ)(e)||(void 0!==e.count&&(this.count=(0,r.DT)(e.count)),void 0!==e.enable&&(this.enable=e.enable),void 0!==e.speed&&(this.speed=(0,r.DT)(e.speed)),void 0!==e.decay&&(this.decay=(0,r.DT)(e.decay)),void 0!==e.delay&&(this.delay=(0,r.DT)(e.delay)),void 0!==e.sync&&(this.sync=e.sync))}}class l extends o{mode;startValue;constructor(){super(),this.mode=a.g.auto,this.startValue=s.S.random}load(e){super.load(e),(0,n.kZ)(e)||(void 0!==e.mode&&(this.mode=e.mode),void 0!==e.startValue&&(this.startValue=e.startValue))}}},3086(e,t,i){i.d(t,{e:()=>r});var a=i(6753),s=i(4920),n=i(8770);class r extends a.p{max;min;offset;constructor(e,t){super(),this.min=e,this.max=t,this.offset=0,this.sync=!0}load(e){super.load(e),(0,s.kZ)(e)||(void 0!==e.max&&(this.max=e.max),void 0!==e.min&&(this.min=e.min),void 0!==e.offset&&(this.offset=(0,n.DT)(e.offset)))}}},3410(e,t,i){i.d(t,{i:()=>r});var a=i(8660),s=i(3086),n=i(4920);class r{h=new s.e(a.L1,a.vS);l=new s.e(a.vd,a.$_);s=new s.e(a.yx,a.eu);load(e){(0,n.kZ)(e)||(this.h.load(e.h),this.s.load(e.s),this.l.load(e.l))}}},8850(e,t,i){i.d(t,{J:()=>c});var a=i(8664),s=i(4920),n=i(9744);class r{color;image;opacity;position;repeat;size;constructor(){this.color=new n.O,this.color.value="",this.image="",this.position="",this.repeat="",this.size="",this.opacity=1}load(e){(0,s.kZ)(e)||(void 0!==e.color&&(this.color=n.O.create(this.color,e.color)),void 0!==e.image&&(this.image=e.image),void 0!==e.position&&(this.position=e.position),void 0!==e.repeat&&(this.repeat=e.repeat),void 0!==e.size&&(this.size=e.size),void 0!==e.opacity&&(this.opacity=e.opacity))}}class o{enable;zIndex;constructor(){this.enable=!0,this.zIndex=0}load(e){(0,s.kZ)(e)||(void 0!==e.enable&&(this.enable=e.enable),void 0!==e.zIndex&&(this.zIndex=e.zIndex))}}class l{delay;enable;constructor(){this.delay=.5,this.enable=!0}load(e){(0,s.kZ)(e)||(void 0!==e.delay&&(this.delay=e.delay),void 0!==e.enable&&(this.enable=e.enable))}}var d=i(2222),u=i(8770);class c{autoPlay;background;clear;defaultThemes;delay;detectRetina;duration;fpsLimit;fullScreen;hdr;key;name;palette;particles;pauseOnBlur;pauseOnOutsideViewport;preset;resize;smooth;style;zLayers;_container;_pluginManager;constructor(e,t){this._pluginManager=e,this._container=t,this.autoPlay=!0,this.background=new r,this.clear=!0,this.defaultThemes={},this.delay=0,this.fullScreen=new o,this.detectRetina=!0,this.duration=0,this.fpsLimit=120,this.hdr=!0,this.particles=(0,d.y)(this._pluginManager,this._container),this.pauseOnBlur=!0,this.pauseOnOutsideViewport=!0,this.resize=new l,this.smooth=!1,this.style={},this.zLayers=100}load(e){if((0,s.kZ)(e))return;void 0!==e.preset&&(this.preset=e.preset,(0,a.wJ)(this.preset,e=>{this._importPreset(e)})),void 0!==e.palette&&(this.palette=e.palette,this._importPalette(this.palette)),void 0!==e.autoPlay&&(this.autoPlay=e.autoPlay),void 0!==e.clear&&(this.clear=e.clear),void 0!==e.key&&(this.key=e.key),void 0!==e.name&&(this.name=e.name),void 0!==e.delay&&(this.delay=(0,u.DT)(e.delay));let t=e.detectRetina;void 0!==t&&(this.detectRetina=t),void 0!==e.duration&&(this.duration=(0,u.DT)(e.duration));let i=e.fpsLimit;void 0!==i&&(this.fpsLimit=i),void 0!==e.hdr&&(this.hdr=e.hdr),void 0!==e.pauseOnBlur&&(this.pauseOnBlur=e.pauseOnBlur),void 0!==e.pauseOnOutsideViewport&&(this.pauseOnOutsideViewport=e.pauseOnOutsideViewport),void 0!==e.zLayers&&(this.zLayers=e.zLayers),this.background.load(e.background);let n=e.fullScreen;(0,s.Lm)(n)?this.fullScreen.enable=n:this.fullScreen.load(n),this.particles.load(e.particles),this.resize.load(e.resize),this.style=(0,a.zw)(this.style,e.style),void 0!==e.smooth&&(this.smooth=e.smooth),this._pluginManager.plugins.forEach(t=>{t.loadOptions(this._container,this,e)})}_importPalette=e=>{let t=this._pluginManager.getPalette(e);t&&this.load({background:{color:t.background},blend:{enable:!0,mode:t.blendMode},particles:{palette:e}})};_importPreset=e=>{this.load(this._pluginManager.getPreset(e))}}},9744(e,t,i){i.d(t,{O:()=>s});var a=i(4920);class s{value;constructor(){this.value=""}static create(e,t){let i=new s;return i.load(e),void 0!==t&&((0,a.Kg)(t)||(0,a.cy)(t)?i.load({value:t}):i.load(t)),i}load(e){!(0,a.kZ)(e)&&((0,a.kZ)(e.value)||(this.value=e.value))}}},8805(e,t,i){i.d(t,{w:()=>n});var a=i(3182),s=i(4920);class n{horizontal;vertical;constructor(){this.horizontal=new a.F,this.vertical=new a.F}load(e){(0,s.kZ)(e)||(this.horizontal.load(e.horizontal),this.vertical.load(e.vertical))}}},3182(e,t,i){i.d(t,{F:()=>s});var a=i(5603);class s extends a.PV{constructor(){super(),this.value=1}}},5240(e,t,i){i.d(t,{S:()=>r});var a=i(2078),s=i(4920),n=i(8770);class r{color;enable;opacity;constructor(){this.enable=!0,this.color=new a.A,this.color.value="#fff",this.opacity=1}load(e){(0,s.kZ)(e)||(void 0!==e.color&&(this.color=a.A.create(this.color,e.color)),void 0!==e.enable&&(this.enable=e.enable),void 0!==e.opacity&&(this.opacity=(0,n.DT)(e.opacity)))}}},3690(e,t,i){i.d(t,{y:()=>h});var a=i(5327),s=i(4920),n=i(2379),r=i(5695),o=i(8954),l=i(7677),d=i(495),u=i(7187),c=i(8770);class h{angle;center;decay;direction;distance;drift;enable;gravity;outModes;path;random;size;speed;spin;straight;vibrate;warp;constructor(){this.angle=new n.h,this.center=new r.Z,this.decay=0,this.distance={},this.direction=a.F.none,this.drift=0,this.enable=!1,this.gravity=new o.y,this.path=new l.v,this.outModes=new d.j,this.random=!1,this.size=!1,this.speed=2,this.spin=new u.t,this.straight=!1,this.vibrate=!1,this.warp=!1}load(e){if((0,s.kZ)(e))return;this.angle.load((0,s.Et)(e.angle)?{value:e.angle}:e.angle),this.center.load(e.center),void 0!==e.decay&&(this.decay=(0,c.DT)(e.decay)),void 0!==e.direction&&(this.direction=e.direction),void 0!==e.distance&&(this.distance=(0,s.Et)(e.distance)?{horizontal:e.distance,vertical:e.distance}:{...e.distance}),void 0!==e.drift&&(this.drift=(0,c.DT)(e.drift)),void 0!==e.enable&&(this.enable=e.enable),this.gravity.load(e.gravity);let t=e.outModes;void 0!==t&&((0,s.Gv)(t)?this.outModes.load(t):this.outModes.load({default:t})),this.path.load(e.path),void 0!==e.random&&(this.random=e.random),void 0!==e.size&&(this.size=e.size),void 0!==e.speed&&(this.speed=(0,c.DT)(e.speed)),this.spin.load(e.spin),void 0!==e.straight&&(this.straight=e.straight),void 0!==e.vibrate&&(this.vibrate=e.vibrate),void 0!==e.warp&&(this.warp=e.warp)}}},2379(e,t,i){i.d(t,{h:()=>n});var a=i(4920),s=i(8770);class n{offset;value;constructor(){this.offset=0,this.value=90}load(e){(0,a.kZ)(e)||(void 0!==e.offset&&(this.offset=(0,s.DT)(e.offset)),void 0!==e.value&&(this.value=(0,s.DT)(e.value)))}}},5695(e,t,i){i.d(t,{Z:()=>n});var a=i(2702),s=i(4920);class n{mode;radius;x;y;constructor(){this.x=50,this.y=50,this.mode=a.q.percent,this.radius=0}load(e){(0,s.kZ)(e)||(void 0!==e.x&&(this.x=e.x),void 0!==e.y&&(this.y=e.y),void 0!==e.mode&&(this.mode=e.mode),void 0!==e.radius&&(this.radius=e.radius))}}},8954(e,t,i){i.d(t,{y:()=>n});var a=i(4920),s=i(8770);class n{acceleration;enable;inverse;maxSpeed;constructor(){this.acceleration=9.81,this.enable=!1,this.inverse=!1,this.maxSpeed=50}load(e){(0,a.kZ)(e)||(void 0!==e.acceleration&&(this.acceleration=(0,s.DT)(e.acceleration)),void 0!==e.enable&&(this.enable=e.enable),void 0!==e.inverse&&(this.inverse=e.inverse),void 0!==e.maxSpeed&&(this.maxSpeed=(0,s.DT)(e.maxSpeed)))}}},495(e,t,i){i.d(t,{j:()=>n});var a=i(3942),s=i(4920);class n{bottom;default;left;right;top;constructor(){this.default=a.Y.out}load(e){(0,s.kZ)(e)||(void 0!==e.default&&(this.default=e.default),this.bottom=e.bottom??e.default,this.left=e.left??e.default,this.right=e.right??e.default,this.top=e.top??e.default)}}},7677(e,t,i){i.d(t,{v:()=>r});var a=i(5603),s=i(8664),n=i(4920);class r{clamp;delay;enable;generator;options;constructor(){this.clamp=!0,this.delay=new a.PV,this.enable=!1,this.options={}}load(e){!(0,n.kZ)(e)&&(void 0!==e.clamp&&(this.clamp=e.clamp),this.delay.load(e.delay),void 0!==e.enable&&(this.enable=e.enable),this.generator=e.generator,e.options&&(this.options=(0,s.zw)(this.options,e.options)))}}},7187(e,t,i){i.d(t,{t:()=>r});var a=i(8664),s=i(4920),n=i(8770);class r{acceleration;enable;position;constructor(){this.acceleration=0,this.enable=!1}load(e){!(0,s.kZ)(e)&&(void 0!==e.acceleration&&(this.acceleration=(0,n.DT)(e.acceleration)),void 0!==e.enable&&(this.enable=e.enable),e.position&&(this.position=(0,a.zw)({},e.position)))}}},6177(e,t,i){i.d(t,{N:()=>r});var a=i(4920);class s{enable;height;width;constructor(){this.enable=!1,this.width=1920,this.height=1080}load(e){if((0,a.kZ)(e))return;void 0!==e.enable&&(this.enable=e.enable);let t=e.width;void 0!==t&&(this.width=t);let i=e.height;void 0!==i&&(this.height=i)}}var n=i(5358);class r{density;limit;value;constructor(){this.density=new s,this.limit=new n.A,this.value=0}load(e){(0,a.kZ)(e)||(this.density.load(e.density),this.limit.load(e.limit),void 0!==e.value&&(this.value=e.value))}}},5358(e,t,i){i.d(t,{A:()=>n});var a=i(7345),s=i(4920);class n{mode;value;constructor(){this.mode=a.d.delete,this.value=0}load(e){(0,s.kZ)(e)||(void 0!==e.mode&&(this.mode=e.mode),void 0!==e.value&&(this.value=e.value))}}},5446(e,t,i){i.d(t,{Y:()=>r});var a=i(1918),s=i(5603),n=i(4920);class r extends s.AI{animation;constructor(){super(),this.animation=new a.I,this.value=1}load(e){if((0,n.kZ)(e))return;super.load(e);let t=e.animation;void 0!==t&&this.animation.load(t)}}},1918(e,t,i){i.d(t,{I:()=>r});var a=i(202),s=i(6753),n=i(4920);class r extends s.Q{destroy;constructor(){super(),this.destroy=a.V.none,this.speed=2}load(e){super.load(e),(0,n.kZ)(e)||void 0!==e.destroy&&(this.destroy=e.destroy)}}},8869(e,t,i){i.d(t,{P:()=>r});var a=i(5240),s=i(7349),n=i(4920);class r{fill;stroke;load(e){(0,n.kZ)(e)||(void 0!==e.fill&&(this.fill??=new a.S,this.fill.load(e.fill)),void 0!==e.stroke&&(this.stroke??=new s.t,this.stroke.load(e.stroke)))}}},6334(e,t,i){i.d(t,{U:()=>v});var a=i(8664),s=i(4920);class n{close;options;type;constructor(){this.close=!0,this.options={},this.type=[]}load(e){if((0,s.kZ)(e))return;let t=e.options;if(void 0!==t)for(let e in t){let i=t[e];i&&(this.options[e]=(0,a.zw)(this.options[e]??{},i))}void 0!==e.close&&(this.close=e.close),void 0!==e.type&&(this.type=e.type)}}var r=i(3690),o=i(5446),l=i(8869),d=i(8805),u=i(6177),c=i(5746),h=i(3442),p=i(6992);class v{bounce;effect;groups;move;number;opacity;paint;palette;reduceDuplicates;shape;size;zIndex;_container;_pluginManager;constructor(e,t){this._pluginManager=e,this._container=t,this.bounce=new d.w,this.effect=new n,this.groups={},this.move=new r.y,this.number=new u.N,this.opacity=new o.Y,this.paint=new l.P,this.reduceDuplicates=!1,this.shape=new c.y,this.size=new h.o,this.zIndex=new p.P}load(e){if((0,s.kZ)(e))return;if(e.palette&&(this.palette=e.palette,this._importPalette(this.palette)),void 0!==e.groups)for(let t of Object.keys(e.groups)){if(!(t in e.groups))continue;let i=e.groups[t];void 0!==i&&(this.groups[t]=(0,a.zw)(this.groups[t]??{},i))}void 0!==e.reduceDuplicates&&(this.reduceDuplicates=e.reduceDuplicates),this.bounce.load(e.bounce),this.effect.load(e.effect),this.move.load(e.move),this.number.load(e.number),this.opacity.load(e.opacity);let t=e.paint;if(t&&(this.paint=(0,a.wJ)(t,e=>{let t=new l.P;return t.load(e),t})),this.shape.load(e.shape),this.size.load(e.size),this.zIndex.load(e.zIndex),this._container){for(let t of this._pluginManager.plugins)t.loadParticlesOptions&&t.loadParticlesOptions(this._container,this,e);let t=this._pluginManager.updaters.get(this._container);if(t)for(let i of t)i.loadOptions&&i.loadOptions(this,e)}}_importPalette=e=>{let t=this._pluginManager.getPalette(e);if(!t)return;let i=t.colors,a=((0,s.cy)(i)?i:[i]).flatMap(e=>{let t=e.fill,i=e.stroke,a=t?{color:{value:t.value},enable:t.enable,opacity:t.opacity}:void 0;return i?[{fill:a,stroke:{color:{value:i.value},opacity:i.opacity,width:i.width||0}}]:[{fill:a}]}),n=a.length>1?a:a[0]??{};this.load({paint:n,blend:{enable:!0,mode:t.blendMode}})}}},5746(e,t,i){i.d(t,{y:()=>n});var a=i(8664),s=i(4920);class n{close;options;type;constructor(){this.close=!0,this.options={},this.type="circle"}load(e){if((0,s.kZ)(e))return;let t=e.options;if(void 0!==t)for(let e in t){let i=t[e];i&&(this.options[e]=(0,a.zw)(this.options[e]??{},i))}void 0!==e.close&&(this.close=e.close),void 0!==e.type&&(this.type=e.type)}}},3442(e,t,i){i.d(t,{o:()=>r});var a=i(5603),s=i(4234),n=i(4920);class r extends a.AI{animation;constructor(){super(),this.animation=new s.q,this.value=3}load(e){if(super.load(e),(0,n.kZ)(e))return;let t=e.animation;void 0!==t&&this.animation.load(t)}}},4234(e,t,i){i.d(t,{q:()=>r});var a=i(202),s=i(6753),n=i(4920);class r extends s.Q{destroy;constructor(){super(),this.destroy=a.V.none,this.speed=5}load(e){super.load(e),(0,n.kZ)(e)||void 0!==e.destroy&&(this.destroy=e.destroy)}}},7349(e,t,i){i.d(t,{t:()=>r});var a=i(2078),s=i(4920),n=i(8770);class r{color;opacity;width;constructor(){this.width=0}load(e){(0,s.kZ)(e)||(void 0!==e.color&&(this.color=a.A.create(this.color,e.color)),void 0!==e.width&&(this.width=(0,n.DT)(e.width)),void 0!==e.opacity&&(this.opacity=(0,n.DT)(e.opacity)))}}},6992(e,t,i){i.d(t,{P:()=>n});var a=i(5603),s=i(4920);class n extends a.PV{opacityRate;sizeRate;velocityRate;constructor(){super(),this.opacityRate=1,this.sizeRate=1,this.velocityRate=1}load(e){super.load(e),(0,s.kZ)(e)||(void 0!==e.opacityRate&&(this.opacityRate=e.opacityRate),void 0!==e.sizeRate&&(this.sizeRate=e.sizeRate),void 0!==e.velocityRate&&(this.velocityRate=e.velocityRate))}}},5603(e,t,i){i.d(t,{AI:()=>l,PV:()=>r});var a=i(6753),s=i(4920),n=i(8770);class r{value;constructor(){this.value=0}load(e){!(0,s.kZ)(e)&&((0,s.kZ)(e.value)||(this.value=(0,n.DT)(e.value)))}}class o extends r{animation=new a.p;load(e){if(super.load(e),(0,s.kZ)(e))return;let t=e.animation;void 0!==t&&this.animation.load(t)}}class l extends o{animation;constructor(){super(),this.animation=new a.Q}load(e){super.load(e)}}},3252(e,t,i){i.d(t,{IU:()=>r,Md:()=>n,Sn:()=>s,Wb:()=>l,p0:()=>o});var a=i(8660);function s(e,t,i){e.fillStyle=i??"rgba(0,0,0,0)",e.fillRect(a.bo.x,a.bo.y,t.width,t.height)}function n(e,t,i,s){if(!i)return;let n=e.globalAlpha;e.globalAlpha=s,e.drawImage(i,a.bo.x,a.bo.y,t.width,t.height),e.globalAlpha=n}function r(e,t){e.clearRect(a.bo.x,a.bo.y,t.width,t.height)}function o(e){let{container:t,context:i,particle:s,delta:n,colorStyles:r,radius:o,opacity:l,transform:d}=e,{effectDrawers:u,shapeDrawers:c}=t,h=s.getPosition(),p=s.getTransformData(d),v=a.Pf,f={x:h.x,y:h.y};i.setTransform(p.a,p.b,p.c,p.d,h.x,h.y),r.fill&&(i.fillStyle=r.fill);let g=!!s.fillEnabled,y=s.strokeWidth??a.Dv;i.lineWidth=y,r.stroke&&(i.strokeStyle=r.stroke);let m={context:i,particle:s,radius:o,drawRadius:o*v,opacity:l,delta:n,pixelRatio:t.retina.pixelRatio,fill:g,stroke:y>a.Dv,transformData:p,position:{...h},drawPosition:f,drawScale:v};for(let e of t.plugins)e.drawParticleTransform?.(m);let b=s.effect?u.get(s.effect):void 0,w=s.shape?c.get(s.shape):void 0;(function(e,t){if(!e?.drawBefore)return;let{particle:i}=t;i.effect&&e.drawBefore(t)})(b,m),function(e,t){if(!e?.beforeDraw)return;let{particle:i}=t;i.shape&&e.beforeDraw(t)}(w,m),function(e,t){if(!e)return;let{context:i,fill:a,particle:s,stroke:n}=t;s.shape&&(i.beginPath(),e.draw(t),s.shapeClose&&i.closePath(),a&&i.fill(),n&&i.stroke())}(w,m),function(e,t){if(!e?.afterDraw)return;let{particle:i}=t;i.shape&&e.afterDraw(t)}(w,m),function(e,t){if(!e?.drawAfter)return;let{particle:i}=t;i.effect&&e.drawAfter(t)}(b,m),i.resetTransform()}function l(e,t,i,a){t.drawParticle&&t.drawParticle(e,i,a)}},7621(e,t,i){i.d(t,{BN:()=>c,Jv:()=>M,LC:()=>y,O_:()=>m,R5:()=>h,YL:()=>p,ay:()=>v,pz:()=>b,xx:()=>f,yx:()=>z});var a=i(8770),s=i(8660),n=i(4920),r=i(6932),o=i(2314),l=i(8664);let d=new Map;function u(e,t){let i=d.get(e);return i||(i=t(),d.size>=1e3&&[...d.keys()].slice(0,1e3*s.MX).forEach(e=>d.delete(e)),d.set(e,i)),i}function c(e,t,i,r=!0){if(!t)return;let o=(0,n.Kg)(t)?{value:t}:t;if((0,n.Kg)(o.value))return function e(t,i,r,o=!0){if(!i)return;let d=(0,n.Kg)(i)?{value:i}:i;if((0,n.Kg)(d.value)){let e,i,n;return d.value===s.mR?(e=(void 0)??s.Fl,i=s.oi+s.D_,{b:(n=()=>Math.floor((0,a.e4)(e,i)))(),g:n(),r:n()}):function(e,t){if(t){for(let i of e.colorManagers.values())if(i.accepts(t))return i.parseString(t)}}(t,d.value)}if((0,n.cy)(d.value)){let i=(0,l.Vh)(d.value,r,o);if(!i)return;return e(t,{value:i})}for(let e of t.colorManagers.values()){let t=e.handleColor(d);if(t)return t}}(e,o.value,i,r);if((0,n.cy)(o.value)){let t=(0,l.Vh)(o.value,i,r);if(!t)return;return c(e,{value:t})}for(let t of e.colorManagers.values()){let e=t.handleRangeColor(o);if(e)return e}}function h(e,t,i,a=!0){var n;let r,o,l,d,u,p,v=c(e,t,i,a);return v?(r=(n=v).r/s.oi,o=n.g/s.oi,d=Math.max(r,o,l=n.b/s.oi),u=Math.min(r,o,l),p={h:s.L1,l:(d+u)*s.MX,s:s.yx},d!==u&&(p.s=p.l<s.MX?(d-u)/(d+u):(d-u)/(s.gd-d-u),r===d?p.h=(o-l)/(d-u):o===d?p.h=s.gd+(l-r)/(d-u):p.h=s.gd*s.gd+(r-o)/(d-u)),p.l*=s.$_,p.s*=s.eu,p.h*=s.U0,p.h<s.L1&&(p.h+=s.vS),p.h>=s.vS&&(p.h-=s.vS),p):void 0}function p(e){let t=(e.h%s.vS+s.vS)%s.vS,i=Math.max(s.yx,Math.min(s.eu,e.s)),a=Math.max(s.vd,Math.min(s.$_,e.l)),n=t/s.vS,r=i/s.eu,o=a/s.$_;if(i===s.yx){let e=Math.round(o*s.oi);return{r:e,g:e,b:e}}let l=(e,t,i)=>(i<0&&i++,i>1&&i--,i*s.zg<1)?e+(t-e)*s.zg*i:i*s.gd<1?t:i*s.Nu<+s.gd?e+(t-e)*(s.gd/s.Nu-i)*s.zg:e,d=o<s.MX?o*(s.aE+r):o+r-o*r,u=s.gd*o-d,c=s.BF/s.Nu;return{r:Math.round(Math.min(s.oi,s.oi*l(u,d,n+c))),g:Math.round(Math.min(s.oi,s.oi*l(u,d,n))),b:Math.round(Math.min(s.oi,s.oi*l(u,d,n-c)))}}function v(e){let t=p(e);return{a:e.a,b:t.b,g:t.g,r:t.r}}function f(e,t,i){let a=i??s.hv;return u(`rgb-${e.r.toFixed(2)}-${e.g.toFixed(2)}-${e.b.toFixed(2)}-${t?"hdr":"sdr"}-${a.toString()}`,()=>{var a,n;return t?g(e,i):(a=e,n=i,`rgba(${a.r.toString()}, ${a.g.toString()}, ${a.b.toString()}, ${(n??s.hv).toString()})`)})}function g(e,t){return`color(display-p3 ${(e.r/s.oi).toString()} ${(e.g/s.oi).toString()} ${(e.b/s.oi).toString()} / ${(t??s.hv).toString()})`}function y(e,t,i){let a=i??s.hv;return u(`hsl-${e.h.toFixed(2)}-${e.s.toFixed(2)}-${e.l.toFixed(2)}-${t?"hdr":"sdr"}-${a.toString()}`,()=>{var a,n,r,o;return t?(a=e,n=i,g(p(a),n)):(r=e,o=i,`hsla(${r.h.toString()}, ${r.s.toString()}%, ${r.l.toString()}%, ${(o??s.hv).toString()})`)})}function m(e){return void 0===e?void 0:{h:e.h.value,s:e.s.value,l:e.l.value}}function b(e,t,i){let a={h:{enable:!1,value:e.h,min:s.L1,max:s.vS},s:{enable:!1,value:e.s,min:s.yx,max:s.eu},l:{enable:!1,value:e.l,min:s.vd,max:s.$_}};return t&&(w(a.h,t.h,i),w(a.s,t.s,i),w(a.l,t.l,i)),a}function w(e,t,i){e.enable=t.enable,e.min=t.min,e.max=t.max,e.enable?(e.velocity=(0,a.VG)(t.speed)/s.a5*i,e.decay=s.WH-(0,a.VG)(t.decay),e.status=o.H.increasing,e.loops=s.hK,e.maxLoops=(0,a.VG)(t.count),e.time=s.tR,e.delayTime=(0,a.VG)(t.delay)*s.Xu,t.sync||(e.velocity*=(0,a.G0)(),e.value*=(0,a.G0)()),e.initialValue=e.value,e.offset=(0,a.DT)(t.offset)):e.velocity=s.jn}function x(e,t,i){if(!e.enable||(e.maxLoops??0)>0&&(e.loops??0)>(e.maxLoops??0)||(e.time??=0,(e.delayTime??0)>0&&e.time<(e.delayTime??0)&&(e.time+=i.value),(e.delayTime??0)>0&&e.time<(e.delayTime??0)))return;let s=e.offset?(0,a.vE)(e.offset):0,n=(e.velocity??0)*i.factor+3.6*s,r=e.decay??1,l=e.max,d=e.min;t&&e.status!==o.H.increasing?(e.value-=n,e.value<d&&(e.loops??=0,e.loops++,e.status=o.H.increasing)):(e.value+=n,e.value>l&&(e.loops??=0,e.loops++,t?e.status=o.H.decreasing:e.value-=l)),e.velocity&&1!==r&&(e.velocity*=r),e.value=(0,a.qE)(e.value,d,l)}function M(e,t){if(!e)return;let{h:i,s:a,l:s}=e;x(i,!1,t),x(a,!0,t),x(s,!0,t)}function z(e,t,i){return{h:e.h,s:e.s,l:e.l+(t===r.H.darken?-s.iU:s.iU)*i}}},2914(e,t,i){i.d(t,{t:()=>s});let a={debug:console.debug,error:(e,t)=>{console.error(`tsParticles - Error - ${e}`,t)},info:console.info,log:console.log,trace:console.trace,verbose:console.log,warning:console.warn};function s(){return a}},8770(e,t,i){i.d(t,{$m:()=>k,DT:()=>function e(t,i){if(t===i||void 0===i&&(0,r.Et)(t))return t;let a=g(t),s=y(t);return void 0!==i?{min:Math.min(a,i),max:Math.max(s,i)}:e(a,s)},G0:()=>d,JY:()=>z,M3:()=>S,Nx:()=>_,Sg:()=>g,VG:()=>f,W9:()=>y,Yf:()=>w,e4:()=>u,gp:()=>x,i0:()=>c,pu:()=>M,px:()=>h,qE:()=>p,vE:()=>v,vr:()=>m});var a=i(5327),s=i(8660),n=i(4037),r=i(4920);let o=Math.PI/180,l=Math.random;function d(){return p(l(),0,1-Number.EPSILON)}function u(e,t){return d()*(t-e)+e}function c(e){return requestAnimationFrame(e)}function h(e){cancelAnimationFrame(e)}function p(e,t,i){return Math.min(Math.max(e,t),i)}function v(e){let t=y(e),i=g(e);return t===i&&(i=0),u(i,t)}function f(e){return(0,r.Et)(e)?e:v(e)}function g(e){return(0,r.Et)(e)?e:e.min}function y(e){return(0,r.Et)(e)?e:e.max}function m(e,t){let i=e.x-t.x,a=e.y-t.y;return{dx:i,dy:a,distance:Math.hypot(i,a)}}function b(e,t){let i=e.x-t.x,a=e.y-t.y;return i*i+a*a}function w(e,t){return Math.sqrt(b(e,t))}function x(e,t,i){return b(e,t)<=i*i}function M(e){return e*o}function z(e,t,i){if((0,r.Et)(e))return e*o;switch(e){case a.F.top:return-Math.PI*s.MX;case a.F.topRight:return-Math.PI*s.$G;case a.F.right:return s.Ie;case a.F.bottomRight:return Math.PI*s.$G;case a.F.bottom:return Math.PI*s.MX;case a.F.bottomLeft:return Math.PI*s.Rq;case a.F.left:return Math.PI;case a.F.topLeft:return-Math.PI*s.Rq;case a.F.inside:return Math.atan2(i.y-t.y,i.x-t.x);case a.F.outside:return Math.atan2(t.y-i.y,t.x-i.x);default:return d()*s.R1}}function k(e){let t=n.M.origin;return t.length=1,t.angle=e,t}function _(e){let{position:t,size:i}=e;return{x:t?.x??d()*i.width,y:t?.y??d()*i.height}}function S(e){return e?e.endsWith("%")?parseFloat(e)/s.a5:parseFloat(e):1}},2222(e,t,i){i.d(t,{Z:()=>s,y:()=>n});var a=i(6334);function s(e,...t){for(let i of t)e.load(i)}function n(e,t,...i){let r=new a.U(e,t);return s(r,...i),r}},4920(e,t,i){function a(e){return"boolean"==typeof e}function s(e){return"string"==typeof e}function n(e){return"number"==typeof e}function r(e){return"object"==typeof e&&null!==e}function o(e){return Array.isArray(e)}function l(e){return null==e}i.d(t,{Et:()=>n,Gv:()=>r,Kg:()=>s,Lm:()=>a,cy:()=>o,kZ:()=>l})},8664(e,t,i){let a,s,n,r,o;i.d(t,{AE:()=>_,BR:()=>w,E9:()=>T,HQ:()=>A,Kp:()=>D,Ot:()=>$,T5:()=>m,TA:()=>P,Tj:()=>k,UC:()=>L,Vh:()=>z,Xs:()=>E,hJ:()=>R,hn:()=>M,lV:()=>b,tG:()=>x,td:()=>I,w3:()=>O,wJ:()=>S,zw:()=>function e(t,...i){for(let a of i){if((0,c.kZ)(a))continue;if(!(0,c.Gv)(a)){t=a;continue}Array.isArray(a)?Array.isArray(t)||(t=[]):(!(0,c.Gv)(t)||Array.isArray(t))&&(t={});let i=Object.keys(a),s=new Set(["__proto__","constructor","prototype"]);if(!i.some(e=>{let t=a[e];return(0,c.Gv)(t)||Array.isArray(t)})){let e=t;for(let t of i)if(!s.has(t)&&t in a){let i=a[t];void 0!==i&&(e[t]=i)}continue}for(let n of i){if(s.has(n))continue;let i=t,r=a[n];i[n]=Array.isArray(r)?r.map(t=>e(void 0,t)):e(i[n],r)}}return t}});var l,d=i(8770),u=i(8660),c=i(4920),h=i(4992),p=i(2314),v=i(202),f=i(7341),g=i(2702),y=i(9983);function m(){return globalThis.document}function b(e){if("u">typeof matchMedia)return matchMedia(e)}function w(e){if("u">typeof IntersectionObserver)return new IntersectionObserver(e)}function x(e){if("u">typeof MutationObserver)return new MutationObserver(e)}function M(e,t){return e===t||(0,c.cy)(t)&&t.includes(e)}function z(e,t,i=!0){return e[void 0!==t&&i?t%e.length:Math.floor((0,d.G0)()*e.length)]}function k(e,t,i,a,s){var n,r,o,l;let d;return n=_(e,a??0),r=t,o=i,d=!0,(l=s)&&l!==f.v.bottom||(d=n.top<r.height+o.x),d&&(!l||l===f.v.left)&&(d=n.right>o.x),d&&(!l||l===f.v.right)&&(d=n.left<r.width+o.y),d&&(!l||l===f.v.top)&&(d=n.bottom>o.y),d}function _(e,t){return{bottom:e.y+t,left:e.x-t,right:e.x+t,top:e.y-t}}function S(e,t){return(0,c.cy)(e)?e.map((e,i)=>t(e,i)):t(e,0)}function P(e,t,i){return(0,c.cy)(e)?z(e,t,i):e}function O(e,t){return(0,c.cy)(e)?e.find((e,i)=>t(e,i)):t(e,0)?e:void 0}function E(e,t){let i=e.value,a=e.animation,s={delayTime:(0,d.VG)(a.delay)*u.Xu,enable:a.enable,value:(0,d.VG)(e.value)*t,max:(0,d.W9)(i)*t,min:(0,d.Sg)(i)*t,loops:0,maxLoops:(0,d.VG)(a.count),time:0};if(a.enable){switch(s.decay=1-(0,d.VG)(a.decay),a.mode){case h.g.increase:s.status=p.H.increasing;break;case h.g.decrease:s.status=p.H.decreasing;break;case h.g.random:s.status=(0,d.G0)()>=u.MX?p.H.increasing:p.H.decreasing}let e=a.mode===h.g.auto;switch(a.startValue){case y.S.min:s.value=s.min,e&&(s.status=p.H.increasing);break;case y.S.max:s.value=s.max,e&&(s.status=p.H.decreasing);break;case y.S.random:default:s.value=(0,d.vE)(s),e&&(s.status=(0,d.G0)()>=u.MX?p.H.increasing:p.H.decreasing)}}return s.initialValue=s.value,s}function T(e,t){return function(e,t){if(e.mode!==g.q.percent){let{mode:t,...i}=e;return i}return"x"in e?{x:e.x/u.a5*t.width,y:e.y/u.a5*t.height}:{width:e.width/u.a5*t.width,height:e.height/u.a5*t.height}}(e,t)}function L(e,t,i,a,s){if(e.destroyed||!t.enable||(t.maxLoops??0)>0&&(t.loops??0)>(t.maxLoops??0))return;let n=(t.velocity??0)*s.factor,r=t.min,o=t.max,l=t.decay??1;if(t.time??=0,(t.delayTime??0)>0&&t.time<(t.delayTime??0)&&(t.time+=s.value),!((t.delayTime??0)>0)||!(t.time<(t.delayTime??0))){switch(t.status){case p.H.increasing:t.value+=n;break;case p.H.decreasing:t.value-=n}switch(t.velocity&&1!==l&&(t.velocity*=l),t.status){case p.H.increasing:t.value>=o&&(i?t.status=p.H.decreasing:t.value-=o,t.loops??=0,t.loops++);break;case p.H.decreasing:t.value<=r&&(i?t.status=p.H.increasing:t.value+=o,t.loops??=0,t.loops++)}var u=t.value;switch(a){case v.V.max:u>=o&&e.destroy();break;case v.V.min:u<=r&&e.destroy()}e.destroyed||(t.value=(0,d.qE)(t.value,r,o))}}function I(e){let t=m().createElement("div").style;for(let i in e){let a=e[i];if(!(i in e)||(0,c.kZ)(a))continue;let s=e.getPropertyValue?.(a);if(!s)continue;let n=e.getPropertyPriority?.(a);n?t.setProperty(a,s,n):t.setProperty(a,s)}return t}i(4037);let R=(l=function(e){let t=m().createElement("div").style,i={width:"100%",height:"100%",margin:"0",padding:"0",borderWidth:"0",position:"fixed",zIndex:e.toString(10),"z-index":e.toString(10),top:"0",left:"0"};for(let e in i){let a=i[e];void 0!==a&&t.setProperty(e,a)}return t},a=new Map,s=void 0,n=void 0,r=void 0,o=(e,t=new WeakSet)=>{if(null===e)return"null";let i=typeof e;if("undefined"===i)return"undefined";if("number"===i||"boolean"===i||"string"===i)return JSON.stringify(e);if("function"===i)try{return e.toString()}catch{return'"[Function]"'}if("symbol"===i)try{return e.toString()}catch{return'"[Symbol]"'}if(Array.isArray(e))return`[${e.map(e=>o(e,t)).join(",")}]`;if(t.has(e))return'"[Circular]"';t.add(e);let a=Object.keys(e).sort();return`{${a.map(i=>`${JSON.stringify(i)}:${o(e[i],t)}`).join(",")}}`},(...e)=>{let t,i=(t=e,r?r(t):o(t)),d=Date.now(),u=a.get(i);if(void 0!==u)if(!n||!(d-u.ts>n))return a.delete(i),a.set(i,{value:u.value,ts:u.ts}),u.value;else a.delete(i);let c=l(...e);if(a.set(i,{value:c,ts:d}),"number"==typeof s&&s>=0)for(;a.size>s;){let e=a.keys().next().value;if(void 0===e)break;a.delete(e)}return c});function D(e,t,i,a,s){if(a){let a={passive:!0};(0,c.Lm)(s)?a.capture=s:void 0!==s&&(a=s),e.addEventListener(t,i,a)}else e.removeEventListener(t,i,s)}async function A(e,t,i,a=!1){let s=t.get(e);return(!s||a)&&(s=await Promise.all([...i.values()].map(t=>t(e))),t.set(e,s)),s}async function $(e,t,i,a=!1){let s=t.get(e);return(!s||a)&&(s=new Map(await Promise.all([...i.entries()].map(([t,i])=>i(e).then(e=>[t,e])))),t.set(e,s)),s}},3227(e,t,i){i.d(t,{Yzx:()=>x.Y,v5k:()=>w.v,x_I:()=>M.x,pTR:()=>r,Miz:()=>b.M,AEc:()=>u.AE,qE8:()=>f.qE,WH8:()=>d.WH,zwS:()=>u.zw,puj:()=>f.pu,gdl:()=>d.gd,R1e:()=>d.R1,wJ2:()=>u.wJ,w3Z:()=>u.w3,YfF:()=>f.Yf,vrU:()=>f.vr,pzy:()=>z.pz,OtU:()=>u.Ot,HQK:()=>u.HQ,G0i:()=>f.G0,W9e:()=>f.W9,VGA:()=>f.VG,MXx:()=>d.MX,YLU:()=>z.YL,ayx:()=>z.ay,XsS:()=>u.Xs,cyL:()=>k.cy,hnD:()=>u.hn,kZJ:()=>k.kZ,Gvm:()=>k.Gv,Tj8:()=>u.Tj,Vh1:()=>u.Vh,TA3:()=>u.TA,K3:()=>d.K3,KpY:()=>u.Kp,XuV:()=>d.Xu,boI:()=>d.bo,M3Y:()=>f.M3,a56:()=>d.a5,vEz:()=>f.vE,R5R:()=>z.R5,T5G:()=>u.T5,BRq:()=>u.BR,DT4:()=>f.DT,$k3:()=>_,UC0:()=>u.UC,JvX:()=>z.Jv,nKi:()=>d.nK});var a,s,n,r,o,l,d=i(8660),u=i(8664);class c{_listeners;constructor(){this._listeners=new Map}addEventListener(e,t){this.removeEventListener(e,t);let i=this._listeners.get(e);i||(i=[],this._listeners.set(e,i)),i.push(t)}dispatchEvent(e,t){let i=this._listeners.get(e);i?.forEach(e=>{e(t)})}hasEventListener(e){return!!this._listeners.get(e)}removeAllEventListeners(e){e?this._listeners.delete(e):this._listeners=new Map}removeEventListener(e,t){let i=this._listeners.get(e);if(!i)return;let a=i.length,s=i.indexOf(t);s<d.z9||(a===d.LD?this._listeners.delete(e):i.splice(s,d.LD))}}var h=i(6128);class p{colorManagers=new Map;easingFunctions=new Map;effectDrawers=new Map;initializers={effects:new Map,shapes:new Map,updaters:new Map};palettes=new Map;plugins=[];presets=new Map;shapeDrawers=new Map;updaters=new Map;_allLoadersSet=new Set;_configs=new Map;_engine;_executedSet=new Set;_initialized=!1;_isRunningLoaders=!1;_loadPromises=new Set;constructor(e){this._engine=e}get configs(){let e={};for(let[t,i]of this._configs)e[t]=i;return e}addColorManager(e,t){this.colorManagers.set(e,t)}addConfig(e){let t=e.key??e.name??"default";this._configs.set(t,e),this._engine.dispatchEvent(h.B.configAdded,{data:{name:t,config:e}})}addEasing(e,t){this.easingFunctions.get(e)||this.easingFunctions.set(e,t)}addEffect(e,t){this.initializers.effects.set(e,t)}addPalette(e,t){this.palettes.set(e,t)}addParticleUpdater(e,t){this.initializers.updaters.set(e,t)}addPlugin(e){this.getPlugin(e.id)||this.plugins.push(e)}addPreset(e,t,i=!1){(i||!this.getPreset(e))&&this.presets.set(e,t)}addShape(e,t){for(let i of e)this.initializers.shapes.set(i,t)}clearPlugins(e){this.effectDrawers.delete(e),this.shapeDrawers.delete(e),this.updaters.delete(e)}getEasing(e){return this.easingFunctions.get(e)??(e=>e)}getEffectDrawers(e,t=!1){return(0,u.Ot)(e,this.effectDrawers,this.initializers.effects,t)}getPalette(e){return this.palettes.get(e)}getPlugin(e){return this.plugins.find(t=>t.id===e)}getPreset(e){return this.presets.get(e)}async getShapeDrawers(e,t=!1){return(0,u.Ot)(e,this.shapeDrawers,this.initializers.shapes,t)}async getUpdaters(e,t=!1){return(0,u.HQ)(e,this.updaters,this.initializers.updaters,t)}async init(){if(!this._initialized&&!this._isRunningLoaders){this._isRunningLoaders=!0,this._executedSet=new Set,this._allLoadersSet=new Set(this._loadPromises);try{for(let e of this._allLoadersSet)await this._runLoader(e,this._executedSet,this._allLoadersSet)}finally{this._loadPromises.clear(),this._isRunningLoaders=!1,this._initialized=!0}}}loadParticlesOptions(e,t,...i){let a=this.updaters.get(e);a&&a.forEach(e=>e.loadOptions?.(t,...i))}async register(...e){if(this._initialized)throw Error("Register plugins can only be done before calling tsParticles.load()");for(let t of e)this._isRunningLoaders?await this._runLoader(t,this._executedSet,this._allLoadersSet):this._loadPromises.add(t)}async _runLoader(e,t,i){t.has(e)||(t.add(e),i.add(e),await e(this._engine))}}var v=i(2914),f=i(8770);let g="100%";async function y(e){let t=(0,u.TA)(e.url,e.index);if(!t)return e.fallback;let i=await fetch(t);return i.ok?await i.json():((0,v.t)().error(`${i.status.toString()} while retrieving config file`),e.fallback)}class m{pluginManager=new p(this);_domArray=[];_eventDispatcher=new c;_initialized=!1;get items(){return this._domArray}get version(){return"4.0.0-beta.11"}addEventListener(e,t){this._eventDispatcher.addEventListener(e,t)}checkVersion(e){if(this.version!==e)throw Error(`The tsParticles version is different from the loaded plugins version. Engine version: ${this.version}. Plugin version: ${e}`)}dispatchEvent(e,t){this._eventDispatcher.dispatchEvent(e,t)}async init(){this._initialized||(await this.pluginManager.init(),this._initialized=!0)}item(e){let{items:t}=this,i=t[e];return i?.destroyed?void t.splice(e,d.JC):i}async load(e){var t;let a,s;await this.init();let{Container:n}=await i.e(467).then(i.bind(i,1467)),r=e.id??e.element?.id??`tsparticles${Math.floor((0,f.G0)()*d.$v).toString()}`,{index:o,url:l}=e,c=l?await y({fallback:e.options,url:l,index:o}):e.options,h=(0,u.TA)(c,o),{items:p}=this,v=p.findIndex(e=>e.id.description===r),m=new n({dispatchCallback:(e,t)=>{this.dispatchEvent(e,t)},id:r,onDestroy:e=>{if(!e)return;let t=this.items,i=t.indexOf(m);i>=d.vF&&t.splice(i,d.JC)},pluginManager:this.pluginManager,sourceOptions:h});if(v>=d.PZ){let e=this.item(v),t=e?d.xH:d.dv;e&&!e.destroyed&&e.destroy(!1),p.splice(v,t,m)}else p.push(m);let b=(e=>{let t,i=(0,u.T5)();if(e instanceof HTMLCanvasElement||e.tagName.toLowerCase()===d.RF)t=e,t.dataset[d.eb]??=d.X$;else{let a=e.getElementsByTagName(d.RF)[d.Nx];a?(t=a).dataset[d.eb]=d.X$:((t=i.createElement(d.RF)).dataset[d.eb]=d.ce,e.appendChild(t))}return t.style.width||=g,t.style.height||=g,t})((t=e.element,a=(0,u.T5)(),(s=t??a.getElementById(r))||((s=a.createElement("canvas")).id=r,s.dataset[d.eb]=d.ce,a.body.append(s)),s));return m.canvas.loadCanvas(b),await m.start(),m}async refresh(e=!0){e&&await Promise.all(this.items.map(e=>e.refresh()))}removeEventListener(e,t){this._eventDispatcher.removeEventListener(e,t)}}i(6197);var b=i(4037);i(5327),(a=r||(r={})).clockwise="clockwise",a.counterClockwise="counter-clockwise",a.random="random";var w=i(7341);i(4992),i(7345);var x=i(3942);i(2702),i(6932),i(202),(s=o||(o={})).linear="linear",s.radial="radial",s.random="random";var M=i(510);i(9983),(n=l||(l={})).easeInBack="ease-in-back",n.easeInBounce="ease-in-bounce",n.easeInCirc="ease-in-circ",n.easeInCubic="ease-in-cubic",n.easeInElastic="ease-in-elastic",n.easeInExpo="ease-in-expo",n.easeInGaussian="ease-in-gaussian",n.easeInLinear="ease-in-linear",n.easeInQuad="ease-in-quad",n.easeInQuart="ease-in-quart",n.easeInQuint="ease-in-quint",n.easeInSigmoid="ease-in-sigmoid",n.easeInSine="ease-in-sine",n.easeInSmoothstep="ease-in-smoothstep",n.easeOutBack="ease-out-back",n.easeOutBounce="ease-out-bounce",n.easeOutCirc="ease-out-circ",n.easeOutCubic="ease-out-cubic",n.easeOutElastic="ease-out-elastic",n.easeOutExpo="ease-out-expo",n.easeOutGaussian="ease-out-gaussian",n.easeOutLinear="ease-out-linear",n.easeOutQuad="ease-out-quad",n.easeOutQuart="ease-out-quart",n.easeOutQuint="ease-out-quint",n.easeOutSigmoid="ease-out-sigmoid",n.easeOutSine="ease-out-sine",n.easeOutSmoothstep="ease-out-smoothstep",n.easeInOutBack="ease-in-out-back",n.easeInOutBounce="ease-in-out-bounce",n.easeInOutCirc="ease-in-out-circ",n.easeInOutCubic="ease-in-out-cubic",n.easeInOutElastic="ease-in-out-elastic",n.easeInOutExpo="ease-in-out-expo",n.easeInOutGaussian="ease-in-out-gaussian",n.easeInOutLinear="ease-in-out-linear",n.easeInOutQuad="ease-in-out-quad",n.easeInOutQuart="ease-in-out-quart",n.easeInOutQuint="ease-in-out-quint",n.easeInOutSigmoid="ease-in-out-sigmoid",n.easeInOutSine="ease-in-out-sine",n.easeInOutSmoothstep="ease-in-out-smoothstep",i(2314),i(2078),i(6753),i(3086),i(3410),i(8850),i(8805),i(3182),i(6334),i(5240),i(8869),i(7349),i(3690),i(2379),i(5695),i(8954),i(495),i(7677),i(7187),i(6177),i(5358),i(5446),i(1918),i(5746),i(3442),i(4234),i(6992),i(5603),i(3252);var z=i(7621);i(2222);var k=i(4920);let _=new m;globalThis.tsParticles=_}},s={};function n(e){var t=s[e];if(void 0!==t)return t.exports;var i=s[e]={exports:{}};return a[e](i,i.exports,n),i.exports}n.m=a,n.d=(e,t)=>{for(var i in t)n.o(t,i)&&!n.o(e,i)&&Object.defineProperty(e,i,{enumerable:!0,get:t[i]})},n.f={},n.e=e=>Promise.all(Object.keys(n.f).reduce((t,i)=>(n.f[i](e,t),t),[])),n.u=e=>""+e+".min.js",n.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||Function("return this")()}catch(e){if("object"==typeof window)return window}}(),n.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),r={},n.l=(e,t,i,a)=>{if(r[e])return void r[e].push(t);if(void 0!==i)for(var s,o,l=document.getElementsByTagName("script"),d=0;d<l.length;d++){var u=l[d];if(u.getAttribute("src")==e||u.getAttribute("data-webpack")=="@tsparticles/preset-fire:"+i){s=u;break}}s||(o=!0,(s=document.createElement("script")).charset="utf-8",n.nc&&s.setAttribute("nonce",n.nc),s.setAttribute("data-webpack","@tsparticles/preset-fire:"+i),s.src=e),r[e]=[t];var c=(t,i)=>{s.onerror=s.onload=null,clearTimeout(h);var a=r[e];if(delete r[e],s.parentNode&&s.parentNode.removeChild(s),a&&a.forEach(e=>e(i)),t)return t(i)},h=setTimeout(c.bind(null,void 0,{type:"timeout",target:s}),12e4);s.onerror=c.bind(null,s.onerror),s.onload=c.bind(null,s.onload),o&&document.head.appendChild(s)},n.r=e=>{"u">typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},n.g.importScripts&&(o=n.g.location+"");var r,o,l=n.g.document;if(!o&&l&&(l.currentScript&&"SCRIPT"===l.currentScript.tagName.toUpperCase()&&(o=l.currentScript.src),!o)){var d=l.getElementsByTagName("script");if(d.length)for(var u=d.length-1;u>-1&&(!o||!/^http(s?):/.test(o));)o=d[u--].src}if(!o)throw Error("Automatic publicPath is not supported in this browser");n.p=o=o.replace(/^blob:/,"").replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),e={178:0},n.f.j=(t,i)=>{var a=n.o(e,t)?e[t]:void 0;if(0!==a)if(a)i.push(a[2]);else{var s=new Promise((i,s)=>a=e[t]=[i,s]);i.push(a[2]=s);var r=n.p+n.u(t),o=Error();n.l(r,i=>{if(n.o(e,t)&&(0!==(a=e[t])&&(e[t]=void 0),a)){var s=i&&("load"===i.type?"missing":i.type),r=i&&i.target&&i.target.src;o.message="Loading chunk "+t+` failed.
|
|
2
|
+
(`+s+": "+r+")",o.name="ChunkLoadError",o.type=s,o.request=r,a[1](o)}},"chunk-"+t,t)}},t=(t,i)=>{var a,s,[r,o,l]=i,d=0;if(r.some(t=>0!==e[t])){for(a in o)n.o(o,a)&&(n.m[a]=o[a]);l&&l(n)}for(t&&t(i);d<r.length;d++)s=r[d],n.o(e,s)&&e[s]&&e[s][0](),e[s]=0},(i=this.webpackChunk_tsparticles_preset_fire=this.webpackChunk_tsparticles_preset_fire||[]).forEach(t.bind(null,0)),i.push=t.bind(null,i.push.bind(i));var c={};async function h(e){await e.pluginManager.register(async e=>{let[{loadBasic:t},{loadInteractivityPlugin:i},{loadExternalPushInteraction:a},{options:s}]=await Promise.all([n.e(719).then(n.bind(n,9719)),n.e(153).then(n.bind(n,3153)),n.e(959).then(n.bind(n,8959)),n.e(361).then(n.bind(n,1361))]);await Promise.all([t(e),(async()=>{await i(e),await a(e)})()]),e.pluginManager.addPreset("fire",s)})}n.r(c),n.d(c,{loadFirePreset:()=>h,tsParticles:()=>p.$k3});var p=n(3227);return c})());
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
* Demo / Generator : https://particles.js.org/
|
|
5
5
|
* GitHub : https://www.github.com/matteobruni/tsparticles
|
|
6
6
|
* How to use? : Check the GitHub README
|
|
7
|
-
* v4.0.0-
|
|
7
|
+
* v4.0.0-beta.0
|
|
8
8
|
*/
|
|
9
9
|
/*
|
|
10
10
|
* ATTENTION: The "eval" devtool has been used (maybe by default in mode: "development").
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
!function(e,t){if("object"==typeof exports&&"object"==typeof module)module.exports=t(require("@tsparticles/interaction-external-push"),require("@tsparticles/plugin-interactivity"),require("@tsparticles/basic"));else if("function"==typeof define&&define.amd)define(["@tsparticles/interaction-external-push","@tsparticles/plugin-interactivity","@tsparticles/basic"],t);else{var r="object"==typeof exports?t(require("@tsparticles/interaction-external-push"),require("@tsparticles/plugin-interactivity"),require("@tsparticles/basic")):t(e.window,e.window,e.window);for(var i in r)("object"==typeof exports?exports:e)[i]=r[i]}}(this,(e,t,r)=>(()=>{"use strict";var i,o,n,a={145(e){e.exports=r},184(t){t.exports=e},702(e){e.exports=t}},s={};function c(e){var t=s[e];if(void 0!==t)return t.exports;var r=s[e]={exports:{}};return a[e](r,r.exports,c),r.exports}c.m=a,l=Object.getPrototypeOf?e=>Object.getPrototypeOf(e):e=>e.__proto__,c.t=function(e,t){if(1&t&&(e=this(e)),8&t||"object"==typeof e&&e&&(4&t&&e.__esModule||16&t&&"function"==typeof e.then))return e;var r=Object.create(null);c.r(r);var i={};p=p||[null,l({}),l([]),l(l)];for(var o=2&t&&e;("object"==typeof o||"function"==typeof o)&&!~p.indexOf(o);o=l(o))Object.getOwnPropertyNames(o).forEach(t=>i[t]=()=>e[t]);return i.default=()=>e,c.d(r,i),r},c.d=(e,t)=>{for(var r in t)c.o(t,r)&&!c.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},c.f={},c.e=e=>Promise.all(Object.keys(c.f).reduce((t,r)=>(c.f[r](e,t),t),[])),c.u=e=>""+e+".min.js",c.g=function(){if("object"==typeof globalThis)return globalThis;try{return this||Function("return this")()}catch(e){if("object"==typeof window)return window}}(),c.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),u={},c.l=(e,t,r,i)=>{if(u[e])return void u[e].push(t);if(void 0!==r)for(var o,n,a=document.getElementsByTagName("script"),s=0;s<a.length;s++){var p=a[s];if(p.getAttribute("src")==e||p.getAttribute("data-webpack")=="@tsparticles/preset-fire:"+r){o=p;break}}o||(n=!0,(o=document.createElement("script")).charset="utf-8",c.nc&&o.setAttribute("nonce",c.nc),o.setAttribute("data-webpack","@tsparticles/preset-fire:"+r),o.src=e),u[e]=[t];var l=(t,r)=>{o.onerror=o.onload=null,clearTimeout(f);var i=u[e];if(delete u[e],o.parentNode&&o.parentNode.removeChild(o),i&&i.forEach(e=>e(r)),t)return t(r)},f=setTimeout(l.bind(null,void 0,{type:"timeout",target:o}),12e4);o.onerror=l.bind(null,o.onerror),o.onload=l.bind(null,o.onload),n&&document.head.appendChild(o)},c.r=e=>{"u">typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},c.g.importScripts&&(f=c.g.location+"");var p,l,u,f,d=c.g.document;if(!f&&d&&(d.currentScript&&"SCRIPT"===d.currentScript.tagName.toUpperCase()&&(f=d.currentScript.src),!f)){var b=d.getElementsByTagName("script");if(b.length)for(var h=b.length-1;h>-1&&(!f||!/^http(s?):/.test(f));)f=b[h--].src}if(!f)throw Error("Automatic publicPath is not supported in this browser");c.p=f=f.replace(/^blob:/,"").replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),i={860:0},c.f.j=(e,t)=>{var r=c.o(i,e)?i[e]:void 0;if(0!==r)if(r)t.push(r[2]);else{var o=new Promise((t,o)=>r=i[e]=[t,o]);t.push(r[2]=o);var n=c.p+c.u(e),a=Error();c.l(n,t=>{if(c.o(i,e)&&(0!==(r=i[e])&&(i[e]=void 0),r)){var o=t&&("load"===t.type?"missing":t.type),n=t&&t.target&&t.target.src;a.message="Loading chunk "+e+` failed.
|
|
2
|
-
(`+o+": "+n+")",a.name="ChunkLoadError",a.type=o,a.request=n,r[1](a)}},"chunk-"+e,e)}},o=(e,t)=>{var r,o,[n,a,s]=t,p=0;if(n.some(e=>0!==i[e])){for(r in a)c.o(a,r)&&(c.m[r]=a[r]);s&&s(c)}for(e&&e(t);p<n.length;p++)o=n[p],c.o(i,o)&&i[o]&&i[o][0](),i[o]=0},(n=this.webpackChunk_tsparticles_preset_fire=this.webpackChunk_tsparticles_preset_fire||[]).forEach(o.bind(null,0)),n.push=o.bind(null,n.push.bind(n));var g={};async function m(e){await e.pluginManager.register(async e=>{let[{loadBasic:t},{loadInteractivityPlugin:r},{loadExternalPushInteraction:i},{options:o}]=await Promise.all([Promise.resolve().then(c.t.bind(c,145,19)),Promise.resolve().then(c.t.bind(c,702,19)),Promise.resolve().then(c.t.bind(c,184,19)),c.e(
|
|
2
|
+
(`+o+": "+n+")",a.name="ChunkLoadError",a.type=o,a.request=n,r[1](a)}},"chunk-"+e,e)}},o=(e,t)=>{var r,o,[n,a,s]=t,p=0;if(n.some(e=>0!==i[e])){for(r in a)c.o(a,r)&&(c.m[r]=a[r]);s&&s(c)}for(e&&e(t);p<n.length;p++)o=n[p],c.o(i,o)&&i[o]&&i[o][0](),i[o]=0},(n=this.webpackChunk_tsparticles_preset_fire=this.webpackChunk_tsparticles_preset_fire||[]).forEach(o.bind(null,0)),n.push=o.bind(null,n.push.bind(n));var g={};async function m(e){await e.pluginManager.register(async e=>{let[{loadBasic:t},{loadInteractivityPlugin:r},{loadExternalPushInteraction:i},{options:o}]=await Promise.all([Promise.resolve().then(c.t.bind(c,145,19)),Promise.resolve().then(c.t.bind(c,702,19)),Promise.resolve().then(c.t.bind(c,184,19)),c.e(361).then(c.bind(c,361))]);await Promise.all([t(e),(async()=>{await r(e),await i(e)})()]),e.pluginManager.addPreset("fire",o)})}return c.r(g),c.d(g,{loadFirePreset:()=>m}),g})());
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Author : Matteo Bruni
|
|
3
|
+
* MIT license: https://opensource.org/licenses/MIT
|
|
4
|
+
* Demo / Generator : https://particles.js.org/
|
|
5
|
+
* GitHub : https://www.github.com/matteobruni/tsparticles
|
|
6
|
+
* How to use? : Check the GitHub README
|
|
7
|
+
* v4.0.0-beta.0
|
|
8
|
+
*/
|
|
9
|
+
"use strict";
|
|
10
|
+
/*
|
|
11
|
+
* ATTENTION: The "eval" devtool has been used (maybe by default in mode: "development").
|
|
12
|
+
* This devtool is neither made for production nor for readable output files.
|
|
13
|
+
* It uses "eval()" calls to create a separate source file in the browser devtools.
|
|
14
|
+
* If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
|
|
15
|
+
* or disable the default devtool with "devtool: false".
|
|
16
|
+
* If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
|
|
17
|
+
*/
|
|
18
|
+
(this["webpackChunk_tsparticles_preset_fire"] = this["webpackChunk_tsparticles_preset_fire"] || []).push([["vendors-node_modules_pnpm_tsparticles_engine_4_0_0-beta_11_node_modules_tsparticles_engine_br-ca098e"],{
|
|
19
|
+
|
|
20
|
+
/***/ "../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/CanvasManager.js"
|
|
21
|
+
/*!*********************************************************************************************************************************!*\
|
|
22
|
+
!*** ../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/CanvasManager.js ***!
|
|
23
|
+
\*********************************************************************************************************************************/
|
|
24
|
+
(__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
|
|
25
|
+
|
|
26
|
+
eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ CanvasManager: () => (/* binding */ CanvasManager)\n/* harmony export */ });\n/* harmony import */ var _Utils_Utils_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Utils/Utils.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Utils/Utils.js\");\n/* harmony import */ var _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Utils/Constants.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Utils/Constants.js\");\n/* harmony import */ var _Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../Utils/ColorUtils.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Utils/ColorUtils.js\");\n/* harmony import */ var _RenderManager_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./RenderManager.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/RenderManager.js\");\n\n\n\n\nfunction setStyle(canvas, style, important = false) {\n if (!style) {\n return;\n }\n const element = canvas, elementStyle = element.style, keys = new Set();\n for (let i = 0; i < elementStyle.length; i++) {\n const key = elementStyle.item(i);\n if (!key) {\n continue;\n }\n keys.add(key);\n }\n for (let i = 0; i < style.length; i++) {\n const key = style.item(i);\n if (!key) {\n continue;\n }\n keys.add(key);\n }\n for (const key of keys) {\n const value = style.getPropertyValue(key);\n if (value) {\n elementStyle.setProperty(key, value, important ? \"important\" : \"\");\n }\n else {\n elementStyle.removeProperty(key);\n }\n }\n}\nclass CanvasManager {\n element;\n render;\n size;\n zoom = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.defaultZoom;\n _container;\n _generated;\n _mutationObserver;\n _originalStyle;\n _pluginManager;\n _pointerEvents;\n _resizePlugins;\n _standardSize;\n _zoomCenter;\n constructor(pluginManager, container) {\n this._pluginManager = pluginManager;\n this._container = container;\n this.render = new _RenderManager_js__WEBPACK_IMPORTED_MODULE_3__.RenderManager(pluginManager, container, this);\n this._standardSize = {\n height: 0,\n width: 0,\n };\n const pxRatio = container.retina.pixelRatio, stdSize = this._standardSize;\n this.size = {\n height: stdSize.height * pxRatio,\n width: stdSize.width * pxRatio,\n };\n this._generated = false;\n this._resizePlugins = [];\n this._pointerEvents = \"none\";\n }\n get _fullScreen() {\n return this._container.actualOptions.fullScreen.enable;\n }\n destroy() {\n this.stop();\n if (this._generated) {\n const element = this.element;\n element?.remove();\n this.element = undefined;\n }\n else {\n this._resetOriginalStyle();\n }\n this.render.destroy();\n this._resizePlugins = [];\n }\n getZoomCenter() {\n const pxRatio = this._container.retina.pixelRatio, { width, height } = this.size;\n if (this._zoomCenter) {\n return this._zoomCenter;\n }\n return {\n x: (width * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.half) / pxRatio,\n y: (height * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.half) / pxRatio,\n };\n }\n init() {\n this._safeMutationObserver(obs => {\n obs.disconnect();\n });\n this._mutationObserver = (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_0__.safeMutationObserver)(records => {\n for (const record of records) {\n if (record.type === \"attributes\" && record.attributeName === \"style\") {\n this._repairStyle();\n }\n }\n });\n this.resize();\n this._initStyle();\n this.initBackground();\n this._safeMutationObserver(obs => {\n if (!this.element || !(this.element instanceof Node)) {\n return;\n }\n obs.observe(this.element, { attributes: true });\n });\n this.initPlugins();\n this.render.init();\n }\n initBackground() {\n const { _container } = this, options = _container.actualOptions, background = options.background, element = this.element;\n if (!element) {\n return;\n }\n const elementStyle = element.style, color = (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_2__.rangeColorToRgb)(this._pluginManager, background.color);\n if (color) {\n elementStyle.backgroundColor = (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_2__.getStyleFromRgb)(color, _container.hdr, background.opacity);\n }\n else {\n elementStyle.backgroundColor = \"\";\n }\n elementStyle.backgroundImage = background.image || \"\";\n elementStyle.backgroundPosition = background.position || \"\";\n elementStyle.backgroundRepeat = background.repeat || \"\";\n elementStyle.backgroundSize = background.size || \"\";\n }\n initPlugins() {\n this._resizePlugins = [];\n for (const plugin of this._container.plugins) {\n if (plugin.resize) {\n this._resizePlugins.push(plugin);\n }\n }\n }\n loadCanvas(canvas) {\n if (this._generated && this.element) {\n this.element.remove();\n }\n const container = this._container;\n this._generated =\n _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.generatedAttribute in canvas.dataset ? canvas.dataset[_Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.generatedAttribute] === \"true\" : this._generated;\n this.element = canvas;\n this.element.ariaHidden = \"true\";\n this._originalStyle = (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_0__.cloneStyle)(this.element.style);\n const standardSize = this._standardSize;\n standardSize.height = canvas.offsetHeight;\n standardSize.width = canvas.offsetWidth;\n const pxRatio = this._container.retina.pixelRatio, retinaSize = this.size;\n canvas.height = retinaSize.height = standardSize.height * pxRatio;\n canvas.width = retinaSize.width = standardSize.width * pxRatio;\n const canSupportHdrQuery = (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_0__.safeMatchMedia)(\"(color-gamut: p3)\");\n this.render.setContextSettings({\n alpha: true,\n colorSpace: canSupportHdrQuery?.matches && container.hdr ? \"display-p3\" : \"srgb\",\n desynchronized: true,\n willReadFrequently: false,\n });\n this.render.setContext(this.element.getContext(\"2d\", this.render.settings));\n this._safeMutationObserver(obs => {\n obs.disconnect();\n });\n container.retina.init();\n this.initBackground();\n this._safeMutationObserver(obs => {\n if (!this.element || !(this.element instanceof Node)) {\n return;\n }\n obs.observe(this.element, { attributes: true });\n });\n }\n resize() {\n if (!this.element) {\n return false;\n }\n const container = this._container, currentSize = container.canvas._standardSize, newSize = {\n width: this.element.offsetWidth,\n height: this.element.offsetHeight,\n }, pxRatio = container.retina.pixelRatio, retinaSize = {\n width: newSize.width * pxRatio,\n height: newSize.height * pxRatio,\n };\n if (newSize.height === currentSize.height &&\n newSize.width === currentSize.width &&\n retinaSize.height === this.element.height &&\n retinaSize.width === this.element.width) {\n return false;\n }\n const oldSize = { ...currentSize };\n currentSize.height = newSize.height;\n currentSize.width = newSize.width;\n const canvasSize = this.size;\n this.element.width = canvasSize.width = retinaSize.width;\n this.element.height = canvasSize.height = retinaSize.height;\n if (this._container.started) {\n container.particles.setResizeFactor({\n width: currentSize.width / oldSize.width,\n height: currentSize.height / oldSize.height,\n });\n }\n return true;\n }\n setPointerEvents(type) {\n const element = this.element;\n if (!element) {\n return;\n }\n this._pointerEvents = type;\n this._repairStyle();\n }\n setZoom(zoomLevel, center) {\n this.zoom = zoomLevel;\n this._zoomCenter = center;\n }\n stop() {\n this._safeMutationObserver(obs => {\n obs.disconnect();\n });\n this._mutationObserver = undefined;\n this.render.stop();\n }\n async windowResize() {\n if (!this.element || !this.resize()) {\n return;\n }\n const container = this._container, needsRefresh = container.updateActualOptions();\n container.particles.setDensity();\n this._applyResizePlugins();\n if (needsRefresh) {\n await container.refresh();\n }\n }\n _applyResizePlugins = () => {\n for (const plugin of this._resizePlugins) {\n plugin.resize?.();\n }\n };\n _initStyle = () => {\n const element = this.element, options = this._container.actualOptions;\n if (!element) {\n return;\n }\n if (this._fullScreen) {\n this._setFullScreenStyle();\n }\n else {\n this._resetOriginalStyle();\n }\n for (const key in options.style) {\n if (!key || !(key in options.style)) {\n continue;\n }\n const value = options.style[key];\n if (!value) {\n continue;\n }\n element.style.setProperty(key, value, \"important\");\n }\n };\n _repairStyle = () => {\n const element = this.element;\n if (!element) {\n return;\n }\n this._safeMutationObserver(observer => {\n observer.disconnect();\n });\n this._initStyle();\n this.initBackground();\n const pointerEvents = this._pointerEvents;\n element.style.pointerEvents = pointerEvents;\n element.setAttribute(\"pointer-events\", pointerEvents);\n this._safeMutationObserver(observer => {\n if (!(element instanceof Node)) {\n return;\n }\n observer.observe(element, { attributes: true });\n });\n };\n _resetOriginalStyle = () => {\n const element = this.element, originalStyle = this._originalStyle;\n if (!element || !originalStyle) {\n return;\n }\n setStyle(element, originalStyle, true);\n };\n _safeMutationObserver = callback => {\n if (!this._mutationObserver) {\n return;\n }\n callback(this._mutationObserver);\n };\n _setFullScreenStyle = () => {\n const element = this.element;\n if (!element) {\n return;\n }\n setStyle(element, (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_0__.getFullScreenStyle)(this._container.actualOptions.fullScreen.zIndex), true);\n };\n}\n\n\n//# sourceURL=webpack://@tsparticles/preset-fire/../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/CanvasManager.js?\n}");
|
|
27
|
+
|
|
28
|
+
/***/ },
|
|
29
|
+
|
|
30
|
+
/***/ "../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Container.js"
|
|
31
|
+
/*!*****************************************************************************************************************************!*\
|
|
32
|
+
!*** ../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Container.js ***!
|
|
33
|
+
\*****************************************************************************************************************************/
|
|
34
|
+
(__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
|
|
35
|
+
|
|
36
|
+
eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Container: () => (/* binding */ Container)\n/* harmony export */ });\n/* harmony import */ var _Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Utils/MathUtils.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Utils/MathUtils.js\");\n/* harmony import */ var _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Utils/Constants.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Utils/Constants.js\");\n/* harmony import */ var _CanvasManager_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./CanvasManager.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/CanvasManager.js\");\n/* harmony import */ var _Utils_EventListeners_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./Utils/EventListeners.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Utils/EventListeners.js\");\n/* harmony import */ var _Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../Enums/Types/EventType.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Enums/Types/EventType.js\");\n/* harmony import */ var _Options_Classes_Options_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../Options/Classes/Options.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Options/Classes/Options.js\");\n/* harmony import */ var _ParticlesManager_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./ParticlesManager.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/ParticlesManager.js\");\n/* harmony import */ var _Retina_js__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./Retina.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Retina.js\");\n/* harmony import */ var _Utils_LogUtils_js__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../Utils/LogUtils.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Utils/LogUtils.js\");\n/* harmony import */ var _Utils_OptionsUtils_js__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../Utils/OptionsUtils.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Utils/OptionsUtils.js\");\n\n\n\n\n\n\n\n\n\n\nfunction guardCheck(container) {\n return !container.destroyed;\n}\nfunction updateDelta(delta, value, fpsLimit = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.defaultFps, smooth = false) {\n delta.value = value;\n delta.factor = smooth ? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.defaultFps / fpsLimit : (_Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.defaultFps * value) / _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.millisecondsToSeconds;\n}\nfunction loadContainerOptions(pluginManager, container, ...sourceOptionsArr) {\n const options = new _Options_Classes_Options_js__WEBPACK_IMPORTED_MODULE_5__.Options(pluginManager, container);\n (0,_Utils_OptionsUtils_js__WEBPACK_IMPORTED_MODULE_9__.loadOptions)(options, ...sourceOptionsArr);\n return options;\n}\nclass Container {\n actualOptions;\n canvas;\n destroyed;\n effectDrawers;\n fpsLimit;\n hdr;\n id;\n pageHidden;\n particleCreatedPlugins;\n particleDestroyedPlugins;\n particlePositionPlugins;\n particleUpdaters;\n particles;\n plugins;\n retina;\n shapeDrawers;\n started;\n zLayers;\n _delay;\n _delayTimeout;\n _delta = { value: 0, factor: 0 };\n _dispatchCallback;\n _drawAnimationFrame;\n _duration;\n _eventListeners;\n _firstStart;\n _initialSourceOptions;\n _lastFrameTime;\n _lifeTime;\n _onDestroy;\n _options;\n _paused;\n _pluginManager;\n _smooth;\n _sourceOptions;\n constructor(params) {\n const { dispatchCallback, pluginManager, id, onDestroy, sourceOptions } = params;\n this._pluginManager = pluginManager;\n this._dispatchCallback = dispatchCallback;\n this._onDestroy = onDestroy;\n this.id = Symbol(id);\n this.fpsLimit = 120;\n this.hdr = false;\n this._smooth = false;\n this._delay = 0;\n this._duration = 0;\n this._lifeTime = 0;\n this._firstStart = true;\n this.started = false;\n this.destroyed = false;\n this._paused = true;\n this._lastFrameTime = 0;\n this.zLayers = 100;\n this.pageHidden = false;\n this._sourceOptions = sourceOptions;\n this._initialSourceOptions = sourceOptions;\n this.effectDrawers = new Map();\n this.shapeDrawers = new Map();\n this.particleUpdaters = [];\n this.retina = new _Retina_js__WEBPACK_IMPORTED_MODULE_7__.Retina(this);\n this.canvas = new _CanvasManager_js__WEBPACK_IMPORTED_MODULE_2__.CanvasManager(this._pluginManager, this);\n this.particles = new _ParticlesManager_js__WEBPACK_IMPORTED_MODULE_6__.ParticlesManager(this._pluginManager, this);\n this.plugins = [];\n this.particleDestroyedPlugins = [];\n this.particleCreatedPlugins = [];\n this.particlePositionPlugins = [];\n this._options = loadContainerOptions(this._pluginManager, this);\n this.actualOptions = loadContainerOptions(this._pluginManager, this);\n this._eventListeners = new _Utils_EventListeners_js__WEBPACK_IMPORTED_MODULE_3__.EventListeners(this);\n this.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.containerBuilt);\n }\n get animationStatus() {\n return !this._paused && !this.pageHidden && guardCheck(this);\n }\n get options() {\n return this._options;\n }\n get sourceOptions() {\n return this._sourceOptions;\n }\n addLifeTime(value) {\n this._lifeTime += value;\n }\n alive() {\n return !this._duration || this._lifeTime <= this._duration;\n }\n destroy(remove = true) {\n if (!guardCheck(this)) {\n return;\n }\n this.stop();\n this.particles.destroy();\n this.canvas.destroy();\n for (const [, effectDrawer] of this.effectDrawers) {\n effectDrawer.destroy?.(this);\n }\n for (const [, shapeDrawer] of this.shapeDrawers) {\n shapeDrawer.destroy?.(this);\n }\n for (const plugin of this.plugins) {\n plugin.destroy?.();\n }\n this.effectDrawers = new Map();\n this.shapeDrawers = new Map();\n this.particleUpdaters = [];\n this.plugins.length = 0;\n this._pluginManager.clearPlugins(this);\n this.destroyed = true;\n this._onDestroy(remove);\n this.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.containerDestroyed);\n }\n dispatchEvent(type, data) {\n this._dispatchCallback(type, {\n container: this,\n data,\n });\n }\n draw(force) {\n if (!guardCheck(this)) {\n return;\n }\n let refreshTime = force;\n this._drawAnimationFrame = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_0__.animate)((timestamp) => {\n if (refreshTime) {\n this._lastFrameTime = undefined;\n refreshTime = false;\n }\n this._nextFrame(timestamp);\n });\n }\n async export(type, options = {}) {\n for (const plugin of this.plugins) {\n if (!plugin.export) {\n continue;\n }\n const res = await plugin.export(type, options);\n if (!res.supported) {\n continue;\n }\n return res.blob;\n }\n (0,_Utils_LogUtils_js__WEBPACK_IMPORTED_MODULE_8__.getLogger)().error(`Export plugin with type ${type} not found`);\n return undefined;\n }\n async init() {\n if (!guardCheck(this)) {\n return;\n }\n const allContainerPlugins = new Map();\n for (const plugin of this._pluginManager.plugins) {\n const containerPlugin = await plugin.getPlugin(this);\n if (containerPlugin.preInit) {\n await containerPlugin.preInit();\n }\n allContainerPlugins.set(plugin, containerPlugin);\n }\n await this.initDrawersAndUpdaters();\n this._options = loadContainerOptions(this._pluginManager, this, this._initialSourceOptions, this.sourceOptions);\n this.actualOptions = loadContainerOptions(this._pluginManager, this, this._options);\n this.plugins.length = 0;\n this.particleDestroyedPlugins.length = 0;\n this.particleCreatedPlugins.length = 0;\n this.particlePositionPlugins.length = 0;\n for (const [plugin, containerPlugin] of allContainerPlugins) {\n if (plugin.needsPlugin(this.actualOptions)) {\n this.plugins.push(containerPlugin);\n if (containerPlugin.particleCreated) {\n this.particleCreatedPlugins.push(containerPlugin);\n }\n if (containerPlugin.particleDestroyed) {\n this.particleDestroyedPlugins.push(containerPlugin);\n }\n if (containerPlugin.particlePosition) {\n this.particlePositionPlugins.push(containerPlugin);\n }\n }\n }\n this.retina.init();\n this.canvas.init();\n this.updateActualOptions();\n this.canvas.initBackground();\n this.canvas.resize();\n const { delay, duration, fpsLimit, hdr, smooth, zLayers } = this.actualOptions;\n this.hdr = hdr;\n this.zLayers = zLayers;\n this._duration = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_0__.getRangeValue)(duration) * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.millisecondsToSeconds;\n this._delay = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_0__.getRangeValue)(delay) * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.millisecondsToSeconds;\n this._lifeTime = 0;\n this.fpsLimit = fpsLimit > _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.minFpsLimit ? fpsLimit : _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.defaultFpsLimit;\n this._smooth = smooth;\n for (const plugin of this.plugins) {\n await plugin.init?.();\n }\n await this.particles.init();\n this.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.containerInit);\n this.particles.setDensity();\n for (const plugin of this.plugins) {\n plugin.particlesSetup?.();\n }\n this.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.particlesSetup);\n }\n async initDrawersAndUpdaters() {\n const pluginManager = this._pluginManager;\n this.effectDrawers = await pluginManager.getEffectDrawers(this, true);\n this.shapeDrawers = await pluginManager.getShapeDrawers(this, true);\n this.particleUpdaters = await pluginManager.getUpdaters(this, true);\n }\n pause() {\n if (!guardCheck(this)) {\n return;\n }\n if (this._drawAnimationFrame !== undefined) {\n (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_0__.cancelAnimation)(this._drawAnimationFrame);\n delete this._drawAnimationFrame;\n }\n if (this._paused) {\n return;\n }\n for (const plugin of this.plugins) {\n plugin.pause?.();\n }\n if (!this.pageHidden) {\n this._paused = true;\n }\n this.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.containerPaused);\n }\n play(force) {\n if (!guardCheck(this)) {\n return;\n }\n const needsUpdate = this._paused || force;\n if (this._firstStart && !this.actualOptions.autoPlay) {\n this._firstStart = false;\n return;\n }\n if (this._paused) {\n this._paused = false;\n }\n if (needsUpdate) {\n for (const plugin of this.plugins) {\n if (plugin.play) {\n plugin.play();\n }\n }\n }\n this.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.containerPlay);\n this.draw(needsUpdate ?? false);\n }\n async refresh() {\n if (!guardCheck(this)) {\n return;\n }\n this.stop();\n return this.start();\n }\n async reset(sourceOptions) {\n if (!guardCheck(this)) {\n return;\n }\n this._initialSourceOptions = sourceOptions;\n this._sourceOptions = sourceOptions;\n this._options = loadContainerOptions(this._pluginManager, this, this._initialSourceOptions, this.sourceOptions);\n this.actualOptions = loadContainerOptions(this._pluginManager, this, this._options);\n return this.refresh();\n }\n async start() {\n if (!guardCheck(this) || this.started) {\n return;\n }\n await this.init();\n this.started = true;\n await new Promise(resolve => {\n const start = async () => {\n this._eventListeners.addListeners();\n for (const plugin of this.plugins) {\n await plugin.start?.();\n }\n this.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.containerStarted);\n this.play();\n resolve();\n };\n this._delayTimeout = setTimeout(() => void start(), this._delay);\n });\n }\n stop() {\n if (!guardCheck(this) || !this.started) {\n return;\n }\n if (this._delayTimeout) {\n clearTimeout(this._delayTimeout);\n delete this._delayTimeout;\n }\n this._firstStart = true;\n this.started = false;\n this._eventListeners.removeListeners();\n this.pause();\n this.particles.clear();\n this.canvas.stop();\n for (const plugin of this.plugins) {\n plugin.stop?.();\n }\n this.particleCreatedPlugins.length = 0;\n this.particleDestroyedPlugins.length = 0;\n this.particlePositionPlugins.length = 0;\n this._sourceOptions = this._options;\n this.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.containerStopped);\n }\n updateActualOptions() {\n let refresh = false;\n for (const plugin of this.plugins) {\n if (plugin.updateActualOptions) {\n refresh = plugin.updateActualOptions() || refresh;\n }\n }\n return refresh;\n }\n _nextFrame = (timestamp) => {\n try {\n if (!this._smooth &&\n this._lastFrameTime !== undefined &&\n timestamp < this._lastFrameTime + _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.millisecondsToSeconds / this.fpsLimit) {\n this.draw(false);\n return;\n }\n this._lastFrameTime ??= timestamp;\n updateDelta(this._delta, timestamp - this._lastFrameTime, this.fpsLimit, this._smooth);\n this.addLifeTime(this._delta.value);\n this._lastFrameTime = timestamp;\n if (this._delta.value > _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.millisecondsToSeconds) {\n this.draw(false);\n return;\n }\n this.canvas.render.drawParticles(this._delta);\n if (!this.alive()) {\n this.destroy();\n return;\n }\n if (this.animationStatus) {\n this.draw(false);\n }\n }\n catch (e) {\n (0,_Utils_LogUtils_js__WEBPACK_IMPORTED_MODULE_8__.getLogger)().error(\"error in animation loop\", e);\n }\n };\n}\n\n\n//# sourceURL=webpack://@tsparticles/preset-fire/../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Container.js?\n}");
|
|
37
|
+
|
|
38
|
+
/***/ },
|
|
39
|
+
|
|
40
|
+
/***/ "../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Particle.js"
|
|
41
|
+
/*!****************************************************************************************************************************!*\
|
|
42
|
+
!*** ../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Particle.js ***!
|
|
43
|
+
\****************************************************************************************************************************/
|
|
44
|
+
(__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
|
|
45
|
+
|
|
46
|
+
eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Particle: () => (/* binding */ Particle)\n/* harmony export */ });\n/* harmony import */ var _Utils_Vectors_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./Utils/Vectors.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Utils/Vectors.js\");\n/* harmony import */ var _Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../Utils/ColorUtils.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Utils/ColorUtils.js\");\n/* harmony import */ var _Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../Utils/MathUtils.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Utils/MathUtils.js\");\n/* harmony import */ var _Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../Utils/Utils.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Utils/Utils.js\");\n/* harmony import */ var _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./Utils/Constants.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Utils/Constants.js\");\n/* harmony import */ var _Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../Enums/Types/EventType.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Enums/Types/EventType.js\");\n/* harmony import */ var _Enums_Directions_MoveDirection_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../Enums/Directions/MoveDirection.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Enums/Directions/MoveDirection.js\");\n/* harmony import */ var _Enums_Modes_OutMode_js__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../Enums/Modes/OutMode.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Enums/Modes/OutMode.js\");\n/* harmony import */ var _Enums_Types_ParticleOutType_js__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../Enums/Types/ParticleOutType.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Enums/Types/ParticleOutType.js\");\n/* harmony import */ var _Utils_OptionsUtils_js__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../Utils/OptionsUtils.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Utils/OptionsUtils.js\");\n\n\n\n\n\n\n\n\n\n\nfunction loadEffectData(effect, effectOptions, id, reduceDuplicates) {\n const effectData = effectOptions.options[effect];\n return (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.deepExtend)({\n close: effectOptions.close,\n }, (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.itemFromSingleOrMultiple)(effectData, id, reduceDuplicates));\n}\nfunction loadShapeData(shape, shapeOptions, id, reduceDuplicates) {\n const shapeData = shapeOptions.options[shape];\n return (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.deepExtend)({\n close: shapeOptions.close,\n }, (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.itemFromSingleOrMultiple)(shapeData, id, reduceDuplicates));\n}\nfunction fixOutMode(data) {\n if (!(0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.isInArray)(data.outMode, data.checkModes)) {\n return;\n }\n const diameter = data.radius * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.double;\n if (data.coord > data.maxCoord - diameter) {\n data.setCb(-data.radius);\n }\n else if (data.coord < diameter) {\n data.setCb(data.radius);\n }\n}\nclass Particle {\n backColor;\n bubble;\n destroyed;\n direction;\n effect;\n effectClose;\n effectData;\n fillColor;\n fillEnabled;\n fillOpacity;\n group;\n id;\n ignoresResizeRatio;\n initialPosition;\n initialVelocity;\n isRotating;\n lastPathTime;\n misplaced;\n moveCenter;\n offset;\n opacity;\n options;\n outType;\n pathRotation;\n position;\n randomIndexData;\n retina;\n roll;\n rotation;\n shape;\n shapeClose;\n shapeData;\n sides;\n size;\n slow;\n spawning;\n strokeColor;\n strokeOpacity;\n strokeWidth;\n unbreakable;\n velocity;\n zIndexFactor;\n _cachedOpacityData = {\n fillOpacity: _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultOpacity,\n opacity: _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultOpacity,\n strokeOpacity: _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultOpacity,\n };\n _cachedPosition = _Utils_Vectors_js__WEBPACK_IMPORTED_MODULE_0__.Vector3d.origin;\n _cachedRotateData = { sin: 0, cos: 0 };\n _cachedTransform = {\n a: 1,\n b: 0,\n c: 0,\n d: 1,\n };\n _container;\n _pluginManager;\n constructor(pluginManager, container) {\n this._pluginManager = pluginManager;\n this._container = container;\n }\n destroy(override) {\n if (this.unbreakable || this.destroyed) {\n return;\n }\n this.destroyed = true;\n this.bubble.inRange = false;\n this.slow.inRange = false;\n const container = this._container, shapeDrawer = this.shape ? container.shapeDrawers.get(this.shape) : undefined;\n shapeDrawer?.particleDestroy?.(this);\n for (const plugin of container.particleDestroyedPlugins) {\n plugin.particleDestroyed?.(this, override);\n }\n for (const updater of container.particleUpdaters) {\n updater.particleDestroyed?.(this, override);\n }\n this._container.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_5__.EventType.particleDestroyed, {\n particle: this,\n });\n }\n draw(delta) {\n const container = this._container, render = container.canvas.render;\n render.drawParticlePlugins(this, delta);\n render.drawParticle(this, delta);\n }\n getAngle() {\n return this.rotation + (this.pathRotation ? this.velocity.angle : _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultAngle);\n }\n getFillColor() {\n return this._getRollColor(this.bubble.color ?? (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_1__.getHslFromAnimation)(this.fillColor));\n }\n getMass() {\n return this.getRadius() ** _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.squareExp * Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.half;\n }\n getOpacity() {\n const zIndexOptions = this.options.zIndex, zIndexFactor = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.zIndexFactorOffset - this.zIndexFactor, zOpacityFactor = zIndexFactor ** zIndexOptions.opacityRate, opacity = this.bubble.opacity ?? (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.getRangeValue)(this.opacity?.value ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultOpacity), fillOpacity = this.fillOpacity ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultOpacity, strokeOpacity = this.strokeOpacity ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultOpacity;\n this._cachedOpacityData.fillOpacity = opacity * fillOpacity * zOpacityFactor;\n this._cachedOpacityData.opacity = opacity * zOpacityFactor;\n this._cachedOpacityData.strokeOpacity = opacity * strokeOpacity * zOpacityFactor;\n return this._cachedOpacityData;\n }\n getPosition() {\n this._cachedPosition.x = this.position.x + this.offset.x;\n this._cachedPosition.y = this.position.y + this.offset.y;\n this._cachedPosition.z = this.position.z;\n return this._cachedPosition;\n }\n getRadius() {\n return this.bubble.radius ?? this.size.value;\n }\n getRotateData() {\n const angle = this.getAngle();\n this._cachedRotateData.sin = Math.sin(angle);\n this._cachedRotateData.cos = Math.cos(angle);\n return this._cachedRotateData;\n }\n getStrokeColor() {\n return this._getRollColor(this.bubble.color ?? (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_1__.getHslFromAnimation)(this.strokeColor));\n }\n getTransformData(externalTransform) {\n const rotateData = this.getRotateData(), rotating = this.isRotating;\n this._cachedTransform.a = rotateData.cos * (externalTransform.a ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultTransform.a);\n this._cachedTransform.b = rotating\n ? rotateData.sin * (externalTransform.b ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.identity)\n : (externalTransform.b ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultTransform.b);\n this._cachedTransform.c = rotating\n ? -rotateData.sin * (externalTransform.c ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.identity)\n : (externalTransform.c ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultTransform.c);\n this._cachedTransform.d = rotateData.cos * (externalTransform.d ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultTransform.d);\n return this._cachedTransform;\n }\n init(id, position, overrideOptions, group) {\n const container = this._container;\n this.id = id;\n this.group = group;\n this.effectClose = true;\n this.shapeClose = true;\n this.pathRotation = false;\n this.lastPathTime = 0;\n this.destroyed = false;\n this.unbreakable = false;\n this.isRotating = false;\n this.rotation = 0;\n this.misplaced = false;\n this.retina = {\n maxDistance: {},\n maxSpeed: 0,\n moveDrift: 0,\n moveSpeed: 0,\n sizeAnimationSpeed: 0,\n };\n this.outType = _Enums_Types_ParticleOutType_js__WEBPACK_IMPORTED_MODULE_8__.ParticleOutType.normal;\n this.ignoresResizeRatio = true;\n const pxRatio = container.retina.pixelRatio, mainOptions = container.actualOptions, particlesOptions = (0,_Utils_OptionsUtils_js__WEBPACK_IMPORTED_MODULE_9__.loadParticlesOptions)(this._pluginManager, container, mainOptions.particles), reduceDuplicates = particlesOptions.reduceDuplicates, effectType = particlesOptions.effect.type, shapeType = particlesOptions.shape.type;\n this.effect = (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.itemFromSingleOrMultiple)(effectType, this.id, reduceDuplicates);\n this.shape = (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.itemFromSingleOrMultiple)(shapeType, this.id, reduceDuplicates);\n const effectOptions = particlesOptions.effect, shapeOptions = particlesOptions.shape;\n if (overrideOptions) {\n if (overrideOptions.effect?.type) {\n const overrideEffectType = overrideOptions.effect.type, effect = (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.itemFromSingleOrMultiple)(overrideEffectType, this.id, reduceDuplicates);\n if (effect) {\n this.effect = effect;\n effectOptions.load(overrideOptions.effect);\n }\n }\n if (overrideOptions.shape?.type) {\n const overrideShapeType = overrideOptions.shape.type, shape = (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.itemFromSingleOrMultiple)(overrideShapeType, this.id, reduceDuplicates);\n if (shape) {\n this.shape = shape;\n shapeOptions.load(overrideOptions.shape);\n }\n }\n }\n if (this.effect === _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.randomColorValue) {\n const availableEffects = [...this._container.effectDrawers.keys()];\n this.effect = availableEffects[Math.floor((0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.getRandom)() * availableEffects.length)];\n }\n if (this.shape === _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.randomColorValue) {\n const availableShapes = [...this._container.shapeDrawers.keys()];\n this.shape = availableShapes[Math.floor((0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.getRandom)() * availableShapes.length)];\n }\n this.effectData = this.effect ? loadEffectData(this.effect, effectOptions, this.id, reduceDuplicates) : undefined;\n this.shapeData = this.shape ? loadShapeData(this.shape, shapeOptions, this.id, reduceDuplicates) : undefined;\n particlesOptions.load(overrideOptions);\n const effectData = this.effectData;\n if (effectData) {\n particlesOptions.load(effectData.particles);\n }\n const shapeData = this.shapeData;\n if (shapeData) {\n particlesOptions.load(shapeData.particles);\n }\n this.effectClose = effectData?.close ?? particlesOptions.effect.close;\n this.shapeClose = shapeData?.close ?? particlesOptions.shape.close;\n this.options = particlesOptions;\n container.retina.initParticle(this);\n this.size = (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.initParticleNumericAnimationValue)(this.options.size, pxRatio);\n this.bubble = {\n inRange: false,\n };\n this.slow = {\n inRange: false,\n factor: 1,\n };\n this._initPosition(position);\n this.initialVelocity = this._calculateVelocity();\n this.velocity = this.initialVelocity.copy();\n const particles = container.particles;\n particles.setLastZIndex(this.position.z);\n this.zIndexFactor = this.position.z / container.zLayers;\n this.sides = 24;\n let effectDrawer, shapeDrawer;\n if (this.effect) {\n effectDrawer = container.effectDrawers.get(this.effect);\n }\n if (effectDrawer?.loadEffect) {\n effectDrawer.loadEffect(this);\n }\n if (this.shape) {\n shapeDrawer = container.shapeDrawers.get(this.shape);\n }\n if (shapeDrawer?.loadShape) {\n shapeDrawer.loadShape(this);\n }\n const sideCountFunc = shapeDrawer?.getSidesCount;\n if (sideCountFunc) {\n this.sides = sideCountFunc(this);\n }\n this.spawning = false;\n for (const updater of container.particleUpdaters) {\n updater.init(this);\n }\n effectDrawer?.particleInit?.(container, this);\n shapeDrawer?.particleInit?.(container, this);\n for (const plugin of container.particleCreatedPlugins) {\n plugin.particleCreated?.(this);\n }\n }\n isInsideCanvas() {\n const radius = this.getRadius(), canvasSize = this._container.canvas.size, position = this.position;\n return (position.x >= -radius &&\n position.y >= -radius &&\n position.y <= canvasSize.height + radius &&\n position.x <= canvasSize.width + radius);\n }\n isShowingBack() {\n if (!this.roll) {\n return false;\n }\n const angle = this.roll.angle;\n if (this.roll.horizontal && this.roll.vertical) {\n const normalizedAngle = angle % _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.doublePI, adjustedAngle = normalizedAngle < _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultAngle ? normalizedAngle + _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.doublePI : normalizedAngle;\n return adjustedAngle >= Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.half && adjustedAngle < Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.triple * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.half;\n }\n if (this.roll.horizontal) {\n const normalizedAngle = (angle + Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.half) % (Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.double), adjustedAngle = normalizedAngle < _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultAngle ? normalizedAngle + Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.double : normalizedAngle;\n return adjustedAngle >= Math.PI && adjustedAngle < Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.double;\n }\n if (this.roll.vertical) {\n const normalizedAngle = angle % (Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.double), adjustedAngle = normalizedAngle < _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultAngle ? normalizedAngle + Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.double : normalizedAngle;\n return adjustedAngle >= Math.PI && adjustedAngle < Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.double;\n }\n return false;\n }\n isVisible() {\n return !this.destroyed && !this.spawning && this.isInsideCanvas();\n }\n reset() {\n for (const updater of this._container.particleUpdaters) {\n updater.reset?.(this);\n }\n }\n _calcPosition = (position, zIndex) => {\n let tryCount = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultRetryCount, posVec = position ? _Utils_Vectors_js__WEBPACK_IMPORTED_MODULE_0__.Vector3d.create(position.x, position.y, zIndex) : undefined;\n const container = this._container, plugins = container.particlePositionPlugins, outModes = this.options.move.outModes, radius = this.getRadius(), canvasSize = container.canvas.size, abortController = new AbortController(), { signal } = abortController;\n while (!signal.aborted) {\n for (const plugin of plugins) {\n const pluginPos = plugin.particlePosition?.(posVec, this);\n if (pluginPos) {\n return _Utils_Vectors_js__WEBPACK_IMPORTED_MODULE_0__.Vector3d.create(pluginPos.x, pluginPos.y, zIndex);\n }\n }\n const exactPosition = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.calcExactPositionOrRandomFromSize)({\n size: canvasSize,\n position: posVec,\n }), pos = _Utils_Vectors_js__WEBPACK_IMPORTED_MODULE_0__.Vector3d.create(exactPosition.x, exactPosition.y, zIndex);\n this._fixHorizontal(pos, radius, outModes.left ?? outModes.default);\n this._fixHorizontal(pos, radius, outModes.right ?? outModes.default);\n this._fixVertical(pos, radius, outModes.top ?? outModes.default);\n this._fixVertical(pos, radius, outModes.bottom ?? outModes.default);\n let isValidPosition = true;\n for (const plugin of container.particles.checkParticlePositionPlugins) {\n isValidPosition = plugin.checkParticlePosition?.(this, pos, tryCount) ?? true;\n if (!isValidPosition) {\n break;\n }\n }\n if (isValidPosition) {\n return pos;\n }\n tryCount += _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.tryCountIncrement;\n posVec = undefined;\n }\n return posVec;\n };\n _calculateVelocity = () => {\n const baseVelocity = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.getParticleBaseVelocity)(this.direction), res = baseVelocity.copy(), moveOptions = this.options.move;\n if (moveOptions.direction === _Enums_Directions_MoveDirection_js__WEBPACK_IMPORTED_MODULE_6__.MoveDirection.inside || moveOptions.direction === _Enums_Directions_MoveDirection_js__WEBPACK_IMPORTED_MODULE_6__.MoveDirection.outside) {\n return res;\n }\n const rad = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.degToRad)((0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.getRangeValue)(moveOptions.angle.value)), radOffset = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.degToRad)((0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.getRangeValue)(moveOptions.angle.offset)), range = {\n left: radOffset - rad * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.half,\n right: radOffset + rad * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.half,\n };\n if (!moveOptions.straight) {\n res.angle += (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.randomInRangeValue)((0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.setRangeValue)(range.left, range.right));\n }\n if (moveOptions.random && typeof moveOptions.speed === \"number\") {\n res.length *= (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.getRandom)();\n }\n return res;\n };\n _fixHorizontal = (pos, radius, outMode) => {\n fixOutMode({\n outMode,\n checkModes: [_Enums_Modes_OutMode_js__WEBPACK_IMPORTED_MODULE_7__.OutMode.bounce],\n coord: pos.x,\n maxCoord: this._container.canvas.size.width,\n setCb: (value) => (pos.x += value),\n radius,\n });\n };\n _fixVertical = (pos, radius, outMode) => {\n fixOutMode({\n outMode,\n checkModes: [_Enums_Modes_OutMode_js__WEBPACK_IMPORTED_MODULE_7__.OutMode.bounce],\n coord: pos.y,\n maxCoord: this._container.canvas.size.height,\n setCb: (value) => (pos.y += value),\n radius,\n });\n };\n _getRollColor = color => {\n if (!color || !this.roll || (!this.backColor && !this.roll.alter)) {\n return color;\n }\n if (!this.isShowingBack()) {\n return color;\n }\n if (this.backColor) {\n return this.backColor;\n }\n if (this.roll.alter) {\n return (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_1__.alterHsl)(color, this.roll.alter.type, this.roll.alter.value);\n }\n return color;\n };\n _initPosition = position => {\n const container = this._container, zIndexValue = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.getRangeValue)(this.options.zIndex.value), initialPosition = this._calcPosition(position, (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.clamp)(zIndexValue, _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.minZ, container.zLayers));\n if (!initialPosition) {\n throw new Error(\"a valid position cannot be found for particle\");\n }\n this.position = initialPosition;\n this.initialPosition = this.position.copy();\n const canvasSize = container.canvas.size;\n this.moveCenter = {\n ...(0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.getPosition)(this.options.move.center, canvasSize),\n radius: this.options.move.center.radius,\n mode: this.options.move.center.mode,\n };\n this.direction = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.getParticleDirectionAngle)(this.options.move.direction, this.position, this.moveCenter);\n switch (this.options.move.direction) {\n case _Enums_Directions_MoveDirection_js__WEBPACK_IMPORTED_MODULE_6__.MoveDirection.inside:\n this.outType = _Enums_Types_ParticleOutType_js__WEBPACK_IMPORTED_MODULE_8__.ParticleOutType.inside;\n break;\n case _Enums_Directions_MoveDirection_js__WEBPACK_IMPORTED_MODULE_6__.MoveDirection.outside:\n this.outType = _Enums_Types_ParticleOutType_js__WEBPACK_IMPORTED_MODULE_8__.ParticleOutType.outside;\n break;\n default:\n break;\n }\n this.offset = _Utils_Vectors_js__WEBPACK_IMPORTED_MODULE_0__.Vector.origin;\n };\n}\n\n\n//# sourceURL=webpack://@tsparticles/preset-fire/../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Particle.js?\n}");
|
|
47
|
+
|
|
48
|
+
/***/ },
|
|
49
|
+
|
|
50
|
+
/***/ "../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/ParticlesManager.js"
|
|
51
|
+
/*!************************************************************************************************************************************!*\
|
|
52
|
+
!*** ../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/ParticlesManager.js ***!
|
|
53
|
+
\************************************************************************************************************************************/
|
|
54
|
+
(__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
|
|
55
|
+
|
|
56
|
+
eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ ParticlesManager: () => (/* binding */ ParticlesManager)\n/* harmony export */ });\n/* harmony import */ var _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./Utils/Constants.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Utils/Constants.js\");\n/* harmony import */ var _Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../Enums/Types/EventType.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Enums/Types/EventType.js\");\n/* harmony import */ var _Enums_Modes_LimitMode_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../Enums/Modes/LimitMode.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Enums/Modes/LimitMode.js\");\n/* harmony import */ var _Particle_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./Particle.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Particle.js\");\n/* harmony import */ var _Utils_SpatialHashGrid_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./Utils/SpatialHashGrid.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Utils/SpatialHashGrid.js\");\n/* harmony import */ var _Utils_LogUtils_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../Utils/LogUtils.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Utils/LogUtils.js\");\n/* harmony import */ var _Utils_OptionsUtils_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../Utils/OptionsUtils.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Utils/OptionsUtils.js\");\n\n\n\n\n\n\n\nclass ParticlesManager {\n checkParticlePositionPlugins;\n grid;\n _array;\n _container;\n _groupLimits;\n _limit;\n _maxZIndex;\n _minZIndex;\n _needsSort;\n _nextId;\n _particleResetPlugins;\n _particleUpdatePlugins;\n _pluginManager;\n _pool;\n _postParticleUpdatePlugins;\n _postUpdatePlugins;\n _resizeFactor;\n _updatePlugins;\n _zArray;\n constructor(pluginManager, container) {\n this._pluginManager = pluginManager;\n this._container = container;\n this._nextId = 0;\n this._array = [];\n this._zArray = [];\n this._pool = [];\n this._limit = 0;\n this._groupLimits = new Map();\n this._needsSort = false;\n this._minZIndex = 0;\n this._maxZIndex = 0;\n this.grid = new _Utils_SpatialHashGrid_js__WEBPACK_IMPORTED_MODULE_4__.SpatialHashGrid(_Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.spatialHashGridCellSize);\n this.checkParticlePositionPlugins = [];\n this._particleResetPlugins = [];\n this._particleUpdatePlugins = [];\n this._postUpdatePlugins = [];\n this._postParticleUpdatePlugins = [];\n this._updatePlugins = [];\n }\n get count() {\n return this._array.length;\n }\n addParticle(position, overrideOptions, group, initializer) {\n const limitMode = this._container.actualOptions.particles.number.limit.mode, limit = group === undefined ? this._limit : (this._groupLimits.get(group) ?? this._limit), currentCount = this.count;\n if (limit > _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.minLimit) {\n switch (limitMode) {\n case _Enums_Modes_LimitMode_js__WEBPACK_IMPORTED_MODULE_2__.LimitMode.delete: {\n const countToRemove = currentCount + _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.countOffset - limit;\n if (countToRemove > _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.minCount) {\n this.removeQuantity(countToRemove);\n }\n break;\n }\n case _Enums_Modes_LimitMode_js__WEBPACK_IMPORTED_MODULE_2__.LimitMode.wait:\n if (currentCount >= limit) {\n return;\n }\n break;\n default:\n break;\n }\n }\n try {\n const particle = this._pool.pop() ?? new _Particle_js__WEBPACK_IMPORTED_MODULE_3__.Particle(this._pluginManager, this._container);\n particle.init(this._nextId, position, overrideOptions, group);\n let canAdd = true;\n if (initializer) {\n canAdd = initializer(particle);\n }\n if (!canAdd) {\n this._pool.push(particle);\n return;\n }\n this._array.push(particle);\n this._zArray.push(particle);\n this._nextId++;\n this._container.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_1__.EventType.particleAdded, {\n particle,\n });\n return particle;\n }\n catch (e) {\n (0,_Utils_LogUtils_js__WEBPACK_IMPORTED_MODULE_5__.getLogger)().warning(`error adding particle: ${e}`);\n }\n return undefined;\n }\n clear() {\n this._array = [];\n this._zArray = [];\n }\n destroy() {\n this._array = [];\n this._pool.length = 0;\n this._zArray = [];\n this.checkParticlePositionPlugins = [];\n this._particleResetPlugins = [];\n this._particleUpdatePlugins = [];\n this._postUpdatePlugins = [];\n this._postParticleUpdatePlugins = [];\n this._updatePlugins = [];\n }\n drawParticles(delta) {\n for (const particle of this._zArray) {\n particle.draw(delta);\n }\n }\n filter(condition) {\n return this._array.filter(condition);\n }\n find(condition) {\n return this._array.find(condition);\n }\n get(index) {\n return this._array[index];\n }\n async init() {\n const container = this._container, options = container.actualOptions;\n this._minZIndex = 0;\n this._maxZIndex = 0;\n this._needsSort = false;\n this.checkParticlePositionPlugins = [];\n this._updatePlugins = [];\n this._particleUpdatePlugins = [];\n this._postUpdatePlugins = [];\n this._particleResetPlugins = [];\n this._postParticleUpdatePlugins = [];\n this.grid = new _Utils_SpatialHashGrid_js__WEBPACK_IMPORTED_MODULE_4__.SpatialHashGrid(_Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.spatialHashGridCellSize * container.retina.pixelRatio);\n for (const plugin of container.plugins) {\n if (plugin.redrawInit) {\n await plugin.redrawInit();\n }\n if (plugin.checkParticlePosition) {\n this.checkParticlePositionPlugins.push(plugin);\n }\n if (plugin.update) {\n this._updatePlugins.push(plugin);\n }\n if (plugin.particleUpdate) {\n this._particleUpdatePlugins.push(plugin);\n }\n if (plugin.postUpdate) {\n this._postUpdatePlugins.push(plugin);\n }\n if (plugin.particleReset) {\n this._particleResetPlugins.push(plugin);\n }\n if (plugin.postParticleUpdate) {\n this._postParticleUpdatePlugins.push(plugin);\n }\n }\n await this._container.initDrawersAndUpdaters();\n for (const drawer of this._container.effectDrawers.values()) {\n await drawer.init?.(container);\n }\n for (const drawer of this._container.shapeDrawers.values()) {\n await drawer.init?.(container);\n }\n let handled = false;\n for (const plugin of container.plugins) {\n handled = plugin.particlesInitialization?.() ?? handled;\n if (handled) {\n break;\n }\n }\n if (!handled) {\n const particlesOptions = options.particles, groups = particlesOptions.groups;\n for (const group in groups) {\n const groupOptions = groups[group];\n if (!groupOptions) {\n continue;\n }\n for (let i = this.count, j = 0; j < groupOptions.number.value && i < particlesOptions.number.value; i++, j++) {\n this.addParticle(undefined, groupOptions, group);\n }\n }\n for (let i = this.count; i < particlesOptions.number.value; i++) {\n this.addParticle();\n }\n }\n }\n push(nb, position, overrideOptions, group) {\n for (let i = 0; i < nb; i++) {\n this.addParticle(position, overrideOptions, group);\n }\n }\n async redraw() {\n this.clear();\n await this.init();\n this._container.canvas.render.drawParticles({ value: 0, factor: 0 });\n }\n remove(particle, group, override) {\n this.removeAt(this._array.indexOf(particle), undefined, group, override);\n }\n removeAt(index, quantity = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.defaultRemoveQuantity, group, override) {\n if (index < _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.minIndex || index > this.count) {\n return;\n }\n let deleted = 0;\n for (let i = index; deleted < quantity && i < this.count; i++) {\n if (this._removeParticle(i, group, override)) {\n i--;\n deleted++;\n }\n }\n }\n removeQuantity(quantity, group) {\n this.removeAt(_Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.minIndex, quantity, group);\n }\n setDensity() {\n const options = this._container.actualOptions, groups = options.particles.groups;\n let pluginsCount = 0;\n for (const plugin of this._container.plugins) {\n if (plugin.particlesDensityCount) {\n pluginsCount += plugin.particlesDensityCount();\n }\n }\n for (const group in groups) {\n const groupData = groups[group];\n if (!groupData) {\n continue;\n }\n const groupDataOptions = (0,_Utils_OptionsUtils_js__WEBPACK_IMPORTED_MODULE_6__.loadParticlesOptions)(this._pluginManager, this._container, groupData);\n this._applyDensity(groupDataOptions, pluginsCount, group);\n }\n this._applyDensity(options.particles, pluginsCount);\n }\n setLastZIndex(zIndex) {\n this._needsSort ||= zIndex >= this._maxZIndex || (zIndex > this._minZIndex && zIndex < this._maxZIndex);\n }\n setResizeFactor(factor) {\n this._resizeFactor = factor;\n }\n update(delta) {\n const particlesToDelete = new Set();\n this.grid.clear();\n for (const plugin of this._updatePlugins) {\n plugin.update?.(delta);\n }\n const resizeFactor = this._resizeFactor;\n for (const particle of this._array) {\n if (resizeFactor && !particle.ignoresResizeRatio) {\n particle.position.x *= resizeFactor.width;\n particle.position.y *= resizeFactor.height;\n particle.initialPosition.x *= resizeFactor.width;\n particle.initialPosition.y *= resizeFactor.height;\n }\n particle.ignoresResizeRatio = false;\n for (const plugin of this._particleResetPlugins) {\n plugin.particleReset?.(particle);\n }\n for (const plugin of this._particleUpdatePlugins) {\n if (particle.destroyed) {\n break;\n }\n plugin.particleUpdate?.(particle, delta);\n }\n if (particle.destroyed) {\n particlesToDelete.add(particle);\n continue;\n }\n this.grid.insert(particle);\n }\n for (const plugin of this._postUpdatePlugins) {\n plugin.postUpdate?.(delta);\n }\n for (const particle of this._array) {\n if (particle.destroyed) {\n particlesToDelete.add(particle);\n continue;\n }\n for (const updater of this._container.particleUpdaters) {\n updater.update(particle, delta);\n }\n if (!particle.destroyed && !particle.spawning) {\n for (const plugin of this._postParticleUpdatePlugins) {\n plugin.postParticleUpdate?.(particle, delta);\n }\n }\n else if (particle.destroyed) {\n particlesToDelete.add(particle);\n }\n }\n if (particlesToDelete.size) {\n for (const particle of particlesToDelete) {\n this.remove(particle);\n }\n }\n delete this._resizeFactor;\n if (this._needsSort) {\n const zArray = this._zArray;\n zArray.sort((a, b) => b.position.z - a.position.z || a.id - b.id);\n const firstItem = zArray[_Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.minIndex], lastItem = zArray[zArray.length - _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.lengthOffset];\n if (!firstItem || !lastItem) {\n return;\n }\n this._maxZIndex = firstItem.position.z;\n this._minZIndex = lastItem.position.z;\n this._needsSort = false;\n }\n }\n _addToPool = (...particles) => {\n this._pool.push(...particles);\n };\n _applyDensity = (options, pluginsCount, group, groupOptions) => {\n const numberOptions = options.number;\n if (!numberOptions.density.enable) {\n if (group === undefined) {\n this._limit = numberOptions.limit.value;\n }\n else if (groupOptions?.number.limit.value ?? numberOptions.limit.value) {\n this._groupLimits.set(group, groupOptions?.number.limit.value ?? numberOptions.limit.value);\n }\n return;\n }\n const densityFactor = this._initDensityFactor(numberOptions.density), optParticlesNumber = numberOptions.value, optParticlesLimit = numberOptions.limit.value > _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.minLimit ? numberOptions.limit.value : optParticlesNumber, particlesNumber = Math.min(optParticlesNumber, optParticlesLimit) * densityFactor + pluginsCount, particlesCount = Math.min(this.count, this.filter(t => t.group === group).length);\n if (group === undefined) {\n this._limit = numberOptions.limit.value * densityFactor;\n }\n else {\n this._groupLimits.set(group, numberOptions.limit.value * densityFactor);\n }\n if (particlesCount < particlesNumber) {\n this.push(Math.abs(particlesNumber - particlesCount), undefined, options, group);\n }\n else if (particlesCount > particlesNumber) {\n this.removeQuantity(particlesCount - particlesNumber, group);\n }\n };\n _initDensityFactor = densityOptions => {\n const container = this._container;\n if (!container.canvas.element || !densityOptions.enable) {\n return _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.defaultDensityFactor;\n }\n const canvas = container.canvas.element, pxRatio = container.retina.pixelRatio;\n return (canvas.width * canvas.height) / (densityOptions.height * densityOptions.width * pxRatio ** _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.squareExp);\n };\n _removeParticle = (index, group, override) => {\n const particle = this._array[index];\n if (!particle) {\n return false;\n }\n if (particle.group !== group) {\n return false;\n }\n const zIdx = this._zArray.indexOf(particle);\n this._array.splice(index, _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.deleteCount);\n this._zArray.splice(zIdx, _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.deleteCount);\n particle.destroy(override);\n this._container.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_1__.EventType.particleRemoved, {\n particle,\n });\n this._addToPool(particle);\n return true;\n };\n}\n\n\n//# sourceURL=webpack://@tsparticles/preset-fire/../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/ParticlesManager.js?\n}");
|
|
57
|
+
|
|
58
|
+
/***/ },
|
|
59
|
+
|
|
60
|
+
/***/ "../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/RenderManager.js"
|
|
61
|
+
/*!*********************************************************************************************************************************!*\
|
|
62
|
+
!*** ../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/RenderManager.js ***!
|
|
63
|
+
\*********************************************************************************************************************************/
|
|
64
|
+
(__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
|
|
65
|
+
|
|
66
|
+
eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ RenderManager: () => (/* binding */ RenderManager)\n/* harmony export */ });\n/* harmony import */ var _Utils_CanvasUtils_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Utils/CanvasUtils.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Utils/CanvasUtils.js\");\n/* harmony import */ var _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Utils/Constants.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Utils/Constants.js\");\n/* harmony import */ var _Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../Utils/ColorUtils.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Utils/ColorUtils.js\");\n\n\n\nconst fColorIndex = 0, sColorIndex = 1;\nfunction setTransformValue(factor, newFactor, key) {\n const newValue = newFactor[key];\n if (newValue !== undefined) {\n factor[key] = (factor[key] ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.defaultTransformValue) * newValue;\n }\n}\nclass RenderManager {\n _canvasClearPlugins;\n _canvasManager;\n _canvasPaintPlugins;\n _clearDrawPlugins;\n _colorPlugins;\n _container;\n _context;\n _contextSettings;\n _drawParticlePlugins;\n _drawParticlesCleanupPlugins;\n _drawParticlesSetupPlugins;\n _drawPlugins;\n _drawSettingsCleanupPlugins;\n _drawSettingsSetupPlugins;\n _pluginManager;\n _postDrawUpdaters;\n _preDrawUpdaters;\n _reusableColorStyles = {};\n _reusablePluginColors = [undefined, undefined];\n _reusableTransform = {};\n constructor(pluginManager, container, canvasManager) {\n this._pluginManager = pluginManager;\n this._container = container;\n this._canvasManager = canvasManager;\n this._context = null;\n this._preDrawUpdaters = [];\n this._postDrawUpdaters = [];\n this._colorPlugins = [];\n this._canvasClearPlugins = [];\n this._canvasPaintPlugins = [];\n this._clearDrawPlugins = [];\n this._drawParticlePlugins = [];\n this._drawParticlesCleanupPlugins = [];\n this._drawParticlesSetupPlugins = [];\n this._drawPlugins = [];\n this._drawSettingsSetupPlugins = [];\n this._drawSettingsCleanupPlugins = [];\n }\n get settings() {\n return this._contextSettings;\n }\n canvasClear() {\n if (!this._container.actualOptions.clear) {\n return;\n }\n this.draw(ctx => {\n (0,_Utils_CanvasUtils_js__WEBPACK_IMPORTED_MODULE_0__.clear)(ctx, this._canvasManager.size);\n });\n }\n clear() {\n let pluginHandled = false;\n for (const plugin of this._canvasClearPlugins) {\n pluginHandled = plugin.canvasClear?.() ?? false;\n if (pluginHandled) {\n break;\n }\n }\n if (pluginHandled) {\n return;\n }\n this.canvasClear();\n }\n destroy() {\n this.stop();\n this._preDrawUpdaters = [];\n this._postDrawUpdaters = [];\n this._colorPlugins = [];\n this._canvasClearPlugins = [];\n this._canvasPaintPlugins = [];\n this._clearDrawPlugins = [];\n this._drawParticlePlugins = [];\n this._drawParticlesCleanupPlugins = [];\n this._drawParticlesSetupPlugins = [];\n this._drawPlugins = [];\n this._drawSettingsSetupPlugins = [];\n this._drawSettingsCleanupPlugins = [];\n }\n draw(cb) {\n const ctx = this._context;\n if (!ctx) {\n return;\n }\n return cb(ctx);\n }\n drawParticle(particle, delta) {\n if (particle.spawning || particle.destroyed) {\n return;\n }\n const radius = particle.getRadius();\n if (radius <= _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.minimumSize) {\n return;\n }\n const pfColor = particle.getFillColor(), psColor = particle.getStrokeColor();\n let [fColor, sColor] = this._getPluginParticleColors(particle);\n fColor ??= pfColor;\n sColor ??= psColor;\n if (!fColor && !sColor) {\n return;\n }\n const container = this._container, zIndexOptions = particle.options.zIndex, zIndexFactor = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.zIndexFactorOffset - particle.zIndexFactor, { fillOpacity, opacity, strokeOpacity } = particle.getOpacity(), transform = this._reusableTransform, colorStyles = this._reusableColorStyles, fill = fColor ? (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_2__.getStyleFromHsl)(fColor, container.hdr, fillOpacity * opacity) : undefined, stroke = sColor ? (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_2__.getStyleFromHsl)(sColor, container.hdr, strokeOpacity * opacity) : fill;\n transform.a = transform.b = transform.c = transform.d = undefined;\n colorStyles.fill = fill;\n colorStyles.stroke = stroke;\n this.draw((context) => {\n for (const plugin of this._drawParticlesSetupPlugins) {\n plugin.drawParticleSetup?.(context, particle, delta);\n }\n this._applyPreDrawUpdaters(context, particle, radius, opacity, colorStyles, transform);\n (0,_Utils_CanvasUtils_js__WEBPACK_IMPORTED_MODULE_0__.drawParticle)({\n container,\n context,\n particle,\n delta,\n colorStyles,\n radius: radius * zIndexFactor ** zIndexOptions.sizeRate,\n opacity: opacity,\n transform,\n });\n this._applyPostDrawUpdaters(particle);\n for (const plugin of this._drawParticlesCleanupPlugins) {\n plugin.drawParticleCleanup?.(context, particle, delta);\n }\n });\n }\n drawParticlePlugins(particle, delta) {\n this.draw(ctx => {\n for (const plugin of this._drawParticlePlugins) {\n (0,_Utils_CanvasUtils_js__WEBPACK_IMPORTED_MODULE_0__.drawParticlePlugin)(ctx, plugin, particle, delta);\n }\n });\n }\n drawParticles(delta) {\n const { particles } = this._container;\n this.clear();\n particles.update(delta);\n this.draw(ctx => {\n for (const plugin of this._drawSettingsSetupPlugins) {\n plugin.drawSettingsSetup?.(ctx, delta);\n }\n for (const plugin of this._drawPlugins) {\n plugin.draw?.(ctx, delta);\n }\n particles.drawParticles(delta);\n for (const plugin of this._clearDrawPlugins) {\n plugin.clearDraw?.(ctx, delta);\n }\n for (const plugin of this._drawSettingsCleanupPlugins) {\n plugin.drawSettingsCleanup?.(ctx, delta);\n }\n });\n }\n init() {\n this.initUpdaters();\n this.initPlugins();\n this.paint();\n }\n initPlugins() {\n this._colorPlugins = [];\n this._canvasClearPlugins = [];\n this._canvasPaintPlugins = [];\n this._clearDrawPlugins = [];\n this._drawParticlePlugins = [];\n this._drawParticlesSetupPlugins = [];\n this._drawParticlesCleanupPlugins = [];\n this._drawPlugins = [];\n this._drawSettingsSetupPlugins = [];\n this._drawSettingsCleanupPlugins = [];\n for (const plugin of this._container.plugins) {\n if (plugin.particleFillColor ?? plugin.particleStrokeColor) {\n this._colorPlugins.push(plugin);\n }\n if (plugin.canvasClear) {\n this._canvasClearPlugins.push(plugin);\n }\n if (plugin.canvasPaint) {\n this._canvasPaintPlugins.push(plugin);\n }\n if (plugin.drawParticle) {\n this._drawParticlePlugins.push(plugin);\n }\n if (plugin.drawParticleSetup) {\n this._drawParticlesSetupPlugins.push(plugin);\n }\n if (plugin.drawParticleCleanup) {\n this._drawParticlesCleanupPlugins.push(plugin);\n }\n if (plugin.draw) {\n this._drawPlugins.push(plugin);\n }\n if (plugin.drawSettingsSetup) {\n this._drawSettingsSetupPlugins.push(plugin);\n }\n if (plugin.drawSettingsCleanup) {\n this._drawSettingsCleanupPlugins.push(plugin);\n }\n if (plugin.clearDraw) {\n this._clearDrawPlugins.push(plugin);\n }\n }\n }\n initUpdaters() {\n this._preDrawUpdaters = [];\n this._postDrawUpdaters = [];\n for (const updater of this._container.particleUpdaters) {\n if (updater.afterDraw) {\n this._postDrawUpdaters.push(updater);\n }\n if (updater.getColorStyles ?? updater.getTransformValues ?? updater.beforeDraw) {\n this._preDrawUpdaters.push(updater);\n }\n }\n }\n paint() {\n let handled = false;\n for (const plugin of this._canvasPaintPlugins) {\n handled = plugin.canvasPaint?.() ?? false;\n if (handled) {\n break;\n }\n }\n if (handled) {\n return;\n }\n this.paintBase();\n }\n paintBase(baseColor) {\n this.draw(ctx => {\n (0,_Utils_CanvasUtils_js__WEBPACK_IMPORTED_MODULE_0__.paintBase)(ctx, this._canvasManager.size, baseColor);\n });\n }\n paintImage(image, opacity) {\n this.draw(ctx => {\n (0,_Utils_CanvasUtils_js__WEBPACK_IMPORTED_MODULE_0__.paintImage)(ctx, this._canvasManager.size, image, opacity);\n });\n }\n setContext(context) {\n this._context = context;\n if (this._context) {\n this._context.globalCompositeOperation = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.defaultCompositeValue;\n }\n }\n setContextSettings(settings) {\n this._contextSettings = settings;\n }\n stop() {\n this.draw(ctx => {\n (0,_Utils_CanvasUtils_js__WEBPACK_IMPORTED_MODULE_0__.clear)(ctx, this._canvasManager.size);\n });\n }\n _applyPostDrawUpdaters = particle => {\n for (const updater of this._postDrawUpdaters) {\n updater.afterDraw?.(particle);\n }\n };\n _applyPreDrawUpdaters = (ctx, particle, radius, zOpacity, colorStyles, transform) => {\n for (const updater of this._preDrawUpdaters) {\n if (updater.getColorStyles) {\n const { fill, stroke } = updater.getColorStyles(particle, ctx, radius, zOpacity);\n if (fill) {\n colorStyles.fill = fill;\n }\n if (stroke) {\n colorStyles.stroke = stroke;\n }\n }\n if (updater.getTransformValues) {\n const updaterTransform = updater.getTransformValues(particle);\n for (const key in updaterTransform) {\n setTransformValue(transform, updaterTransform, key);\n }\n }\n updater.beforeDraw?.(particle);\n }\n };\n _getPluginParticleColors = particle => {\n let fColor, sColor;\n for (const plugin of this._colorPlugins) {\n if (!fColor && plugin.particleFillColor) {\n fColor = (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_2__.rangeColorToHsl)(this._pluginManager, plugin.particleFillColor(particle));\n }\n if (!sColor && plugin.particleStrokeColor) {\n sColor = (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_2__.rangeColorToHsl)(this._pluginManager, plugin.particleStrokeColor(particle));\n }\n if (fColor && sColor) {\n break;\n }\n }\n this._reusablePluginColors[fColorIndex] = fColor;\n this._reusablePluginColors[sColorIndex] = sColor;\n return this._reusablePluginColors;\n };\n}\n\n\n//# sourceURL=webpack://@tsparticles/preset-fire/../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/RenderManager.js?\n}");
|
|
67
|
+
|
|
68
|
+
/***/ },
|
|
69
|
+
|
|
70
|
+
/***/ "../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Retina.js"
|
|
71
|
+
/*!**************************************************************************************************************************!*\
|
|
72
|
+
!*** ../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Retina.js ***!
|
|
73
|
+
\**************************************************************************************************************************/
|
|
74
|
+
(__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
|
|
75
|
+
|
|
76
|
+
eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Retina: () => (/* binding */ Retina)\n/* harmony export */ });\n/* harmony import */ var _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./Utils/Constants.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Utils/Constants.js\");\n/* harmony import */ var _Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../Utils/MathUtils.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Utils/MathUtils.js\");\n\n\nclass Retina {\n container;\n pixelRatio;\n reduceFactor;\n constructor(container) {\n this.container = container;\n this.pixelRatio = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.defaultRatio;\n this.reduceFactor = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.defaultReduceFactor;\n }\n init() {\n const container = this.container, options = container.actualOptions;\n this.pixelRatio = options.detectRetina ? devicePixelRatio : _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.defaultRatio;\n this.reduceFactor = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.defaultReduceFactor;\n const ratio = this.pixelRatio, canvas = container.canvas;\n if (canvas.element) {\n const element = canvas.element;\n canvas.size.width = element.offsetWidth * ratio;\n canvas.size.height = element.offsetHeight * ratio;\n }\n }\n initParticle(particle) {\n const options = particle.options, ratio = this.pixelRatio, moveOptions = options.move, moveDistance = moveOptions.distance, props = particle.retina;\n props.maxSpeed = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getRangeValue)(moveOptions.gravity.maxSpeed) * ratio;\n props.moveDrift = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getRangeValue)(moveOptions.drift) * ratio;\n props.moveSpeed = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getRangeValue)(moveOptions.speed) * ratio;\n props.sizeAnimationSpeed = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getRangeValue)(options.size.animation.speed) * ratio;\n const maxDistance = props.maxDistance;\n maxDistance.horizontal = moveDistance.horizontal === undefined ? undefined : moveDistance.horizontal * ratio;\n maxDistance.vertical = moveDistance.vertical === undefined ? undefined : moveDistance.vertical * ratio;\n }\n}\n\n\n//# sourceURL=webpack://@tsparticles/preset-fire/../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Retina.js?\n}");
|
|
77
|
+
|
|
78
|
+
/***/ },
|
|
79
|
+
|
|
80
|
+
/***/ "../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Utils/EventListeners.js"
|
|
81
|
+
/*!****************************************************************************************************************************************!*\
|
|
82
|
+
!*** ../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Utils/EventListeners.js ***!
|
|
83
|
+
\****************************************************************************************************************************************/
|
|
84
|
+
(__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
|
|
85
|
+
|
|
86
|
+
eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ EventListeners: () => (/* binding */ EventListeners)\n/* harmony export */ });\n/* harmony import */ var _Utils_Utils_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../Utils/Utils.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Utils/Utils.js\");\n/* harmony import */ var _Constants_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Constants.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Utils/Constants.js\");\n\n\nclass EventListeners {\n container;\n _handlers;\n _resizeObserver;\n _resizeTimeout;\n constructor(container) {\n this.container = container;\n this._handlers = {\n visibilityChange: () => {\n this._handleVisibilityChange();\n },\n resize: () => {\n this._handleWindowResize();\n },\n };\n }\n addListeners() {\n this._manageListeners(true);\n }\n removeListeners() {\n this._manageListeners(false);\n }\n _handleVisibilityChange = () => {\n const container = this.container, options = container.actualOptions;\n if (!options.pauseOnBlur) {\n return;\n }\n if ((0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_0__.safeDocument)().hidden) {\n container.pageHidden = true;\n container.pause();\n }\n else {\n container.pageHidden = false;\n if (container.animationStatus) {\n container.play(true);\n }\n else {\n container.draw(true);\n }\n }\n };\n _handleWindowResize = () => {\n if (this._resizeTimeout) {\n clearTimeout(this._resizeTimeout);\n delete this._resizeTimeout;\n }\n const handleResize = async () => {\n const canvas = this.container.canvas;\n await canvas.windowResize();\n };\n this._resizeTimeout = setTimeout(() => void handleResize(), this.container.actualOptions.resize.delay * _Constants_js__WEBPACK_IMPORTED_MODULE_1__.millisecondsToSeconds);\n };\n _manageListeners = add => {\n const handlers = this._handlers;\n this._manageResize(add);\n (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_0__.manageListener)(document, _Constants_js__WEBPACK_IMPORTED_MODULE_1__.visibilityChangeEvent, handlers.visibilityChange, add, false);\n };\n _manageResize = add => {\n const handlers = this._handlers, container = this.container, options = container.actualOptions;\n if (!options.resize.enable) {\n return;\n }\n if (typeof ResizeObserver === \"undefined\") {\n (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_0__.manageListener)(globalThis, _Constants_js__WEBPACK_IMPORTED_MODULE_1__.resizeEvent, handlers.resize, add);\n return;\n }\n const canvasEl = container.canvas.element;\n if (this._resizeObserver && !add) {\n if (canvasEl) {\n this._resizeObserver.unobserve(canvasEl);\n }\n this._resizeObserver.disconnect();\n delete this._resizeObserver;\n }\n else if (!this._resizeObserver && add && canvasEl) {\n this._resizeObserver = new ResizeObserver((entries) => {\n const entry = entries.find(e => e.target === canvasEl);\n if (!entry) {\n return;\n }\n this._handleWindowResize();\n });\n this._resizeObserver.observe(canvasEl);\n }\n };\n}\n\n\n//# sourceURL=webpack://@tsparticles/preset-fire/../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Utils/EventListeners.js?\n}");
|
|
87
|
+
|
|
88
|
+
/***/ },
|
|
89
|
+
|
|
90
|
+
/***/ "../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Utils/SpatialHashGrid.js"
|
|
91
|
+
/*!*****************************************************************************************************************************************!*\
|
|
92
|
+
!*** ../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Utils/SpatialHashGrid.js ***!
|
|
93
|
+
\*****************************************************************************************************************************************/
|
|
94
|
+
(__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
|
|
95
|
+
|
|
96
|
+
eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ SpatialHashGrid: () => (/* binding */ SpatialHashGrid)\n/* harmony export */ });\n/* harmony import */ var _Ranges_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./Ranges.js */ \"../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Utils/Ranges.js\");\n\nclass SpatialHashGrid {\n _cellSize;\n _cells = new Map();\n _circlePool = [];\n _circlePoolIdx;\n _pendingCellSize;\n _rectanglePool = [];\n _rectanglePoolIdx;\n constructor(cellSize) {\n this._cellSize = cellSize;\n this._circlePoolIdx = 0;\n this._rectanglePoolIdx = 0;\n }\n clear() {\n this._cells.clear();\n const pendingCellSize = this._pendingCellSize;\n if (pendingCellSize) {\n this._cellSize = pendingCellSize;\n }\n this._pendingCellSize = undefined;\n }\n insert(particle) {\n const { x, y } = particle.getPosition(), key = this._cellKeyFromCoords(x, y);\n if (!this._cells.has(key)) {\n this._cells.set(key, []);\n }\n this._cells.get(key)?.push(particle);\n }\n query(range, check, out = []) {\n const bounds = this._getRangeBounds(range);\n if (!bounds) {\n return out;\n }\n const minCellX = Math.floor(bounds.minX / this._cellSize), maxCellX = Math.floor(bounds.maxX / this._cellSize), minCellY = Math.floor(bounds.minY / this._cellSize), maxCellY = Math.floor(bounds.maxY / this._cellSize);\n for (let cx = minCellX; cx <= maxCellX; cx++) {\n for (let cy = minCellY; cy <= maxCellY; cy++) {\n const key = `${cx}_${cy}`, cellParticles = this._cells.get(key);\n if (!cellParticles) {\n continue;\n }\n for (const p of cellParticles) {\n if (check && !check(p)) {\n continue;\n }\n if (range.contains(p.getPosition())) {\n out.push(p);\n }\n }\n }\n }\n return out;\n }\n queryCircle(position, radius, check, out = []) {\n const circle = this._acquireCircle(position.x, position.y, radius), result = this.query(circle, check, out);\n this._releaseShapes();\n return result;\n }\n queryRectangle(position, size, check, out = []) {\n const rect = this._acquireRectangle(position.x, position.y, size.width, size.height), result = this.query(rect, check, out);\n this._releaseShapes();\n return result;\n }\n setCellSize(cellSize) {\n this._pendingCellSize = cellSize;\n }\n _acquireCircle(x, y, r) {\n return (this._circlePool[this._circlePoolIdx++] ??= new _Ranges_js__WEBPACK_IMPORTED_MODULE_0__.Circle(x, y, r)).reset(x, y, r);\n }\n _acquireRectangle(x, y, w, h) {\n return (this._rectanglePool[this._rectanglePoolIdx++] ??= new _Ranges_js__WEBPACK_IMPORTED_MODULE_0__.Rectangle(x, y, w, h)).reset(x, y, w, h);\n }\n _cellKeyFromCoords(x, y) {\n const cellX = Math.floor(x / this._cellSize), cellY = Math.floor(y / this._cellSize);\n return `${cellX}_${cellY}`;\n }\n _getRangeBounds(range) {\n if (range instanceof _Ranges_js__WEBPACK_IMPORTED_MODULE_0__.Circle) {\n const r = range.radius, { x, y } = range.position;\n return {\n minX: x - r,\n maxX: x + r,\n minY: y - r,\n maxY: y + r,\n };\n }\n if (range instanceof _Ranges_js__WEBPACK_IMPORTED_MODULE_0__.Rectangle) {\n const { x, y } = range.position, { width, height } = range.size;\n return {\n minX: x,\n maxX: x + width,\n minY: y,\n maxY: y + height,\n };\n }\n return null;\n }\n _releaseShapes() {\n this._circlePoolIdx = 0;\n this._rectanglePoolIdx = 0;\n }\n}\n\n\n//# sourceURL=webpack://@tsparticles/preset-fire/../../node_modules/.pnpm/@tsparticles+engine@4.0.0-beta.11/node_modules/@tsparticles/engine/browser/Core/Utils/SpatialHashGrid.js?\n}");
|
|
97
|
+
|
|
98
|
+
/***/ }
|
|
99
|
+
|
|
100
|
+
}]);
|