����JFIFXX�����    $.' ",#(7),01444'9=82<.342  2!!22222222222222222222222222222222222222222222222222����"��4�� ���,�PG"Z_�4�˷����kjز�Z�,F+��_z�,�© �����zh6�٨�ic�fu���#ډb���_�N�?��wQ���5-�~�I���8����TK<5o�Iv-�����k�_U_�����~b�M��d����Ӝ�U�Hh��?]��E�w��Q���k�{��_}qFW7HTՑ��Y��F�?_�'ϔ��_�Ջt��=||I ��6�έ"�����D���/[�k�9���Y�8ds|\���Ҿp6�Ҵ���]��.����6�z<�v��@]�i%��$j��~�g��J>��no����pM[me�i$[����s�o�ᘨ�˸ nɜG-�ĨU�ycP�3.DB�li�;��hj���x7Z^�N�h������N3u{�:j�x�힞��#M&��jL P@_���� P��&��o8������9�����@Sz6�t7#O�ߋ �s}Yf�T���lmr����Z)'N��k�۞p����w\�Tȯ?�8`�O��i{wﭹW�[�r�� ��Q4F�׊���3m&L�=��h3����z~��#�\�l :�F,j@�� ʱ�wQT����8�"kJO���6�֚l����}���R�>ډK���]��y����&����p�}b��;N�1�m�r$�|��7�>e�@B�TM*-iH��g�D�)� E�m�|�ؘbҗ�a��Ҿ����t4���o���G��*oCN�rP���Q��@z,|?W[0�����:�n,jWiE��W��$~/�hp\��?��{(�0���+�Y8rΟ�+����>S-S����VN;�}�s?.����� w�9��˟<���Mq4�Wv'��{)0�1mB��V����W[�����8�/<� �%���wT^�5���b��)iM� pg�N�&ݝ��VO~�q���u���9� ����!��J27����$O-���! �:�%H��� ـ����y�ΠM=t{!S�� oK8������t<����è:a������[�����ա�H���~��w��Qz`�po�^ ����Q��n� �,uu�C�$ ^���,������8�#��:�6��e�|~���!�3�3.�\0��q��o�4`.|� ����y�Q�`~;�d�ׯ,��O�Zw�������`73�v�܋�<���Ȏ�� ـ4k��5�K�a�u�=9Yd��$>x�A�&�� j0� ���vF��� Y�|�y��� ~�6�@c��1vOp�Ig����4��l�OD���L����� R���c���j�_�uX6��3?nk��Wy�f;^*B� ��@�~a�`��Eu������+���6�L��.ü>��}y���}_�O�6�͐�:�YrG�X��kG�����l^w���~㒶sy��Iu�!� W ��X��N�7BV��O��!X�2����wvG�R�f�T#�����t�/?���%8�^�W�aT��G�cL�M���I��(J����1~�8�?aT ���]����AS�E��(��*E}� 2��#I/�׍qz��^t�̔���b�Yz4x���t�){ OH��+(E��A&�N�������XT��o��"�XC��'���)}�J�z�p� ��~5�}�^����+�6����w��c��Q�|Lp�d�H��}�(�.|����k��c4^�"�����Z?ȕ ��a<�L�!039C� �Eu�C�F�Ew�ç ;�n?�*o���B�8�bʝ���'#Rqf���M}7����]����s2tcS{�\icTx;�\��7K���P���ʇ Z O-��~��c>"��?�������P��E��O�8��@�8��G��Q�g�a�Վ���󁶠�䧘��_%#r�>�1�z�a��eb��qcPѵ��n���#L��� =��׀t� L�7�`��V���A{�C:�g���e@�w1 Xp3�c3�ġ����p��M"'-�@n4���fG��B3�DJ�8[Jo�ߐ���gK)ƛ��$���� ���8�3�����+���� �����6�ʻ���� ���S�kI�*KZlT _`���?��K����QK�d����B`�s}�>���`��*�>��,*@J�d�oF*����弝��O}�k��s��]��y�ߘ��c1G�V���<=�7��7����6�q�PT��tXԀ�!9*4�4Tހ3XΛex�46���Y��D ����� �BdemDa����\�_l,��G�/���֌7���Y�](�xTt^%�GE�����4�}bT���ڹ�����;Y)���B�Q��u��>J/J �⮶.�XԄ��j�ݳ�+E��d ��r�5�_D�1 ��o�� �B�x�΢�#���<��W�����8���R6�@g�M�.��� dr�D��>(otU��@x=��~v���2� ӣ�d�oBd��3�eO�6�㣷�����ݜ6��6Y��Qz`��S��{���\P�~z m5{J/L��1������<�e�ͅPu�b�]�ϔ���'������f�b� Zpw��c`"��i���BD@:)ִ�:�]��hv�E�w���T�l��P���"Ju�}��وV J��G6��. J/�Qgl߭�e�����@�z�Zev2u�)]կ�����7x���s�M�-<ɯ�c��r�v�����@��$�ޮ}lk���a���'����>x��O\�ZFu>�����ck#��&:��`�$�ai�>2Δ����l���oF[h��lE�ܺ�Πk:)���`�� $[6�����9�����kOw�\|���8}������ބ:��񶐕��I�A1/�=�2[�,�!��.}gN#�u����b��� ~��݊��}34q����d�E��Lc��$��"�[q�U�硬g^��%B �z���r�pJ�ru%v\h1Y�ne`ǥ:g���pQM~�^�Xi� ��`S�:V29.�P���V�?B�k�� AEvw%�_�9C�Q����wKekPؠ�\�;Io d�{ ߞo�c1eP����\� `����E=���@K<�Y���eڼ�J���w����{av�F�'�M�@/J��+9p���|]�����Iw &`��8���&M�hg��[�{��Xj��%��Ӓ�$��(����ʹN���<>�I���RY���K2�NPlL�ɀ)��&e����B+ь����( � �JTx���_?EZ� }@ 6�U���뙢ط�z��dWI�n` D����噥�[��uV��"�G&Ú����2g�}&m��?ċ�"����Om#��������� ��{�ON��"S�X��Ne��ysQ���@Fn��Vg���dX�~nj�]J�<�K]:��FW��b�������62�=��5f����JKw��bf�X�55��~J �%^����:�-�QIE��P��v�nZum� z � ~ə ���� ���ة����;�f��\v���g�8�1��f24;�V���ǔ�)����9���1\��c��v�/'Ƞ�w�������$�4�R-��t���� e�6�/�ġ �̕Ecy�J���u�B���<�W�ַ~�w[B1L۲�-JS΂�{���΃������A��20�c#��@ 0!1@AP"#2Q`$3V�%45a6�FRUq��� ����^7ׅ,$n�������+��F�`��2X'��0vM��p�L=������5��8������u�p~���.�`r�����\���O��,ư�0oS ��_�M�����l���4�kv\JSd���x���SW�<��Ae�IX����������$I���w�:S���y���›R��9�Q[���,�5�;�@]�%���u�@ *ro�lbI �� ��+���%m:�͇ZV�����u�̉����θau<�fc�.����{�4Ա� �Q����*�Sm��8\ujqs]{kN���)qO�y�_*dJ�b�7���yQqI&9�ԌK!�M}�R�;������S�T���1���i[U�ɵz�]��U)V�S6���3$K{�ߊ<�(� E]Զ[ǼENg�����'�\?#)Dkf��J���o��v���'�%ƞ�&K�u�!��b�35LX�Ϸ��63$K�a�;�9>,R��W��3�3� d�JeTYE.Mϧ��-�o�j3+y��y^�c�������VO�9NV\nd�1 ��!͕_)a�v;����թ�M�lWR1��)El��P;��yوÏ�u 3�k�5Pr6<�⒲l�!˞*��u־�n�!�l:����UNW ��%��Chx8vL'��X�@��*��)���̮��ˍ��� ���D-M�+J�U�kvK����+�x8��cY������?�Ԡ��~3mo��|�u@[XeY�C�\Kp�x8�oC�C�&����N�~3-H���� ��MX�s�u<`���~"WL��$8ξ��3���a�)|:@�m�\���^�`�@ҷ)�5p+��6���p�%i)P M���ngc�����#0Aruz���RL+xSS?���ʮ}()#�t��mˇ!��0}}y����<�e� �-ή�Ԩ��X������ MF���ԙ~l L.3���}�V뽺�v�����멬��Nl�)�2����^�Iq��a��M��qG��T�����c3#������3U�Ǎ���}��לS�|qa��ڃ�+���-��2�f����/��bz��ڐ�� �ݼ[2�ç����k�X�2�* �Z�d���J�G����M*9W���s{��w���T��x��y,�in�O�v��]���n����P�$�JB@=4�OTI�n��e�22a\����q�d���%�$��(���:���: /*�K[PR�fr\nڙdN���F�n�$�4�[�� U�zƶ����� �mʋ���,�ao�u 3�z� �x��Kn����\[��VFmbE;�_U��&V�Gg�]L�۪&#n%�$ɯ�dG���D�TI=�%+AB�Ru#��b4�1�»x�cs�YzڙJG��f��Il��d�eF'T� iA��T���uC�$����Y��H?����[!G`}���ͪ� �纤Hv\������j�Ex�K���!���OiƸ�Yj�+u-<���'q����uN�*�r\��+�]���<�wOZ.fp�ێ��,-*)V?j-kÊ#�`�r��dV����(�ݽBk�����G�ƛk�QmUڗe��Z���f}|����8�8��a���i��3'J�����~G_�^���d�8w������ R�`(�~�.��u���l�s+g�bv���W���lGc}��u���afE~1�Ue������Z�0�8�=e�� f@/�jqEKQQ�J��oN��J���W5~M>$6�Lt�;$ʳ{���^��6�{����v6���ķܰg�V�cnn �~z�x�«�,2�u�?cE+Ș�H؎�%�Za�)���X>uW�Tz�Nyo����s���FQƤ��$��*�&�LLXL)�1�" L��eO��ɟ�9=���:t��Z���c��Ž���Y?�ӭV�wv�~,Y��r�ۗ�|�y��GaF�����C�����.�+� ���v1���fήJ�����]�S��T��B��n5sW}y�$��~z�'�c ��8 ��� ,! �p��VN�S��N�N�q��y8z˱�A��4��*��'������2n<�s���^ǧ˭P�Jޮɏ�U�G�L�J�*#��<�V��t7�8����TĜ>��i}K%,���)[��z�21z ?�N�i�n1?T�I�R#��m-�����������������1����lA�`��fT5+��ܐ�c�q՝��ʐ��,���3�f2U�եmab��#ŠdQ�y>\��)�SLY����w#��.���ʑ�f��� ,"+�w�~�N�'�c�O�3F�������N<���)j��&��,-� �љ���֊�_�zS���TǦ����w�>��?�������n��U仆�V���e�����0���$�C�d���rP �m�׈e�Xm�Vu� �L��.�bֹ��� �[Դaզ���*��\y�8�Է:�Ez\�0�Kq�C b��̘��cө���Q��=0Y��s�N��S.���3.���O�o:���#���v7�[#߫ ��5�܎�L���Er4���9n��COWlG�^��0k�%<���ZB���aB_���������'=��{i�v�l�$�uC���mƎҝ{�c㱼�y]���W�i ��ߧc��m�H� m�"�"�����;Y�ߝ�Z�Ǔ�����:S#��|}�y�,/k�Ld� TA�(�AI$+I3��;Y*���Z��}|��ӧO��d�v��..#:n��f>�>���ȶI�TX��� 8��y����"d�R�|�)0���=���n4��6ⲑ�+��r<�O�܂~zh�z����7ܓ�HH�Ga롏���nCo�>������a ���~]���R���̲c?�6(�q�;5%� |�uj�~z8R=X��I�V=�|{v�Gj\gc��q����z�؋%M�ߍ����1y��#��@f^���^�>N�����#x#۹��6�Y~�?�dfPO��{��P�4��V��u1E1J �*|���%���JN��`eWu�zk M6���q t[�� ��g�G���v��WIG��u_ft����5�j�"�Y�:T��ɐ���*�;� e5���4����q$C��2d�}���� _S�L#m�Yp��O�.�C�;��c����Hi#֩%+) �Ӎ��ƲV���SYź��g |���tj��3�8���r|���V��1#;.SQ�A[���S������#���`n�+���$��$I �P\[�@�s��(�ED�z���P��])8�G#��0B��[ى��X�II�q<��9�~[Z멜�Z�⊔IWU&A>�P~�#��dp<�?����7���c��'~���5 ��+$���lx@�M�dm��n<=e�dyX��?{�|Aef ,|n3�<~z�ƃ�uۧ�����P��Y,�ӥQ�*g�#먙R�\���;T��i,��[9Qi歉����c>]9�� ��"�c��P�� �Md?٥��If�ت�u��k��/����F��9�c*9��Ǎ:�ØF���z�n*�@|I�ށ9����N3{'��[�'ͬ�Ҳ4��#}��!�V� Fu��,�,mTIk���v C�7v���B�6k�T9��1�*l� '~��ƞF��lU��'�M ����][ΩũJ_�{�i�I�n��$���L�� j��O�dx�����kza۪��#�E��Cl����x˘�o�����V���ɞ�ljr��)�/,�߬h�L��#��^��L�ф�,íMƁe�̩�NB�L�����iL����q�}��(��q��6IçJ$�W�E$��:������=#����(�K�B����zђ <��K(�N�۫K�w��^O{!����)�H���>x�������lx�?>Պ�+�>�W���,Ly!_�D���Ō�l���Q�!�[ �S����J��1��Ɛ�Y}��b,+�Lo�x�ɓ)����=�y�oh�@�꥟/��I��ѭ=��P�y9��� �ۍYӘ�e+�p�Jnϱ?V\SO%�(�t� ���=?MR�[Ș�����d�/ ��n�l��B�7j� ��!�;ӥ�/�[-���A�>�dN�sLj ��,ɪv��=1c�.SQ�O3�U���ƀ�ܽ�E����������̻��9G�ϷD�7(�}��Ävӌ\�y�_0[w ���<΍>����a_��[0+�L��F.�޺��f�>oN�T����q;���y\��bՃ��y�jH�<|q-eɏ�_?_9+P���Hp$�����[ux�K w�Mw��N�ی'$Y2�=��q���KB��P��~������Yul:�[<����F1�2�O���5=d����]Y�sw:���Ϯ���E��j,_Q��X��z`H1,#II ��d�wr��P˂@�ZJV����y$�\y�{}��^~���[:N����ߌ�U�������O��d�����ؾe��${p>G��3c���Ė�lʌ�� ת��[��`ϱ�-W����dg�I��ig2��� ��}s ��ؤ(%#sS@���~���3�X�nRG�~\jc3�v��ӍL��M[JB�T��s3}��j�Nʖ��W����;7��ç?=X�F=-�=����q�ߚ���#���='�c��7���ڑW�I(O+=:uxq�������������e2�zi+�kuG�R��������0�&e�n���iT^J����~\jy���p'dtG��s����O��3����9* �b#Ɋ�� p������[Bws�T�>d4�ۧs���nv�n���U���_�~,�v����ƜJ1��s�� �QIz��)�(lv8M���U=�;����56��G���s#�K���MP�=��LvyGd��}�VwWBF�'�à �?MH�U�g2�� ����!�p�7Q��j��ڴ����=��j�u��� Jn�A s���uM������e��Ɔ�Ҕ�!)'��8Ϣ�ٔ��ޝ(��Vp���צ֖d=�IC�J�Ǡ{q������kԭ�߸���i��@K����u�|�p=..�*+����x�����z[Aqġ#s2a�Ɗ���RR�)*HRsi�~�a &f��M��P����-K�L@��Z��Xy�'x�{}��Zm+���:�)�) IJ�-i�u���� ���ܒH��'�L(7�y�GӜq���� j��� 6ߌg1�g�o���,kر���tY�?W,���p���e���f�OQS��!K�۟cҒA�|ս�j�>��=⬒��˧L[�� �߿2JaB~R��u�:��Q�] �0H~���]�7��Ƽ�I���(}��cq '�ήET���q�?f�ab���ӥvr� �)o��-Q��_'����ᴎo��K������;��V���o��%���~OK ����*��b�f:���-ťIR��`B�5!RB@���ï�� �u �̯e\�_U�_������� g�ES��3�������QT��a����x����U<~�c?�*�#]�MW,[8O�a�x��]�1bC|踤�P��lw5V%�)�{t�<��d��5���0i�XSU��m:��Z�┵�i�"��1�^B�-��P�hJ��&)O��*�D��c�W��vM��)����}���P��ܗ-q����\mmζZ-l@�}��a��E�6��F�@��&Sg@���ݚ�M����� ȹ 4����#p�\H����dYDo�H���"��\��..R�B�H�z_�/5˘����6��KhJR��P�mƶi�m���3�,#c�co��q�a)*Pt����R�m�k�7x�D�E�\Y�閣_X�<���~�)���c[[�BP����6�Yq���S��0����%_����;��Àv�~�| VS؇ ��'O0��F0��\���U�-�d@�����7�SJ*z��3n��y��P����O���������m�~�P�3|Y��ʉr#�C�<�G~�.,! ���bqx���h~0=��!ǫ�jy����l�O,�[B��~��|9��ٱ����Xly�#�i�B��g%�S��������tˋ���e���ې��\[d�t)��.+u�|1 ������#�~Oj����hS�%��i.�~X���I�H�m��0n���c�1uE�q��cF�RF�o���7� �O�ꮧ� ���ۛ{��ʛi5�rw?׌#Qn�TW��~?y$��m\�\o����%W� ?=>S�N@�� �Ʈ���R����N�)�r"C�:��:����� �����#��qb��Y�. �6[��2K����2u�Ǧ�HYR��Q�MV��� �G�$��Q+.>�����nNH��q�^��� ����q��mM��V��D�+�-�#*�U�̒ ���p욳��u:�������IB���m���PV@O���r[b= �� ��1U�E��_Nm�yKbN�O���U�}�the�`�|6֮P>�\2�P�V���I�D�i�P�O;�9�r�mAHG�W�S]��J*�_�G��+kP�2����Ka�Z���H�'K�x�W�MZ%�O�YD�Rc+o��?�q��Ghm��d�S�oh�\�D�|:W������UA�Qc yT�q������~^�H��/��#p�CZ���T�I�1�ӏT����4��"�ČZ�����}��`w�#�*,ʹ�� ��0�i��課�Om�*�da��^gJ݅{���l�e9uF#T�ֲ��̲�ٞC"�q���ߍ ոޑ�o#�XZTp����@ o�8��(jd��xw�]�,f���`~�|,s��^����f�1���t��|��m�򸄭/ctr��5s��7�9Q�4�H1꠲BB@l9@���C�����+�wp�xu�£Yc�9��?`@#�o�mH�s2��)�=��2�.�l����jg�9$�Y�S�%*L������R�Y������7Z���,*=�䷘$�������arm�o�ϰ���UW.|�r�uf����IGw�t����Zwo��~5 ��YյhO+=8fF�)�W�7�L9lM�̘·Y���֘YLf�큹�pRF���99.A �"wz��=E\Z���'a� 2��Ǚ�#;�'}�G���*��l��^"q��+2FQ� hj��kŦ��${���ޮ-�T�٭cf�|�3#~�RJ����t��$b�(R��(����r���dx� >U b�&9,>���%E\� Ά�e�$��'�q't��*�א���ެ�b��-|d���SB�O�O��$�R+�H�)�܎�K��1m`;�J�2�Y~9��O�g8=vqD`K[�F)k�[���1m޼c��n���]s�k�z$@��)!I �x՝"v��9=�ZA=`Ɠi �:�E��)`7��vI��}d�YI�_ �o�:ob���o ���3Q��&D&�2=�� �Ά��;>�h����y.*ⅥS������Ӭ�+q&����j|UƧ����}���J0��WW< ۋS�)jQR�j���Ư��rN)�Gű�4Ѷ(�S)Ǣ�8��i��W52���No˓� ۍ%�5brOn�L�;�n��\G����=�^U�dI���8$�&���h��'���+�(������cȁ߫k�l��S^���cƗjԌE�ꭔ��gF���Ȓ��@���}O���*;e�v�WV���YJ\�]X'5��ղ�k�F��b 6R�o՜m��i N�i����>J����?��lPm�U��}>_Z&�KK��q�r��I�D�Չ~�q�3fL�:S�e>���E���-G���{L�6p�e,8��������QI��h��a�Xa��U�A'���ʂ���s�+טIjP�-��y�8ۈZ?J$��W�P� ��R�s�]��|�l(�ԓ��sƊi��o(��S0��Y� 8�T97.�����WiL��c�~�dxc�E|�2!�X�K�Ƙਫ਼�$((�6�~|d9u+�qd�^3�89��Y�6L�.I�����?���iI�q���9�)O/뚅����O���X��X�V��ZF[�یgQ�L��K1���RҖr@v�#��X�l��F���Нy�S�8�7�kF!A��sM���^rkp�jP�DyS$N���q��nxҍ!U�f�!eh�i�2�m���`�Y�I�9r�6� �TF���C}/�y�^���Η���5d�'��9A-��J��>{�_l+�`��A���[�'��յ�ϛ#w:݅�%��X�}�&�PSt�Q�"�-��\縵�/����$Ɨh�Xb�*�y��BS����;W�ջ_mc�����vt?2}1�;qS�d�d~u:2k5�2�R�~�z+|HE!)�Ǟl��7`��0�<�,�2*���Hl-��x�^����'_TV�gZA�'j� ^�2Ϊ��N7t�����?w�� �x1��f��Iz�C-Ȗ��K�^q�;���-W�DvT�7��8�Z�������� hK�(P:��Q- �8�n�Z���܃e貾�<�1�YT<�,�����"�6{/ �?�͟��|1�:�#g��W�>$����d��J��d�B��=��jf[��%rE^��il:��B���x���Sּ�1հ��,�=��*�7 fcG��#q� �eh?��2�7�����,�!7x��6�n�LC�4x��},Geǝ�tC.��vS �F�43��zz\��;QYC,6����~;RYS/6���|2���5���v��T��i����������mlv��������&� �nRh^ejR�LG�f���? �ۉҬܦƩ��|��Ȱ����>3����!v��i�ʯ�>�v��オ�X3e���_1z�Kȗ\<������!�8���V��]��?b�k41�Re��T�q��mz��TiOʦ�Z��Xq���L������q"+���2ۨ��8}�&N7XU7Ap�d�X��~�׿��&4e�o�F��� �H����O���č�c�� 懴�6���͉��+)��v;j��ݷ�� �UV�� i��� j���Y9GdÒJ1��詞�����V?h��l����l�cGs�ځ�������y�Ac�����\V3�? �� ܙg�>qH�S,�E�W�[�㺨�uch�⍸�O�}���a��>�q�6�n6����N6�q������N ! 1AQaq�0@����"2BRb�#Pr���3C`��Scst���$4D���%Td�� ?���N����a��3��m���C���w��������xA�m�q�m���m������$����4n淿t'��C"w��zU=D�\R+w�p+Y�T�&�պ@��ƃ��3ޯ?�Aﶂ��aŘ���@-�����Q�=���9D��ռ�ѻ@��M�V��P��܅�G5�f�Y<�u=,EC)�<�Fy'�"�&�չ�X~f��l�KԆV��?�� �W�N����=(� �;���{�r����ٌ�Y���h{�١������jW����P���Tc�����X�K�r��}���w�R��%��?���E��m�� �Y�q|����\lEE4���r���}�lsI�Y������f�$�=�d�yO����p�����yBj8jU�o�/�S��?�U��*������ˍ�0������u�q�m [�?f����a�� )Q�>����6#������� ?����0UQ����,IX���(6ڵ[�DI�MNލ�c&���υ�j\��X�R|,4��� j������T�hA�e��^���d���b<����n�� �즇�=!���3�^�`j�h�ȓr��jẕ�c�,ٞX����-����a�ﶔ���#�$��]w�O��Ӫ�1y%��L�Y<�wg#�ǝ�̗`�x�xa�t�w��»1���o7o5��>�m뭛C���Uƃߜ}�C���y1Xνm�F8�jI���]����H���ۺиE@I�i;r�8ӭ����V�F�Շ| ��&?�3|x�B�MuS�Ge�=Ӕ�#BE5G�����Y!z��_e��q�р/W>|-�Ci߇�t�1ޯќd�R3�u��g�=0 5��[?�#͏��q�cf���H��{ ?u�=?�?ǯ���}Z��z���hmΔ�BFTW�����<�q�(v� ��!��z���iW]*�J�V�z��gX֧A�q�&��/w���u�gYӘa���; �i=����g:��?2�dž6�ى�k�4�>�Pxs����}������G�9��3 ���)gG�R<>r h�$��'nc�h�P��Bj��J�ҧH� -��N1���N��?��~��}-q!=��_2hc�M��l�vY%UE�@|�v����M2�.Y[|y�"Eï��K�ZF,�ɯ?,q�?v�M 80jx�"�;�9vk�����+ ֧�� �ȺU��?�%�vcV��mA�6��Qg^M����A}�3�nl� QRN�l8�kkn�'�����(��M�7m9و�q���%ޟ���*h$Zk"��$�9��: �?U8�Sl��,,|ɒ��xH(ѷ����Gn�/Q�4�P��G�%��Ա8�N��!� �&�7�;���eKM7�4��9R/%����l�c>�x;������>��C�:�����t��h?aKX�bhe�ᜋ^�$�Iհ �hr7%F$�E��Fd���t��5���+�(M6�t����Ü�UU|zW�=a�Ts�Tg������dqP�Q����b'�m���1{|Y����X�N��b �P~��F^F:����k6�"�j!�� �I�r�`��1&�-$�Bevk:y���#yw��I0��x��=D�4��tU���P�ZH��ڠ底taP��6����b>�xa����Q�#� WeF��ŮNj�p�J* mQ�N����*I�-*�ȩ�F�g�3 �5��V�ʊ�ɮ�a��5F���O@{���NX��?����H�]3��1�Ri_u��������ѕ�� ����0��� F��~��:60�p�͈�S��qX#a�5>���`�o&+�<2�D����: �������ڝ�$�nP���*)�N�|y�Ej�F�5ټ�e���ihy�Z �>���k�bH�a�v��h�-#���!�Po=@k̆IEN��@��}Ll?j�O������߭�ʞ���Q|A07x���wt!xf���I2?Z��<ץ�T���cU�j��]��陎Ltl �}5�ϓ��$�,��O�mˊ�;�@O��jE��j(�ا,��LX���LO���Ц�90�O �.����a��nA���7������j4 ��W��_ٓ���zW�jcB������y՗+EM�)d���N�g6�y1_x��p�$Lv:��9�"z��p���ʙ$��^��JԼ*�ϭ����o���=x�Lj�6�J��u82�A�H�3$�ٕ@�=Vv�]�'�qEz�;I˼��)��=��ɯ���x �/�W(V���p�����$ �m�������u�����񶤑Oqˎ�T����r��㠚x�sr�GC��byp�G��1ߠ�w e�8�$⿄����/�M{*}��W�]˷.�CK\�ުx���/$�WPw���r� |i���&�}�{�X� �>��$-��l���?-z���g����lΆ���(F���h�vS*���b���߲ڡn,|)mrH[���a�3�ר�[1��3o_�U�3�TC�$��(�=�)0�kgP���� ��u�^=��4 �WYCҸ:��vQ�ר�X�à��tk�m,�t*��^�,�}D*� �"(�I��9R����>`�`��[~Q]�#af��i6l��8���6�:,s�s�N6�j"�A4���IuQ��6E,�GnH��zS�HO�uk�5$�I�4��ؤ�Q9�@��C����wp�BGv[]�u�Ov���0I4���\��y�����Q�Ѹ��~>Z��8�T��a��q�ޣ;z��a���/��S��I:�ܫ_�|������>=Z����8:�S��U�I�J��"IY���8%b8���H��:�QO�6�;7�I�S��J��ҌAά3��>c���E+&jf$eC+�z�;��V����� �r���ʺ������my�e���aQ�f&��6�ND��.:��NT�vm�<- u���ǝ\MvZY�N�NT��-A�>jr!S��n�O 1�3�Ns�%�3D@���`������ܟ 1�^c<���� �a�ɽ�̲�Xë#�w�|y�cW�=�9I*H8�p�^(4���՗�k��arOcW�tO�\�ƍR��8����'�K���I�Q�����?5�>[�}��yU�ײ -h��=��% q�ThG�2�)���"ו3]�!kB��*p�FDl�A���,�eEi�H�f�Ps�����5�H:�Փ~�H�0Dت�D�I����h�F3�������c��2���E��9�H��5�zԑ�ʚ�i�X�=:m�xg�hd(�v����׊�9iS��O��d@0ڽ���:�p�5�h-��t�&���X�q�ӕ,��ie�|���7A�2���O%P��E��htj��Y1��w�Ѓ!����  ���� ࢽ��My�7�\�a�@�ţ�J �4�Ȼ�F�@o�̒?4�wx��)��]�P��~�����u�����5�����7X ��9��^ܩ�U;Iꭆ 5 �������eK2�7(�{|��Y׎ �V��\"���Z�1� Z�����}��(�Ǝ"�1S���_�vE30>���p;� ΝD��%x�W�?W?v����o�^V�i�d��r[��/&>�~`�9Wh��y�;���R��� ;;ɮT��?����r$�g1�K����A��C��c��K��l:�'��3 c�ﳯ*"t8�~l��)���m��+U,z��`(�>yJ�?����h>��]��v��ЍG*�{`��;y]��I�T� ;c��NU�fo¾h���/$���|NS���1�S�"�H��V���T���4��uhǜ�]�v;���5�͠x��'C\�SBpl���h}�N����� A�Bx���%��ޭ�l��/����T��w�ʽ]D�=����K���ž�r㻠l4�S�O?=�k �M:� ��c�C�a�#ha���)�ѐxc�s���gP�iG��{+���x���Q���I= �� z��ԫ+ �8"�k�ñ�j=|����c ��y��CF��/��*9ж�h{ �?4�o� ��k�m�Q�N�x��;�Y��4膚�a�w?�6�>e]�����Q�r�:����g�,i"�����ԩA�*M�<�G��b�if��l^M��5� �Ҩ�{����6J��ZJ�����P�*�����Y���ݛu�_4�9�I8�7���������,^ToR���m4�H��?�N�S�ѕw��/S��甍�@�9H�S�T��t�ƻ���ʒU��*{Xs�@����f�����֒Li�K{H�w^���������Ϥm�tq���s� ���ք��f:��o~s��g�r��ט� �S�ѱC�e]�x���a��) ���(b-$(�j>�7q�B?ӕ�F��hV25r[7 Y� }L�R��}����*sg+��x�r�2�U=�*'WS��ZDW]�WǞ�<��叓���{�$�9Ou4��y�90-�1�'*D`�c�^o?(�9��u���ݐ��'PI&� f�Jݮ�������:wS����jfP1F:X �H�9dԯ���˝[�_54 �}*;@�ܨ�� ð�yn�T���?�ןd�#���4rG�ͨ��H�1�|-#���Mr�S3��G�3�����)�.᧏3v�z֑��r����$G"�`j �1t��x0<Ɔ�Wh6�y�6��,œ�Ga��gA����y��b��)��h�D��ß�_�m��ü �gG;��e�v��ݝ�nQ� ��C����-�*��o���y�a��M��I�>�<���]obD��"�:���G�A��-\%LT�8���c�)��+y76���o�Q�#*{�(F�⽕�y����=���rW�\p���۩�c���A���^e6��K������ʐ�cVf5$�'->���ՉN"���F�"�UQ@�f��Gb~��#�&�M=��8�ט�JNu9��D��[̤�s�o�~������ G��9T�tW^g5y$b��Y'��س�Ǵ�=��U-2 #�MC�t(�i� �lj�@Q 5�̣i�*�O����s�x�K�f��}\��M{E�V�{�υ��Ƈ�����);�H����I��fe�Lȣr�2��>��W�I�Ȃ6������i��k�� �5�YOxȺ����>��Y�f5'��|��H+��98pj�n�.O�y�������jY��~��i�w'������l�;�s�2��Y��:'lg�ꥴ)o#'Sa�a�K��Z� �m��}�`169�n���"���x��I ��*+� }F<��cГ���F�P�������ֹ*�PqX�x۩��,� ��N�� �4<-����%����:��7����W���u�`����� $�?�I��&����o��o��`v�>��P��"��l���4��5'�Z�gE���8���?��[�X�7(��.Q�-��*���ތL@̲����v��.5���[��=�t\+�CNܛ��,g�SQnH����}*F�G16���&:�t��4ُ"A��̣��$�b �|����#rs��a�����T�� ]�<�j��BS�('$�ɻ� �wP;�/�n��?�ݜ��x�F��yUn�~mL*-�������Xf�wd^�a�}��f�,=t�׵i�.2/wpN�Ep8�OР���•��R�FJ� 55TZ��T �ɭ�<��]��/�0�r�@�f��V��V����Nz�G��^���7hZi����k��3�,kN�e|�vg�1{9]_i��X5y7� 8e]�U����'�-2,���e"����]ot�I��Y_��n�(JҼ��1�O ]bXc���Nu�No��pS���Q_���_�?i�~�x h5d'�(qw52] ��'ޤ�q��o1�R!���`ywy�A4u���h<קy���\[~�4�\ X�Wt/� 6�����n�F�a8��f���z �3$�t(���q��q�x��^�XWeN'p<-v�!�{�(>ӽDP7��ո0�y)�e$ٕv�Ih'Q�EA�m*�H��RI��=:��� ���4牢) �%_iN�ݧ�l]� �Nt���G��H�L��� ɱ�g<���1V�,�J~�ٹ�"K��Q�� 9�HS�9�?@��k����r�;we݁�]I�!{ �@�G�[�"��`���J:�n]�{�cA�E����V��ʆ���#��U9�6����j�#Y�m\��q�e4h�B�7��C�������d<�?J����1g:ٳ���=Y���D�p�ц� ׈ǔ��1�]26؜oS�'��9�V�FVu�P�h�9�xc�oq�X��p�o�5��Ա5$�9W�V(�[Ak�aY錎qf;�'�[�|���b�6�Ck��)��#a#a˙��8���=äh�4��2��C��4tm^ �n'c���]GQ$[Wҿ��i���vN�{Fu ��1�gx��1┷���N�m��{j-,��x�� Ūm�ЧS�[�s���Gna���䑴�� x�p 8<������97�Q���ϴ�v�aϚG��Rt�Һ׈�f^\r��WH�JU�7Z���y)�vg=����n��4�_)y��D'y�6�]�c�5̪�\� �PF�k����&�c;��cq�$~T�7j ���nç]�<�g ":�to�t}�159�<�/�8������m�b�K#g'I'.W�����6��I/��>v��\�MN��g���m�A�yQL�4u�Lj�j9��#44�t��l^�}L����n��R��!��t��±]��r��h6ٍ>�yҏ�N��fU�� ���� Fm@�8}�/u��jb9������he:A�y�ծw��GpΧh�5����l}�3p468��)U��d��c����;Us/�֔�YX�1�O2��uq�s��`hwg�r~�{ R��mhN��؎*q 42�*th��>�#���E����#��Hv�O����q�}�����6�e��\�,Wk�#���X��b>��p}�դ��3���T5��†��6��[��@�P�y*n��|'f�֧>�lư΂�̺����SU�'*�q�p�_S�����M�� '��c�6�����m�� ySʨ;M��r���Ƌ�m�Kxo,���Gm�P��A�G�:��i��w�9�}M(�^�V��$ǒ�ѽ�9���|���� �a����J�SQ�a���r�B;����}���ٻ֢�2�%U���c�#�g���N�a�ݕ�'�v�[�OY'��3L�3�;,p�]@�S��{ls��X�'���c�jw�k'a�.��}�}&�� �dP�*�bK=ɍ!����;3n�gΊU�ߴmt�'*{,=SzfD� A��ko~�G�aoq�_mi}#�m�������P�Xhύ����mxǍ�΂���巿zf��Q���c���|kc�����?���W��Y�$���_Lv����l߶��c���`?����l�j�ݲˏ!V��6����U�Ђ(A���4y)H���p�Z_�x��>���e��R��$�/�`^'3qˏ�-&Q�=?��CFVR �D�fV�9��{�8g�������n�h�(P"��6�[�D���< E�����~0<@�`�G�6����Hг�cc�� �c�K.5��D��d�B���`?�XQ��2��ٿyqo&+�1^� DW�0�ꊩ���G�#��Q�nL3��c���������/��x ��1�1[y�x�პCW��C�c�UĨ80�m�e�4.{�m��u���I=��f�����0QRls9���f���������9���~f�����Ǩ��a�"@�8���ȁ�Q����#c�ic������G��$���G���r/$W�(��W���V�"��m�7�[m�A�m����bo��D� j����۳� l���^�k�h׽����� ��#� iXn�v��eT�k�a�^Y�4�BN��ĕ��0 !01@Q"2AaPq3BR������?���@4�Q�����T3,���㺠�W�[=JK�Ϟ���2�r^7��vc�:�9 �E�ߴ�w�S#d���Ix��u��:��Hp��9E!�� V 2;73|F��9Y���*ʬ�F��D����u&���y؟��^EA��A��(ɩ���^��GV:ݜDy�`��Jr29ܾ�㝉��[���E;Fzx��YG��U�e�Y�C���� ����v-tx����I�sם�Ę�q��Eb�+P\ :>�i�C'�;�����k|z�رn�y]�#ǿb��Q��������w�����(�r|ӹs��[�D��2v-%��@;�8<a���[\o[ϧw��I!��*0�krs)�[�J9^��ʜ��p1)� "��/_>��o��<1����A�E�y^�C��`�x1'ܣn�p��s`l���fQ��):�l����b>�Me�jH^?�kl3(�z:���1ŠK&?Q�~�{�ٺ�h�y���/�[��V�|6��}�KbX����mn[-��7�5q�94�������dm���c^���h� X��5��<�eޘ>G���-�}�دB�ޟ� ��|�rt�M��V+�]�c?�-#ڛ��^ǂ}���Lkr���O��u�>�-D�ry� D?:ޞ�U��ǜ�7�V��?瓮�"�#���r��չģVR;�n���/_� ؉v�ݶe5d�b9��/O��009�G���5n�W����JpA�*�r9�>�1��.[t���s�F���nQ� V 77R�]�ɫ8����_0<՜�IF�u(v��4��F�k�3��E)��N:��yڮe��P�`�1}�$WS��J�SQ�N�j�ٺ��޵�#l���ј(�5=��5�lǏmoW�v-�1����v,W�mn��߀$x�<����v�j(����c]��@#��1������Ǔ���o'��u+����;G�#�޸��v-lη��/(`i⣍Pm^���ԯ̾9Z��F��������n��1��� ��]�[��)�'������:�֪�W��FC����� �B9،!?���]��V��A�Վ�M��b�w��G F>_DȬ0¤�#�QR�[V��kz���m�w�"��9ZG�7'[��=�Q����j8R?�zf�\a�=��O�U����*oB�A�|G���2�54 �p��.w7� �� ��&������ξxGHp� B%��$g�����t�Џ򤵍z���HN�u�Я�-�'4��0��;_��3 !01"@AQa2Pq#3BR������?��ʩca��en��^��8���<�u#��m*08r��y�N"�<�Ѳ0��@\�p��� �����Kv�D��J8�Fҽ� �f�Y��-m�ybX�NP����}�!*8t(�OqѢ��Q�wW�K��ZD��Δ^e��!� ��B�K��p~�����e*l}z#9ң�k���q#�Ft�o��S�R����-�w�!�S���Ӥß|M�l޶V��!eˈ�8Y���c�ЮM2��tk���� ������J�fS����Ö*i/2�����n]�k�\���|4yX�8��U�P.���Ы[���l��@"�t�<������5�lF���vU�����W��W��;�b�cД^6[#7@vU�xgZv��F�6��Q,K�v��� �+Ъ��n��Ǣ��Ft���8��0��c�@�!�Zq s�v�t�;#](B��-�nῃ~���3g������5�J�%���O������n�kB�ĺ�.r��+���#�N$?�q�/�s�6��p��a����a��J/��M�8��6�ܰ"�*������ɗud"\w���aT(����[��F��U՛����RT�b���n�*��6���O��SJ�.�ij<�v�MT��R\c��5l�sZB>F��<7�;EA��{��E���Ö��1U/�#��d1�a�n.1ě����0�ʾR�h��|�R��Ao�3�m3 ��%�� ���28Q� ��y��φ���H�To�7�lW>����#i`�q���c����a��� �m,B�-j����݋�'mR1Ήt�>��V��p���s�0IbI�C.���1R�ea�����]H�6����������4B>��o��](��$B���m�����a�!=��?�B� K�Ǿ+�Ծ"�n���K��*��+��[T#�{E�J�S����Q�����s�5�:�U�\wĐ�f�3����܆&�)����I���Ԇw��E T�lrTf6Q|R�h:��[K�� �z��c֧�G�C��%\��_�a�84��HcO�bi��ؖV��7H �)*ģK~Xhչ0��4?�0��� �E<���}3���#���u�?�� ��|g�S�6ꊤ�|�I#Hڛ� �ա��w�X��9��7���Ŀ%�SL��y6č��|�F�a 8���b��$�sק�h���b9RAu7�˨p�Č�_\*w��묦��F ����4D~�f����|(�"m���NK��i�S�>�$d7SlA��/�²����SL��|6N�}���S�˯���g��]6��; �#�.��<���q'Q�1|KQ$�����񛩶"�$r�b:���N8�w@��8$�� �AjfG|~�9F ���Y��ʺ��Bwؒ������M:I岎�G��`s�YV5����6��A �b:�W���G�q%l�����F��H���7�������Fsv7��k�� 403WebShell
403Webshell
Server IP : 64.57.112.4  /  Your IP : 216.73.216.57
Web Server : Microsoft-IIS/10.0
System : Windows NT WP 10.0 build 17763 (Windows Server 2016) AMD64
User : voguebusinesssuppliers ( 0)
PHP Version : 7.3.3
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : OFF  |  Perl : OFF  |  Python : OFF  |  Sudo : OFF  |  Pkexec : OFF
Directory :  /WEBS/sic/wp-content/plugins/bb-ultimate-addon/assets/js/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /WEBS/sic/wp-content/plugins/bb-ultimate-addon/assets/js//particles.js
( function( $ ) {
    /*!
     * Author : Matteo Bruni - https://www.matteobruni.it
     * MIT license: https://opensource.org/licenses/MIT
     * Demo / Generator : https://particles.matteobruni.it/
     * GitHub : https://www.github.com/matteobruni/tsparticles
     * How to use? : Check the GitHub README
     * v1.18.11
     */
    (function webpackUniversalModuleDefinition(root, factory) {
      if(typeof exports === 'object' && typeof module === 'object')
        module.exports = factory();
      else if(typeof define === 'function' && define.amd)
        define([], factory);
      else {
        var a = factory();
        for(var i in a) (typeof exports === 'object' ? exports : root)[i] = a[i];
      }
    })(this, function() {
    return /******/ (() => { // webpackBootstrap
    /******/  "use strict";
    /******/  var __webpack_modules__ = ({
    
    /***/ 714:
    /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
    
    // ESM COMPAT FLAG
    __webpack_require__.r(__webpack_exports__);
    
    // EXPORTS
    __webpack_require__.d(__webpack_exports__, {
      "AbsorberClickMode": () => /* reexport */ AbsorberClickMode,
      "AnimationStatus": () => /* reexport */ AnimationStatus,
      "CanvasUtils": () => /* reexport */ CanvasUtils,
      "ClickMode": () => /* reexport */ ClickMode,
      "CollisionMode": () => /* reexport */ CollisionMode,
      "ColorUtils": () => /* reexport */ ColorUtils,
      "Constants": () => /* reexport */ Constants,
      "Container": () => /* reexport */ Container,
      "DestroyType": () => /* reexport */ DestroyType,
      "DivMode": () => /* reexport */ DivMode,
      "DivType": () => /* reexport */ DivType,
      "EmitterClickMode": () => /* reexport */ EmitterClickMode,
      "HoverMode": () => /* reexport */ HoverMode,
      "InlineArrangement": () => /* reexport */ InlineArrangement,
      "InteractivityDetect": () => /* reexport */ InteractivityDetect,
      "MoveDirection": () => /* reexport */ MoveDirection,
      "MoveType": () => /* reexport */ MoveType,
      "OutMode": () => /* reexport */ OutMode,
      "ProcessBubbleType": () => /* reexport */ ProcessBubbleType,
      "RotateDirection": () => /* reexport */ RotateDirection,
      "ShapeType": () => /* reexport */ ShapeType,
      "SizeMode": () => /* reexport */ SizeMode,
      "StartValueType": () => /* reexport */ StartValueType,
      "ThemeMode": () => /* reexport */ ThemeMode,
      "Type": () => /* reexport */ Type,
      "Utils": () => /* reexport */ Utils,
      "pJSDom": () => /* binding */ pJSDom,
      "particlesJS": () => /* binding */ particlesJS,
      "tsParticles": () => /* binding */ tsParticles
    });
    
    // CONCATENATED MODULE: ./dist/browser/pjs.js
    const initPjs = main => {
      const particlesJS = (tagId, options) => {
        return main.load(tagId, options);
      };
    
      particlesJS.load = (tagId, pathConfigJson, callback) => {
        main.loadJSON(tagId, pathConfigJson).then(container => {
          if (container) {
            callback(container);
          }
        });
      };
    
      particlesJS.setOnClickHandler = callback => {
        main.setOnClickHandler(callback);
      };
    
      const pJSDom = main.dom();
      return {
        particlesJS,
        pJSDom
      };
    };
    
    
    // CONCATENATED MODULE: ./dist/browser/ShapeDrawers/SquareDrawer.js
    class SquareDrawer {
      getSidesCount() {
        return 4;
      }
    
      draw(context, particle, radius) {
        context.rect(-radius, -radius, radius * 2, radius * 2);
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Enums/Directions/OutModeDirection.js
    var OutModeDirection;
    
    (function (OutModeDirection) {
      OutModeDirection["bottom"] = "bottom";
      OutModeDirection["left"] = "left";
      OutModeDirection["right"] = "right";
      OutModeDirection["top"] = "top";
    })(OutModeDirection || (OutModeDirection = {}));
    // CONCATENATED MODULE: ./dist/browser/Enums/Directions/MoveDirection.js
    var MoveDirection;
    
    (function (MoveDirection) {
      MoveDirection["bottom"] = "bottom";
      MoveDirection["bottomLeft"] = "bottom-left";
      MoveDirection["bottomRight"] = "bottom-right";
      MoveDirection["left"] = "left";
      MoveDirection["none"] = "none";
      MoveDirection["right"] = "right";
      MoveDirection["top"] = "top";
      MoveDirection["topLeft"] = "top-left";
      MoveDirection["topRight"] = "top-right";
    })(MoveDirection || (MoveDirection = {}));
    // CONCATENATED MODULE: ./dist/browser/Enums/Directions/RotateDirection.js
    var RotateDirection;
    
    (function (RotateDirection) {
      RotateDirection["clockwise"] = "clockwise";
      RotateDirection["counterClockwise"] = "counter-clockwise";
      RotateDirection["random"] = "random";
    })(RotateDirection || (RotateDirection = {}));
    // CONCATENATED MODULE: ./dist/browser/Enums/Directions/index.js
    
    
    // CONCATENATED MODULE: ./dist/browser/Utils/NumberUtils.js
    
    class NumberUtils {
      static clamp(num, min, max) {
        return Math.min(Math.max(num, min), max);
      }
    
      static mix(comp1, comp2, weight1, weight2) {
        return Math.floor((comp1 * weight1 + comp2 * weight2) / (weight1 + weight2));
      }
    
      static randomInRange(r1, r2) {
        const max = Math.max(r1, r2),
              min = Math.min(r1, r2);
        return Math.random() * (max - min) + min;
      }
    
      static getValue(options) {
        const random = options.random;
        const {
          enable,
          minimumValue
        } = typeof random === "boolean" ? {
          enable: random,
          minimumValue: 0
        } : random;
        return enable ? NumberUtils.randomInRange(minimumValue, options.value) : options.value;
      }
    
      static getDistances(pointA, pointB) {
        const dx = pointA.x - pointB.x;
        const dy = pointA.y - pointB.y;
        return {
          dx: dx,
          dy: dy,
          distance: Math.sqrt(dx * dx + dy * dy)
        };
      }
    
      static getDistance(pointA, pointB) {
        return NumberUtils.getDistances(pointA, pointB).distance;
      }
    
      static getParticleBaseVelocity(particle) {
        let velocityBase;
    
        switch (particle.direction) {
          case MoveDirection.top:
            velocityBase = {
              x: 0,
              y: -1
            };
            break;
    
          case MoveDirection.topRight:
            velocityBase = {
              x: 0.5,
              y: -0.5
            };
            break;
    
          case MoveDirection.right:
            velocityBase = {
              x: 1,
              y: -0
            };
            break;
    
          case MoveDirection.bottomRight:
            velocityBase = {
              x: 0.5,
              y: 0.5
            };
            break;
    
          case MoveDirection.bottom:
            velocityBase = {
              x: 0,
              y: 1
            };
            break;
    
          case MoveDirection.bottomLeft:
            velocityBase = {
              x: -0.5,
              y: 1
            };
            break;
    
          case MoveDirection.left:
            velocityBase = {
              x: -1,
              y: 0
            };
            break;
    
          case MoveDirection.topLeft:
            velocityBase = {
              x: -0.5,
              y: -0.5
            };
            break;
    
          default:
            velocityBase = {
              x: 0,
              y: 0
            };
            break;
        }
    
        return velocityBase;
      }
    
      static rotateVelocity(velocity, angle) {
        return {
          horizontal: velocity.horizontal * Math.cos(angle) - velocity.vertical * Math.sin(angle),
          vertical: velocity.horizontal * Math.sin(angle) + velocity.vertical * Math.cos(angle)
        };
      }
    
      static collisionVelocity(v1, v2, m1, m2) {
        return {
          horizontal: v1.horizontal * (m1 - m2) / (m1 + m2) + v2.horizontal * 2 * m2 / (m1 + m2),
          vertical: v1.vertical
        };
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Utils/Utils.js
    var __awaiter = undefined && undefined.__awaiter || function (thisArg, _arguments, P, generator) {
      function adopt(value) {
        return value instanceof P ? value : new P(function (resolve) {
          resolve(value);
        });
      }
    
      return new (P || (P = Promise))(function (resolve, reject) {
        function fulfilled(value) {
          try {
            step(generator.next(value));
          } catch (e) {
            reject(e);
          }
        }
    
        function rejected(value) {
          try {
            step(generator["throw"](value));
          } catch (e) {
            reject(e);
          }
        }
    
        function step(result) {
          result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);
        }
    
        step((generator = generator.apply(thisArg, _arguments || [])).next());
      });
    };
    
    
    function rectSideBounce(pSide, pOtherSide, rectSide, rectOtherSide, velocity, factor) {
      const res = {
        bounced: false
      };
    
      if (pOtherSide.min >= rectOtherSide.min && pOtherSide.min <= rectOtherSide.max && pOtherSide.max >= rectOtherSide.min && pOtherSide.max <= rectOtherSide.max) {
        if (pSide.max >= rectSide.min && pSide.max <= (rectSide.max + rectSide.min) / 2 && velocity > 0 || pSide.min <= rectSide.max && pSide.min > (rectSide.max + rectSide.min) / 2 && velocity < 0) {
          res.velocity = velocity * -factor;
          res.bounced = true;
        }
      }
    
      return res;
    }
    
    function checkSelector(element, selectors) {
      if (selectors instanceof Array) {
        for (const selector of selectors) {
          if (element.matches(selector)) {
            return true;
          }
        }
    
        return false;
      } else {
        return element.matches(selectors);
      }
    }
    
    class Utils {
      static isSsr() {
        return typeof window === "undefined" || !window;
      }
    
      static get animate() {
        return Utils.isSsr() ? callback => setTimeout(callback) : callback => (window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || window.oRequestAnimationFrame || window.msRequestAnimationFrame || window.setTimeout)(callback);
      }
    
      static get cancelAnimation() {
        return Utils.isSsr() ? handle => clearTimeout(handle) : handle => (window.cancelAnimationFrame || window.webkitCancelRequestAnimationFrame || window.mozCancelRequestAnimationFrame || window.oCancelRequestAnimationFrame || window.msCancelRequestAnimationFrame || window.clearTimeout)(handle);
      }
    
      static isInArray(value, array) {
        return value === array || array instanceof Array && array.indexOf(value) > -1;
      }
    
      static loadFont(character) {
        return __awaiter(this, void 0, void 0, function* () {
          try {
            yield document.fonts.load(`${character.weight} 36px '${character.font}'`);
          } catch (_a) {}
        });
      }
    
      static arrayRandomIndex(array) {
        return Math.floor(Math.random() * array.length);
      }
    
      static itemFromArray(array, index, useIndex = true) {
        const fixedIndex = index !== undefined && useIndex ? index % array.length : Utils.arrayRandomIndex(array);
        return array[fixedIndex];
      }
    
      static isPointInside(point, size, radius, direction) {
        return Utils.areBoundsInside(Utils.calculateBounds(point, radius !== null && radius !== void 0 ? radius : 0), size, direction);
      }
    
      static areBoundsInside(bounds, size, direction) {
        let inside = true;
    
        if (!direction || direction === OutModeDirection.bottom) {
          inside = bounds.top < size.height;
        }
    
        if (inside && (!direction || direction === OutModeDirection.left)) {
          inside = bounds.right > 0;
        }
    
        if (inside && (!direction || direction === OutModeDirection.right)) {
          inside = bounds.left < size.width;
        }
    
        if (inside && (!direction || direction === OutModeDirection.top)) {
          inside = bounds.bottom > 0;
        }
    
        return inside;
      }
    
      static calculateBounds(point, radius) {
        return {
          bottom: point.y + radius,
          left: point.x - radius,
          right: point.x + radius,
          top: point.y - radius
        };
      }
    
      static loadImage(source) {
        return new Promise((resolve, reject) => {
          if (!source) {
            reject("Error tsParticles - No image.src");
            return;
          }
    
          const image = {
            source: source,
            type: source.substr(source.length - 3)
          };
          const img = new Image();
          img.addEventListener("load", () => {
            image.element = img;
            resolve(image);
          });
          img.addEventListener("error", () => {
            reject(`Error tsParticles - loading image: ${source}`);
          });
          img.src = source;
        });
      }
    
      static downloadSvgImage(source) {
        return __awaiter(this, void 0, void 0, function* () {
          if (!source) {
            throw new Error("Error tsParticles - No image.src");
          }
    
          const image = {
            source: source,
            type: source.substr(source.length - 3)
          };
    
          if (image.type !== "svg") {
            return Utils.loadImage(source);
          }
    
          const response = yield fetch(image.source);
    
          if (!response.ok) {
            throw new Error("Error tsParticles - Image not found");
          }
    
          image.svgData = yield response.text();
          return image;
        });
      }
    
      static deepExtend(destination, ...sources) {
        for (const source of sources) {
          if (source === undefined || source === null) {
            continue;
          }
    
          if (typeof source !== "object") {
            destination = source;
            continue;
          }
    
          const sourceIsArray = Array.isArray(source);
    
          if (sourceIsArray && (typeof destination !== "object" || !destination || !Array.isArray(destination))) {
            destination = [];
          } else if (!sourceIsArray && (typeof destination !== "object" || !destination || Array.isArray(destination))) {
            destination = {};
          }
    
          for (const key in source) {
            if (key === "__proto__") {
              continue;
            }
    
            const sourceDict = source;
            const value = sourceDict[key];
            const isObject = typeof value === "object";
            const destDict = destination;
            destDict[key] = isObject && Array.isArray(value) ? value.map(v => Utils.deepExtend(destDict[key], v)) : Utils.deepExtend(destDict[key], value);
          }
        }
    
        return destination;
      }
    
      static isDivModeEnabled(mode, divs) {
        return divs instanceof Array ? !!divs.find(t => t.enable && Utils.isInArray(mode, t.mode)) : Utils.isInArray(mode, divs.mode);
      }
    
      static divModeExecute(mode, divs, callback) {
        if (divs instanceof Array) {
          for (const div of divs) {
            const divMode = div.mode;
            const divEnabled = div.enable;
    
            if (divEnabled && Utils.isInArray(mode, divMode)) {
              Utils.singleDivModeExecute(div, callback);
            }
          }
        } else {
          const divMode = divs.mode;
          const divEnabled = divs.enable;
    
          if (divEnabled && Utils.isInArray(mode, divMode)) {
            Utils.singleDivModeExecute(divs, callback);
          }
        }
      }
    
      static singleDivModeExecute(div, callback) {
        const selectors = div.selectors;
    
        if (selectors instanceof Array) {
          for (const selector of selectors) {
            callback(selector, div);
          }
        } else {
          callback(selectors, div);
        }
      }
    
      static divMode(divs, element) {
        if (!element || !divs) {
          return;
        }
    
        if (divs instanceof Array) {
          return divs.find(d => checkSelector(element, d.selectors));
        } else if (checkSelector(element, divs.selectors)) {
          return divs;
        }
      }
    
      static circleBounceDataFromParticle(p) {
        return {
          position: p.getPosition(),
          radius: p.getRadius(),
          velocity: p.velocity,
          factor: {
            horizontal: NumberUtils.getValue(p.particlesOptions.bounce.horizontal),
            vertical: NumberUtils.getValue(p.particlesOptions.bounce.vertical)
          }
        };
      }
    
      static circleBounce(p1, p2) {
        const xVelocityDiff = p1.velocity.horizontal;
        const yVelocityDiff = p1.velocity.vertical;
        const pos1 = p1.position;
        const pos2 = p2.position;
        const xDist = pos2.x - pos1.x;
        const yDist = pos2.y - pos1.y;
    
        if (xVelocityDiff * xDist + yVelocityDiff * yDist >= 0) {
          const angle = -Math.atan2(pos2.y - pos1.y, pos2.x - pos1.x);
          const m1 = p1.radius;
          const m2 = p2.radius;
          const u1 = NumberUtils.rotateVelocity(p1.velocity, angle);
          const u2 = NumberUtils.rotateVelocity(p2.velocity, angle);
          const v1 = NumberUtils.collisionVelocity(u1, u2, m1, m2);
          const v2 = NumberUtils.collisionVelocity(u2, u1, m1, m2);
          const vFinal1 = NumberUtils.rotateVelocity(v1, -angle);
          const vFinal2 = NumberUtils.rotateVelocity(v2, -angle);
          p1.velocity.horizontal = vFinal1.horizontal * p1.factor.horizontal;
          p1.velocity.vertical = vFinal1.vertical * p1.factor.vertical;
          p2.velocity.horizontal = vFinal2.horizontal * p2.factor.horizontal;
          p2.velocity.vertical = vFinal2.vertical * p2.factor.vertical;
        }
      }
    
      static rectBounce(particle, divBounds) {
        const pPos = particle.getPosition();
        const size = particle.getRadius();
        const bounds = Utils.calculateBounds(pPos, size);
        const resH = rectSideBounce({
          min: bounds.left,
          max: bounds.right
        }, {
          min: bounds.top,
          max: bounds.bottom
        }, {
          min: divBounds.left,
          max: divBounds.right
        }, {
          min: divBounds.top,
          max: divBounds.bottom
        }, particle.velocity.horizontal, NumberUtils.getValue(particle.particlesOptions.bounce.horizontal));
    
        if (resH.bounced) {
          if (resH.velocity !== undefined) {
            particle.velocity.horizontal = resH.velocity;
          }
    
          if (resH.position !== undefined) {
            particle.position.x = resH.position;
          }
        }
    
        const resV = rectSideBounce({
          min: bounds.top,
          max: bounds.bottom
        }, {
          min: bounds.left,
          max: bounds.right
        }, {
          min: divBounds.top,
          max: divBounds.bottom
        }, {
          min: divBounds.left,
          max: divBounds.right
        }, particle.velocity.vertical, NumberUtils.getValue(particle.particlesOptions.bounce.vertical));
    
        if (resV.bounced) {
          if (resV.velocity !== undefined) {
            particle.velocity.vertical = resV.velocity;
          }
    
          if (resV.position !== undefined) {
            particle.position.y = resV.position;
          }
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Utils/Constants.js
    class Constants {}
    Constants.canvasClass = "tsparticles-canvas-el";
    Constants.randomColorValue = "random";
    Constants.midColorValue = "mid";
    Constants.touchEndEvent = "touchend";
    Constants.mouseDownEvent = "mousedown";
    Constants.mouseUpEvent = "mouseup";
    Constants.mouseMoveEvent = "mousemove";
    Constants.touchStartEvent = "touchstart";
    Constants.touchMoveEvent = "touchmove";
    Constants.mouseLeaveEvent = "mouseleave";
    Constants.mouseOutEvent = "mouseout";
    Constants.touchCancelEvent = "touchcancel";
    Constants.resizeEvent = "resize";
    Constants.visibilityChangeEvent = "visibilitychange";
    Constants.noPolygonDataLoaded = "No polygon data loaded.";
    Constants.noPolygonFound = "No polygon found, you need to specify SVG url in config.";
    // CONCATENATED MODULE: ./dist/browser/Utils/ColorUtils.js
    
    function hue2rgb(p, q, t) {
      let tCalc = t;
    
      if (tCalc < 0) {
        tCalc += 1;
      }
    
      if (tCalc > 1) {
        tCalc -= 1;
      }
    
      if (tCalc < 1 / 6) {
        return p + (q - p) * 6 * tCalc;
      }
    
      if (tCalc < 1 / 2) {
        return q;
      }
    
      if (tCalc < 2 / 3) {
        return p + (q - p) * (2 / 3 - tCalc) * 6;
      }
    
      return p;
    }
    
    function stringToRgba(input) {
      if (input.startsWith("rgb")) {
        const regex = /rgba?\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*(,\s*([\d.]+)\s*)?\)/i;
        const result = regex.exec(input);
        return result ? {
          a: result.length > 4 ? parseFloat(result[5]) : 1,
          b: parseInt(result[3], 10),
          g: parseInt(result[2], 10),
          r: parseInt(result[1], 10)
        } : undefined;
      } else if (input.startsWith("hsl")) {
        const regex = /hsla?\(\s*(\d+)\s*,\s*(\d+)%\s*,\s*(\d+)%\s*(,\s*([\d.]+)\s*)?\)/i;
        const result = regex.exec(input);
        return result ? ColorUtils.hslaToRgba({
          a: result.length > 4 ? parseFloat(result[5]) : 1,
          h: parseInt(result[1], 10),
          l: parseInt(result[3], 10),
          s: parseInt(result[2], 10)
        }) : undefined;
      } else if (input.startsWith("hsv")) {
        const regex = /hsva?\(\s*(\d+)°\s*,\s*(\d+)%\s*,\s*(\d+)%\s*(,\s*([\d.]+)\s*)?\)/i;
        const result = regex.exec(input);
        return result ? ColorUtils.hsvaToRgba({
          a: result.length > 4 ? parseFloat(result[5]) : 1,
          h: parseInt(result[1], 10),
          s: parseInt(result[2], 10),
          v: parseInt(result[3], 10)
        }) : undefined;
      } else {
        const shorthandRegex = /^#?([a-f\d])([a-f\d])([a-f\d])([a-f\d])?$/i;
        const hexFixed = input.replace(shorthandRegex, (_m, r, g, b, a) => {
          return r + r + g + g + b + b + (a !== undefined ? a + a : "");
        });
        const regex = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})?$/i;
        const result = regex.exec(hexFixed);
        return result ? {
          a: result[4] !== undefined ? parseInt(result[4], 16) / 0xff : 1,
          b: parseInt(result[3], 16),
          g: parseInt(result[2], 16),
          r: parseInt(result[1], 16)
        } : undefined;
      }
    }
    
    class ColorUtils {
      static colorToRgb(input, index, useIndex = true) {
        var _a, _b, _c;
    
        if (input === undefined) {
          return;
        }
    
        const color = typeof input === "string" ? {
          value: input
        } : input;
        let res;
    
        if (typeof color.value === "string") {
          if (color.value === Constants.randomColorValue) {
            res = ColorUtils.getRandomRgbColor();
          } else {
            res = ColorUtils.stringToRgb(color.value);
          }
        } else {
          if (color.value instanceof Array) {
            const colorSelected = Utils.itemFromArray(color.value, index, useIndex);
            res = ColorUtils.colorToRgb({
              value: colorSelected
            });
          } else {
            const colorValue = color.value;
            const rgbColor = (_a = colorValue.rgb) !== null && _a !== void 0 ? _a : color.value;
    
            if (rgbColor.r !== undefined) {
              res = rgbColor;
            } else {
              const hslColor = (_b = colorValue.hsl) !== null && _b !== void 0 ? _b : color.value;
    
              if (hslColor.h !== undefined && hslColor.l !== undefined) {
                res = ColorUtils.hslToRgb(hslColor);
              } else {
                const hsvColor = (_c = colorValue.hsv) !== null && _c !== void 0 ? _c : color.value;
    
                if (hsvColor.h !== undefined && hsvColor.v !== undefined) {
                  res = ColorUtils.hsvToRgb(hsvColor);
                }
              }
            }
          }
        }
    
        return res;
      }
    
      static colorToHsl(color, index, useIndex = true) {
        const rgb = ColorUtils.colorToRgb(color, index, useIndex);
        return rgb !== undefined ? ColorUtils.rgbToHsl(rgb) : undefined;
      }
    
      static rgbToHsl(color) {
        const r1 = color.r / 255;
        const g1 = color.g / 255;
        const b1 = color.b / 255;
        const max = Math.max(r1, g1, b1);
        const min = Math.min(r1, g1, b1);
        const res = {
          h: 0,
          l: (max + min) / 2,
          s: 0
        };
    
        if (max != min) {
          res.s = res.l < 0.5 ? (max - min) / (max + min) : (max - min) / (2.0 - max - min);
          res.h = r1 === max ? (g1 - b1) / (max - min) : res.h = g1 === max ? 2.0 + (b1 - r1) / (max - min) : 4.0 + (r1 - g1) / (max - min);
        }
    
        res.l *= 100;
        res.s *= 100;
        res.h *= 60;
    
        if (res.h < 0) {
          res.h += 360;
        }
    
        return res;
      }
    
      static stringToAlpha(input) {
        var _a;
    
        return (_a = stringToRgba(input)) === null || _a === void 0 ? void 0 : _a.a;
      }
    
      static stringToRgb(input) {
        return stringToRgba(input);
      }
    
      static hslToRgb(hsl) {
        const result = {
          b: 0,
          g: 0,
          r: 0
        };
        const hslPercent = {
          h: hsl.h / 360,
          l: hsl.l / 100,
          s: hsl.s / 100
        };
    
        if (hslPercent.s === 0) {
          result.b = hslPercent.l;
          result.g = hslPercent.l;
          result.r = hslPercent.l;
        } else {
          const q = hslPercent.l < 0.5 ? hslPercent.l * (1 + hslPercent.s) : hslPercent.l + hslPercent.s - hslPercent.l * hslPercent.s;
          const p = 2 * hslPercent.l - q;
          result.r = hue2rgb(p, q, hslPercent.h + 1 / 3);
          result.g = hue2rgb(p, q, hslPercent.h);
          result.b = hue2rgb(p, q, hslPercent.h - 1 / 3);
        }
    
        result.r = Math.floor(result.r * 255);
        result.g = Math.floor(result.g * 255);
        result.b = Math.floor(result.b * 255);
        return result;
      }
    
      static hslaToRgba(hsla) {
        const rgbResult = ColorUtils.hslToRgb(hsla);
        return {
          a: hsla.a,
          b: rgbResult.b,
          g: rgbResult.g,
          r: rgbResult.r
        };
      }
    
      static hslToHsv(hsl) {
        const l = hsl.l / 100,
              sl = hsl.s / 100;
        const v = l + sl * Math.min(l, 1 - l),
              sv = !v ? 0 : 2 * (1 - l / v);
        return {
          h: hsl.h,
          s: sv * 100,
          v: v * 100
        };
      }
    
      static hslaToHsva(hsla) {
        const hsvResult = ColorUtils.hslToHsv(hsla);
        return {
          a: hsla.a,
          h: hsvResult.h,
          s: hsvResult.s,
          v: hsvResult.v
        };
      }
    
      static hsvToHsl(hsv) {
        const v = hsv.v / 100,
              sv = hsv.s / 100;
        const l = v * (1 - sv / 2),
              sl = l === 0 || l === 1 ? 0 : (v - l) / Math.min(l, 1 - l);
        return {
          h: hsv.h,
          l: l * 100,
          s: sl * 100
        };
      }
    
      static hsvaToHsla(hsva) {
        const hslResult = ColorUtils.hsvToHsl(hsva);
        return {
          a: hsva.a,
          h: hslResult.h,
          l: hslResult.l,
          s: hslResult.s
        };
      }
    
      static hsvToRgb(hsv) {
        const result = {
          b: 0,
          g: 0,
          r: 0
        };
        const hsvPercent = {
          h: hsv.h / 60,
          s: hsv.s / 100,
          v: hsv.v / 100
        };
        const c = hsvPercent.v * hsvPercent.s,
              x = c * (1 - Math.abs(hsvPercent.h % 2 - 1));
        let tempRgb;
    
        if (hsvPercent.h >= 0 && hsvPercent.h <= 1) {
          tempRgb = {
            r: c,
            g: x,
            b: 0
          };
        } else if (hsvPercent.h > 1 && hsvPercent.h <= 2) {
          tempRgb = {
            r: x,
            g: c,
            b: 0
          };
        } else if (hsvPercent.h > 2 && hsvPercent.h <= 3) {
          tempRgb = {
            r: 0,
            g: c,
            b: x
          };
        } else if (hsvPercent.h > 3 && hsvPercent.h <= 4) {
          tempRgb = {
            r: 0,
            g: x,
            b: c
          };
        } else if (hsvPercent.h > 4 && hsvPercent.h <= 5) {
          tempRgb = {
            r: x,
            g: 0,
            b: c
          };
        } else if (hsvPercent.h > 5 && hsvPercent.h <= 6) {
          tempRgb = {
            r: c,
            g: 0,
            b: x
          };
        }
    
        if (tempRgb) {
          const m = hsvPercent.v - c;
          result.r = Math.floor((tempRgb.r + m) * 255);
          result.g = Math.floor((tempRgb.g + m) * 255);
          result.b = Math.floor((tempRgb.b + m) * 255);
        }
    
        return result;
      }
    
      static hsvaToRgba(hsva) {
        const rgbResult = ColorUtils.hsvToRgb(hsva);
        return {
          a: hsva.a,
          b: rgbResult.b,
          g: rgbResult.g,
          r: rgbResult.r
        };
      }
    
      static rgbToHsv(rgb) {
        const rgbPercent = {
          r: rgb.r / 255,
          g: rgb.g / 255,
          b: rgb.b / 255
        },
              xMax = Math.max(rgbPercent.r, rgbPercent.g, rgbPercent.b),
              xMin = Math.min(rgbPercent.r, rgbPercent.g, rgbPercent.b),
              v = xMax,
              c = xMax - xMin;
        let h = 0;
    
        if (v === rgbPercent.r) {
          h = 60 * ((rgbPercent.g - rgbPercent.b) / c);
        } else if (v === rgbPercent.g) {
          h = 60 * (2 + (rgbPercent.b - rgbPercent.r) / c);
        } else if (v === rgbPercent.b) {
          h = 60 * (4 + (rgbPercent.r - rgbPercent.g) / c);
        }
    
        const s = !v ? 0 : c / v;
        return {
          h,
          s: s * 100,
          v: v * 100
        };
      }
    
      static rgbaToHsva(rgba) {
        const hsvResult = ColorUtils.rgbToHsv(rgba);
        return {
          a: rgba.a,
          h: hsvResult.h,
          s: hsvResult.s,
          v: hsvResult.v
        };
      }
    
      static getRandomRgbColor(min) {
        const fixedMin = min !== null && min !== void 0 ? min : 0;
        return {
          b: Math.floor(NumberUtils.randomInRange(fixedMin, 256)),
          g: Math.floor(NumberUtils.randomInRange(fixedMin, 256)),
          r: Math.floor(NumberUtils.randomInRange(fixedMin, 256))
        };
      }
    
      static getStyleFromRgb(color, opacity) {
        return `rgba(${color.r}, ${color.g}, ${color.b}, ${opacity !== null && opacity !== void 0 ? opacity : 1})`;
      }
    
      static getStyleFromHsl(color, opacity) {
        return `hsla(${color.h}, ${color.s}%, ${color.l}%, ${opacity !== null && opacity !== void 0 ? opacity : 1})`;
      }
    
      static getStyleFromHsv(color, opacity) {
        return ColorUtils.getStyleFromHsl(ColorUtils.hsvToHsl(color), opacity);
      }
    
      static mix(color1, color2, size1, size2) {
        let rgb1 = color1;
        let rgb2 = color2;
    
        if (rgb1.r === undefined) {
          rgb1 = ColorUtils.hslToRgb(color1);
        }
    
        if (rgb2.r === undefined) {
          rgb2 = ColorUtils.hslToRgb(color2);
        }
    
        return {
          b: NumberUtils.mix(rgb1.b, rgb2.b, size1, size2),
          g: NumberUtils.mix(rgb1.g, rgb2.g, size1, size2),
          r: NumberUtils.mix(rgb1.r, rgb2.r, size1, size2)
        };
      }
    
      static replaceColorSvg(image, color, opacity) {
        if (!image.svgData) {
          return "";
        }
    
        const svgXml = image.svgData;
        const rgbHex = /#([0-9A-F]{3,6})/gi;
        return svgXml.replace(rgbHex, () => ColorUtils.getStyleFromHsl(color, opacity));
      }
    
      static getLinkColor(p1, p2, linkColor) {
        var _a, _b;
    
        if (linkColor === Constants.randomColorValue) {
          return ColorUtils.getRandomRgbColor();
        } else if (linkColor === "mid") {
          const sourceColor = (_a = p1.getFillColor()) !== null && _a !== void 0 ? _a : p1.getStrokeColor();
          const destColor = (_b = p2 === null || p2 === void 0 ? void 0 : p2.getFillColor()) !== null && _b !== void 0 ? _b : p2 === null || p2 === void 0 ? void 0 : p2.getStrokeColor();
    
          if (sourceColor && destColor && p2) {
            return ColorUtils.mix(sourceColor, destColor, p1.getRadius(), p2.getRadius());
          } else {
            const hslColor = sourceColor !== null && sourceColor !== void 0 ? sourceColor : destColor;
    
            if (hslColor) {
              return ColorUtils.hslToRgb(hslColor);
            }
          }
        } else {
          return linkColor;
        }
      }
    
      static getLinkRandomColor(optColor, blink, consent) {
        const color = typeof optColor === "string" ? optColor : optColor.value;
    
        if (color === Constants.randomColorValue) {
          if (consent) {
            return ColorUtils.colorToRgb({
              value: color
            });
          } else if (blink) {
            return Constants.randomColorValue;
          } else {
            return Constants.midColorValue;
          }
        } else {
          return ColorUtils.colorToRgb({
            value: color
          });
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Utils/CanvasUtils.js
    
    function drawLine(context, begin, end) {
      context.beginPath();
      context.moveTo(begin.x, begin.y);
      context.lineTo(end.x, end.y);
      context.closePath();
    }
    
    function drawTriangle(context, p1, p2, p3) {
      context.beginPath();
      context.moveTo(p1.x, p1.y);
      context.lineTo(p2.x, p2.y);
      context.lineTo(p3.x, p3.y);
      context.closePath();
    }
    
    class CanvasUtils {
      static paintBase(context, dimension, baseColor) {
        context.save();
        context.fillStyle = baseColor !== null && baseColor !== void 0 ? baseColor : "rgba(0,0,0,0)";
        context.fillRect(0, 0, dimension.width, dimension.height);
        context.restore();
      }
    
      static clear(context, dimension) {
        context.clearRect(0, 0, dimension.width, dimension.height);
      }
    
      static drawLinkLine(context, width, begin, end, maxDistance, canvasSize, warp, backgroundMask, composite, colorLine, opacity, shadow) {
        let drawn = false;
    
        if (NumberUtils.getDistance(begin, end) <= maxDistance) {
          drawLine(context, begin, end);
          drawn = true;
        } else if (warp) {
          let pi1;
          let pi2;
          const endNE = {
            x: end.x - canvasSize.width,
            y: end.y
          };
          const d1 = NumberUtils.getDistances(begin, endNE);
    
          if (d1.distance <= maxDistance) {
            const yi = begin.y - d1.dy / d1.dx * begin.x;
            pi1 = {
              x: 0,
              y: yi
            };
            pi2 = {
              x: canvasSize.width,
              y: yi
            };
          } else {
            const endSW = {
              x: end.x,
              y: end.y - canvasSize.height
            };
            const d2 = NumberUtils.getDistances(begin, endSW);
    
            if (d2.distance <= maxDistance) {
              const yi = begin.y - d2.dy / d2.dx * begin.x;
              const xi = -yi / (d2.dy / d2.dx);
              pi1 = {
                x: xi,
                y: 0
              };
              pi2 = {
                x: xi,
                y: canvasSize.height
              };
            } else {
              const endSE = {
                x: end.x - canvasSize.width,
                y: end.y - canvasSize.height
              };
              const d3 = NumberUtils.getDistances(begin, endSE);
    
              if (d3.distance <= maxDistance) {
                const yi = begin.y - d3.dy / d3.dx * begin.x;
                const xi = -yi / (d3.dy / d3.dx);
                pi1 = {
                  x: xi,
                  y: yi
                };
                pi2 = {
                  x: pi1.x + canvasSize.width,
                  y: pi1.y + canvasSize.height
                };
              }
            }
          }
    
          if (pi1 && pi2) {
            drawLine(context, begin, pi1);
            drawLine(context, end, pi2);
            drawn = true;
          }
        }
    
        if (!drawn) {
          return;
        }
    
        context.lineWidth = width;
    
        if (backgroundMask) {
          context.globalCompositeOperation = composite;
        }
    
        context.strokeStyle = ColorUtils.getStyleFromRgb(colorLine, opacity);
    
        if (shadow.enable) {
          const shadowColor = ColorUtils.colorToRgb(shadow.color);
    
          if (shadowColor) {
            context.shadowBlur = shadow.blur;
            context.shadowColor = ColorUtils.getStyleFromRgb(shadowColor);
          }
        }
    
        context.stroke();
      }
    
      static drawLinkTriangle(context, pos1, pos2, pos3, backgroundMask, composite, colorTriangle, opacityTriangle) {
        drawTriangle(context, pos1, pos2, pos3);
    
        if (backgroundMask) {
          context.globalCompositeOperation = composite;
        }
    
        context.fillStyle = ColorUtils.getStyleFromRgb(colorTriangle, opacityTriangle);
        context.fill();
      }
    
      static drawConnectLine(context, width, lineStyle, begin, end) {
        context.save();
        drawLine(context, begin, end);
        context.lineWidth = width;
        context.strokeStyle = lineStyle;
        context.stroke();
        context.restore();
      }
    
      static gradient(context, p1, p2, opacity) {
        const gradStop = Math.floor(p2.getRadius() / p1.getRadius());
        const color1 = p1.getFillColor();
        const color2 = p2.getFillColor();
    
        if (!color1 || !color2) {
          return;
        }
    
        const sourcePos = p1.getPosition();
        const destPos = p2.getPosition();
        const midRgb = ColorUtils.mix(color1, color2, p1.getRadius(), p2.getRadius());
        const grad = context.createLinearGradient(sourcePos.x, sourcePos.y, destPos.x, destPos.y);
        grad.addColorStop(0, ColorUtils.getStyleFromHsl(color1, opacity));
        grad.addColorStop(gradStop > 1 ? 1 : gradStop, ColorUtils.getStyleFromRgb(midRgb, opacity));
        grad.addColorStop(1, ColorUtils.getStyleFromHsl(color2, opacity));
        return grad;
      }
    
      static drawGrabLine(context, width, begin, end, colorLine, opacity) {
        context.save();
        drawLine(context, begin, end);
        context.strokeStyle = ColorUtils.getStyleFromRgb(colorLine, opacity);
        context.lineWidth = width;
        context.stroke();
        context.restore();
      }
    
      static drawLight(container, context, mousePos) {
        const lightOptions = container.options.interactivity.modes.light.area;
        context.beginPath();
        context.arc(mousePos.x, mousePos.y, lightOptions.radius, 0, 2 * Math.PI);
        const gradientAmbientLight = context.createRadialGradient(mousePos.x, mousePos.y, 0, mousePos.x, mousePos.y, lightOptions.radius);
        const gradient = lightOptions.gradient;
        const gradientRgb = {
          start: ColorUtils.colorToRgb(gradient.start),
          stop: ColorUtils.colorToRgb(gradient.stop)
        };
    
        if (!gradientRgb.start || !gradientRgb.stop) {
          return;
        }
    
        gradientAmbientLight.addColorStop(0, ColorUtils.getStyleFromRgb(gradientRgb.start));
        gradientAmbientLight.addColorStop(1, ColorUtils.getStyleFromRgb(gradientRgb.stop));
        context.fillStyle = gradientAmbientLight;
        context.fill();
      }
    
      static drawParticleShadow(container, context, particle, mousePos) {
        const pos = particle.getPosition();
        const shadowOptions = container.options.interactivity.modes.light.shadow;
        context.save();
        const radius = particle.getRadius();
        const sides = particle.sides;
        const full = Math.PI * 2 / sides;
        const angle = -particle.rotate.value + Math.PI / 4;
        const factor = 1;
        const dots = [];
    
        for (let i = 0; i < sides; i++) {
          dots.push({
            x: pos.x + radius * Math.sin(angle + full * i) * factor,
            y: pos.y + radius * Math.cos(angle + full * i) * factor
          });
        }
    
        const points = [];
        const shadowLength = shadowOptions.length;
    
        for (const dot of dots) {
          const dotAngle = Math.atan2(mousePos.y - dot.y, mousePos.x - dot.x);
          const endX = dot.x + shadowLength * Math.sin(-dotAngle - Math.PI / 2);
          const endY = dot.y + shadowLength * Math.cos(-dotAngle - Math.PI / 2);
          points.push({
            endX: endX,
            endY: endY,
            startX: dot.x,
            startY: dot.y
          });
        }
    
        const shadowRgb = ColorUtils.colorToRgb(shadowOptions.color);
    
        if (!shadowRgb) {
          return;
        }
    
        const shadowColor = ColorUtils.getStyleFromRgb(shadowRgb);
    
        for (let i = points.length - 1; i >= 0; i--) {
          const n = i == points.length - 1 ? 0 : i + 1;
          context.beginPath();
          context.moveTo(points[i].startX, points[i].startY);
          context.lineTo(points[n].startX, points[n].startY);
          context.lineTo(points[n].endX, points[n].endY);
          context.lineTo(points[i].endX, points[i].endY);
          context.fillStyle = shadowColor;
          context.fill();
        }
    
        context.restore();
      }
    
      static drawParticle(container, context, particle, delta, fillColorValue, strokeColorValue, backgroundMask, composite, radius, opacity, shadow) {
        const pos = particle.getPosition();
        context.save();
        context.translate(pos.x, pos.y);
        context.beginPath();
        const angle = particle.rotate.value + (particle.particlesOptions.rotate.path ? particle.pathAngle : 0);
    
        if (angle !== 0) {
          context.rotate(angle);
        }
    
        if (backgroundMask) {
          context.globalCompositeOperation = composite;
        }
    
        const shadowColor = particle.shadowColor;
    
        if (shadow.enable && shadowColor) {
          context.shadowBlur = shadow.blur;
          context.shadowColor = ColorUtils.getStyleFromRgb(shadowColor);
          context.shadowOffsetX = shadow.offset.x;
          context.shadowOffsetY = shadow.offset.y;
        }
    
        if (fillColorValue) {
          context.fillStyle = fillColorValue;
        }
    
        const stroke = particle.stroke;
        context.lineWidth = particle.strokeWidth;
    
        if (strokeColorValue) {
          context.strokeStyle = strokeColorValue;
        }
    
        CanvasUtils.drawShape(container, context, particle, radius, opacity, delta);
    
        if (stroke.width > 0) {
          context.stroke();
        }
    
        if (particle.close) {
          context.closePath();
        }
    
        if (particle.fill) {
          context.fill();
        }
    
        context.restore();
        context.save();
        context.translate(pos.x, pos.y);
    
        if (angle !== 0) {
          context.rotate(angle);
        }
    
        if (backgroundMask) {
          context.globalCompositeOperation = composite;
        }
    
        CanvasUtils.drawShapeAfterEffect(container, context, particle, radius, opacity, delta);
        context.restore();
      }
    
      static drawShape(container, context, particle, radius, opacity, delta) {
        if (!particle.shape) {
          return;
        }
    
        const drawer = container.drawers.get(particle.shape);
    
        if (!drawer) {
          return;
        }
    
        drawer.draw(context, particle, radius, opacity, delta.value, container.retina.pixelRatio);
      }
    
      static drawShapeAfterEffect(container, context, particle, radius, opacity, delta) {
        if (!particle.shape) {
          return;
        }
    
        const drawer = container.drawers.get(particle.shape);
    
        if (!(drawer === null || drawer === void 0 ? void 0 : drawer.afterEffect)) {
          return;
        }
    
        drawer.afterEffect(context, particle, radius, opacity, delta.value, container.retina.pixelRatio);
      }
    
      static drawPlugin(context, plugin, delta) {
        if (plugin.draw !== undefined) {
          context.save();
          plugin.draw(context, delta);
          context.restore();
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Utils/Range.js
    class Range {
      constructor(x, y) {
        this.position = {
          x: x,
          y: y
        };
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Utils/Circle.js
    
    class Circle extends Range {
      constructor(x, y, radius) {
        super(x, y);
        this.radius = radius;
      }
    
      contains(point) {
        const d = Math.pow(point.x - this.position.x, 2) + Math.pow(point.y - this.position.y, 2);
        return d <= this.radius * this.radius;
      }
    
      intersects(range) {
        const rect = range;
        const circle = range;
        const pos1 = this.position;
        const pos2 = range.position;
        const xDist = Math.abs(pos2.x - pos1.x);
        const yDist = Math.abs(pos2.y - pos1.y);
        const r = this.radius;
    
        if (circle.radius !== undefined) {
          const rSum = r + circle.radius;
          const dist = Math.sqrt(xDist * xDist + yDist + yDist);
          return rSum > dist;
        } else if (rect.size !== undefined) {
          const w = rect.size.width;
          const h = rect.size.height;
          const edges = Math.pow(xDist - w, 2) + Math.pow(yDist - h, 2);
    
          if (xDist > r + w || yDist > r + h) {
            return false;
          }
    
          if (xDist <= w || yDist <= h) {
            return true;
          }
    
          return edges <= r * r;
        }
    
        return false;
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Utils/Rectangle.js
    
    class Rectangle extends Range {
      constructor(x, y, width, height) {
        super(x, y);
        this.size = {
          height: height,
          width: width
        };
      }
    
      contains(point) {
        const w = this.size.width;
        const h = this.size.height;
        const pos = this.position;
        return point.x >= pos.x && point.x <= pos.x + w && point.y >= pos.y && point.y <= pos.y + h;
      }
    
      intersects(range) {
        const rect = range;
        const circle = range;
        const w = this.size.width;
        const h = this.size.height;
        const pos1 = this.position;
        const pos2 = range.position;
    
        if (circle.radius !== undefined) {
          return circle.intersects(this);
        } else if (rect.size !== undefined) {
          const size2 = rect.size;
          const w2 = size2.width;
          const h2 = size2.height;
          return pos2.x < pos1.x + w && pos2.x + w2 > pos1.x && pos2.y < pos1.y + h && pos2.y + h2 > pos1.y;
        }
    
        return false;
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Utils/CircleWarp.js
    
    
    class CircleWarp extends Circle {
      constructor(x, y, radius, canvasSize) {
        super(x, y, radius);
        this.canvasSize = canvasSize;
        this.canvasSize = {
          height: canvasSize.height,
          width: canvasSize.width
        };
      }
    
      contains(point) {
        if (super.contains(point)) {
          return true;
        }
    
        const posNE = {
          x: point.x - this.canvasSize.width,
          y: point.y
        };
    
        if (super.contains(posNE)) {
          return true;
        }
    
        const posSE = {
          x: point.x - this.canvasSize.width,
          y: point.y - this.canvasSize.height
        };
    
        if (super.contains(posSE)) {
          return true;
        }
    
        const posSW = {
          x: point.x,
          y: point.y - this.canvasSize.height
        };
        return super.contains(posSW);
      }
    
      intersects(range) {
        if (super.intersects(range)) {
          return true;
        }
    
        const rect = range;
        const circle = range;
        const newPos = {
          x: range.position.x - this.canvasSize.width,
          y: range.position.y - this.canvasSize.height
        };
    
        if (circle.radius !== undefined) {
          const biggerCircle = new Circle(newPos.x, newPos.y, circle.radius * 2);
          return super.intersects(biggerCircle);
        } else if (rect.size !== undefined) {
          const rectSW = new Rectangle(newPos.x, newPos.y, rect.size.width * 2, rect.size.height * 2);
          return super.intersects(rectSW);
        }
    
        return false;
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Enums/Modes/ClickMode.js
    var ClickMode;
    
    (function (ClickMode) {
      ClickMode["attract"] = "attract";
      ClickMode["bubble"] = "bubble";
      ClickMode["push"] = "push";
      ClickMode["remove"] = "remove";
      ClickMode["repulse"] = "repulse";
      ClickMode["pause"] = "pause";
      ClickMode["trail"] = "trail";
    })(ClickMode || (ClickMode = {}));
    // CONCATENATED MODULE: ./dist/browser/Enums/Modes/DivMode.js
    var DivMode;
    
    (function (DivMode) {
      DivMode["bounce"] = "bounce";
      DivMode["bubble"] = "bubble";
      DivMode["repulse"] = "repulse";
    })(DivMode || (DivMode = {}));
    // CONCATENATED MODULE: ./dist/browser/Enums/Modes/HoverMode.js
    var HoverMode;
    
    (function (HoverMode) {
      HoverMode["attract"] = "attract";
      HoverMode["bounce"] = "bounce";
      HoverMode["bubble"] = "bubble";
      HoverMode["connect"] = "connect";
      HoverMode["grab"] = "grab";
      HoverMode["light"] = "light";
      HoverMode["repulse"] = "repulse";
      HoverMode["slow"] = "slow";
      HoverMode["trail"] = "trail";
    })(HoverMode || (HoverMode = {}));
    // CONCATENATED MODULE: ./dist/browser/Enums/Modes/CollisionMode.js
    var CollisionMode;
    
    (function (CollisionMode) {
      CollisionMode["absorb"] = "absorb";
      CollisionMode["bounce"] = "bounce";
      CollisionMode["destroy"] = "destroy";
    })(CollisionMode || (CollisionMode = {}));
    // CONCATENATED MODULE: ./dist/browser/Enums/Modes/OutMode.js
    var OutMode;
    
    (function (OutMode) {
      OutMode["bounce"] = "bounce";
      OutMode["bounceHorizontal"] = "bounce-horizontal";
      OutMode["bounceVertical"] = "bounce-vertical";
      OutMode["none"] = "none";
      OutMode["out"] = "out";
      OutMode["destroy"] = "destroy";
    })(OutMode || (OutMode = {}));
    // CONCATENATED MODULE: ./dist/browser/Enums/Modes/SizeMode.js
    var SizeMode;
    
    (function (SizeMode) {
      SizeMode["precise"] = "precise";
      SizeMode["percent"] = "percent";
    })(SizeMode || (SizeMode = {}));
    // CONCATENATED MODULE: ./dist/browser/Enums/Modes/ThemeMode.js
    var ThemeMode;
    
    (function (ThemeMode) {
      ThemeMode["any"] = "any";
      ThemeMode["dark"] = "dark";
      ThemeMode["light"] = "light";
    })(ThemeMode || (ThemeMode = {}));
    // CONCATENATED MODULE: ./dist/browser/Enums/Modes/index.js
    
    
    
    
    
    
    
    // CONCATENATED MODULE: ./dist/browser/Enums/AnimationStatus.js
    var AnimationStatus;
    
    (function (AnimationStatus) {
      AnimationStatus[AnimationStatus["increasing"] = 0] = "increasing";
      AnimationStatus[AnimationStatus["decreasing"] = 1] = "decreasing";
    })(AnimationStatus || (AnimationStatus = {}));
    // CONCATENATED MODULE: ./dist/browser/Enums/Types/DestroyType.js
    var DestroyType;
    
    (function (DestroyType) {
      DestroyType["none"] = "none";
      DestroyType["max"] = "max";
      DestroyType["min"] = "min";
    })(DestroyType || (DestroyType = {}));
    // CONCATENATED MODULE: ./dist/browser/Enums/Types/ProcessBubbleType.js
    var ProcessBubbleType;
    
    (function (ProcessBubbleType) {
      ProcessBubbleType["color"] = "color";
      ProcessBubbleType["opacity"] = "opacity";
      ProcessBubbleType["size"] = "size";
    })(ProcessBubbleType || (ProcessBubbleType = {}));
    // CONCATENATED MODULE: ./dist/browser/Enums/Types/ShapeType.js
    var ShapeType;
    
    (function (ShapeType) {
      ShapeType["char"] = "char";
      ShapeType["character"] = "character";
      ShapeType["circle"] = "circle";
      ShapeType["edge"] = "edge";
      ShapeType["image"] = "image";
      ShapeType["images"] = "images";
      ShapeType["line"] = "line";
      ShapeType["polygon"] = "polygon";
      ShapeType["square"] = "square";
      ShapeType["star"] = "star";
      ShapeType["triangle"] = "triangle";
    })(ShapeType || (ShapeType = {}));
    // CONCATENATED MODULE: ./dist/browser/Enums/Types/StartValueType.js
    var StartValueType;
    
    (function (StartValueType) {
      StartValueType["max"] = "max";
      StartValueType["min"] = "min";
      StartValueType["random"] = "random";
    })(StartValueType || (StartValueType = {}));
    // CONCATENATED MODULE: ./dist/browser/Enums/Types/DivType.js
    var DivType;
    
    (function (DivType) {
      DivType["circle"] = "circle";
      DivType["rectangle"] = "rectangle";
    })(DivType || (DivType = {}));
    // CONCATENATED MODULE: ./dist/browser/Enums/Types/index.js
    
    
    
    
    
    // CONCATENATED MODULE: ./dist/browser/Enums/InteractivityDetect.js
    var InteractivityDetect;
    
    (function (InteractivityDetect) {
      InteractivityDetect["canvas"] = "canvas";
      InteractivityDetect["parent"] = "parent";
      InteractivityDetect["window"] = "window";
    })(InteractivityDetect || (InteractivityDetect = {}));
    // CONCATENATED MODULE: ./dist/browser/Enums/index.js
    
    
    
    
    
    // CONCATENATED MODULE: ./dist/browser/Utils/EventListeners.js
    
    
    
    function manageListener(element, event, handler, add, options) {
      if (add) {
        let addOptions = {
          passive: true
        };
    
        if (typeof options === "boolean") {
          addOptions.capture = options;
        } else if (options !== undefined) {
          addOptions = options;
        }
    
        element.addEventListener(event, handler, addOptions);
      } else {
        const removeOptions = options;
        element.removeEventListener(event, handler, removeOptions);
      }
    }
    
    class EventListeners {
      constructor(container) {
        this.container = container;
        this.canPush = true;
    
        this.mouseMoveHandler = e => this.mouseTouchMove(e);
    
        this.touchStartHandler = e => this.mouseTouchMove(e);
    
        this.touchMoveHandler = e => this.mouseTouchMove(e);
    
        this.touchEndHandler = () => this.mouseTouchFinish();
    
        this.mouseLeaveHandler = () => this.mouseTouchFinish();
    
        this.touchCancelHandler = () => this.mouseTouchFinish();
    
        this.touchEndClickHandler = e => this.mouseTouchClick(e);
    
        this.mouseUpHandler = e => this.mouseTouchClick(e);
    
        this.mouseDownHandler = () => this.mouseDown();
    
        this.visibilityChangeHandler = () => this.handleVisibilityChange();
    
        this.resizeHandler = () => this.handleWindowResize();
      }
    
      addListeners() {
        this.manageListeners(true);
      }
    
      removeListeners() {
        this.manageListeners(false);
      }
    
      manageListeners(add) {
        var _a;
    
        const container = this.container;
        const options = container.options;
        const detectType = options.interactivity.detectsOn;
        let mouseLeaveEvent = Constants.mouseLeaveEvent;
    
        if (detectType === InteractivityDetect.window) {
          container.interactivity.element = window;
          mouseLeaveEvent = Constants.mouseOutEvent;
        } else if (detectType === InteractivityDetect.parent && container.canvas.element) {
          const canvasEl = container.canvas.element;
          container.interactivity.element = (_a = canvasEl.parentElement) !== null && _a !== void 0 ? _a : canvasEl.parentNode;
        } else {
          container.interactivity.element = container.canvas.element;
        }
    
        const interactivityEl = container.interactivity.element;
    
        if (!interactivityEl) {
          return;
        }
    
        const html = interactivityEl;
    
        if (options.interactivity.events.onHover.enable || options.interactivity.events.onClick.enable) {
          manageListener(interactivityEl, Constants.mouseMoveEvent, this.mouseMoveHandler, add);
          manageListener(interactivityEl, Constants.touchStartEvent, this.touchStartHandler, add);
          manageListener(interactivityEl, Constants.touchMoveEvent, this.touchMoveHandler, add);
    
          if (!options.interactivity.events.onClick.enable) {
            manageListener(interactivityEl, Constants.touchEndEvent, this.touchEndHandler, add);
          } else {
            manageListener(interactivityEl, Constants.touchEndEvent, this.touchEndClickHandler, add);
            manageListener(interactivityEl, Constants.mouseUpEvent, this.mouseUpHandler, add);
            manageListener(interactivityEl, Constants.mouseDownEvent, this.mouseDownHandler, add);
          }
    
          manageListener(interactivityEl, mouseLeaveEvent, this.mouseLeaveHandler, add);
          manageListener(interactivityEl, Constants.touchCancelEvent, this.touchCancelHandler, add);
        }
    
        if (container.canvas.element) {
          container.canvas.element.style.pointerEvents = html === container.canvas.element ? "initial" : "none";
        }
    
        if (options.interactivity.events.resize) {
          manageListener(window, Constants.resizeEvent, this.resizeHandler, add);
        }
    
        if (document) {
          manageListener(document, Constants.visibilityChangeEvent, this.visibilityChangeHandler, add, false);
        }
      }
    
      handleWindowResize() {
        var _a;
    
        (_a = this.container.canvas) === null || _a === void 0 ? void 0 : _a.windowResize();
      }
    
      handleVisibilityChange() {
        const container = this.container;
        const options = container.options;
        this.mouseTouchFinish();
    
        if (!options.pauseOnBlur) {
          return;
        }
    
        if (document === null || document === void 0 ? void 0 : document.hidden) {
          container.pageHidden = true;
          container.pause();
        } else {
          container.pageHidden = false;
    
          if (container.getAnimationStatus()) {
            container.play(true);
          } else {
            container.draw();
          }
        }
      }
    
      mouseDown() {
        const interactivity = this.container.interactivity;
    
        if (interactivity) {
          const mouse = interactivity.mouse;
          mouse.clicking = true;
          mouse.downPosition = mouse.position;
        }
      }
    
      mouseTouchMove(e) {
        var _a, _b, _c, _d, _e, _f, _g;
    
        const container = this.container;
        const options = container.options;
    
        if (((_a = container.interactivity) === null || _a === void 0 ? void 0 : _a.element) === undefined) {
          return;
        }
    
        container.interactivity.mouse.inside = true;
        let pos;
        const canvas = container.canvas.element;
    
        if (e.type.startsWith("mouse")) {
          this.canPush = true;
          const mouseEvent = e;
    
          if (container.interactivity.element === window) {
            if (canvas) {
              const clientRect = canvas.getBoundingClientRect();
              pos = {
                x: mouseEvent.clientX - clientRect.left,
                y: mouseEvent.clientY - clientRect.top
              };
            }
          } else if (options.interactivity.detectsOn === InteractivityDetect.parent) {
            const source = mouseEvent.target;
            const target = mouseEvent.currentTarget;
            const canvasEl = container.canvas.element;
    
            if (source && target && canvasEl) {
              const sourceRect = source.getBoundingClientRect();
              const targetRect = target.getBoundingClientRect();
              const canvasRect = canvasEl.getBoundingClientRect();
              pos = {
                x: mouseEvent.offsetX + 2 * sourceRect.left - (targetRect.left + canvasRect.left),
                y: mouseEvent.offsetY + 2 * sourceRect.top - (targetRect.top + canvasRect.top)
              };
            } else {
              pos = {
                x: (_b = mouseEvent.offsetX) !== null && _b !== void 0 ? _b : mouseEvent.clientX,
                y: (_c = mouseEvent.offsetY) !== null && _c !== void 0 ? _c : mouseEvent.clientY
              };
            }
          } else {
            if (mouseEvent.target === container.canvas.element) {
              pos = {
                x: (_d = mouseEvent.offsetX) !== null && _d !== void 0 ? _d : mouseEvent.clientX,
                y: (_e = mouseEvent.offsetY) !== null && _e !== void 0 ? _e : mouseEvent.clientY
              };
            }
          }
        } else {
          this.canPush = e.type !== "touchmove";
          const touchEvent = e;
          const lastTouch = touchEvent.touches[touchEvent.touches.length - 1];
          const canvasRect = canvas === null || canvas === void 0 ? void 0 : canvas.getBoundingClientRect();
          pos = {
            x: lastTouch.clientX - ((_f = canvasRect === null || canvasRect === void 0 ? void 0 : canvasRect.left) !== null && _f !== void 0 ? _f : 0),
            y: lastTouch.clientY - ((_g = canvasRect === null || canvasRect === void 0 ? void 0 : canvasRect.top) !== null && _g !== void 0 ? _g : 0)
          };
        }
    
        const pxRatio = container.retina.pixelRatio;
    
        if (pos) {
          pos.x *= pxRatio;
          pos.y *= pxRatio;
        }
    
        container.interactivity.mouse.position = pos;
        container.interactivity.status = Constants.mouseMoveEvent;
      }
    
      mouseTouchFinish() {
        const interactivity = this.container.interactivity;
    
        if (interactivity === undefined) {
          return;
        }
    
        const mouse = interactivity.mouse;
        delete mouse.position;
        delete mouse.clickPosition;
        delete mouse.downPosition;
        interactivity.status = Constants.mouseLeaveEvent;
        mouse.inside = false;
        mouse.clicking = false;
      }
    
      mouseTouchClick(e) {
        const container = this.container;
        const options = container.options;
        const mouse = container.interactivity.mouse;
        mouse.inside = true;
        let handled = false;
        const mousePosition = mouse.position;
    
        if (mousePosition === undefined || !options.interactivity.events.onClick.enable) {
          return;
        }
    
        for (const [, plugin] of container.plugins) {
          if (plugin.clickPositionValid !== undefined) {
            handled = plugin.clickPositionValid(mousePosition);
    
            if (handled) {
              break;
            }
          }
        }
    
        if (!handled) {
          this.doMouseTouchClick(e);
        }
    
        mouse.clicking = false;
      }
    
      doMouseTouchClick(e) {
        const container = this.container;
        const options = container.options;
    
        if (this.canPush) {
          const mousePos = container.interactivity.mouse.position;
    
          if (mousePos) {
            container.interactivity.mouse.clickPosition = {
              x: mousePos.x,
              y: mousePos.y
            };
          } else {
            return;
          }
    
          container.interactivity.mouse.clickTime = new Date().getTime();
          const onClick = options.interactivity.events.onClick;
    
          if (onClick.mode instanceof Array) {
            for (const mode of onClick.mode) {
              this.handleClickMode(mode);
            }
          } else {
            this.handleClickMode(onClick.mode);
          }
        }
    
        if (e.type === "touchend") {
          setTimeout(() => this.mouseTouchFinish(), 500);
        }
      }
    
      handleClickMode(mode) {
        const container = this.container;
        const options = container.options;
        const pushNb = options.interactivity.modes.push.quantity;
        const removeNb = options.interactivity.modes.remove.quantity;
    
        switch (mode) {
          case ClickMode.push:
            {
              if (pushNb > 0) {
                container.particles.push(pushNb, container.interactivity.mouse);
              }
    
              break;
            }
    
          case ClickMode.remove:
            container.particles.removeQuantity(removeNb);
            break;
    
          case ClickMode.bubble:
            container.bubble.clicking = true;
            break;
    
          case ClickMode.repulse:
            container.repulse.clicking = true;
            container.repulse.count = 0;
    
            for (const particle of container.repulse.particles) {
              particle.velocity.horizontal = particle.initialVelocity.horizontal;
              particle.velocity.vertical = particle.initialVelocity.vertical;
            }
    
            container.repulse.particles = [];
            container.repulse.finish = false;
            setTimeout(() => {
              if (!container.destroyed) {
                container.repulse.clicking = false;
              }
            }, options.interactivity.modes.repulse.duration * 1000);
            break;
    
          case ClickMode.attract:
            container.attract.clicking = true;
            container.attract.count = 0;
    
            for (const particle of container.attract.particles) {
              particle.velocity.horizontal = particle.initialVelocity.horizontal;
              particle.velocity.vertical = particle.initialVelocity.vertical;
            }
    
            container.attract.particles = [];
            container.attract.finish = false;
            setTimeout(() => {
              if (!container.destroyed) {
                container.attract.clicking = false;
              }
            }, options.interactivity.modes.attract.duration * 1000);
            break;
    
          case ClickMode.pause:
            if (container.getAnimationStatus()) {
              container.pause();
            } else {
              container.play();
            }
    
            break;
        }
    
        for (const [, plugin] of container.plugins) {
          if (plugin.handleClickMode) {
            plugin.handleClickMode(mode);
          }
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Utils/Plugins.js
    const plugins = [];
    const presets = new Map();
    const drawers = new Map();
    class Plugins {
      static getPlugin(plugin) {
        return plugins.find(t => t.id === plugin);
      }
    
      static addPlugin(plugin) {
        if (!Plugins.getPlugin(plugin.id)) {
          plugins.push(plugin);
        }
      }
    
      static getAvailablePlugins(container) {
        const res = new Map();
    
        for (const plugin of plugins) {
          if (!plugin.needsPlugin(container.options)) {
            continue;
          }
    
          res.set(plugin.id, plugin.getPlugin(container));
        }
    
        return res;
      }
    
      static loadOptions(options, sourceOptions) {
        for (const plugin of plugins) {
          plugin.loadOptions(options, sourceOptions);
        }
      }
    
      static getPreset(preset) {
        return presets.get(preset);
      }
    
      static addPreset(presetKey, options) {
        if (!Plugins.getPreset(presetKey)) {
          presets.set(presetKey, options);
        }
      }
    
      static addShapeDrawer(type, drawer) {
        if (!Plugins.getShapeDrawer(type)) {
          drawers.set(type, drawer);
        }
      }
    
      static getShapeDrawer(type) {
        return drawers.get(type);
      }
    
      static getSupportedShapes() {
        return drawers.keys();
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Utils/Point.js
    class Point {
      constructor(position, particle) {
        this.position = position;
        this.particle = particle;
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Utils/QuadTree.js
    
    
    
    class QuadTree {
      constructor(rectangle, capacity) {
        this.rectangle = rectangle;
        this.capacity = capacity;
        this.points = [];
        this.divided = false;
      }
    
      subdivide() {
        const x = this.rectangle.position.x;
        const y = this.rectangle.position.y;
        const w = this.rectangle.size.width;
        const h = this.rectangle.size.height;
        const capacity = this.capacity;
        this.northEast = new QuadTree(new Rectangle(x, y, w / 2, h / 2), capacity);
        this.northWest = new QuadTree(new Rectangle(x + w / 2, y, w / 2, h / 2), capacity);
        this.southEast = new QuadTree(new Rectangle(x, y + h / 2, w / 2, h / 2), capacity);
        this.southWest = new QuadTree(new Rectangle(x + w / 2, y + h / 2, w / 2, h / 2), capacity);
        this.divided = true;
      }
    
      insert(point) {
        var _a, _b, _c, _d, _e;
    
        if (!this.rectangle.contains(point.position)) {
          return false;
        }
    
        if (this.points.length < this.capacity) {
          this.points.push(point);
          return true;
        }
    
        if (!this.divided) {
          this.subdivide();
        }
    
        return (_e = ((_a = this.northEast) === null || _a === void 0 ? void 0 : _a.insert(point)) || ((_b = this.northWest) === null || _b === void 0 ? void 0 : _b.insert(point)) || ((_c = this.southEast) === null || _c === void 0 ? void 0 : _c.insert(point)) || ((_d = this.southWest) === null || _d === void 0 ? void 0 : _d.insert(point))) !== null && _e !== void 0 ? _e : false;
      }
    
      queryCircle(position, radius) {
        return this.query(new Circle(position.x, position.y, radius));
      }
    
      queryCircleWarp(position, radius, containerOrSize) {
        const container = containerOrSize;
        const size = containerOrSize;
        return this.query(new CircleWarp(position.x, position.y, radius, container.canvas !== undefined ? container.canvas.size : size));
      }
    
      queryRectangle(position, size) {
        return this.query(new Rectangle(position.x, position.y, size.width, size.height));
      }
    
      query(range, found) {
        var _a, _b, _c, _d;
    
        const res = found !== null && found !== void 0 ? found : [];
    
        if (!range.intersects(this.rectangle)) {
          return [];
        } else {
          for (const p of this.points) {
            if (!range.contains(p.position)) {
              continue;
            }
    
            res.push(p.particle);
          }
    
          if (this.divided) {
            (_a = this.northEast) === null || _a === void 0 ? void 0 : _a.query(range, res);
            (_b = this.northWest) === null || _b === void 0 ? void 0 : _b.query(range, res);
            (_c = this.southEast) === null || _c === void 0 ? void 0 : _c.query(range, res);
            (_d = this.southWest) === null || _d === void 0 ? void 0 : _d.query(range, res);
          }
        }
    
        return res;
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Utils/index.js
    
    
    
    
    
    
    
    
    
    
    
    
    
    // CONCATENATED MODULE: ./dist/browser/ShapeDrawers/TextDrawer.js
    var TextDrawer_awaiter = undefined && undefined.__awaiter || function (thisArg, _arguments, P, generator) {
      function adopt(value) {
        return value instanceof P ? value : new P(function (resolve) {
          resolve(value);
        });
      }
    
      return new (P || (P = Promise))(function (resolve, reject) {
        function fulfilled(value) {
          try {
            step(generator.next(value));
          } catch (e) {
            reject(e);
          }
        }
    
        function rejected(value) {
          try {
            step(generator["throw"](value));
          } catch (e) {
            reject(e);
          }
        }
    
        function step(result) {
          result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);
        }
    
        step((generator = generator.apply(thisArg, _arguments || [])).next());
      });
    };
    
    
    
    class TextDrawer {
      getSidesCount() {
        return 12;
      }
    
      init(container) {
        var _a;
    
        return TextDrawer_awaiter(this, void 0, void 0, function* () {
          const options = container.options;
    
          if (Utils.isInArray(ShapeType.char, options.particles.shape.type) || Utils.isInArray(ShapeType.character, options.particles.shape.type)) {
            const shapeOptions = (_a = options.particles.shape.options[ShapeType.character]) !== null && _a !== void 0 ? _a : options.particles.shape.options[ShapeType.char];
    
            if (shapeOptions instanceof Array) {
              for (const character of shapeOptions) {
                yield Utils.loadFont(character);
              }
            } else {
              if (shapeOptions !== undefined) {
                yield Utils.loadFont(shapeOptions);
              }
            }
          }
        });
      }
    
      draw(context, particle, radius) {
        const character = particle.shapeData;
    
        if (character === undefined) {
          return;
        }
    
        const textData = character.value;
    
        if (textData === undefined) {
          return;
        }
    
        const textParticle = particle;
    
        if (textParticle.text === undefined) {
          textParticle.text = textData instanceof Array ? Utils.itemFromArray(textData, particle.randomIndexData) : textData;
        }
    
        const text = textParticle.text;
        const style = character.style;
        const weight = character.weight;
        const size = Math.round(radius) * 2;
        const font = character.font;
        const fill = particle.fill;
        const offsetX = text.length * radius / 2;
        context.font = `${style} ${weight} ${size}px "${font}"`;
        const pos = {
          x: -offsetX,
          y: radius / 2
        };
    
        if (fill) {
          context.fillText(text, pos.x, pos.y);
        } else {
          context.strokeText(text, pos.x, pos.y);
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/ShapeDrawers/ImageDrawer.js
    var ImageDrawer_awaiter = undefined && undefined.__awaiter || function (thisArg, _arguments, P, generator) {
      function adopt(value) {
        return value instanceof P ? value : new P(function (resolve) {
          resolve(value);
        });
      }
    
      return new (P || (P = Promise))(function (resolve, reject) {
        function fulfilled(value) {
          try {
            step(generator.next(value));
          } catch (e) {
            reject(e);
          }
        }
    
        function rejected(value) {
          try {
            step(generator["throw"](value));
          } catch (e) {
            reject(e);
          }
        }
    
        function step(result) {
          result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);
        }
    
        step((generator = generator.apply(thisArg, _arguments || [])).next());
      });
    };
    
    
    
    class ImageDrawer {
      constructor() {
        this.images = [];
      }
    
      getSidesCount() {
        return 12;
      }
    
      getImages(container) {
        const containerImages = this.images.filter(t => t.id === container.id);
    
        if (!containerImages.length) {
          this.images.push({
            id: container.id,
            images: []
          });
          return this.getImages(container);
        } else {
          return containerImages[0];
        }
      }
    
      addImage(container, image) {
        const containerImages = this.getImages(container);
        containerImages === null || containerImages === void 0 ? void 0 : containerImages.images.push(image);
      }
    
      init(container) {
        var _a;
    
        return ImageDrawer_awaiter(this, void 0, void 0, function* () {
          const options = container.options;
          const shapeOptions = options.particles.shape;
    
          if (!Utils.isInArray(ShapeType.image, shapeOptions.type) && !Utils.isInArray(ShapeType.images, shapeOptions.type)) {
            return;
          }
    
          const imageOptions = (_a = shapeOptions.options[ShapeType.images]) !== null && _a !== void 0 ? _a : shapeOptions.options[ShapeType.image];
    
          if (imageOptions instanceof Array) {
            for (const optionsImage of imageOptions) {
              yield this.loadImageShape(container, optionsImage);
            }
          } else {
            yield this.loadImageShape(container, imageOptions);
          }
        });
      }
    
      destroy() {
        this.images = [];
      }
    
      loadImageShape(container, imageShape) {
        return ImageDrawer_awaiter(this, void 0, void 0, function* () {
          try {
            const image = imageShape.replaceColor ? yield Utils.downloadSvgImage(imageShape.src) : yield Utils.loadImage(imageShape.src);
            this.addImage(container, image);
          } catch (_a) {
            console.warn(`tsParticles error - ${imageShape.src} not found`);
          }
        });
      }
    
      draw(context, particle, radius, opacity) {
        var _a, _b;
    
        if (!context) {
          return;
        }
    
        const image = particle.image;
        const element = (_a = image === null || image === void 0 ? void 0 : image.data) === null || _a === void 0 ? void 0 : _a.element;
    
        if (!element) {
          return;
        }
    
        const ratio = (_b = image === null || image === void 0 ? void 0 : image.ratio) !== null && _b !== void 0 ? _b : 1;
        const pos = {
          x: -radius,
          y: -radius
        };
    
        if (!(image === null || image === void 0 ? void 0 : image.data.svgData) || !(image === null || image === void 0 ? void 0 : image.replaceColor)) {
          context.globalAlpha = opacity;
        }
    
        context.drawImage(element, pos.x, pos.y, radius * 2, radius * 2 / ratio);
    
        if (!(image === null || image === void 0 ? void 0 : image.data.svgData) || !(image === null || image === void 0 ? void 0 : image.replaceColor)) {
          context.globalAlpha = 1;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/ShapeDrawers/LineDrawer.js
    class LineDrawer {
      getSidesCount() {
        return 1;
      }
    
      draw(context, particle, radius) {
        context.moveTo(0, -radius / 2);
        context.lineTo(0, radius / 2);
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/ShapeDrawers/CircleDrawer.js
    class CircleDrawer {
      getSidesCount() {
        return 12;
      }
    
      draw(context, particle, radius) {
        context.arc(0, 0, radius, 0, Math.PI * 2, false);
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/ShapeDrawers/PolygonDrawerBase.js
    class PolygonDrawerBase {
      getSidesCount(particle) {
        var _a, _b;
    
        const polygon = particle.shapeData;
        return (_b = (_a = polygon === null || polygon === void 0 ? void 0 : polygon.sides) !== null && _a !== void 0 ? _a : polygon === null || polygon === void 0 ? void 0 : polygon.nb_sides) !== null && _b !== void 0 ? _b : 5;
      }
    
      draw(context, particle, radius) {
        const start = this.getCenter(particle, radius);
        const side = this.getSidesData(particle, radius);
        const sideCount = side.count.numerator * side.count.denominator;
        const decimalSides = side.count.numerator / side.count.denominator;
        const interiorAngleDegrees = 180 * (decimalSides - 2) / decimalSides;
        const interiorAngle = Math.PI - Math.PI * interiorAngleDegrees / 180;
    
        if (!context) {
          return;
        }
    
        context.beginPath();
        context.translate(start.x, start.y);
        context.moveTo(0, 0);
    
        for (let i = 0; i < sideCount; i++) {
          context.lineTo(side.length, 0);
          context.translate(side.length, 0);
          context.rotate(interiorAngle);
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/ShapeDrawers/TriangleDrawer.js
    
    class TriangleDrawer extends PolygonDrawerBase {
      getSidesCount() {
        return 3;
      }
    
      getSidesData(particle, radius) {
        return {
          count: {
            denominator: 2,
            numerator: 3
          },
          length: radius * 2
        };
      }
    
      getCenter(particle, radius) {
        return {
          x: -radius,
          y: radius / 1.66
        };
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/ShapeDrawers/StarDrawer.js
    class StarDrawer {
      getSidesCount(particle) {
        var _a, _b;
    
        const star = particle.shapeData;
        return (_b = (_a = star === null || star === void 0 ? void 0 : star.sides) !== null && _a !== void 0 ? _a : star === null || star === void 0 ? void 0 : star.nb_sides) !== null && _b !== void 0 ? _b : 5;
      }
    
      draw(context, particle, radius) {
        var _a;
    
        const star = particle.shapeData;
        const sides = this.getSidesCount(particle);
        const inset = (_a = star === null || star === void 0 ? void 0 : star.inset) !== null && _a !== void 0 ? _a : 2;
        context.moveTo(0, 0 - radius);
    
        for (let i = 0; i < sides; i++) {
          context.rotate(Math.PI / sides);
          context.lineTo(0, 0 - radius * inset);
          context.rotate(Math.PI / sides);
          context.lineTo(0, 0 - radius);
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/ShapeDrawers/PolygonDrawer.js
    
    class PolygonDrawer extends PolygonDrawerBase {
      getSidesData(particle, radius) {
        var _a, _b;
    
        const polygon = particle.shapeData;
        const sides = (_b = (_a = polygon === null || polygon === void 0 ? void 0 : polygon.sides) !== null && _a !== void 0 ? _a : polygon === null || polygon === void 0 ? void 0 : polygon.nb_sides) !== null && _b !== void 0 ? _b : 5;
        return {
          count: {
            denominator: 1,
            numerator: sides
          },
          length: radius * 2.66 / (sides / 3)
        };
      }
    
      getCenter(particle, radius) {
        const sides = this.getSidesCount(particle);
        return {
          x: -radius / (sides / 3.5),
          y: -radius / (2.66 / 3.5)
        };
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Core/Canvas.js
    
    class Canvas {
      constructor(container) {
        this.container = container;
        this.size = {
          height: 0,
          width: 0
        };
        this.context = null;
        this.generatedCanvas = false;
      }
    
      init() {
        var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m;
    
        this.resize();
        const options = this.container.options;
        const element = this.element;
    
        if (element) {
          if (options.backgroundMode.enable) {
            this.originalStyle = Utils.deepExtend({}, element.style);
            element.style.position = "fixed";
            element.style.zIndex = options.backgroundMode.zIndex.toString(10);
            element.style.top = "0";
            element.style.left = "0";
            element.style.width = "100%";
            element.style.height = "100%";
          } else {
            element.style.position = (_b = (_a = this.originalStyle) === null || _a === void 0 ? void 0 : _a.position) !== null && _b !== void 0 ? _b : "";
            element.style.zIndex = (_d = (_c = this.originalStyle) === null || _c === void 0 ? void 0 : _c.zIndex) !== null && _d !== void 0 ? _d : "";
            element.style.top = (_f = (_e = this.originalStyle) === null || _e === void 0 ? void 0 : _e.top) !== null && _f !== void 0 ? _f : "";
            element.style.left = (_h = (_g = this.originalStyle) === null || _g === void 0 ? void 0 : _g.left) !== null && _h !== void 0 ? _h : "";
            element.style.width = (_k = (_j = this.originalStyle) === null || _j === void 0 ? void 0 : _j.width) !== null && _k !== void 0 ? _k : "";
            element.style.height = (_m = (_l = this.originalStyle) === null || _l === void 0 ? void 0 : _l.height) !== null && _m !== void 0 ? _m : "";
          }
        }
    
        const cover = options.backgroundMask.cover;
        const color = cover.color;
        const trail = options.particles.move.trail;
        const coverRgb = ColorUtils.colorToRgb(color);
        this.coverColor = coverRgb !== undefined ? {
          r: coverRgb.r,
          g: coverRgb.g,
          b: coverRgb.b,
          a: cover.opacity
        } : undefined;
        this.trailFillColor = ColorUtils.colorToRgb(trail.fillColor);
        this.initBackground();
        this.paint();
      }
    
      loadCanvas(canvas, generatedCanvas) {
        var _a;
    
        if (!canvas.className) {
          canvas.className = Constants.canvasClass;
        }
    
        if (this.generatedCanvas) {
          (_a = this.element) === null || _a === void 0 ? void 0 : _a.remove();
        }
    
        this.generatedCanvas = generatedCanvas !== null && generatedCanvas !== void 0 ? generatedCanvas : this.generatedCanvas;
        this.element = canvas;
        this.originalStyle = Utils.deepExtend({}, this.element.style);
        this.size.height = canvas.offsetHeight;
        this.size.width = canvas.offsetWidth;
        this.context = this.element.getContext("2d");
        this.container.retina.init();
        this.initBackground();
      }
    
      destroy() {
        var _a;
    
        if (this.generatedCanvas) {
          (_a = this.element) === null || _a === void 0 ? void 0 : _a.remove();
        }
    
        if (this.context) {
          CanvasUtils.clear(this.context, this.size);
        }
      }
    
      resize() {
        if (!this.element) {
          return;
        }
    
        this.element.width = this.size.width;
        this.element.height = this.size.height;
      }
    
      paint() {
        const options = this.container.options;
    
        if (!this.context) {
          return;
        }
    
        if (options.backgroundMask.enable && options.backgroundMask.cover && this.coverColor) {
          CanvasUtils.clear(this.context, this.size);
          this.paintBase(ColorUtils.getStyleFromRgb(this.coverColor, this.coverColor.a));
        } else {
          this.paintBase();
        }
      }
    
      clear() {
        const options = this.container.options;
        const trail = options.particles.move.trail;
    
        if (options.backgroundMask.enable) {
          this.paint();
        } else if (trail.enable && trail.length > 0 && this.trailFillColor) {
          this.paintBase(ColorUtils.getStyleFromRgb(this.trailFillColor, 1 / trail.length));
        } else if (this.context) {
          CanvasUtils.clear(this.context, this.size);
        }
      }
    
      windowResize() {
        if (!this.element) {
          return;
        }
    
        const container = this.container;
        container.canvas.initSize();
        container.particles.setDensity();
    
        for (const [, plugin] of container.plugins) {
          if (plugin.resize !== undefined) {
            plugin.resize();
          }
        }
      }
    
      initSize() {
        if (!this.element) {
          return;
        }
    
        const container = this.container;
        const pxRatio = container.retina.pixelRatio;
        container.canvas.size.width = this.element.offsetWidth * pxRatio;
        container.canvas.size.height = this.element.offsetHeight * pxRatio;
        this.element.width = container.canvas.size.width;
        this.element.height = container.canvas.size.height;
      }
    
      drawConnectLine(p1, p2) {
        var _a;
    
        const lineStyle = this.lineStyle(p1, p2);
    
        if (!lineStyle) {
          return;
        }
    
        const ctx = this.context;
    
        if (!ctx) {
          return;
        }
    
        const pos1 = p1.getPosition();
        const pos2 = p2.getPosition();
        CanvasUtils.drawConnectLine(ctx, (_a = p1.linksWidth) !== null && _a !== void 0 ? _a : this.container.retina.linksWidth, lineStyle, pos1, pos2);
      }
    
      drawGrabLine(particle, lineColor, opacity, mousePos) {
        var _a;
    
        const container = this.container;
        const ctx = container.canvas.context;
    
        if (!ctx) {
          return;
        }
    
        const beginPos = particle.getPosition();
        CanvasUtils.drawGrabLine(ctx, (_a = particle.linksWidth) !== null && _a !== void 0 ? _a : container.retina.linksWidth, beginPos, mousePos, lineColor, opacity);
      }
    
      drawParticleShadow(particle, mousePos) {
        if (!this.context) {
          return;
        }
    
        CanvasUtils.drawParticleShadow(this.container, this.context, particle, mousePos);
      }
    
      drawLinkTriangle(p1, link1, link2) {
        var _a;
    
        const container = this.container;
        const options = container.options;
        const p2 = link1.destination;
        const p3 = link2.destination;
        const triangleOptions = p1.particlesOptions.links.triangles;
        const opacityTriangle = (_a = triangleOptions.opacity) !== null && _a !== void 0 ? _a : (link1.opacity + link2.opacity) / 2;
    
        if (opacityTriangle <= 0) {
          return;
        }
    
        const pos1 = p1.getPosition();
        const pos2 = p2.getPosition();
        const pos3 = p3.getPosition();
        const ctx = this.context;
    
        if (!ctx) {
          return;
        }
    
        if (NumberUtils.getDistance(pos1, pos2) > container.retina.linksDistance || NumberUtils.getDistance(pos3, pos2) > container.retina.linksDistance || NumberUtils.getDistance(pos3, pos1) > container.retina.linksDistance) {
          return;
        }
    
        let colorTriangle = ColorUtils.colorToRgb(triangleOptions.color);
    
        if (!colorTriangle) {
          const linksOptions = p1.particlesOptions.links;
          const linkColor = linksOptions.id !== undefined ? container.particles.linksColors.get(linksOptions.id) : container.particles.linksColor;
          colorTriangle = ColorUtils.getLinkColor(p1, p2, linkColor);
        }
    
        if (!colorTriangle) {
          return;
        }
    
        CanvasUtils.drawLinkTriangle(ctx, pos1, pos2, pos3, options.backgroundMask.enable, options.backgroundMask.composite, colorTriangle, opacityTriangle);
      }
    
      drawLinkLine(p1, link) {
        var _a, _b;
    
        const container = this.container;
        const options = container.options;
        const p2 = link.destination;
        let opacity = link.opacity;
        const pos1 = p1.getPosition();
        const pos2 = p2.getPosition();
        const ctx = this.context;
    
        if (!ctx) {
          return;
        }
    
        let colorLine;
        const twinkle = p1.particlesOptions.twinkle.lines;
    
        if (twinkle.enable) {
          const twinkleFreq = twinkle.frequency;
          const twinkleRgb = ColorUtils.colorToRgb(twinkle.color);
          const twinkling = Math.random() < twinkleFreq;
    
          if (twinkling && twinkleRgb !== undefined) {
            colorLine = twinkleRgb;
            opacity = twinkle.opacity;
          }
        }
    
        if (!colorLine) {
          const linksOptions = p1.particlesOptions.links;
          const linkColor = linksOptions.id !== undefined ? container.particles.linksColors.get(linksOptions.id) : container.particles.linksColor;
          colorLine = ColorUtils.getLinkColor(p1, p2, linkColor);
        }
    
        if (!colorLine) {
          return;
        }
    
        const width = (_a = p1.linksWidth) !== null && _a !== void 0 ? _a : container.retina.linksWidth;
        const maxDistance = (_b = p1.linksDistance) !== null && _b !== void 0 ? _b : container.retina.linksDistance;
        CanvasUtils.drawLinkLine(ctx, width, pos1, pos2, maxDistance, container.canvas.size, p1.particlesOptions.links.warp, options.backgroundMask.enable, options.backgroundMask.composite, colorLine, opacity, p1.particlesOptions.links.shadow);
      }
    
      drawParticle(particle, delta) {
        var _a, _b, _c, _d;
    
        if (((_a = particle.image) === null || _a === void 0 ? void 0 : _a.loaded) === false || particle.spawning || particle.destroyed) {
          return;
        }
    
        const pfColor = particle.getFillColor();
        const psColor = (_b = particle.getStrokeColor()) !== null && _b !== void 0 ? _b : pfColor;
    
        if (!pfColor && !psColor) {
          return;
        }
    
        const options = this.container.options;
        const pOptions = particle.particlesOptions;
        const twinkle = pOptions.twinkle.particles;
        const twinkleFreq = twinkle.frequency;
        const twinkleRgb = ColorUtils.colorToRgb(twinkle.color);
        const twinkling = twinkle.enable && Math.random() < twinkleFreq;
        const radius = particle.getRadius();
        const opacity = twinkling ? twinkle.opacity : (_c = particle.bubble.opacity) !== null && _c !== void 0 ? _c : particle.opacity.value;
        const infectionStage = particle.infecter.infectionStage;
        const infection = options.infection;
        const infectionStages = infection.stages;
        const infectionColor = infectionStage !== undefined ? infectionStages[infectionStage].color : undefined;
        const infectionRgb = ColorUtils.colorToRgb(infectionColor);
        const fColor = twinkling && twinkleRgb !== undefined ? twinkleRgb : infectionRgb !== null && infectionRgb !== void 0 ? infectionRgb : pfColor ? ColorUtils.hslToRgb(pfColor) : undefined;
        const sColor = twinkling && twinkleRgb !== undefined ? twinkleRgb : infectionRgb !== null && infectionRgb !== void 0 ? infectionRgb : psColor ? ColorUtils.hslToRgb(psColor) : undefined;
        const fillColorValue = fColor !== undefined ? ColorUtils.getStyleFromRgb(fColor, opacity) : undefined;
    
        if (!this.context || !fillColorValue && !sColor) {
          return;
        }
    
        const strokeColorValue = sColor !== undefined ? ColorUtils.getStyleFromRgb(sColor, (_d = particle.stroke.opacity) !== null && _d !== void 0 ? _d : opacity) : fillColorValue;
        this.drawParticleLinks(particle);
    
        if (radius > 0) {
          CanvasUtils.drawParticle(this.container, this.context, particle, delta, fillColorValue, strokeColorValue, options.backgroundMask.enable, options.backgroundMask.composite, radius, opacity, particle.particlesOptions.shadow);
        }
      }
    
      drawParticleLinks(particle) {
        if (!this.context) {
          return;
        }
    
        const container = this.container;
        const particles = container.particles;
        const pOptions = particle.particlesOptions;
    
        if (particle.links.length > 0) {
          this.context.save();
          const p1Links = particle.links.filter(l => {
            const linkFreq = container.particles.getLinkFrequency(particle, l.destination);
            return linkFreq <= pOptions.links.frequency;
          });
    
          for (const link of p1Links) {
            const p2 = link.destination;
    
            if (pOptions.links.triangles.enable) {
              const links = p1Links.map(l => l.destination);
              const vertices = p2.links.filter(t => {
                const linkFreq = container.particles.getLinkFrequency(p2, t.destination);
                return linkFreq <= p2.particlesOptions.links.frequency && links.indexOf(t.destination) >= 0;
              });
    
              if (vertices.length) {
                for (const vertex of vertices) {
                  const p3 = vertex.destination;
                  const triangleFreq = particles.getTriangleFrequency(particle, p2, p3);
    
                  if (triangleFreq > pOptions.links.triangles.frequency) {
                    continue;
                  }
    
                  this.drawLinkTriangle(particle, link, vertex);
                }
              }
            }
    
            if (link.opacity > 0 && container.retina.linksWidth > 0) {
              this.drawLinkLine(particle, link);
            }
          }
    
          this.context.restore();
        }
      }
    
      drawPlugin(plugin, delta) {
        if (!this.context) {
          return;
        }
    
        CanvasUtils.drawPlugin(this.context, plugin, delta);
      }
    
      drawLight(mousePos) {
        if (!this.context) {
          return;
        }
    
        CanvasUtils.drawLight(this.container, this.context, mousePos);
      }
    
      paintBase(baseColor) {
        if (!this.context) {
          return;
        }
    
        CanvasUtils.paintBase(this.context, this.size, baseColor);
      }
    
      lineStyle(p1, p2) {
        const options = this.container.options;
        const connectOptions = options.interactivity.modes.connect;
    
        if (this.context) {
          return CanvasUtils.gradient(this.context, p1, p2, connectOptions.links.opacity);
        }
      }
    
      initBackground() {
        const options = this.container.options;
        const background = options.background;
        const element = this.element;
    
        if (!element) {
          return;
        }
    
        const elementStyle = element.style;
    
        if (background.color) {
          const color = ColorUtils.colorToRgb(background.color);
    
          if (color) {
            elementStyle.backgroundColor = ColorUtils.getStyleFromRgb(color, background.opacity);
          }
        }
    
        if (background.image) {
          elementStyle.backgroundImage = background.image;
        }
    
        if (background.position) {
          elementStyle.backgroundPosition = background.position;
        }
    
        if (background.repeat) {
          elementStyle.backgroundRepeat = background.repeat;
        }
    
        if (background.size) {
          elementStyle.backgroundSize = background.size;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Core/Particle/Updater.js
    
    
    
    
    function bounceHorizontal(data) {
      if (data.outMode === OutMode.bounce || data.outMode === OutMode.bounceHorizontal || data.outMode === "bounceHorizontal") {
        const velocity = data.particle.velocity.horizontal;
        let bounced = false;
    
        if (data.direction === OutModeDirection.right && data.bounds.right >= data.canvasSize.width && velocity > 0 || data.direction === OutModeDirection.left && data.bounds.left <= 0 && velocity < 0) {
          const newVelocity = NumberUtils.getValue(data.particle.particlesOptions.bounce.horizontal);
          data.particle.velocity.horizontal *= -newVelocity;
          bounced = true;
        }
    
        if (bounced) {
          const minPos = data.offset.x + data.size;
    
          if (data.bounds.right >= data.canvasSize.width) {
            data.particle.position.x = data.canvasSize.width - minPos;
          } else if (data.bounds.left <= 0) {
            data.particle.position.x = minPos;
          }
        }
      }
    }
    
    function bounceVertical(data) {
      if (data.outMode === OutMode.bounce || data.outMode === OutMode.bounceVertical || data.outMode === "bounceVertical") {
        const velocity = data.particle.velocity.vertical;
        let bounced = false;
    
        if (data.direction === OutModeDirection.bottom && data.bounds.bottom >= data.canvasSize.height && velocity > 0 || data.direction === OutModeDirection.top && data.bounds.top <= 0 && velocity < 0) {
          const newVelocity = NumberUtils.getValue(data.particle.particlesOptions.bounce.vertical);
          data.particle.velocity.vertical *= -newVelocity;
          bounced = true;
        }
    
        if (bounced) {
          const minPos = data.offset.y + data.size;
    
          if (data.bounds.bottom >= data.canvasSize.height) {
            data.particle.position.y = data.canvasSize.height - minPos;
          } else if (data.bounds.top <= 0) {
            data.particle.position.y = minPos;
          }
        }
      }
    }
    
    function checkDestroy(particle, destroy, value, minValue, maxValue) {
      switch (destroy) {
        case DestroyType.max:
          if (value >= maxValue) {
            particle.destroy();
          }
    
          break;
    
        case DestroyType.min:
          if (value <= minValue) {
            particle.destroy();
          }
    
          break;
      }
    }
    
    class Updater {
      constructor(container, particle) {
        this.container = container;
        this.particle = particle;
      }
    
      update(delta) {
        if (this.particle.destroyed) {
          return;
        }
    
        this.updateLife(delta);
    
        if (this.particle.destroyed || this.particle.spawning) {
          return;
        }
    
        this.updateOpacity(delta);
        this.updateSize(delta);
        this.updateAngle(delta);
        this.updateColor(delta);
        this.updateStrokeColor(delta);
        this.updateOutModes(delta);
      }
    
      updateLife(delta) {
        const particle = this.particle;
        let justSpawned = false;
    
        if (particle.spawning) {
          particle.lifeDelayTime += delta.value;
    
          if (particle.lifeDelayTime >= particle.lifeDelay) {
            justSpawned = true;
            particle.spawning = false;
            particle.lifeDelayTime = 0;
            particle.lifeTime = 0;
          }
        }
    
        if (particle.lifeDuration === -1) {
          return;
        }
    
        if (!particle.spawning) {
          if (justSpawned) {
            particle.lifeTime = 0;
          } else {
            particle.lifeTime += delta.value;
          }
    
          if (particle.lifeTime >= particle.lifeDuration) {
            particle.lifeTime = 0;
    
            if (particle.livesRemaining > 0) {
              particle.livesRemaining--;
            }
    
            if (particle.livesRemaining === 0) {
              particle.destroy();
              return;
            }
    
            const canvasSize = this.container.canvas.size;
            particle.position.x = NumberUtils.randomInRange(0, canvasSize.width);
            particle.position.y = NumberUtils.randomInRange(0, canvasSize.height);
            particle.spawning = true;
            particle.lifeDelayTime = 0;
            particle.lifeTime = 0;
            const lifeOptions = particle.particlesOptions.life;
            particle.lifeDelay = NumberUtils.getValue(lifeOptions.delay) * 1000;
            particle.lifeDuration = NumberUtils.getValue(lifeOptions.duration) * 1000;
          }
        }
      }
    
      updateOpacity(delta) {
        var _a, _b;
    
        const particle = this.particle;
        const opacityAnim = particle.particlesOptions.opacity.anim;
        const minValue = opacityAnim.minimumValue;
        const maxValue = particle.particlesOptions.opacity.value;
    
        if (opacityAnim.enable) {
          switch (particle.opacity.status) {
            case AnimationStatus.increasing:
              if (particle.opacity.value >= maxValue) {
                particle.opacity.status = AnimationStatus.decreasing;
              } else {
                particle.opacity.value += ((_a = particle.opacity.velocity) !== null && _a !== void 0 ? _a : 0) * delta.factor;
              }
    
              break;
    
            case AnimationStatus.decreasing:
              if (particle.opacity.value <= minValue) {
                particle.opacity.status = AnimationStatus.increasing;
              } else {
                particle.opacity.value -= ((_b = particle.opacity.velocity) !== null && _b !== void 0 ? _b : 0) * delta.factor;
              }
    
              break;
          }
    
          checkDestroy(particle, opacityAnim.destroy, particle.opacity.value, minValue, maxValue);
    
          if (!particle.destroyed) {
            particle.opacity.value = NumberUtils.clamp(particle.opacity.value, minValue, maxValue);
          }
        }
      }
    
      updateSize(delta) {
        var _a, _b;
    
        const container = this.container;
        const particle = this.particle;
        const sizeOpt = particle.particlesOptions.size;
        const sizeAnim = sizeOpt.animation;
        const sizeVelocity = ((_a = particle.size.velocity) !== null && _a !== void 0 ? _a : 0) * delta.factor;
        const maxValue = (_b = particle.sizeValue) !== null && _b !== void 0 ? _b : container.retina.sizeValue;
        const minValue = sizeAnim.minimumValue * container.retina.pixelRatio;
    
        if (sizeAnim.enable) {
          switch (particle.size.status) {
            case AnimationStatus.increasing:
              if (particle.size.value >= maxValue) {
                particle.size.status = AnimationStatus.decreasing;
              } else {
                particle.size.value += sizeVelocity;
              }
    
              break;
    
            case AnimationStatus.decreasing:
              if (particle.size.value <= minValue) {
                particle.size.status = AnimationStatus.increasing;
              } else {
                particle.size.value -= sizeVelocity;
              }
    
          }
    
          checkDestroy(particle, sizeAnim.destroy, particle.size.value, minValue, maxValue);
    
          if (!particle.destroyed) {
            particle.size.value = NumberUtils.clamp(particle.size.value, minValue, maxValue);
          }
        }
      }
    
      updateAngle(delta) {
        var _a;
    
        const particle = this.particle;
        const rotate = particle.particlesOptions.rotate;
        const rotateAnimation = rotate.animation;
        const speed = ((_a = particle.rotate.velocity) !== null && _a !== void 0 ? _a : 0) * delta.factor;
        const max = 2 * Math.PI;
    
        if (rotate.path) {
          particle.pathAngle = Math.atan2(particle.velocity.vertical, particle.velocity.horizontal);
        } else if (rotateAnimation.enable) {
          switch (particle.rotate.status) {
            case AnimationStatus.increasing:
              particle.rotate.value += speed;
    
              if (particle.rotate.value > max) {
                particle.rotate.value -= max;
              }
    
              break;
    
            case AnimationStatus.decreasing:
            default:
              particle.rotate.value -= speed;
    
              if (particle.rotate.value < 0) {
                particle.rotate.value += max;
              }
    
              break;
          }
        }
      }
    
      updateColor(delta) {
        var _a;
    
        const particle = this.particle;
    
        if (particle.color.value === undefined) {
          return;
        }
    
        if (particle.particlesOptions.color.animation.enable) {
          particle.color.value.h += ((_a = particle.color.velocity) !== null && _a !== void 0 ? _a : 0) * delta.factor;
    
          if (particle.color.value.h > 360) {
            particle.color.value.h -= 360;
          }
        }
      }
    
      updateStrokeColor(delta) {
        var _a, _b;
    
        const particle = this.particle;
        const color = particle.stroke.color;
    
        if (typeof color === "string" || color === undefined) {
          return;
        }
    
        if (particle.strokeColor.value === undefined) {
          return;
        }
    
        if (color.animation.enable) {
          particle.strokeColor.value.h += ((_b = (_a = particle.strokeColor.velocity) !== null && _a !== void 0 ? _a : particle.color.velocity) !== null && _b !== void 0 ? _b : 0) * delta.factor;
    
          if (particle.strokeColor.value.h > 360) {
            particle.strokeColor.value.h -= 360;
          }
        }
      }
    
      updateOutModes(delta) {
        var _a, _b, _c, _d;
    
        const outModes = this.particle.particlesOptions.move.outModes;
        this.updateOutMode(delta, (_a = outModes.bottom) !== null && _a !== void 0 ? _a : outModes.default, OutModeDirection.bottom);
        this.updateOutMode(delta, (_b = outModes.left) !== null && _b !== void 0 ? _b : outModes.default, OutModeDirection.left);
        this.updateOutMode(delta, (_c = outModes.right) !== null && _c !== void 0 ? _c : outModes.default, OutModeDirection.right);
        this.updateOutMode(delta, (_d = outModes.top) !== null && _d !== void 0 ? _d : outModes.default, OutModeDirection.top);
      }
    
      updateOutMode(delta, outMode, direction) {
        const container = this.container;
        const particle = this.particle;
    
        switch (outMode) {
          case OutMode.bounce:
          case OutMode.bounceVertical:
          case OutMode.bounceHorizontal:
          case "bounceVertical":
          case "bounceHorizontal":
            this.updateBounce(delta, direction, outMode);
            break;
    
          case OutMode.destroy:
            if (!Utils.isPointInside(particle.position, container.canvas.size, particle.getRadius(), direction)) {
              container.particles.remove(particle);
            }
    
            break;
    
          case OutMode.out:
            if (!Utils.isPointInside(particle.position, container.canvas.size, particle.getRadius(), direction)) {
              this.fixOutOfCanvasPosition(direction);
            }
    
            break;
    
          case OutMode.none:
            this.bounceNone(direction);
            break;
        }
      }
    
      fixOutOfCanvasPosition(direction) {
        const container = this.container;
        const particle = this.particle;
        const wrap = particle.particlesOptions.move.warp;
        const canvasSize = container.canvas.size;
        const newPos = {
          bottom: canvasSize.height + particle.getRadius() - particle.offset.y,
          left: -particle.getRadius() - particle.offset.x,
          right: canvasSize.width + particle.getRadius() + particle.offset.x,
          top: -particle.getRadius() - particle.offset.y
        };
        const sizeValue = particle.getRadius();
        const nextBounds = Utils.calculateBounds(particle.position, sizeValue);
    
        if (direction === OutModeDirection.right && nextBounds.left > canvasSize.width - particle.offset.x) {
          particle.position.x = newPos.left;
    
          if (!wrap) {
            particle.position.y = Math.random() * canvasSize.height;
          }
        } else if (direction === OutModeDirection.left && nextBounds.right < -particle.offset.x) {
          particle.position.x = newPos.right;
    
          if (!wrap) {
            particle.position.y = Math.random() * canvasSize.height;
          }
        }
    
        if (direction === OutModeDirection.bottom && nextBounds.top > canvasSize.height - particle.offset.y) {
          if (!wrap) {
            particle.position.x = Math.random() * canvasSize.width;
          }
    
          particle.position.y = newPos.top;
        } else if (direction === OutModeDirection.top && nextBounds.bottom < -particle.offset.y) {
          if (!wrap) {
            particle.position.x = Math.random() * canvasSize.width;
          }
    
          particle.position.y = newPos.bottom;
        }
      }
    
      updateBounce(delta, direction, outMode) {
        const container = this.container;
        const particle = this.particle;
        let handled = false;
    
        for (const [, plugin] of container.plugins) {
          if (plugin.particleBounce !== undefined) {
            handled = plugin.particleBounce(particle, delta, direction);
          }
    
          if (handled) {
            break;
          }
        }
    
        if (handled) {
          return;
        }
    
        const pos = particle.getPosition(),
              offset = particle.offset,
              size = particle.getRadius(),
              bounds = Utils.calculateBounds(pos, size),
              canvasSize = container.canvas.size;
        bounceHorizontal({
          particle,
          outMode,
          direction,
          bounds,
          canvasSize,
          offset,
          size
        });
        bounceVertical({
          particle,
          outMode,
          direction,
          bounds,
          canvasSize,
          offset,
          size
        });
      }
    
      bounceNone(direction) {
        const particle = this.particle;
    
        if (particle.particlesOptions.move.distance) {
          return;
        }
    
        const gravityOptions = particle.particlesOptions.move.gravity;
        const container = this.container;
    
        if (!gravityOptions.enable) {
          if (!Utils.isPointInside(particle.position, container.canvas.size, particle.getRadius(), direction)) {
            container.particles.remove(particle);
          }
        } else {
          const position = particle.position;
    
          if (gravityOptions.acceleration >= 0 && position.y > container.canvas.size.height && direction === OutModeDirection.bottom || gravityOptions.acceleration < 0 && position.y < 0 && direction === OutModeDirection.top) {
            container.particles.remove(particle);
          }
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/OptionsColor.js
    class OptionsColor {
      constructor() {
        this.value = "#fff";
      }
    
      static create(source, data) {
        const color = source !== null && source !== void 0 ? source : new OptionsColor();
    
        if (data !== undefined) {
          color.load(typeof data === "string" ? {
            value: data
          } : data);
        }
    
        return color;
      }
    
      load(data) {
        if ((data === null || data === void 0 ? void 0 : data.value) === undefined) {
          return;
        }
    
        this.value = data.value;
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Links/LinksShadow.js
    
    class LinksShadow {
      constructor() {
        this.blur = 5;
        this.color = new OptionsColor();
        this.enable = false;
        this.color.value = "#00ff00";
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.blur !== undefined) {
          this.blur = data.blur;
        }
    
        this.color = OptionsColor.create(this.color, data.color);
    
        if (data.enable !== undefined) {
          this.enable = data.enable;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Links/LinksTriangle.js
    
    class LinksTriangle {
      constructor() {
        this.enable = false;
        this.frequency = 1;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.color !== undefined) {
          this.color = OptionsColor.create(this.color, data.color);
        }
    
        if (data.enable !== undefined) {
          this.enable = data.enable;
        }
    
        if (data.frequency !== undefined) {
          this.frequency = data.frequency;
        }
    
        if (data.opacity !== undefined) {
          this.opacity = data.opacity;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Links/Links.js
    
    
    
    class Links {
      constructor() {
        this.blink = false;
        this.color = new OptionsColor();
        this.consent = false;
        this.distance = 100;
        this.enable = false;
        this.frequency = 1;
        this.opacity = 1;
        this.shadow = new LinksShadow();
        this.triangles = new LinksTriangle();
        this.width = 1;
        this.warp = false;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.id !== undefined) {
          this.id = data.id;
        }
    
        if (data.blink !== undefined) {
          this.blink = data.blink;
        }
    
        this.color = OptionsColor.create(this.color, data.color);
    
        if (data.consent !== undefined) {
          this.consent = data.consent;
        }
    
        if (data.distance !== undefined) {
          this.distance = data.distance;
        }
    
        if (data.enable !== undefined) {
          this.enable = data.enable;
        }
    
        if (data.frequency !== undefined) {
          this.frequency = data.frequency;
        }
    
        if (data.opacity !== undefined) {
          this.opacity = data.opacity;
        }
    
        this.shadow.load(data.shadow);
        this.triangles.load(data.triangles);
    
        if (data.width !== undefined) {
          this.width = data.width;
        }
    
        if (data.warp !== undefined) {
          this.warp = data.warp;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Move/Attract.js
    class Attract {
      constructor() {
        this.enable = false;
        this.rotate = {
          x: 3000,
          y: 3000
        };
      }
    
      get rotateX() {
        return this.rotate.x;
      }
    
      set rotateX(value) {
        this.rotate.x = value;
      }
    
      get rotateY() {
        return this.rotate.y;
      }
    
      set rotateY(value) {
        this.rotate.y = value;
      }
    
      load(data) {
        var _a, _b, _c, _d;
    
        if (data === undefined) {
          return;
        }
    
        if (data.enable !== undefined) {
          this.enable = data.enable;
        }
    
        const rotateX = (_b = (_a = data.rotate) === null || _a === void 0 ? void 0 : _a.x) !== null && _b !== void 0 ? _b : data.rotateX;
    
        if (rotateX !== undefined) {
          this.rotate.x = rotateX;
        }
    
        const rotateY = (_d = (_c = data.rotate) === null || _c === void 0 ? void 0 : _c.y) !== null && _d !== void 0 ? _d : data.rotateY;
    
        if (rotateY !== undefined) {
          this.rotate.y = rotateY;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Move/Trail.js
    
    class Trail {
      constructor() {
        this.enable = false;
        this.length = 10;
        this.fillColor = new OptionsColor();
        this.fillColor.value = "#000000";
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.enable !== undefined) {
          this.enable = data.enable;
        }
    
        this.fillColor = OptionsColor.create(this.fillColor, data.fillColor);
    
        if (data.length !== undefined) {
          this.length = data.length;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Random.js
    class Random {
      constructor() {
        this.enable = false;
        this.minimumValue = 0;
      }
    
      load(data) {
        if (!data) {
          return;
        }
    
        if (data.enable !== undefined) {
          this.enable = data.enable;
        }
    
        if (data.minimumValue !== undefined) {
          this.minimumValue = data.minimumValue;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/ValueWithRandom.js
    
    class ValueWithRandom {
      constructor() {
        this.random = new Random();
        this.value = 0;
      }
    
      load(data) {
        if (!data) {
          return;
        }
    
        if (typeof data.random === "boolean") {
          this.random.enable = data.random;
        } else {
          this.random.load(data.random);
        }
    
        if (data.value !== undefined) {
          this.value = data.value;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Move/Noise/NoiseDelay.js
    
    class NoiseDelay extends ValueWithRandom {
      constructor() {
        super();
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Move/Noise/Noise.js
    
    class Noise {
      constructor() {
        this.delay = new NoiseDelay();
        this.enable = false;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        this.delay.load(data.delay);
    
        if (data.enable !== undefined) {
          this.enable = data.enable;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Move/MoveAngle.js
    class MoveAngle {
      constructor() {
        this.offset = 45;
        this.value = 90;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.offset !== undefined) {
          this.offset = data.offset;
        }
    
        if (data.value !== undefined) {
          this.value = data.value;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Move/MoveGravity.js
    class MoveGravity {
      constructor() {
        this.acceleration = 9.81;
        this.enable = false;
        this.maxSpeed = 50;
      }
    
      load(data) {
        if (!data) {
          return;
        }
    
        if (data.acceleration !== undefined) {
          this.acceleration = data.acceleration;
        }
    
        if (data.enable !== undefined) {
          this.enable = data.enable;
        }
    
        if (data.maxSpeed !== undefined) {
          this.maxSpeed = data.maxSpeed;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Move/OutModes.js
    
    class OutModes {
      constructor() {
        this.default = OutMode.out;
      }
    
      load(data) {
        var _a, _b, _c, _d;
    
        if (!data) {
          return;
        }
    
        if (data.default !== undefined) {
          this.default = data.default;
        }
    
        this.bottom = (_a = data.bottom) !== null && _a !== void 0 ? _a : data.default;
        this.left = (_b = data.left) !== null && _b !== void 0 ? _b : data.default;
        this.right = (_c = data.right) !== null && _c !== void 0 ? _c : data.default;
        this.top = (_d = data.top) !== null && _d !== void 0 ? _d : data.default;
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Move/Move.js
    
    
    
    
    
    
    
    class Move {
      constructor() {
        this.angle = new MoveAngle();
        this.attract = new Attract();
        this.direction = MoveDirection.none;
        this.distance = 0;
        this.enable = false;
        this.gravity = new MoveGravity();
        this.noise = new Noise();
        this.outModes = new OutModes();
        this.random = false;
        this.size = false;
        this.speed = 2;
        this.straight = false;
        this.trail = new Trail();
        this.vibrate = false;
        this.warp = false;
      }
    
      get collisions() {
        return false;
      }
    
      set collisions(value) {}
    
      get bounce() {
        return this.collisions;
      }
    
      set bounce(value) {
        this.collisions = value;
      }
    
      get out_mode() {
        return this.outMode;
      }
    
      set out_mode(value) {
        this.outMode = value;
      }
    
      get outMode() {
        return this.outModes.default;
      }
    
      set outMode(value) {
        this.outModes.default = value;
      }
    
      load(data) {
        var _a, _b;
    
        if (data === undefined) {
          return;
        }
    
        if (data.angle !== undefined) {
          if (typeof data.angle === "number") {
            this.angle.value = data.angle;
          } else {
            this.angle.load(data.angle);
          }
        }
    
        this.attract.load(data.attract);
    
        if (data.direction !== undefined) {
          this.direction = data.direction;
        }
    
        if (data.distance !== undefined) {
          this.distance = data.distance;
        }
    
        if (data.enable !== undefined) {
          this.enable = data.enable;
        }
    
        this.gravity.load(data.gravity);
        this.noise.load(data.noise);
        const outMode = (_a = data.outMode) !== null && _a !== void 0 ? _a : data.out_mode;
    
        if (data.outModes !== undefined || outMode !== undefined) {
          if (typeof data.outModes === "string" || data.outModes === undefined && outMode !== undefined) {
            this.outModes.load({
              default: (_b = data.outModes) !== null && _b !== void 0 ? _b : outMode
            });
          } else {
            this.outModes.load(data.outModes);
          }
        }
    
        if (data.random !== undefined) {
          this.random = data.random;
        }
    
        if (data.size !== undefined) {
          this.size = data.size;
        }
    
        if (data.speed !== undefined) {
          this.speed = data.speed;
        }
    
        if (data.straight !== undefined) {
          this.straight = data.straight;
        }
    
        this.trail.load(data.trail);
    
        if (data.vibrate !== undefined) {
          this.vibrate = data.vibrate;
        }
    
        if (data.warp !== undefined) {
          this.warp = data.warp;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Number/Density.js
    class Density {
      constructor() {
        this.enable = false;
        this.area = 800;
        this.factor = 1000;
      }
    
      get value_area() {
        return this.area;
      }
    
      set value_area(value) {
        this.area = value;
      }
    
      load(data) {
        var _a;
    
        if (data === undefined) {
          return;
        }
    
        if (data.enable !== undefined) {
          this.enable = data.enable;
        }
    
        const area = (_a = data.area) !== null && _a !== void 0 ? _a : data.value_area;
    
        if (area !== undefined) {
          this.area = area;
        }
    
        if (data.factor !== undefined) {
          this.factor = data.factor;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Number/ParticlesNumber.js
    
    class ParticlesNumber {
      constructor() {
        this.density = new Density();
        this.limit = 0;
        this.value = 100;
      }
    
      get max() {
        return this.limit;
      }
    
      set max(value) {
        this.limit = value;
      }
    
      load(data) {
        var _a;
    
        if (data === undefined) {
          return;
        }
    
        this.density.load(data.density);
        const limit = (_a = data.limit) !== null && _a !== void 0 ? _a : data.max;
    
        if (limit !== undefined) {
          this.limit = limit;
        }
    
        if (data.value !== undefined) {
          this.value = data.value;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Opacity/OpacityAnimation.js
    
    class OpacityAnimation {
      constructor() {
        this.destroy = DestroyType.none;
        this.enable = false;
        this.minimumValue = 0;
        this.speed = 2;
        this.startValue = StartValueType.random;
        this.sync = false;
      }
    
      get opacity_min() {
        return this.minimumValue;
      }
    
      set opacity_min(value) {
        this.minimumValue = value;
      }
    
      load(data) {
        var _a;
    
        if (data === undefined) {
          return;
        }
    
        if (data.destroy !== undefined) {
          this.destroy = data.destroy;
        }
    
        if (data.enable !== undefined) {
          this.enable = data.enable;
        }
    
        const minimumValue = (_a = data.minimumValue) !== null && _a !== void 0 ? _a : data.opacity_min;
    
        if (minimumValue !== undefined) {
          this.minimumValue = minimumValue;
        }
    
        if (data.speed !== undefined) {
          this.speed = data.speed;
        }
    
        if (data.startValue !== undefined) {
          this.startValue = data.startValue;
        }
    
        if (data.sync !== undefined) {
          this.sync = data.sync;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Opacity/Opacity.js
    
    
    class Opacity extends ValueWithRandom {
      constructor() {
        super();
        this.animation = new OpacityAnimation();
        this.random.minimumValue = 0.1;
        this.value = 1;
      }
    
      get anim() {
        return this.animation;
      }
    
      set anim(value) {
        this.animation = value;
      }
    
      load(data) {
        var _a;
    
        if (!data) {
          return;
        }
    
        super.load(data);
        this.animation.load((_a = data.animation) !== null && _a !== void 0 ? _a : data.anim);
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Shape/Shape.js
    
    
    class Shape {
      constructor() {
        this.options = {};
        this.type = ShapeType.circle;
      }
    
      get image() {
        var _a;
    
        return (_a = this.options[ShapeType.image]) !== null && _a !== void 0 ? _a : this.options[ShapeType.images];
      }
    
      set image(value) {
        this.options[ShapeType.image] = value;
        this.options[ShapeType.images] = value;
      }
    
      get custom() {
        return this.options;
      }
    
      set custom(value) {
        this.options = value;
      }
    
      get images() {
        return this.image instanceof Array ? this.image : [this.image];
      }
    
      set images(value) {
        this.image = value;
      }
    
      get stroke() {
        return [];
      }
    
      set stroke(_value) {}
    
      get character() {
        var _a;
    
        return (_a = this.options[ShapeType.character]) !== null && _a !== void 0 ? _a : this.options[ShapeType.char];
      }
    
      set character(value) {
        this.options[ShapeType.character] = value;
        this.options[ShapeType.char] = value;
      }
    
      get polygon() {
        var _a;
    
        return (_a = this.options[ShapeType.polygon]) !== null && _a !== void 0 ? _a : this.options[ShapeType.star];
      }
    
      set polygon(value) {
        this.options[ShapeType.polygon] = value;
        this.options[ShapeType.star] = value;
      }
    
      load(data) {
        var _a, _b, _c;
    
        if (data === undefined) {
          return;
        }
    
        const options = (_a = data.options) !== null && _a !== void 0 ? _a : data.custom;
    
        if (options !== undefined) {
          for (const shape in options) {
            const item = options[shape];
    
            if (item !== undefined) {
              this.options[shape] = Utils.deepExtend((_b = this.options[shape]) !== null && _b !== void 0 ? _b : {}, item);
            }
          }
        }
    
        this.loadShape(data.character, ShapeType.character, ShapeType.char, true);
        this.loadShape(data.polygon, ShapeType.polygon, ShapeType.star, false);
        this.loadShape((_c = data.image) !== null && _c !== void 0 ? _c : data.images, ShapeType.image, ShapeType.images, true);
    
        if (data.type !== undefined) {
          this.type = data.type;
        }
      }
    
      loadShape(item, mainKey, altKey, altOverride) {
        var _a, _b, _c, _d;
    
        if (item === undefined) {
          return;
        }
    
        if (item instanceof Array) {
          if (!(this.options[mainKey] instanceof Array)) {
            this.options[mainKey] = [];
    
            if (!this.options[altKey] || altOverride) {
              this.options[altKey] = [];
            }
          }
    
          this.options[mainKey] = Utils.deepExtend((_a = this.options[mainKey]) !== null && _a !== void 0 ? _a : [], item);
    
          if (!this.options[altKey] || altOverride) {
            this.options[altKey] = Utils.deepExtend((_b = this.options[altKey]) !== null && _b !== void 0 ? _b : [], item);
          }
        } else {
          if (this.options[mainKey] instanceof Array) {
            this.options[mainKey] = {};
    
            if (!this.options[altKey] || altOverride) {
              this.options[altKey] = {};
            }
          }
    
          this.options[mainKey] = Utils.deepExtend((_c = this.options[mainKey]) !== null && _c !== void 0 ? _c : {}, item);
    
          if (!this.options[altKey] || altOverride) {
            this.options[altKey] = Utils.deepExtend((_d = this.options[altKey]) !== null && _d !== void 0 ? _d : {}, item);
          }
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Size/SizeAnimation.js
    
    class SizeAnimation {
      constructor() {
        this.destroy = DestroyType.none;
        this.enable = false;
        this.minimumValue = 0;
        this.speed = 5;
        this.startValue = StartValueType.random;
        this.sync = false;
      }
    
      get size_min() {
        return this.minimumValue;
      }
    
      set size_min(value) {
        this.minimumValue = value;
      }
    
      load(data) {
        var _a;
    
        if (data === undefined) {
          return;
        }
    
        if (data.destroy !== undefined) {
          this.destroy = data.destroy;
        }
    
        if (data.enable !== undefined) {
          this.enable = data.enable;
        }
    
        const minimumValue = (_a = data.minimumValue) !== null && _a !== void 0 ? _a : data.size_min;
    
        if (minimumValue !== undefined) {
          this.minimumValue = minimumValue;
        }
    
        if (data.speed !== undefined) {
          this.speed = data.speed;
        }
    
        if (data.startValue !== undefined) {
          this.startValue = data.startValue;
        }
    
        if (data.sync !== undefined) {
          this.sync = data.sync;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Size/Size.js
    
    
    class Size extends ValueWithRandom {
      constructor() {
        super();
        this.animation = new SizeAnimation();
        this.random.minimumValue = 1;
        this.value = 3;
      }
    
      get anim() {
        return this.animation;
      }
    
      set anim(value) {
        this.animation = value;
      }
    
      load(data) {
        var _a;
    
        if (!data) {
          return;
        }
    
        super.load(data);
        const animation = (_a = data.animation) !== null && _a !== void 0 ? _a : data.anim;
    
        if (animation !== undefined) {
          this.animation.load(animation);
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Rotate/RotateAnimation.js
    class RotateAnimation {
      constructor() {
        this.enable = false;
        this.speed = 0;
        this.sync = false;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.enable !== undefined) {
          this.enable = data.enable;
        }
    
        if (data.speed !== undefined) {
          this.speed = data.speed;
        }
    
        if (data.sync !== undefined) {
          this.sync = data.sync;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Rotate/Rotate.js
    
    
    
    class Rotate extends ValueWithRandom {
      constructor() {
        super();
        this.animation = new RotateAnimation();
        this.direction = RotateDirection.clockwise;
        this.path = false;
      }
    
      load(data) {
        if (!data) {
          return;
        }
    
        super.load(data);
    
        if (data.direction !== undefined) {
          this.direction = data.direction;
        }
    
        this.animation.load(data.animation);
    
        if (data.path !== undefined) {
          this.path = data.path;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Shadow.js
    
    class Shadow {
      constructor() {
        this.blur = 0;
        this.color = new OptionsColor();
        this.enable = false;
        this.offset = {
          x: 0,
          y: 0
        };
        this.color.value = "#000000";
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.blur !== undefined) {
          this.blur = data.blur;
        }
    
        this.color = OptionsColor.create(this.color, data.color);
    
        if (data.enable !== undefined) {
          this.enable = data.enable;
        }
    
        if (data.offset === undefined) {
          return;
        }
    
        if (data.offset.x !== undefined) {
          this.offset.x = data.offset.x;
        }
    
        if (data.offset.y !== undefined) {
          this.offset.y = data.offset.y;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/ColorAnimation.js
    class ColorAnimation {
      constructor() {
        this.enable = false;
        this.speed = 1;
        this.sync = true;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.enable !== undefined) {
          this.enable = data.enable;
        }
    
        if (data.speed !== undefined) {
          this.speed = data.speed;
        }
    
        if (data.sync !== undefined) {
          this.sync = data.sync;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/AnimatableColor.js
    
    
    class AnimatableColor extends OptionsColor {
      constructor() {
        super();
        this.animation = new ColorAnimation();
      }
    
      static create(source, data) {
        const color = source !== null && source !== void 0 ? source : new AnimatableColor();
    
        if (data !== undefined) {
          color.load(typeof data === "string" ? {
            value: data
          } : data);
        }
    
        return color;
      }
    
      load(data) {
        super.load(data);
        this.animation.load(data === null || data === void 0 ? void 0 : data.animation);
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Stroke.js
    
    class Stroke {
      constructor() {
        this.width = 0;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.color !== undefined) {
          this.color = AnimatableColor.create(this.color, data.color);
        }
    
        if (data.width !== undefined) {
          this.width = data.width;
        }
    
        if (data.opacity !== undefined) {
          this.opacity = data.opacity;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Bounce/BounceFactor.js
    
    class BounceFactor extends ValueWithRandom {
      constructor() {
        super();
        this.random.minimumValue = 0.1;
        this.value = 1;
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Bounce/Bounce.js
    
    class Bounce {
      constructor() {
        this.horizontal = new BounceFactor();
        this.vertical = new BounceFactor();
      }
    
      load(data) {
        if (!data) {
          return;
        }
    
        this.horizontal.load(data.horizontal);
        this.vertical.load(data.vertical);
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Collisions.js
    
    
    class Collisions {
      constructor() {
        this.bounce = new Bounce();
        this.enable = false;
        this.mode = CollisionMode.bounce;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        this.bounce.load(data.bounce);
    
        if (data.enable !== undefined) {
          this.enable = data.enable;
        }
    
        if (data.mode !== undefined) {
          this.mode = data.mode;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Twinkle/TwinkleValues.js
    
    class TwinkleValues {
      constructor() {
        this.enable = false;
        this.frequency = 0.05;
        this.opacity = 1;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.color !== undefined) {
          this.color = OptionsColor.create(this.color, data.color);
        }
    
        if (data.enable !== undefined) {
          this.enable = data.enable;
        }
    
        if (data.frequency !== undefined) {
          this.frequency = data.frequency;
        }
    
        if (data.opacity !== undefined) {
          this.opacity = data.opacity;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Twinkle/Twinkle.js
    
    class Twinkle {
      constructor() {
        this.lines = new TwinkleValues();
        this.particles = new TwinkleValues();
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        this.lines.load(data.lines);
        this.particles.load(data.particles);
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Life/LifeDelay.js
    
    class LifeDelay extends ValueWithRandom {
      constructor() {
        super();
        this.sync = false;
      }
    
      load(data) {
        if (!data) {
          return;
        }
    
        super.load(data);
    
        if (data.sync !== undefined) {
          this.sync = data.sync;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Life/LifeDuration.js
    
    class LifeDuration extends ValueWithRandom {
      constructor() {
        super();
        this.random.minimumValue = 0.0001;
        this.sync = false;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        super.load(data);
    
        if (data.sync !== undefined) {
          this.sync = data.sync;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Life/Life.js
    
    
    class Life {
      constructor() {
        this.count = 0;
        this.delay = new LifeDelay();
        this.duration = new LifeDuration();
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.count !== undefined) {
          this.count = data.count;
        }
    
        this.delay.load(data.delay);
        this.duration.load(data.duration);
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Particles/Particles.js
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    class Particles {
      constructor() {
        this.bounce = new Bounce();
        this.collisions = new Collisions();
        this.color = new AnimatableColor();
        this.life = new Life();
        this.links = new Links();
        this.move = new Move();
        this.number = new ParticlesNumber();
        this.opacity = new Opacity();
        this.reduceDuplicates = false;
        this.rotate = new Rotate();
        this.shadow = new Shadow();
        this.shape = new Shape();
        this.size = new Size();
        this.stroke = new Stroke();
        this.twinkle = new Twinkle();
      }
    
      get line_linked() {
        return this.links;
      }
    
      set line_linked(value) {
        this.links = value;
      }
    
      get lineLinked() {
        return this.links;
      }
    
      set lineLinked(value) {
        this.links = value;
      }
    
      load(data) {
        var _a, _b, _c, _d, _e, _f, _g;
    
        if (data === undefined) {
          return;
        }
    
        this.bounce.load(data.bounce);
        this.color = AnimatableColor.create(this.color, data.color);
        this.life.load(data.life);
        const links = (_b = (_a = data.links) !== null && _a !== void 0 ? _a : data.lineLinked) !== null && _b !== void 0 ? _b : data.line_linked;
    
        if (links !== undefined) {
          this.links.load(links);
        }
    
        this.move.load(data.move);
        this.number.load(data.number);
        this.opacity.load(data.opacity);
    
        if (data.reduceDuplicates !== undefined) {
          this.reduceDuplicates = data.reduceDuplicates;
        }
    
        this.rotate.load(data.rotate);
        this.shape.load(data.shape);
        this.size.load(data.size);
        this.shadow.load(data.shadow);
        this.twinkle.load(data.twinkle);
        const collisions = (_d = (_c = data.move) === null || _c === void 0 ? void 0 : _c.collisions) !== null && _d !== void 0 ? _d : (_e = data.move) === null || _e === void 0 ? void 0 : _e.bounce;
    
        if (collisions !== undefined) {
          this.collisions.enable = collisions;
        }
    
        this.collisions.load(data.collisions);
        const strokeToLoad = (_f = data.stroke) !== null && _f !== void 0 ? _f : (_g = data.shape) === null || _g === void 0 ? void 0 : _g.stroke;
    
        if (strokeToLoad === undefined) {
          return;
        }
    
        if (strokeToLoad instanceof Array) {
          this.stroke = strokeToLoad.map(s => {
            const tmp = new Stroke();
            tmp.load(s);
            return tmp;
          });
        } else {
          if (this.stroke instanceof Array) {
            this.stroke = new Stroke();
          }
    
          this.stroke.load(strokeToLoad);
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Core/Particle/Infecter.js
    class Infecter {
      constructor(container) {
        this.container = container;
      }
    
      startInfection(stage) {
        const options = this.container.options;
        const stages = options.infection.stages;
        const stagesCount = stages.length;
    
        if (stage > stagesCount || stage < 0) {
          return;
        }
    
        this.infectionDelay = 0;
        this.infectionDelayStage = stage;
      }
    
      updateInfectionStage(stage) {
        const options = this.container.options;
        const stagesCount = options.infection.stages.length;
    
        if (stage > stagesCount || stage < 0 || this.infectionStage !== undefined && this.infectionStage > stage) {
          return;
        }
    
        this.infectionStage = stage;
        this.infectionTime = 0;
      }
    
      updateInfection(delta) {
        const options = this.container.options;
        const infection = options.infection;
        const stages = options.infection.stages;
        const stagesCount = stages.length;
    
        if (this.infectionDelay !== undefined && this.infectionDelayStage !== undefined) {
          const stage = this.infectionDelayStage;
    
          if (stage > stagesCount || stage < 0) {
            return;
          }
    
          if (this.infectionDelay > infection.delay * 1000) {
            this.infectionStage = stage;
            this.infectionTime = 0;
            delete this.infectionDelay;
            delete this.infectionDelayStage;
          } else {
            this.infectionDelay += delta;
          }
        } else {
          delete this.infectionDelay;
          delete this.infectionDelayStage;
        }
    
        if (this.infectionStage !== undefined && this.infectionTime !== undefined) {
          const infectionStage = stages[this.infectionStage];
    
          if (infectionStage.duration !== undefined && infectionStage.duration >= 0) {
            if (this.infectionTime > infectionStage.duration * 1000) {
              this.nextInfectionStage();
            } else {
              this.infectionTime += delta;
            }
          } else {
            this.infectionTime += delta;
          }
        } else {
          delete this.infectionStage;
          delete this.infectionTime;
        }
      }
    
      nextInfectionStage() {
        const options = this.container.options;
        const stagesCount = options.infection.stages.length;
    
        if (stagesCount <= 0 || this.infectionStage === undefined) {
          return;
        }
    
        this.infectionTime = 0;
    
        if (stagesCount <= ++this.infectionStage) {
          if (options.infection.cure) {
            delete this.infectionStage;
            delete this.infectionTime;
            return;
          } else {
            this.infectionStage = 0;
            this.infectionTime = 0;
          }
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Core/Particle/Mover.js
    
    
    class Mover {
      constructor(container, particle) {
        this.container = container;
        this.particle = particle;
      }
    
      move(delta) {
        const particle = this.particle;
        particle.bubble.inRange = false;
        particle.links = [];
    
        for (const [, plugin] of this.container.plugins) {
          if (particle.destroyed) {
            break;
          }
    
          if (plugin.particleUpdate) {
            plugin.particleUpdate(particle, delta);
          }
        }
    
        if (particle.destroyed) {
          return;
        }
    
        this.moveParticle(delta);
        this.moveParallax();
      }
    
      moveParticle(delta) {
        var _a, _b;
    
        const particle = this.particle;
        const particlesOptions = particle.particlesOptions;
    
        if (!particlesOptions.move.enable) {
          return;
        }
    
        const container = this.container;
        const slowFactor = this.getProximitySpeedFactor();
        const baseSpeed = ((_a = particle.moveSpeed) !== null && _a !== void 0 ? _a : container.retina.moveSpeed) * container.retina.reduceFactor;
        const maxSize = (_b = particle.sizeValue) !== null && _b !== void 0 ? _b : container.retina.sizeValue;
        const sizeFactor = particlesOptions.move.size ? particle.getRadius() / maxSize : 1;
        const moveSpeed = baseSpeed / 2 * sizeFactor * slowFactor * delta.factor;
        this.applyNoise(delta);
        const gravityOptions = particlesOptions.move.gravity;
    
        if (gravityOptions.enable) {
          particle.velocity.vertical += gravityOptions.acceleration * delta.factor / (60 * moveSpeed);
        }
    
        const velocity = {
          horizontal: particle.velocity.horizontal * moveSpeed,
          vertical: particle.velocity.vertical * moveSpeed
        };
    
        if (gravityOptions.enable && velocity.vertical >= gravityOptions.maxSpeed && gravityOptions.maxSpeed > 0) {
          velocity.vertical = gravityOptions.maxSpeed;
          particle.velocity.vertical = velocity.vertical / moveSpeed;
        }
    
        particle.position.x += velocity.horizontal;
        particle.position.y += velocity.vertical;
    
        if (particlesOptions.move.vibrate) {
          particle.position.x += Math.sin(particle.position.x * Math.cos(particle.position.y));
          particle.position.y += Math.cos(particle.position.y * Math.sin(particle.position.x));
        }
    
        const initialPosition = particle.initialPosition;
        const initialDistance = NumberUtils.getDistance(initialPosition, particle.position);
    
        if (particle.maxDistance) {
          if (initialDistance >= particle.maxDistance && !particle.misplaced) {
            particle.misplaced = initialDistance > particle.maxDistance;
            particle.velocity.horizontal = particle.velocity.vertical / 2 - particle.velocity.horizontal;
            particle.velocity.vertical = particle.velocity.horizontal / 2 - particle.velocity.vertical;
          } else if (initialDistance < particle.maxDistance && particle.misplaced) {
            particle.misplaced = false;
          } else if (particle.misplaced) {
            if (particle.position.x < initialPosition.x && particle.velocity.horizontal < 0 || particle.position.x > initialPosition.x && particle.velocity.horizontal > 0) {
              particle.velocity.horizontal *= -Math.random();
            }
    
            if (particle.position.y < initialPosition.y && particle.velocity.vertical < 0 || particle.position.y > initialPosition.y && particle.velocity.vertical > 0) {
              particle.velocity.vertical *= -Math.random();
            }
          }
        }
      }
    
      applyNoise(delta) {
        const particle = this.particle;
        const particlesOptions = particle.particlesOptions;
        const noiseOptions = particlesOptions.move.noise;
        const noiseEnabled = noiseOptions.enable;
    
        if (!noiseEnabled) {
          return;
        }
    
        const container = this.container;
    
        if (particle.lastNoiseTime <= particle.noiseDelay) {
          particle.lastNoiseTime += delta.value;
          return;
        }
    
        const noise = container.noise.generate(particle);
        particle.velocity.horizontal += Math.cos(noise.angle) * noise.length;
        particle.velocity.horizontal = NumberUtils.clamp(particle.velocity.horizontal, -1, 1);
        particle.velocity.vertical += Math.sin(noise.angle) * noise.length;
        particle.velocity.vertical = NumberUtils.clamp(particle.velocity.vertical, -1, 1);
        particle.lastNoiseTime -= particle.noiseDelay;
      }
    
      moveParallax() {
        const container = this.container;
        const options = container.options;
    
        if (Utils.isSsr() || !options.interactivity.events.onHover.parallax.enable) {
          return;
        }
    
        const particle = this.particle;
        const parallaxForce = options.interactivity.events.onHover.parallax.force;
        const mousePos = container.interactivity.mouse.position;
    
        if (!mousePos) {
          return;
        }
    
        const canvasCenter = {
          x: container.canvas.size.width / 2,
          y: container.canvas.size.height / 2
        };
        const parallaxSmooth = options.interactivity.events.onHover.parallax.smooth;
        const factor = particle.getRadius() / parallaxForce;
        const tmp = {
          x: (mousePos.x - canvasCenter.x) * factor,
          y: (mousePos.y - canvasCenter.y) * factor
        };
        particle.offset.x += (tmp.x - particle.offset.x) / parallaxSmooth;
        particle.offset.y += (tmp.y - particle.offset.y) / parallaxSmooth;
      }
    
      getProximitySpeedFactor() {
        const container = this.container;
        const options = container.options;
        const active = Utils.isInArray(HoverMode.slow, options.interactivity.events.onHover.mode);
    
        if (!active) {
          return 1;
        }
    
        const mousePos = this.container.interactivity.mouse.position;
    
        if (!mousePos) {
          return 1;
        }
    
        const particlePos = this.particle.getPosition();
        const dist = NumberUtils.getDistance(mousePos, particlePos);
        const radius = container.retina.slowModeRadius;
    
        if (dist > radius) {
          return 1;
        }
    
        const proximityFactor = dist / radius || 0;
        const slowFactor = options.interactivity.modes.slow.factor;
        return proximityFactor / slowFactor;
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Core/Particle.js
    
    
    
    
    
    
    
    class Particle {
      constructor(id, container, position, overrideOptions) {
        var _a, _b, _c, _d, _e, _f, _g, _h, _j;
    
        this.id = id;
        this.container = container;
        this.links = [];
        this.fill = true;
        this.close = true;
        this.lastNoiseTime = 0;
        this.destroyed = false;
        this.misplaced = false;
        const pxRatio = container.retina.pixelRatio;
        const options = container.options;
        const particlesOptions = new Particles();
        particlesOptions.load(options.particles);
        const shapeType = particlesOptions.shape.type;
        const reduceDuplicates = particlesOptions.reduceDuplicates;
        this.shape = shapeType instanceof Array ? Utils.itemFromArray(shapeType, this.id, reduceDuplicates) : shapeType;
    
        if (overrideOptions === null || overrideOptions === void 0 ? void 0 : overrideOptions.shape) {
          if (overrideOptions.shape.type) {
            const overrideShapeType = overrideOptions.shape.type;
            this.shape = overrideShapeType instanceof Array ? Utils.itemFromArray(overrideShapeType, this.id, reduceDuplicates) : overrideShapeType;
          }
    
          const shapeOptions = new Shape();
          shapeOptions.load(overrideOptions.shape);
    
          if (this.shape) {
            const shapeData = shapeOptions.options[this.shape];
    
            if (shapeData) {
              this.shapeData = Utils.deepExtend({}, shapeData instanceof Array ? Utils.itemFromArray(shapeData, this.id, reduceDuplicates) : shapeData);
            }
          }
        } else {
          const shapeData = particlesOptions.shape.options[this.shape];
    
          if (shapeData) {
            this.shapeData = Utils.deepExtend({}, shapeData instanceof Array ? Utils.itemFromArray(shapeData, this.id, reduceDuplicates) : shapeData);
          }
        }
    
        if (overrideOptions !== undefined) {
          particlesOptions.load(overrideOptions);
        }
    
        if (((_a = this.shapeData) === null || _a === void 0 ? void 0 : _a.particles) !== undefined) {
          particlesOptions.load((_b = this.shapeData) === null || _b === void 0 ? void 0 : _b.particles);
        }
    
        this.fill = (_d = (_c = this.shapeData) === null || _c === void 0 ? void 0 : _c.fill) !== null && _d !== void 0 ? _d : this.fill;
        this.close = (_f = (_e = this.shapeData) === null || _e === void 0 ? void 0 : _e.close) !== null && _f !== void 0 ? _f : this.close;
        this.particlesOptions = particlesOptions;
        this.noiseDelay = NumberUtils.getValue(this.particlesOptions.move.noise.delay) * 1000;
        container.retina.initParticle(this);
        const color = this.particlesOptions.color;
        const sizeOptions = this.particlesOptions.size;
        const sizeValue = NumberUtils.getValue(sizeOptions) * container.retina.pixelRatio;
        const randomSize = typeof sizeOptions.random === "boolean" ? sizeOptions.random : sizeOptions.random.enable;
        this.size = {
          value: sizeValue
        };
        this.direction = this.particlesOptions.move.direction;
        this.bubble = {
          inRange: false
        };
        this.initialVelocity = this.calculateVelocity();
        this.velocity = {
          horizontal: this.initialVelocity.horizontal,
          vertical: this.initialVelocity.vertical
        };
        this.pathAngle = Math.atan2(this.initialVelocity.vertical, this.initialVelocity.horizontal);
        const rotateOptions = this.particlesOptions.rotate;
        this.rotate = {
          value: (rotateOptions.random.enable ? Math.random() * 360 : rotateOptions.value) * Math.PI / 180
        };
        let rotateDirection = rotateOptions.direction;
    
        if (rotateDirection === RotateDirection.random) {
          const index = Math.floor(Math.random() * 2);
          rotateDirection = index > 0 ? RotateDirection.counterClockwise : RotateDirection.clockwise;
        }
    
        switch (rotateDirection) {
          case RotateDirection.counterClockwise:
          case "counterClockwise":
            this.rotate.status = AnimationStatus.decreasing;
            break;
    
          case RotateDirection.clockwise:
            this.rotate.status = AnimationStatus.increasing;
            break;
        }
    
        const rotateAnimation = this.particlesOptions.rotate.animation;
    
        if (rotateAnimation.enable) {
          this.rotate.velocity = rotateAnimation.speed / 360 * container.retina.reduceFactor;
    
          if (!rotateAnimation.sync) {
            this.rotate.velocity *= Math.random();
          }
        }
    
        const sizeAnimation = this.particlesOptions.size.animation;
    
        if (sizeAnimation.enable) {
          this.size.status = AnimationStatus.increasing;
    
          if (!randomSize) {
            switch (sizeAnimation.startValue) {
              case StartValueType.min:
                this.size.value = sizeAnimation.minimumValue * pxRatio;
                break;
    
              case StartValueType.random:
                this.size.value = NumberUtils.randomInRange(sizeAnimation.minimumValue * pxRatio, this.size.value);
                break;
    
              case StartValueType.max:
              default:
                this.size.status = AnimationStatus.decreasing;
                break;
            }
          }
    
          this.size.velocity = ((_g = this.sizeAnimationSpeed) !== null && _g !== void 0 ? _g : container.retina.sizeAnimationSpeed) / 100 * container.retina.reduceFactor;
    
          if (!sizeAnimation.sync) {
            this.size.velocity *= Math.random();
          }
        }
    
        this.color = {
          value: ColorUtils.colorToHsl(color, this.id, reduceDuplicates)
        };
        const colorAnimation = this.particlesOptions.color.animation;
    
        if (colorAnimation.enable) {
          this.color.velocity = colorAnimation.speed / 100 * container.retina.reduceFactor;
    
          if (!colorAnimation.sync) {
            this.color.velocity *= Math.random();
          }
        }
    
        this.position = this.calcPosition(this.container, position);
        this.initialPosition = {
          x: this.position.x,
          y: this.position.y
        };
        this.offset = {
          x: 0,
          y: 0
        };
        const opacityOptions = this.particlesOptions.opacity;
        const randomOpacity = typeof opacityOptions.random === "boolean" ? opacityOptions.random : opacityOptions.random.enable;
        this.opacity = {
          value: NumberUtils.getValue(opacityOptions)
        };
        const opacityAnimation = opacityOptions.animation;
    
        if (opacityAnimation.enable) {
          this.opacity.status = AnimationStatus.increasing;
    
          if (!randomOpacity) {
            switch (opacityAnimation.startValue) {
              case StartValueType.min:
                this.opacity.value = opacityAnimation.minimumValue;
                break;
    
              case StartValueType.random:
                this.opacity.value = NumberUtils.randomInRange(opacityAnimation.minimumValue, this.opacity.value);
                break;
    
              case StartValueType.max:
              default:
                this.opacity.status = AnimationStatus.decreasing;
                break;
            }
          }
    
          this.opacity.velocity = opacityAnimation.speed / 100 * container.retina.reduceFactor;
    
          if (!opacityAnimation.sync) {
            this.opacity.velocity *= Math.random();
          }
        }
    
        this.sides = 24;
        let drawer = container.drawers.get(this.shape);
    
        if (!drawer) {
          drawer = Plugins.getShapeDrawer(this.shape);
    
          if (drawer) {
            container.drawers.set(this.shape, drawer);
          }
        }
    
        const sideCountFunc = drawer === null || drawer === void 0 ? void 0 : drawer.getSidesCount;
    
        if (sideCountFunc) {
          this.sides = sideCountFunc(this);
        }
    
        const imageShape = this.loadImageShape(container, drawer);
    
        if (imageShape) {
          this.image = imageShape.image;
          this.fill = imageShape.fill;
          this.close = imageShape.close;
        }
    
        this.stroke = this.particlesOptions.stroke instanceof Array ? Utils.itemFromArray(this.particlesOptions.stroke, this.id, reduceDuplicates) : this.particlesOptions.stroke;
        this.strokeWidth = this.stroke.width * container.retina.pixelRatio;
        this.strokeColor = {
          value: (_h = ColorUtils.colorToHsl(this.stroke.color)) !== null && _h !== void 0 ? _h : this.color.value
        };
    
        if (typeof this.stroke.color !== "string") {
          const strokeColorAnimation = (_j = this.stroke.color) === null || _j === void 0 ? void 0 : _j.animation;
    
          if (strokeColorAnimation && this.strokeColor) {
            if (strokeColorAnimation.enable) {
              this.strokeColor.velocity = strokeColorAnimation.speed / 100 * container.retina.reduceFactor;
    
              if (!strokeColorAnimation.sync) {
                this.strokeColor.velocity = this.strokeColor.velocity * Math.random();
              }
            } else {
              this.strokeColor.velocity = 0;
            }
    
            if (strokeColorAnimation.enable && !strokeColorAnimation.sync && this.strokeColor.value) {
              this.strokeColor.value.h = Math.random() * 360;
            }
          }
        }
    
        const lifeOptions = particlesOptions.life;
        this.lifeDelay = container.retina.reduceFactor ? NumberUtils.getValue(lifeOptions.delay) * (lifeOptions.delay.sync ? 1 : Math.random()) / container.retina.reduceFactor * 1000 : 0;
        this.lifeDelayTime = 0;
        this.lifeDuration = container.retina.reduceFactor ? NumberUtils.getValue(lifeOptions.duration) * (lifeOptions.duration.sync ? 1 : Math.random()) / container.retina.reduceFactor * 1000 : 0;
        this.lifeTime = 0;
        this.livesRemaining = particlesOptions.life.count;
        this.spawning = this.lifeDelay > 0;
    
        if (this.lifeDuration <= 0) {
          this.lifeDuration = -1;
        }
    
        if (this.livesRemaining <= 0) {
          this.livesRemaining = -1;
        }
    
        this.shadowColor = ColorUtils.colorToRgb(this.particlesOptions.shadow.color);
        this.updater = new Updater(container, this);
        this.infecter = new Infecter(container);
        this.mover = new Mover(container, this);
      }
    
      move(delta) {
        this.mover.move(delta);
      }
    
      update(delta) {
        this.updater.update(delta);
      }
    
      draw(delta) {
        this.container.canvas.drawParticle(this, delta);
      }
    
      getPosition() {
        return {
          x: this.position.x + this.offset.x,
          y: this.position.y + this.offset.y
        };
      }
    
      getRadius() {
        return this.bubble.radius || this.size.value;
      }
    
      getFillColor() {
        var _a;
    
        return (_a = this.bubble.color) !== null && _a !== void 0 ? _a : this.color.value;
      }
    
      getStrokeColor() {
        var _a, _b;
    
        return (_b = (_a = this.bubble.color) !== null && _a !== void 0 ? _a : this.strokeColor.value) !== null && _b !== void 0 ? _b : this.color.value;
      }
    
      destroy() {
        this.destroyed = true;
        this.bubble.inRange = false;
        this.links = [];
      }
    
      calcPosition(container, position) {
        var _a, _b;
    
        for (const [, plugin] of container.plugins) {
          const pluginPos = plugin.particlePosition !== undefined ? plugin.particlePosition(position, this) : undefined;
    
          if (pluginPos !== undefined) {
            return Utils.deepExtend({}, pluginPos);
          }
        }
    
        const pos = {
          x: (_a = position === null || position === void 0 ? void 0 : position.x) !== null && _a !== void 0 ? _a : Math.random() * container.canvas.size.width,
          y: (_b = position === null || position === void 0 ? void 0 : position.y) !== null && _b !== void 0 ? _b : Math.random() * container.canvas.size.height
        };
        const outMode = this.particlesOptions.move.outMode;
    
        if (Utils.isInArray(outMode, OutMode.bounce) || Utils.isInArray(outMode, OutMode.bounceHorizontal)) {
          if (pos.x > container.canvas.size.width - this.size.value * 2) {
            pos.x -= this.size.value;
          } else if (pos.x < this.size.value * 2) {
            pos.x += this.size.value;
          }
        }
    
        if (Utils.isInArray(outMode, OutMode.bounce) || Utils.isInArray(outMode, OutMode.bounceVertical)) {
          if (pos.y > container.canvas.size.height - this.size.value * 2) {
            pos.y -= this.size.value;
          } else if (pos.y < this.size.value * 2) {
            pos.y += this.size.value;
          }
        }
    
        return pos;
      }
    
      calculateVelocity() {
        const baseVelocity = NumberUtils.getParticleBaseVelocity(this);
        const res = {
          horizontal: 0,
          vertical: 0
        };
        const moveOptions = this.particlesOptions.move;
        let rad;
        let radOffset = Math.PI / 4;
    
        if (typeof moveOptions.angle === "number") {
          rad = Math.PI / 180 * moveOptions.angle;
        } else {
          rad = Math.PI / 180 * moveOptions.angle.value;
          radOffset = Math.PI / 180 * moveOptions.angle.offset;
        }
    
        const range = {
          left: Math.sin(radOffset + rad / 2) - Math.sin(radOffset - rad / 2),
          right: Math.cos(radOffset + rad / 2) - Math.cos(radOffset - rad / 2)
        };
    
        if (moveOptions.straight) {
          res.horizontal = baseVelocity.x;
          res.vertical = baseVelocity.y;
    
          if (moveOptions.random) {
            res.horizontal += NumberUtils.randomInRange(range.left, range.right) / 2;
            res.vertical += NumberUtils.randomInRange(range.left, range.right) / 2;
          }
        } else {
          res.horizontal = baseVelocity.x + NumberUtils.randomInRange(range.left, range.right) / 2;
          res.vertical = baseVelocity.y + NumberUtils.randomInRange(range.left, range.right) / 2;
        }
    
        return res;
      }
    
      loadImageShape(container, drawer) {
        var _a, _b, _c, _d, _e;
    
        if (!(this.shape === ShapeType.image || this.shape === ShapeType.images)) {
          return;
        }
    
        const imageDrawer = drawer;
        const images = imageDrawer.getImages(container).images;
        const imageData = this.shapeData;
        const image = (_a = images.find(t => t.source === imageData.src)) !== null && _a !== void 0 ? _a : images[0];
        const color = this.getFillColor();
        let imageRes;
    
        if (!image) {
          return;
        }
    
        if (image.svgData !== undefined && imageData.replaceColor && color) {
          const svgColoredData = ColorUtils.replaceColorSvg(image, color, this.opacity.value);
          const svg = new Blob([svgColoredData], {
            type: "image/svg+xml"
          });
          const domUrl = URL || window.URL || window.webkitURL || window;
          const url = domUrl.createObjectURL(svg);
          const img = new Image();
          imageRes = {
            data: image,
            loaded: false,
            ratio: imageData.width / imageData.height,
            replaceColor: (_b = imageData.replaceColor) !== null && _b !== void 0 ? _b : imageData.replace_color,
            source: imageData.src
          };
          img.addEventListener("load", () => {
            if (this.image) {
              this.image.loaded = true;
              image.element = img;
            }
    
            domUrl.revokeObjectURL(url);
          });
          img.addEventListener("error", () => {
            domUrl.revokeObjectURL(url);
            Utils.loadImage(imageData.src).then(img2 => {
              if (this.image) {
                image.element = img2.element;
                this.image.loaded = true;
              }
            });
          });
          img.src = url;
        } else {
          imageRes = {
            data: image,
            loaded: true,
            ratio: imageData.width / imageData.height,
            replaceColor: (_c = imageData.replaceColor) !== null && _c !== void 0 ? _c : imageData.replace_color,
            source: imageData.src
          };
        }
    
        if (!imageRes.ratio) {
          imageRes.ratio = 1;
        }
    
        const fill = (_d = imageData.fill) !== null && _d !== void 0 ? _d : this.fill;
        const close = (_e = imageData.close) !== null && _e !== void 0 ? _e : this.close;
        return {
          image: imageRes,
          fill,
          close
        };
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Interactions/External/Grabber.js
    
    
    class Grabber {
      constructor(container) {
        this.container = container;
      }
    
      isEnabled() {
        const container = this.container;
        const mouse = container.interactivity.mouse;
        const events = container.options.interactivity.events;
    
        if (!(events.onHover.enable && mouse.position)) {
          return false;
        }
    
        const hoverMode = events.onHover.mode;
        return Utils.isInArray(HoverMode.grab, hoverMode);
      }
    
      reset() {}
    
      interact() {
        var _a;
    
        const container = this.container;
        const options = container.options;
        const interactivity = options.interactivity;
    
        if (interactivity.events.onHover.enable && container.interactivity.status === Constants.mouseMoveEvent) {
          const mousePos = container.interactivity.mouse.position;
    
          if (mousePos === undefined) {
            return;
          }
    
          const distance = container.retina.grabModeDistance;
          const query = container.particles.quadTree.queryCircle(mousePos, distance);
    
          for (const particle of query) {
            const pos = particle.getPosition();
            const pointDistance = NumberUtils.getDistance(pos, mousePos);
    
            if (pointDistance <= distance) {
              const grabLineOptions = interactivity.modes.grab.links;
              const lineOpacity = grabLineOptions.opacity;
              const opacityLine = lineOpacity - pointDistance * lineOpacity / distance;
    
              if (opacityLine > 0) {
                const optColor = (_a = grabLineOptions.color) !== null && _a !== void 0 ? _a : particle.particlesOptions.links.color;
    
                if (!container.particles.grabLineColor) {
                  const linksOptions = container.options.interactivity.modes.grab.links;
                  container.particles.grabLineColor = ColorUtils.getLinkRandomColor(optColor, linksOptions.blink, linksOptions.consent);
                }
    
                const colorLine = ColorUtils.getLinkColor(particle, undefined, container.particles.grabLineColor);
    
                if (colorLine === undefined) {
                  return;
                }
    
                container.canvas.drawGrabLine(particle, colorLine, opacityLine, mousePos);
              }
            }
          }
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Interactions/External/Repulser.js
    
    
    class Repulser {
      constructor(container) {
        this.container = container;
      }
    
      isEnabled() {
        const container = this.container;
        const options = container.options;
        const mouse = container.interactivity.mouse;
        const events = options.interactivity.events;
        const divs = events.onDiv;
        const divRepulse = Utils.isDivModeEnabled(DivMode.repulse, divs);
    
        if (!(divRepulse || events.onHover.enable && mouse.position || events.onClick.enable && mouse.clickPosition)) {
          return false;
        }
    
        const hoverMode = events.onHover.mode;
        const clickMode = events.onClick.mode;
        return Utils.isInArray(HoverMode.repulse, hoverMode) || Utils.isInArray(ClickMode.repulse, clickMode) || divRepulse;
      }
    
      reset() {}
    
      interact() {
        const container = this.container;
        const options = container.options;
        const mouseMoveStatus = container.interactivity.status === Constants.mouseMoveEvent;
        const events = options.interactivity.events;
        const hoverEnabled = events.onHover.enable;
        const hoverMode = events.onHover.mode;
        const clickEnabled = events.onClick.enable;
        const clickMode = events.onClick.mode;
        const divs = events.onDiv;
    
        if (mouseMoveStatus && hoverEnabled && Utils.isInArray(HoverMode.repulse, hoverMode)) {
          this.hoverRepulse();
        } else if (clickEnabled && Utils.isInArray(ClickMode.repulse, clickMode)) {
          this.clickRepulse();
        } else {
          Utils.divModeExecute(DivMode.repulse, divs, (selector, div) => this.singleSelectorRepulse(selector, div));
        }
      }
    
      singleSelectorRepulse(selector, div) {
        const container = this.container;
        const query = document.querySelectorAll(selector);
    
        if (!query.length) {
          return;
        }
    
        query.forEach(item => {
          const elem = item;
          const pxRatio = container.retina.pixelRatio;
          const pos = {
            x: (elem.offsetLeft + elem.offsetWidth / 2) * pxRatio,
            y: (elem.offsetTop + elem.offsetHeight / 2) * pxRatio
          };
          const repulseRadius = elem.offsetWidth / 2 * pxRatio;
          const area = div.type === DivType.circle ? new Circle(pos.x, pos.y, repulseRadius) : new Rectangle(elem.offsetLeft * pxRatio, elem.offsetTop * pxRatio, elem.offsetWidth * pxRatio, elem.offsetHeight * pxRatio);
          const divs = container.options.interactivity.modes.repulse.divs;
          const divRepulse = Utils.divMode(divs, elem);
          this.processRepulse(pos, repulseRadius, area, divRepulse);
        });
      }
    
      hoverRepulse() {
        const container = this.container;
        const mousePos = container.interactivity.mouse.position;
    
        if (!mousePos) {
          return;
        }
    
        const repulseRadius = container.retina.repulseModeDistance;
        this.processRepulse(mousePos, repulseRadius, new Circle(mousePos.x, mousePos.y, repulseRadius));
      }
    
      processRepulse(position, repulseRadius, area, divRepulse) {
        var _a;
    
        const container = this.container;
        const query = container.particles.quadTree.query(area);
    
        for (const particle of query) {
          const {
            dx,
            dy,
            distance
          } = NumberUtils.getDistances(particle.position, position);
          const normVec = {
            x: dx / distance,
            y: dy / distance
          };
          const velocity = ((_a = divRepulse === null || divRepulse === void 0 ? void 0 : divRepulse.speed) !== null && _a !== void 0 ? _a : container.options.interactivity.modes.repulse.speed) * 100;
          const repulseFactor = NumberUtils.clamp((1 - Math.pow(distance / repulseRadius, 2)) * velocity, 0, 50);
          particle.position.x = particle.position.x + normVec.x * repulseFactor;
          particle.position.y = particle.position.y + normVec.y * repulseFactor;
        }
      }
    
      clickRepulse() {
        const container = this.container;
    
        if (!container.repulse.finish) {
          if (!container.repulse.count) {
            container.repulse.count = 0;
          }
    
          container.repulse.count++;
    
          if (container.repulse.count === container.particles.count) {
            container.repulse.finish = true;
          }
        }
    
        if (container.repulse.clicking) {
          const repulseDistance = container.retina.repulseModeDistance;
          const repulseRadius = Math.pow(repulseDistance / 6, 3);
          const mouseClickPos = container.interactivity.mouse.clickPosition;
    
          if (mouseClickPos === undefined) {
            return;
          }
    
          const range = new Circle(mouseClickPos.x, mouseClickPos.y, repulseRadius);
          const query = container.particles.quadTree.query(range);
    
          for (const particle of query) {
            const {
              dx,
              dy,
              distance
            } = NumberUtils.getDistances(mouseClickPos, particle.position);
            const d = distance * distance;
            const velocity = container.options.interactivity.modes.repulse.speed;
            const force = -repulseRadius * velocity / d;
    
            if (d <= repulseRadius) {
              container.repulse.particles.push(particle);
              const angle = Math.atan2(dy, dx);
              particle.velocity.horizontal = force * Math.cos(angle);
              particle.velocity.vertical = force * Math.sin(angle);
            }
          }
        } else if (container.repulse.clicking === false) {
          for (const particle of container.repulse.particles) {
            particle.velocity.horizontal = particle.initialVelocity.horizontal;
            particle.velocity.vertical = particle.initialVelocity.vertical;
          }
    
          container.repulse.particles = [];
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Interactions/External/Bubbler.js
    
    
    
    function calculateBubbleValue(particleValue, modeValue, optionsValue, ratio) {
      if (modeValue > optionsValue) {
        const size = particleValue + (modeValue - optionsValue) * ratio;
        return NumberUtils.clamp(size, particleValue, modeValue);
      } else if (modeValue < optionsValue) {
        const size = particleValue - (optionsValue - modeValue) * ratio;
        return NumberUtils.clamp(size, modeValue, particleValue);
      }
    }
    
    class Bubbler {
      constructor(container) {
        this.container = container;
      }
    
      isEnabled() {
        const container = this.container;
        const options = container.options;
        const mouse = container.interactivity.mouse;
        const events = options.interactivity.events;
        const divs = events.onDiv;
        const divBubble = Utils.isDivModeEnabled(DivMode.bubble, divs);
    
        if (!(divBubble || events.onHover.enable && mouse.position || events.onClick.enable && mouse.clickPosition)) {
          return false;
        }
    
        const hoverMode = events.onHover.mode;
        const clickMode = events.onClick.mode;
        return Utils.isInArray(HoverMode.bubble, hoverMode) || Utils.isInArray(ClickMode.bubble, clickMode) || divBubble;
      }
    
      reset(particle, force) {
        if (!particle.bubble.inRange || force) {
          delete particle.bubble.div;
          delete particle.bubble.opacity;
          delete particle.bubble.radius;
          delete particle.bubble.color;
        }
      }
    
      interact() {
        const options = this.container.options;
        const events = options.interactivity.events;
        const onHover = events.onHover;
        const onClick = events.onClick;
        const hoverEnabled = onHover.enable;
        const hoverMode = onHover.mode;
        const clickEnabled = onClick.enable;
        const clickMode = onClick.mode;
        const divs = events.onDiv;
    
        if (hoverEnabled && Utils.isInArray(HoverMode.bubble, hoverMode)) {
          this.hoverBubble();
        } else if (clickEnabled && Utils.isInArray(ClickMode.bubble, clickMode)) {
          this.clickBubble();
        } else {
          Utils.divModeExecute(DivMode.bubble, divs, (selector, div) => this.singleSelectorHover(selector, div));
        }
      }
    
      singleSelectorHover(selector, div) {
        const container = this.container;
        const selectors = document.querySelectorAll(selector);
    
        if (!selectors.length) {
          return;
        }
    
        selectors.forEach(item => {
          const elem = item;
          const pxRatio = container.retina.pixelRatio;
          const pos = {
            x: (elem.offsetLeft + elem.offsetWidth / 2) * pxRatio,
            y: (elem.offsetTop + elem.offsetHeight / 2) * pxRatio
          };
          const repulseRadius = elem.offsetWidth / 2 * pxRatio;
          const area = div.type === DivType.circle ? new Circle(pos.x, pos.y, repulseRadius) : new Rectangle(elem.offsetLeft * pxRatio, elem.offsetTop * pxRatio, elem.offsetWidth * pxRatio, elem.offsetHeight * pxRatio);
          const query = container.particles.quadTree.query(area);
    
          for (const particle of query) {
            if (!area.contains(particle.getPosition())) {
              continue;
            }
    
            particle.bubble.inRange = true;
            const divs = container.options.interactivity.modes.bubble.divs;
            const divBubble = Utils.divMode(divs, elem);
    
            if (!particle.bubble.div || particle.bubble.div !== elem) {
              this.reset(particle, true);
              particle.bubble.div = elem;
            }
    
            this.hoverBubbleSize(particle, 1, divBubble);
            this.hoverBubbleOpacity(particle, 1, divBubble);
            this.hoverBubbleColor(particle, divBubble);
          }
        });
      }
    
      process(particle, distMouse, timeSpent, data) {
        const container = this.container;
        const bubbleParam = data.bubbleObj.optValue;
    
        if (bubbleParam === undefined) {
          return;
        }
    
        const options = container.options;
        const bubbleDuration = options.interactivity.modes.bubble.duration;
        const bubbleDistance = container.retina.bubbleModeDistance;
        const particlesParam = data.particlesObj.optValue;
        const pObjBubble = data.bubbleObj.value;
        const pObj = data.particlesObj.value || 0;
        const type = data.type;
    
        if (bubbleParam !== particlesParam) {
          if (!container.bubble.durationEnd) {
            if (distMouse <= bubbleDistance) {
              const obj = pObjBubble !== null && pObjBubble !== void 0 ? pObjBubble : pObj;
    
              if (obj !== bubbleParam) {
                const value = pObj - timeSpent * (pObj - bubbleParam) / bubbleDuration;
    
                if (type === ProcessBubbleType.size) {
                  particle.bubble.radius = value;
                }
    
                if (type === ProcessBubbleType.opacity) {
                  particle.bubble.opacity = value;
                }
              }
            } else {
              if (type === ProcessBubbleType.size) {
                delete particle.bubble.radius;
              }
    
              if (type === ProcessBubbleType.opacity) {
                delete particle.bubble.opacity;
              }
            }
          } else if (pObjBubble) {
            if (type === ProcessBubbleType.size) {
              delete particle.bubble.radius;
            }
    
            if (type === ProcessBubbleType.opacity) {
              delete particle.bubble.opacity;
            }
          }
        }
      }
    
      clickBubble() {
        var _a;
    
        const container = this.container;
        const options = container.options;
        const mouseClickPos = container.interactivity.mouse.clickPosition;
    
        if (mouseClickPos === undefined) {
          return;
        }
    
        const distance = container.retina.bubbleModeDistance;
        const query = container.particles.quadTree.queryCircle(mouseClickPos, distance);
    
        for (const particle of query) {
          if (!container.bubble.clicking) {
            continue;
          }
    
          particle.bubble.inRange = !container.bubble.durationEnd;
          const pos = particle.getPosition();
          const distMouse = NumberUtils.getDistance(pos, mouseClickPos);
          const timeSpent = (new Date().getTime() - (container.interactivity.mouse.clickTime || 0)) / 1000;
    
          if (timeSpent > options.interactivity.modes.bubble.duration) {
            container.bubble.durationEnd = true;
          }
    
          if (timeSpent > options.interactivity.modes.bubble.duration * 2) {
            container.bubble.clicking = false;
            container.bubble.durationEnd = false;
          }
    
          const sizeData = {
            bubbleObj: {
              optValue: container.retina.bubbleModeSize,
              value: particle.bubble.radius
            },
            particlesObj: {
              optValue: (_a = particle.sizeValue) !== null && _a !== void 0 ? _a : container.retina.sizeValue,
              value: particle.size.value
            },
            type: ProcessBubbleType.size
          };
          this.process(particle, distMouse, timeSpent, sizeData);
          const opacityData = {
            bubbleObj: {
              optValue: options.interactivity.modes.bubble.opacity,
              value: particle.bubble.opacity
            },
            particlesObj: {
              optValue: particle.particlesOptions.opacity.value,
              value: particle.opacity.value
            },
            type: ProcessBubbleType.opacity
          };
          this.process(particle, distMouse, timeSpent, opacityData);
    
          if (!container.bubble.durationEnd) {
            if (distMouse <= container.retina.bubbleModeDistance) {
              this.hoverBubbleColor(particle);
            } else {
              delete particle.bubble.color;
            }
          } else {
            delete particle.bubble.color;
          }
        }
      }
    
      hoverBubble() {
        const container = this.container;
        const mousePos = container.interactivity.mouse.position;
    
        if (mousePos === undefined) {
          return;
        }
    
        const distance = container.retina.bubbleModeDistance;
        const query = container.particles.quadTree.queryCircle(mousePos, distance);
    
        for (const particle of query) {
          particle.bubble.inRange = true;
          const pos = particle.getPosition();
          const pointDistance = NumberUtils.getDistance(pos, mousePos);
          const ratio = 1 - pointDistance / distance;
    
          if (pointDistance <= distance) {
            if (ratio >= 0 && container.interactivity.status === Constants.mouseMoveEvent) {
              this.hoverBubbleSize(particle, ratio);
              this.hoverBubbleOpacity(particle, ratio);
              this.hoverBubbleColor(particle);
            }
          } else {
            this.reset(particle);
          }
    
          if (container.interactivity.status === Constants.mouseLeaveEvent) {
            this.reset(particle);
          }
        }
      }
    
      hoverBubbleSize(particle, ratio, divBubble) {
        var _a;
    
        const container = this.container;
        const modeSize = (divBubble === null || divBubble === void 0 ? void 0 : divBubble.size) ? divBubble.size * container.retina.pixelRatio : container.retina.bubbleModeSize;
    
        if (modeSize === undefined) {
          return;
        }
    
        const optSize = (_a = particle.sizeValue) !== null && _a !== void 0 ? _a : container.retina.sizeValue;
        const pSize = particle.size.value;
        const size = calculateBubbleValue(pSize, modeSize, optSize, ratio);
    
        if (size !== undefined) {
          particle.bubble.radius = size;
        }
      }
    
      hoverBubbleOpacity(particle, ratio, divBubble) {
        var _a;
    
        const options = this.container.options;
        const modeOpacity = (_a = divBubble === null || divBubble === void 0 ? void 0 : divBubble.opacity) !== null && _a !== void 0 ? _a : options.interactivity.modes.bubble.opacity;
    
        if (modeOpacity === undefined) {
          return;
        }
    
        const optOpacity = particle.particlesOptions.opacity.value;
        const pOpacity = particle.opacity.value;
        const opacity = calculateBubbleValue(pOpacity, modeOpacity, optOpacity, ratio);
    
        if (opacity !== undefined) {
          particle.bubble.opacity = opacity;
        }
      }
    
      hoverBubbleColor(particle, divBubble) {
        var _a;
    
        const options = this.container.options;
    
        if (particle.bubble.color === undefined) {
          const modeColor = (_a = divBubble === null || divBubble === void 0 ? void 0 : divBubble.color) !== null && _a !== void 0 ? _a : options.interactivity.modes.bubble.color;
    
          if (modeColor === undefined) {
            return;
          }
    
          const bubbleColor = modeColor instanceof Array ? Utils.itemFromArray(modeColor) : modeColor;
          particle.bubble.color = ColorUtils.colorToHsl(bubbleColor);
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Interactions/External/Connector.js
    
    
    class Connector {
      constructor(container) {
        this.container = container;
      }
    
      isEnabled() {
        const container = this.container;
        const mouse = container.interactivity.mouse;
        const events = container.options.interactivity.events;
    
        if (!(events.onHover.enable && mouse.position)) {
          return false;
        }
    
        const hoverMode = events.onHover.mode;
        return Utils.isInArray(HoverMode.connect, hoverMode);
      }
    
      reset() {}
    
      interact() {
        const container = this.container;
        const options = container.options;
    
        if (options.interactivity.events.onHover.enable && container.interactivity.status === "mousemove") {
          const mousePos = container.interactivity.mouse.position;
    
          if (!mousePos) {
            return;
          }
    
          const distance = Math.abs(container.retina.connectModeRadius);
          const query = container.particles.quadTree.queryCircle(mousePos, distance);
          let i = 0;
    
          for (const p1 of query) {
            const pos1 = p1.getPosition();
    
            for (const p2 of query.slice(i + 1)) {
              const pos2 = p2.getPosition();
              const distMax = Math.abs(container.retina.connectModeDistance);
              const xDiff = Math.abs(pos1.x - pos2.x);
              const yDiff = Math.abs(pos1.y - pos2.y);
    
              if (xDiff < distMax && yDiff < distMax) {
                container.canvas.drawConnectLine(p1, p2);
              }
            }
    
            ++i;
          }
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Interactions/Particles/Linker.js
    
    class Linker {
      constructor(container) {
        this.container = container;
      }
    
      isEnabled(particle) {
        return particle.particlesOptions.links.enable;
      }
    
      reset() {}
    
      interact(p1) {
        var _a;
    
        const container = this.container;
        const linkOpt1 = p1.particlesOptions.links;
        const optOpacity = linkOpt1.opacity;
        const optDistance = (_a = p1.linksDistance) !== null && _a !== void 0 ? _a : container.retina.linksDistance;
        const canvasSize = container.canvas.size;
        const warp = linkOpt1.warp;
        const pos1 = p1.getPosition();
        const range = warp ? new CircleWarp(pos1.x, pos1.y, optDistance, canvasSize) : new Circle(pos1.x, pos1.y, optDistance);
        const query = container.particles.quadTree.query(range);
    
        for (const p2 of query) {
          const linkOpt2 = p2.particlesOptions.links;
    
          if (p1 === p2 || !linkOpt2.enable || linkOpt1.id !== linkOpt2.id || p2.spawning || p2.destroyed) {
            continue;
          }
    
          const pos2 = p2.getPosition();
          let distance = NumberUtils.getDistance(pos1, pos2);
    
          if (warp) {
            if (distance > optDistance) {
              const pos2NE = {
                x: pos2.x - canvasSize.width,
                y: pos2.y
              };
              distance = NumberUtils.getDistance(pos1, pos2NE);
    
              if (distance > optDistance) {
                const pos2SE = {
                  x: pos2.x - canvasSize.width,
                  y: pos2.y - canvasSize.height
                };
                distance = NumberUtils.getDistance(pos1, pos2SE);
    
                if (distance > optDistance) {
                  const pos2SW = {
                    x: pos2.x,
                    y: pos2.y - canvasSize.height
                  };
                  distance = NumberUtils.getDistance(pos1, pos2SW);
                }
              }
            }
          }
    
          if (distance > optDistance) {
            return;
          }
    
          const opacityLine = (1 - distance / optDistance) * optOpacity;
          const linksOptions = p1.particlesOptions.links;
          let linkColor = linksOptions.id !== undefined ? container.particles.linksColors.get(linksOptions.id) : container.particles.linksColor;
    
          if (!linkColor) {
            const optColor = linksOptions.color;
            linkColor = ColorUtils.getLinkRandomColor(optColor, linksOptions.blink, linksOptions.consent);
    
            if (linksOptions.id !== undefined) {
              container.particles.linksColors.set(linksOptions.id, linkColor);
            } else {
              container.particles.linksColor = linkColor;
            }
          }
    
          if (p2.links.map(t => t.destination).indexOf(p1) === -1 && p1.links.map(t => t.destination).indexOf(p2) === -1) {
            p1.links.push({
              destination: p2,
              opacity: opacityLine
            });
          }
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Interactions/Particles/Attractor.js
    
    class Attractor {
      constructor(container) {
        this.container = container;
      }
    
      interact(p1) {
        var _a;
    
        const container = this.container;
        const distance = (_a = p1.linksDistance) !== null && _a !== void 0 ? _a : container.retina.linksDistance;
        const pos1 = p1.getPosition();
        const query = container.particles.quadTree.queryCircle(pos1, distance);
    
        for (const p2 of query) {
          if (p1 === p2 || !p2.particlesOptions.move.attract.enable || p2.destroyed || p2.spawning) {
            continue;
          }
    
          const pos2 = p2.getPosition();
          const {
            dx,
            dy
          } = NumberUtils.getDistances(pos1, pos2);
          const rotate = p1.particlesOptions.move.attract.rotate;
          const ax = dx / (rotate.x * 1000);
          const ay = dy / (rotate.y * 1000);
          p1.velocity.horizontal -= ax;
          p1.velocity.vertical -= ay;
          p2.velocity.horizontal += ax;
          p2.velocity.vertical += ay;
        }
      }
    
      isEnabled(particle) {
        return particle.particlesOptions.move.attract.enable;
      }
    
      reset() {}
    
    }
    // CONCATENATED MODULE: ./dist/browser/Interactions/Particles/Collider.js
    
    
    
    function bounce(p1, p2) {
      Utils.circleBounce(Utils.circleBounceDataFromParticle(p1), Utils.circleBounceDataFromParticle(p2));
    }
    
    function destroy(p1, p2) {
      if (p1.getRadius() === undefined && p2.getRadius() !== undefined) {
        p1.destroy();
      } else if (p1.getRadius() !== undefined && p2.getRadius() === undefined) {
        p2.destroy();
      } else if (p1.getRadius() !== undefined && p2.getRadius() !== undefined) {
        if (p1.getRadius() >= p2.getRadius()) {
          p2.destroy();
        } else {
          p1.destroy();
        }
      }
    }
    
    class Collider {
      constructor(container) {
        this.container = container;
      }
    
      isEnabled(particle) {
        return particle.particlesOptions.collisions.enable;
      }
    
      reset() {}
    
      interact(p1) {
        const container = this.container;
        const pos1 = p1.getPosition();
        const query = container.particles.quadTree.queryCircle(pos1, p1.getRadius() * 2);
    
        for (const p2 of query) {
          if (p1 === p2 || !p2.particlesOptions.collisions.enable || p1.particlesOptions.collisions.mode !== p2.particlesOptions.collisions.mode || p2.destroyed || p2.spawning) {
            continue;
          }
    
          const pos2 = p2.getPosition();
          const dist = NumberUtils.getDistance(pos1, pos2);
          const radius1 = p1.getRadius();
          const radius2 = p2.getRadius();
          const distP = radius1 + radius2;
    
          if (dist <= distP) {
            this.resolveCollision(p1, p2);
          }
        }
      }
    
      resolveCollision(p1, p2) {
        switch (p1.particlesOptions.collisions.mode) {
          case CollisionMode.absorb:
            {
              this.absorb(p1, p2);
              break;
            }
    
          case CollisionMode.bounce:
            {
              bounce(p1, p2);
              break;
            }
    
          case CollisionMode.destroy:
            {
              destroy(p1, p2);
              break;
            }
        }
      }
    
      absorb(p1, p2) {
        const container = this.container;
        const fps = container.options.fpsLimit / 1000;
    
        if (p1.getRadius() === undefined && p2.getRadius() !== undefined) {
          p1.destroy();
        } else if (p1.getRadius() !== undefined && p2.getRadius() === undefined) {
          p2.destroy();
        } else if (p1.getRadius() !== undefined && p2.getRadius() !== undefined) {
          if (p1.getRadius() >= p2.getRadius()) {
            const factor = NumberUtils.clamp(p1.getRadius() / p2.getRadius(), 0, p2.getRadius()) * fps;
            p1.size.value += factor;
            p2.size.value -= factor;
    
            if (p2.getRadius() <= container.retina.pixelRatio) {
              p2.size.value = 0;
              p2.destroy();
            }
          } else {
            const factor = NumberUtils.clamp(p2.getRadius() / p1.getRadius(), 0, p1.getRadius()) * fps;
            p1.size.value -= factor;
            p2.size.value += factor;
    
            if (p1.getRadius() <= container.retina.pixelRatio) {
              p1.size.value = 0;
              p1.destroy();
            }
          }
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Interactions/Particles/Infecter.js
    class Infecter_Infecter {
      constructor(container) {
        this.container = container;
      }
    
      isEnabled() {
        return this.container.options.infection.enable;
      }
    
      reset() {}
    
      interact(p1, delta) {
        var _a, _b;
    
        const infecter1 = p1.infecter;
        infecter1.updateInfection(delta.value);
    
        if (infecter1.infectionStage === undefined) {
          return;
        }
    
        const container = this.container;
        const options = container.options;
        const infectionOptions = options.infection;
    
        if (!infectionOptions.enable || infectionOptions.stages.length < 1) {
          return;
        }
    
        const infectionStage1 = infectionOptions.stages[infecter1.infectionStage];
        const pxRatio = container.retina.pixelRatio;
        const radius = p1.getRadius() * 2 + infectionStage1.radius * pxRatio;
        const pos = p1.getPosition();
        const infectedStage1 = (_a = infectionStage1.infectedStage) !== null && _a !== void 0 ? _a : infecter1.infectionStage;
        const query = container.particles.quadTree.queryCircle(pos, radius);
        const infections = infectionStage1.rate;
        const neighbors = query.length;
    
        for (const p2 of query) {
          if (p2 === p1 || p2.destroyed || p2.spawning || !(p2.infecter.infectionStage === undefined || p2.infecter.infectionStage !== infecter1.infectionStage)) {
            continue;
          }
    
          const infecter2 = p2.infecter;
    
          if (Math.random() < infections / neighbors) {
            if (infecter2.infectionStage === undefined) {
              infecter2.startInfection(infectedStage1);
            } else if (infecter2.infectionStage < infecter1.infectionStage) {
              infecter2.updateInfectionStage(infectedStage1);
            } else if (infecter2.infectionStage > infecter1.infectionStage) {
              const infectionStage2 = infectionOptions.stages[infecter2.infectionStage];
              const infectedStage2 = (_b = infectionStage2 === null || infectionStage2 === void 0 ? void 0 : infectionStage2.infectedStage) !== null && _b !== void 0 ? _b : infecter2.infectionStage;
              infecter1.updateInfectionStage(infectedStage2);
            }
          }
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Interactions/External/TrailMaker.js
    
    
    class TrailMaker {
      constructor(container) {
        this.container = container;
        this.delay = 0;
      }
    
      interact(delta) {
        if (!this.container.retina.reduceFactor) {
          return;
        }
    
        const container = this.container;
        const options = container.options;
        const trailOptions = options.interactivity.modes.trail;
        const optDelay = trailOptions.delay * 1000 / this.container.retina.reduceFactor;
    
        if (this.delay < optDelay) {
          this.delay += delta.value;
        }
    
        if (this.delay >= optDelay) {
          container.particles.push(trailOptions.quantity, container.interactivity.mouse, trailOptions.particles);
          this.delay -= optDelay;
        }
      }
    
      isEnabled() {
        const container = this.container;
        const options = container.options;
        const mouse = container.interactivity.mouse;
        const events = options.interactivity.events;
        return mouse.clicking && mouse.inside && !!mouse.position && Utils.isInArray(ClickMode.trail, events.onClick.mode) || mouse.inside && !!mouse.position && Utils.isInArray(HoverMode.trail, events.onHover.mode);
      }
    
      reset() {}
    
    }
    // CONCATENATED MODULE: ./dist/browser/Interactions/External/Attractor.js
    
    
    class Attractor_Attractor {
      constructor(container) {
        this.container = container;
      }
    
      isEnabled() {
        const container = this.container;
        const options = container.options;
        const mouse = container.interactivity.mouse;
        const events = options.interactivity.events;
    
        if (!(events.onHover.enable && mouse.position || events.onClick.enable && mouse.clickPosition)) {
          return false;
        }
    
        const hoverMode = events.onHover.mode;
        const clickMode = events.onClick.mode;
        return Utils.isInArray(HoverMode.attract, hoverMode) || Utils.isInArray(ClickMode.attract, clickMode);
      }
    
      reset() {}
    
      interact() {
        const container = this.container;
        const options = container.options;
        const mouseMoveStatus = container.interactivity.status === Constants.mouseMoveEvent;
        const events = options.interactivity.events;
        const hoverEnabled = events.onHover.enable;
        const hoverMode = events.onHover.mode;
        const clickEnabled = events.onClick.enable;
        const clickMode = events.onClick.mode;
    
        if (mouseMoveStatus && hoverEnabled && Utils.isInArray(HoverMode.attract, hoverMode)) {
          this.hoverAttract();
        } else if (clickEnabled && Utils.isInArray(ClickMode.attract, clickMode)) {
          this.clickAttract();
        }
      }
    
      hoverAttract() {
        const container = this.container;
        const mousePos = container.interactivity.mouse.position;
    
        if (!mousePos) {
          return;
        }
    
        const attractRadius = container.retina.attractModeDistance;
        this.processAttract(mousePos, attractRadius, new Circle(mousePos.x, mousePos.y, attractRadius));
      }
    
      processAttract(position, attractRadius, area) {
        const container = this.container;
        const query = container.particles.quadTree.query(area);
    
        for (const particle of query) {
          const {
            dx,
            dy,
            distance
          } = NumberUtils.getDistances(particle.position, position);
          const normVec = {
            x: dx / distance,
            y: dy / distance
          };
          const velocity = container.options.interactivity.modes.attract.speed;
          const attractFactor = NumberUtils.clamp((1 - Math.pow(distance / attractRadius, 2)) * velocity, 0, 50);
          particle.position.x = particle.position.x - normVec.x * attractFactor;
          particle.position.y = particle.position.y - normVec.y * attractFactor;
        }
      }
    
      clickAttract() {
        const container = this.container;
    
        if (!container.attract.finish) {
          if (!container.attract.count) {
            container.attract.count = 0;
          }
    
          container.attract.count++;
    
          if (container.attract.count === container.particles.count) {
            container.attract.finish = true;
          }
        }
    
        if (container.attract.clicking) {
          const mousePos = container.interactivity.mouse.clickPosition;
    
          if (!mousePos) {
            return;
          }
    
          const attractRadius = container.retina.attractModeDistance;
          this.processAttract(mousePos, attractRadius, new Circle(mousePos.x, mousePos.y, attractRadius));
        } else if (container.attract.clicking === false) {
          container.attract.particles = [];
        }
    
        return;
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Interactions/Particles/Lighter.js
    
    
    class Lighter {
      constructor(container) {
        this.container = container;
      }
    
      interact(particle) {
        const container = this.container;
        const options = container.options;
    
        if (options.interactivity.events.onHover.enable && container.interactivity.status === "mousemove") {
          const mousePos = this.container.interactivity.mouse.position;
    
          if (mousePos) {
            container.canvas.drawParticleShadow(particle, mousePos);
          }
        }
      }
    
      isEnabled() {
        const container = this.container;
        const mouse = container.interactivity.mouse;
        const events = container.options.interactivity.events;
    
        if (!(events.onHover.enable && mouse.position)) {
          return false;
        }
    
        const hoverMode = events.onHover.mode;
        return Utils.isInArray(HoverMode.light, hoverMode);
      }
    
      reset() {}
    
    }
    // CONCATENATED MODULE: ./dist/browser/Interactions/External/Lighter.js
    
    
    class Lighter_Lighter {
      constructor(container) {
        this.container = container;
      }
    
      interact() {
        const container = this.container;
        const options = container.options;
    
        if (options.interactivity.events.onHover.enable && container.interactivity.status === "mousemove") {
          const mousePos = container.interactivity.mouse.position;
    
          if (!mousePos) {
            return;
          }
    
          container.canvas.drawLight(mousePos);
        }
      }
    
      isEnabled() {
        const container = this.container;
        const mouse = container.interactivity.mouse;
        const events = container.options.interactivity.events;
    
        if (!(events.onHover.enable && mouse.position)) {
          return false;
        }
    
        const hoverMode = events.onHover.mode;
        return Utils.isInArray(HoverMode.light, hoverMode);
      }
    
      reset() {}
    
    }
    // CONCATENATED MODULE: ./dist/browser/Interactions/External/Bouncer.js
    
    
    
    
    
    class Bouncer {
      constructor(container) {
        this.container = container;
      }
    
      isEnabled() {
        const container = this.container;
        const options = container.options;
        const mouse = container.interactivity.mouse;
        const events = options.interactivity.events;
        const divs = events.onDiv;
        return mouse.position && events.onHover.enable && Utils.isInArray(HoverMode.bounce, events.onHover.mode) || Utils.isDivModeEnabled(DivMode.bounce, divs);
      }
    
      interact() {
        const container = this.container;
        const options = container.options;
        const events = options.interactivity.events;
        const mouseMoveStatus = container.interactivity.status === Constants.mouseMoveEvent;
        const hoverEnabled = events.onHover.enable;
        const hoverMode = events.onHover.mode;
        const divs = events.onDiv;
    
        if (mouseMoveStatus && hoverEnabled && Utils.isInArray(HoverMode.bounce, hoverMode)) {
          this.processMouseBounce();
        } else {
          Utils.divModeExecute(DivMode.bounce, divs, (selector, div) => this.singleSelectorBounce(selector, div));
        }
      }
    
      reset() {}
    
      processMouseBounce() {
        const container = this.container;
        const pxRatio = container.retina.pixelRatio;
        const tolerance = 10 * pxRatio;
        const mousePos = container.interactivity.mouse.position;
        const radius = container.retina.bounceModeDistance;
    
        if (mousePos) {
          this.processBounce(mousePos, radius, new Circle(mousePos.x, mousePos.y, radius + tolerance));
        }
      }
    
      singleSelectorBounce(selector, div) {
        const container = this.container;
        const query = document.querySelectorAll(selector);
    
        if (!query.length) {
          return;
        }
    
        query.forEach(item => {
          const elem = item;
          const pxRatio = container.retina.pixelRatio;
          const pos = {
            x: (elem.offsetLeft + elem.offsetWidth / 2) * pxRatio,
            y: (elem.offsetTop + elem.offsetHeight / 2) * pxRatio
          };
          const radius = elem.offsetWidth / 2 * pxRatio;
          const tolerance = 10 * pxRatio;
          const area = div.type === DivType.circle ? new Circle(pos.x, pos.y, radius + tolerance) : new Rectangle(elem.offsetLeft * pxRatio - tolerance, elem.offsetTop * pxRatio - tolerance, elem.offsetWidth * pxRatio + tolerance * 2, elem.offsetHeight * pxRatio + tolerance * 2);
          this.processBounce(pos, radius, area);
        });
      }
    
      processBounce(position, radius, area) {
        const query = this.container.particles.quadTree.query(area);
    
        for (const particle of query) {
          if (area instanceof Circle) {
            Utils.circleBounce(Utils.circleBounceDataFromParticle(particle), {
              position,
              radius,
              velocity: {
                horizontal: 0,
                vertical: 0
              },
              factor: {
                horizontal: 0,
                vertical: 0
              }
            });
          } else if (area instanceof Rectangle) {
            Utils.rectBounce(particle, Utils.calculateBounds(position, radius));
          }
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Core/Particle/InteractionManager.js
    
    
    
    
    
    
    
    
    
    
    
    
    
    class InteractionManager {
      constructor(container) {
        this.container = container;
        this.externalInteractors = [new Bouncer(container), new Bubbler(container), new Connector(container), new Grabber(container), new Lighter_Lighter(container), new Attractor_Attractor(container), new Repulser(container), new TrailMaker(container)];
        this.particleInteractors = [new Attractor(container), new Lighter(container), new Collider(container), new Infecter_Infecter(container), new Linker(container)];
      }
    
      init() {}
    
      externalInteract(delta) {
        for (const interactor of this.externalInteractors) {
          if (interactor.isEnabled()) {
            interactor.interact(delta);
          }
        }
      }
    
      particlesInteract(particle, delta) {
        for (const interactor of this.externalInteractors) {
          interactor.reset(particle);
        }
    
        for (const interactor of this.particleInteractors) {
          if (interactor.isEnabled(particle)) {
            interactor.interact(particle, delta);
          }
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Core/Particles.js
    
    
    
    class Particles_Particles {
      constructor(container) {
        this.container = container;
        this.nextId = 0;
        this.array = [];
        this.limit = 0;
        this.linksFreq = new Map();
        this.trianglesFreq = new Map();
        this.interactionManager = new InteractionManager(container);
        const canvasSize = this.container.canvas.size;
        this.linksColors = new Map();
        this.quadTree = new QuadTree(new Rectangle(-canvasSize.width / 4, -canvasSize.height / 4, canvasSize.width * 3 / 2, canvasSize.height * 3 / 2), 4);
      }
    
      get count() {
        return this.array.length;
      }
    
      init() {
        const container = this.container;
        const options = container.options;
        this.linksFreq = new Map();
        this.trianglesFreq = new Map();
        let handled = false;
    
        for (const particle of options.manualParticles) {
          const pos = particle.position ? {
            x: particle.position.x * container.canvas.size.width / 100,
            y: particle.position.y * container.canvas.size.height / 100
          } : undefined;
          this.addParticle(pos, particle.options);
        }
    
        for (const [, plugin] of container.plugins) {
          if (plugin.particlesInitialization !== undefined) {
            handled = plugin.particlesInitialization();
          }
    
          if (handled) {
            break;
          }
        }
    
        if (!handled) {
          for (let i = this.count; i < options.particles.number.value; i++) {
            this.addParticle();
          }
        }
    
        if (options.infection.enable) {
          for (let i = 0; i < options.infection.infections; i++) {
            const notInfected = this.array.filter(p => p.infecter.infectionStage === undefined);
            const infected = Utils.itemFromArray(notInfected);
            infected.infecter.startInfection(0);
          }
        }
    
        this.interactionManager.init();
        container.noise.init();
      }
    
      redraw() {
        this.clear();
        this.init();
        this.draw({
          value: 0,
          factor: 0
        });
      }
    
      removeAt(index, quantity) {
        if (index >= 0 && index <= this.count) {
          for (const particle of this.array.splice(index, quantity !== null && quantity !== void 0 ? quantity : 1)) {
            particle.destroy();
          }
        }
      }
    
      remove(particle) {
        this.removeAt(this.array.indexOf(particle));
      }
    
      update(delta) {
        const container = this.container;
        const particlesToDelete = [];
        container.noise.update();
    
        for (const particle of this.array) {
          particle.move(delta);
    
          if (particle.destroyed) {
            particlesToDelete.push(particle);
            continue;
          }
    
          this.quadTree.insert(new Point(particle.getPosition(), particle));
        }
    
        for (const particle of particlesToDelete) {
          this.remove(particle);
        }
    
        this.interactionManager.externalInteract(delta);
    
        for (const particle of this.container.particles.array) {
          particle.update(delta);
    
          if (!particle.destroyed && !particle.spawning) {
            this.interactionManager.particlesInteract(particle, delta);
          }
        }
      }
    
      draw(delta) {
        const container = this.container;
        container.canvas.clear();
        const canvasSize = this.container.canvas.size;
        this.quadTree = new QuadTree(new Rectangle(-canvasSize.width / 4, -canvasSize.height / 4, canvasSize.width * 3 / 2, canvasSize.height * 3 / 2), 4);
        this.update(delta);
    
        for (const [, plugin] of container.plugins) {
          container.canvas.drawPlugin(plugin, delta);
        }
    
        for (const p of this.array) {
          p.draw(delta);
        }
      }
    
      clear() {
        this.array = [];
      }
    
      push(nb, mouse, overrideOptions) {
        const container = this.container;
        const options = container.options;
        const limit = options.particles.number.limit * container.density;
        this.pushing = true;
    
        if (limit > 0) {
          const countToRemove = this.count + nb - limit;
    
          if (countToRemove > 0) {
            this.removeQuantity(countToRemove);
          }
        }
    
        for (let i = 0; i < nb; i++) {
          this.addParticle(mouse === null || mouse === void 0 ? void 0 : mouse.position, overrideOptions);
        }
    
        this.pushing = false;
      }
    
      addParticle(position, overrideOptions) {
        try {
          const particle = new Particle(this.nextId, this.container, position, overrideOptions);
          this.array.push(particle);
          this.nextId++;
          return particle;
        } catch (_a) {
          console.warn("error adding particle");
          return;
        }
      }
    
      removeQuantity(quantity) {
        this.removeAt(0, quantity);
      }
    
      getLinkFrequency(p1, p2) {
        const key = `${Math.min(p1.id, p2.id)}_${Math.max(p1.id, p2.id)}`;
        let res = this.linksFreq.get(key);
    
        if (res === undefined) {
          res = Math.random();
          this.linksFreq.set(key, res);
        }
    
        return res;
      }
    
      getTriangleFrequency(p1, p2, p3) {
        let [id1, id2, id3] = [p1.id, p2.id, p3.id];
    
        if (id1 > id2) {
          [id2, id1] = [id1, id2];
        }
    
        if (id2 > id3) {
          [id3, id2] = [id2, id3];
        }
    
        if (id1 > id3) {
          [id3, id1] = [id1, id3];
        }
    
        const key = `${id1}_${id2}_${id3}`;
        let res = this.trianglesFreq.get(key);
    
        if (res === undefined) {
          res = Math.random();
          this.trianglesFreq.set(key, res);
        }
    
        return res;
      }
    
      setDensity() {
        const options = this.container.options;
        this.applyDensity(options.particles);
      }
    
      applyDensity(options) {
        var _a;
    
        if (!((_a = options.number.density) === null || _a === void 0 ? void 0 : _a.enable)) {
          return;
        }
    
        const numberOptions = options.number;
        const densityFactor = this.initDensityFactor(numberOptions.density);
        const optParticlesNumber = numberOptions.value;
        const optParticlesLimit = numberOptions.limit > 0 ? numberOptions.limit : optParticlesNumber;
        const particlesNumber = Math.min(optParticlesNumber, optParticlesLimit) * densityFactor;
        const particlesCount = this.count;
        this.limit = numberOptions.limit * densityFactor;
    
        if (particlesCount < particlesNumber) {
          this.push(Math.abs(particlesNumber - particlesCount), undefined, options);
        } else if (particlesCount > particlesNumber) {
          this.removeQuantity(particlesCount - particlesNumber);
        }
      }
    
      initDensityFactor(densityOptions) {
        const container = this.container;
    
        if (!container.canvas.element || !densityOptions.enable) {
          return 1;
        }
    
        const canvas = container.canvas.element;
        const pxRatio = container.retina.pixelRatio;
        return canvas.width * canvas.height / (densityOptions.factor * pxRatio * pxRatio * densityOptions.area);
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Core/Retina.js
    
    class Retina {
      constructor(container) {
        this.container = container;
      }
    
      init() {
        const container = this.container;
        const options = container.options;
    
        if (options.detectRetina) {
          this.pixelRatio = Utils.isSsr() ? 1 : window.devicePixelRatio;
        } else {
          this.pixelRatio = 1;
        }
    
        const motionOptions = this.container.options.motion;
    
        if (motionOptions && (motionOptions.disable || motionOptions.reduce.value)) {
          if (Utils.isSsr() || typeof matchMedia === "undefined" || !matchMedia) {
            this.reduceFactor = 1;
          } else {
            const mediaQuery = matchMedia("(prefers-reduced-motion: reduce)");
    
            if (mediaQuery) {
              this.handleMotionChange(mediaQuery);
    
              const handleChange = () => {
                this.handleMotionChange(mediaQuery);
                container.refresh().catch(() => {});
              };
    
              if (mediaQuery.addEventListener !== undefined) {
                mediaQuery.addEventListener("change", handleChange);
              } else if (mediaQuery.addListener !== undefined) {
                mediaQuery.addListener(handleChange);
              }
            }
          }
        } else {
          this.reduceFactor = 1;
        }
    
        const ratio = this.pixelRatio;
    
        if (container.canvas.element) {
          const element = container.canvas.element;
          container.canvas.size.width = element.offsetWidth * ratio;
          container.canvas.size.height = element.offsetHeight * ratio;
        }
    
        const particles = options.particles;
        this.linksDistance = particles.links.distance * ratio;
        this.linksWidth = particles.links.width * ratio;
        this.moveSpeed = particles.move.speed * ratio;
        this.sizeValue = particles.size.value * ratio;
        this.sizeAnimationSpeed = particles.size.animation.speed * ratio;
        const modes = options.interactivity.modes;
        this.connectModeDistance = modes.connect.distance * ratio;
        this.connectModeRadius = modes.connect.radius * ratio;
        this.grabModeDistance = modes.grab.distance * ratio;
        this.repulseModeDistance = modes.repulse.distance * ratio;
        this.bounceModeDistance = modes.bounce.distance * ratio;
        this.attractModeDistance = modes.attract.distance * ratio;
        this.slowModeRadius = modes.slow.radius * ratio;
        this.bubbleModeDistance = modes.bubble.distance * ratio;
    
        if (modes.bubble.size) {
          this.bubbleModeSize = modes.bubble.size * ratio;
        }
      }
    
      initParticle(particle) {
        const particlesOptions = particle.particlesOptions;
        const ratio = this.pixelRatio;
        particle.linksDistance = particlesOptions.links.distance * ratio;
        particle.linksWidth = particlesOptions.links.width * ratio;
        particle.moveSpeed = particlesOptions.move.speed * ratio;
        particle.sizeValue = particlesOptions.size.value * ratio;
        particle.sizeAnimationSpeed = particlesOptions.size.animation.speed * ratio;
        particle.maxDistance = particlesOptions.move.distance * ratio;
      }
    
      handleMotionChange(mediaQuery) {
        const options = this.container.options;
    
        if (mediaQuery.matches) {
          const motion = options.motion;
          this.reduceFactor = motion.disable ? 0 : motion.reduce.value ? 1 / motion.reduce.factor : 1;
        } else {
          this.reduceFactor = 1;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Core/FrameManager.js
    class FrameManager {
      constructor(container) {
        this.container = container;
      }
    
      nextFrame(timestamp) {
        try {
          const container = this.container;
    
          if (container.lastFrameTime !== undefined && timestamp < container.lastFrameTime + 1000 / container.fpsLimit) {
            container.draw();
            return;
          }
    
          const deltaValue = timestamp - container.lastFrameTime;
          const delta = {
            value: deltaValue,
            factor: 60 * deltaValue / 1000
          };
          container.lastFrameTime = timestamp;
          container.particles.draw(delta);
    
          if (container.getAnimationStatus()) {
            container.draw();
          }
        } catch (e) {
          console.error("tsParticles error in animation loop", e);
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Events/ClickEvent.js
    class ClickEvent {
      constructor() {
        this.enable = false;
        this.mode = [];
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.enable !== undefined) {
          this.enable = data.enable;
        }
    
        if (data.mode !== undefined) {
          this.mode = data.mode;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Events/DivEvent.js
    
    class DivEvent {
      constructor() {
        this.selectors = [];
        this.enable = false;
        this.mode = [];
        this.type = DivType.circle;
      }
    
      get elementId() {
        return this.ids;
      }
    
      set elementId(value) {
        this.ids = value;
      }
    
      get el() {
        return this.elementId;
      }
    
      set el(value) {
        this.elementId = value;
      }
    
      get ids() {
        if (this.selectors instanceof Array) {
          return this.selectors.map(t => t.replace("#", ""));
        } else {
          return this.selectors.replace("#", "");
        }
      }
    
      set ids(value) {
        if (value instanceof Array) {
          this.selectors = value.map(t => `#${t}`);
        } else {
          this.selectors = `#${value}`;
        }
      }
    
      load(data) {
        var _a, _b;
    
        if (data === undefined) {
          return;
        }
    
        const ids = (_b = (_a = data.ids) !== null && _a !== void 0 ? _a : data.elementId) !== null && _b !== void 0 ? _b : data.el;
    
        if (ids !== undefined) {
          this.ids = ids;
        }
    
        if (data.selectors !== undefined) {
          this.selectors = data.selectors;
        }
    
        if (data.enable !== undefined) {
          this.enable = data.enable;
        }
    
        if (data.mode !== undefined) {
          this.mode = data.mode;
        }
    
        if (data.type !== undefined) {
          this.type = data.type;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Events/Parallax.js
    class Parallax {
      constructor() {
        this.enable = false;
        this.force = 2;
        this.smooth = 10;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.enable !== undefined) {
          this.enable = data.enable;
        }
    
        if (data.force !== undefined) {
          this.force = data.force;
        }
    
        if (data.smooth !== undefined) {
          this.smooth = data.smooth;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Events/HoverEvent.js
    
    class HoverEvent {
      constructor() {
        this.enable = false;
        this.mode = [];
        this.parallax = new Parallax();
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.enable !== undefined) {
          this.enable = data.enable;
        }
    
        if (data.mode !== undefined) {
          this.mode = data.mode;
        }
    
        this.parallax.load(data.parallax);
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Events/Events.js
    
    
    
    class Events {
      constructor() {
        this.onClick = new ClickEvent();
        this.onDiv = new DivEvent();
        this.onHover = new HoverEvent();
        this.resize = true;
      }
    
      get onclick() {
        return this.onClick;
      }
    
      set onclick(value) {
        this.onClick = value;
      }
    
      get ondiv() {
        return this.onDiv;
      }
    
      set ondiv(value) {
        this.onDiv = value;
      }
    
      get onhover() {
        return this.onHover;
      }
    
      set onhover(value) {
        this.onHover = value;
      }
    
      load(data) {
        var _a, _b, _c;
    
        if (data === undefined) {
          return;
        }
    
        this.onClick.load((_a = data.onClick) !== null && _a !== void 0 ? _a : data.onclick);
        const onDiv = (_b = data.onDiv) !== null && _b !== void 0 ? _b : data.ondiv;
    
        if (onDiv !== undefined) {
          if (onDiv instanceof Array) {
            this.onDiv = onDiv.map(div => {
              const tmp = new DivEvent();
              tmp.load(div);
              return tmp;
            });
          } else {
            this.onDiv = new DivEvent();
            this.onDiv.load(onDiv);
          }
        }
    
        this.onHover.load((_c = data.onHover) !== null && _c !== void 0 ? _c : data.onhover);
    
        if (data.resize !== undefined) {
          this.resize = data.resize;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Modes/BubbleBase.js
    
    class BubbleBase {
      constructor() {
        this.distance = 200;
        this.duration = 0.4;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.distance !== undefined) {
          this.distance = data.distance;
        }
    
        if (data.duration !== undefined) {
          this.duration = data.duration;
        }
    
        if (data.opacity !== undefined) {
          this.opacity = data.opacity;
        }
    
        if (data.color !== undefined) {
          if (data.color instanceof Array) {
            this.color = data.color.map(s => OptionsColor.create(undefined, s));
          } else {
            if (this.color instanceof Array) {
              this.color = new OptionsColor();
            }
    
            this.color = OptionsColor.create(this.color, data.color);
          }
        }
    
        if (data.size !== undefined) {
          this.size = data.size;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Modes/BubbleDiv.js
    
    class BubbleDiv extends BubbleBase {
      constructor() {
        super();
        this.selectors = [];
      }
    
      get ids() {
        if (this.selectors instanceof Array) {
          return this.selectors.map(t => t.replace("#", ""));
        } else {
          return this.selectors.replace("#", "");
        }
      }
    
      set ids(value) {
        if (value instanceof Array) {
          this.selectors = value.map(t => `#${t}`);
        } else {
          this.selectors = `#${value}`;
        }
      }
    
      load(data) {
        super.load(data);
    
        if (data === undefined) {
          return;
        }
    
        if (data.ids !== undefined) {
          this.ids = data.ids;
        }
    
        if (data.selectors !== undefined) {
          this.selectors = data.selectors;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Modes/Bubble.js
    
    
    class Bubble extends BubbleBase {
      load(data) {
        super.load(data);
    
        if (!(data !== undefined && data.divs !== undefined)) {
          return;
        }
    
        if (data.divs instanceof Array) {
          this.divs = data.divs.map(s => {
            const tmp = new BubbleDiv();
            tmp.load(s);
            return tmp;
          });
        } else {
          if (this.divs instanceof Array || !this.divs) {
            this.divs = new BubbleDiv();
          }
    
          this.divs.load(data.divs);
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Modes/ConnectLinks.js
    class ConnectLinks {
      constructor() {
        this.opacity = 0.5;
      }
    
      load(data) {
        if (!(data !== undefined && data.opacity !== undefined)) {
          return;
        }
    
        this.opacity = data.opacity;
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Modes/Connect.js
    
    class Connect {
      constructor() {
        this.distance = 80;
        this.links = new ConnectLinks();
        this.radius = 60;
      }
    
      get line_linked() {
        return this.links;
      }
    
      set line_linked(value) {
        this.links = value;
      }
    
      get lineLinked() {
        return this.links;
      }
    
      set lineLinked(value) {
        this.links = value;
      }
    
      load(data) {
        var _a, _b;
    
        if (data === undefined) {
          return;
        }
    
        if (data.distance !== undefined) {
          this.distance = data.distance;
        }
    
        this.links.load((_b = (_a = data.links) !== null && _a !== void 0 ? _a : data.lineLinked) !== null && _b !== void 0 ? _b : data.line_linked);
    
        if (data.radius !== undefined) {
          this.radius = data.radius;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Modes/GrabLinks.js
    
    class GrabLinks {
      constructor() {
        this.blink = false;
        this.consent = false;
        this.opacity = 1;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.blink !== undefined) {
          this.blink = data.blink;
        }
    
        if (data.color !== undefined) {
          this.color = OptionsColor.create(this.color, data.color);
        }
    
        if (data.consent !== undefined) {
          this.consent = data.consent;
        }
    
        if (data.opacity !== undefined) {
          this.opacity = data.opacity;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Modes/Grab.js
    
    class Grab {
      constructor() {
        this.distance = 100;
        this.links = new GrabLinks();
      }
    
      get line_linked() {
        return this.links;
      }
    
      set line_linked(value) {
        this.links = value;
      }
    
      get lineLinked() {
        return this.links;
      }
    
      set lineLinked(value) {
        this.links = value;
      }
    
      load(data) {
        var _a, _b;
    
        if (data === undefined) {
          return;
        }
    
        if (data.distance !== undefined) {
          this.distance = data.distance;
        }
    
        this.links.load((_b = (_a = data.links) !== null && _a !== void 0 ? _a : data.lineLinked) !== null && _b !== void 0 ? _b : data.line_linked);
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Modes/Remove.js
    class Remove {
      constructor() {
        this.quantity = 2;
      }
    
      get particles_nb() {
        return this.quantity;
      }
    
      set particles_nb(value) {
        this.quantity = value;
      }
    
      load(data) {
        var _a;
    
        if (data === undefined) {
          return;
        }
    
        const quantity = (_a = data.quantity) !== null && _a !== void 0 ? _a : data.particles_nb;
    
        if (quantity !== undefined) {
          this.quantity = quantity;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Modes/Push.js
    class Push {
      constructor() {
        this.quantity = 4;
      }
    
      get particles_nb() {
        return this.quantity;
      }
    
      set particles_nb(value) {
        this.quantity = value;
      }
    
      load(data) {
        var _a;
    
        if (data === undefined) {
          return;
        }
    
        const quantity = (_a = data.quantity) !== null && _a !== void 0 ? _a : data.particles_nb;
    
        if (quantity !== undefined) {
          this.quantity = quantity;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Modes/RepulseBase.js
    class RepulseBase {
      constructor() {
        this.distance = 200;
        this.duration = 0.4;
        this.speed = 1;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.distance !== undefined) {
          this.distance = data.distance;
        }
    
        if (data.duration !== undefined) {
          this.duration = data.duration;
        }
    
        if (data.speed !== undefined) {
          this.speed = data.speed;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Modes/RepulseDiv.js
    
    class RepulseDiv extends RepulseBase {
      constructor() {
        super();
        this.selectors = [];
      }
    
      get ids() {
        if (this.selectors instanceof Array) {
          return this.selectors.map(t => t.replace("#", ""));
        } else {
          return this.selectors.replace("#", "");
        }
      }
    
      set ids(value) {
        if (value instanceof Array) {
          this.selectors = value.map(() => `#${value}`);
        } else {
          this.selectors = `#${value}`;
        }
      }
    
      load(data) {
        super.load(data);
    
        if (data === undefined) {
          return;
        }
    
        if (data.ids !== undefined) {
          this.ids = data.ids;
        }
    
        if (data.selectors !== undefined) {
          this.selectors = data.selectors;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Modes/Repulse.js
    
    
    class Repulse extends RepulseBase {
      load(data) {
        super.load(data);
    
        if ((data === null || data === void 0 ? void 0 : data.divs) === undefined) {
          return;
        }
    
        if (data.divs instanceof Array) {
          this.divs = data.divs.map(s => {
            const tmp = new RepulseDiv();
            tmp.load(s);
            return tmp;
          });
        } else {
          if (this.divs instanceof Array || !this.divs) {
            this.divs = new RepulseDiv();
          }
    
          this.divs.load(data.divs);
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Modes/Slow.js
    class Slow {
      constructor() {
        this.factor = 3;
        this.radius = 200;
      }
    
      get active() {
        return false;
      }
    
      set active(_value) {}
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.factor !== undefined) {
          this.factor = data.factor;
        }
    
        if (data.radius !== undefined) {
          this.radius = data.radius;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Modes/Trail.js
    
    class Trail_Trail {
      constructor() {
        this.delay = 1;
        this.quantity = 1;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.delay !== undefined) {
          this.delay = data.delay;
        }
    
        if (data.quantity !== undefined) {
          this.quantity = data.quantity;
        }
    
        if (data.particles !== undefined) {
          this.particles = Utils.deepExtend({}, data.particles);
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Modes/Attract.js
    class Attract_Attract {
      constructor() {
        this.distance = 200;
        this.duration = 0.4;
        this.speed = 1;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.distance !== undefined) {
          this.distance = data.distance;
        }
    
        if (data.duration !== undefined) {
          this.duration = data.duration;
        }
    
        if (data.speed !== undefined) {
          this.speed = data.speed;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Modes/LightGradient.js
    
    class LightGradient {
      constructor() {
        this.start = new OptionsColor();
        this.stop = new OptionsColor();
        this.start.value = "#ffffff";
        this.stop.value = "#000000";
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        this.start = OptionsColor.create(this.start, data.start);
        this.stop = OptionsColor.create(this.stop, data.stop);
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Modes/LightArea.js
    
    class LightArea {
      constructor() {
        this.gradient = new LightGradient();
        this.radius = 1000;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        this.gradient.load(data.gradient);
    
        if (data.radius !== undefined) {
          this.radius = data.radius;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Modes/LightShadow.js
    
    class LightShadow {
      constructor() {
        this.color = new OptionsColor();
        this.color.value = "#000000";
        this.length = 2000;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        this.color = OptionsColor.create(this.color, data.color);
    
        if (data.length !== undefined) {
          this.length = data.length;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Modes/Light.js
    
    
    class Light {
      constructor() {
        this.area = new LightArea();
        this.shadow = new LightShadow();
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        this.area.load(data.area);
        this.shadow.load(data.shadow);
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Modes/Bounce.js
    class Bounce_Bounce {
      constructor() {
        this.distance = 200;
      }
    
      load(data) {
        if (!data) {
          return;
        }
    
        if (data.distance !== undefined) {
          this.distance = data.distance;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Modes/Modes.js
    
    
    
    
    
    
    
    
    
    
    
    class Modes {
      constructor() {
        this.attract = new Attract_Attract();
        this.bounce = new Bounce_Bounce();
        this.bubble = new Bubble();
        this.connect = new Connect();
        this.grab = new Grab();
        this.light = new Light();
        this.push = new Push();
        this.remove = new Remove();
        this.repulse = new Repulse();
        this.slow = new Slow();
        this.trail = new Trail_Trail();
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        this.attract.load(data.attract);
        this.bubble.load(data.bubble);
        this.connect.load(data.connect);
        this.grab.load(data.grab);
        this.light.load(data.light);
        this.push.load(data.push);
        this.remove.load(data.remove);
        this.repulse.load(data.repulse);
        this.slow.load(data.slow);
        this.trail.load(data.trail);
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Interactivity/Interactivity.js
    
    
    
    class Interactivity {
      constructor() {
        this.detectsOn = InteractivityDetect.canvas;
        this.events = new Events();
        this.modes = new Modes();
      }
    
      get detect_on() {
        return this.detectsOn;
      }
    
      set detect_on(value) {
        this.detectsOn = value;
      }
    
      load(data) {
        var _a, _b, _c;
    
        if (data === undefined) {
          return;
        }
    
        const detectsOn = (_a = data.detectsOn) !== null && _a !== void 0 ? _a : data.detect_on;
    
        if (detectsOn !== undefined) {
          this.detectsOn = detectsOn;
        }
    
        this.events.load(data.events);
        this.modes.load(data.modes);
    
        if (((_c = (_b = data.modes) === null || _b === void 0 ? void 0 : _b.slow) === null || _c === void 0 ? void 0 : _c.active) === true) {
          if (this.events.onHover.mode instanceof Array) {
            if (this.events.onHover.mode.indexOf(HoverMode.slow) < 0) {
              this.events.onHover.mode.push(HoverMode.slow);
            }
          } else if (this.events.onHover.mode !== HoverMode.slow) {
            this.events.onHover.mode = [this.events.onHover.mode, HoverMode.slow];
          }
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/BackgroundMask/BackgroundMaskCover.js
    
    class BackgroundMaskCover {
      constructor() {
        this.color = new OptionsColor();
        this.opacity = 1;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.color !== undefined) {
          this.color = OptionsColor.create(this.color, data.color);
        }
    
        if (data.opacity !== undefined) {
          this.opacity = data.opacity;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/BackgroundMask/BackgroundMask.js
    
    class BackgroundMask {
      constructor() {
        this.composite = "destination-out";
        this.cover = new BackgroundMaskCover();
        this.enable = false;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.composite !== undefined) {
          this.composite = data.composite;
        }
    
        if (data.cover !== undefined) {
          const cover = data.cover;
          const color = typeof data.cover === "string" ? {
            color: data.cover
          } : data.cover;
          this.cover.load(cover.color !== undefined ? cover : {
            color: color
          });
        }
    
        if (data.enable !== undefined) {
          this.enable = data.enable;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Background/Background.js
    
    class Background {
      constructor() {
        this.color = new OptionsColor();
        this.color.value = "";
        this.image = "";
        this.position = "";
        this.repeat = "";
        this.size = "";
        this.opacity = 1;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.color !== undefined) {
          this.color = OptionsColor.create(this.color, data.color);
        }
    
        if (data.image !== undefined) {
          this.image = data.image;
        }
    
        if (data.position !== undefined) {
          this.position = data.position;
        }
    
        if (data.repeat !== undefined) {
          this.repeat = data.repeat;
        }
    
        if (data.size !== undefined) {
          this.size = data.size;
        }
    
        if (data.opacity !== undefined) {
          this.opacity = data.opacity;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Infection/InfectionStage.js
    
    class InfectionStage {
      constructor() {
        this.color = new OptionsColor();
        this.color.value = "#ff0000";
        this.radius = 0;
        this.rate = 1;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.color !== undefined) {
          this.color = OptionsColor.create(this.color, data.color);
        }
    
        this.duration = data.duration;
        this.infectedStage = data.infectedStage;
    
        if (data.radius !== undefined) {
          this.radius = data.radius;
        }
    
        if (data.rate !== undefined) {
          this.rate = data.rate;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Infection/Infection.js
    
    class Infection {
      constructor() {
        this.cure = false;
        this.delay = 0;
        this.enable = false;
        this.infections = 0;
        this.stages = [];
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.cure !== undefined) {
          this.cure = data.cure;
        }
    
        if (data.delay !== undefined) {
          this.delay = data.delay;
        }
    
        if (data.enable !== undefined) {
          this.enable = data.enable;
        }
    
        if (data.infections !== undefined) {
          this.infections = data.infections;
        }
    
        if (data.stages === undefined) {
          return;
        }
    
        this.stages = data.stages.map(t => {
          const s = new InfectionStage();
          s.load(t);
          return s;
        });
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Theme/ThemeDefault.js
    
    class ThemeDefault {
      constructor() {
        this.mode = ThemeMode.any;
        this.value = false;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.mode !== undefined) {
          this.mode = data.mode;
        }
    
        if (data.value !== undefined) {
          this.value = data.value;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Theme/Theme.js
    
    
    class Theme {
      constructor() {
        this.name = "";
        this.default = new ThemeDefault();
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.name !== undefined) {
          this.name = data.name;
        }
    
        this.default.load(data.default);
    
        if (data.options !== undefined) {
          this.options = Utils.deepExtend({}, data.options);
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/BackgroundMode/BackgroundMode.js
    class BackgroundMode {
      constructor() {
        this.enable = false;
        this.zIndex = -1;
      }
    
      load(data) {
        if (!data) {
          return;
        }
    
        if (data.enable !== undefined) {
          this.enable = data.enable;
        }
    
        if (data.zIndex !== undefined) {
          this.zIndex = data.zIndex;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Motion/MotionReduce.js
    class MotionReduce {
      constructor() {
        this.factor = 4;
        this.value = false;
      }
    
      load(data) {
        if (!data) {
          return;
        }
    
        if (data.factor !== undefined) {
          this.factor = data.factor;
        }
    
        if (data.value !== undefined) {
          this.value = data.value;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Motion/Motion.js
    
    class Motion {
      constructor() {
        this.disable = false;
        this.reduce = new MotionReduce();
      }
    
      load(data) {
        if (!data) {
          return;
        }
    
        if (data.disable !== undefined) {
          this.disable = data.disable;
        }
    
        this.reduce.load(data.reduce);
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/ManualParticle.js
    
    class ManualParticle {
      load(data) {
        var _a, _b;
    
        if (!data) {
          return;
        }
    
        if (data.position !== undefined) {
          this.position = {
            x: (_a = data.position.x) !== null && _a !== void 0 ? _a : 50,
            y: (_b = data.position.y) !== null && _b !== void 0 ? _b : 50
          };
        }
    
        if (data.options !== undefined) {
          this.options = Utils.deepExtend({}, data.options);
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Options/Classes/Options.js
    
    
    
    
    
    
    
    
    
    
    
    class Options {
      constructor() {
        this.autoPlay = true;
        this.background = new Background();
        this.backgroundMask = new BackgroundMask();
        this.backgroundMode = new BackgroundMode();
        this.detectRetina = true;
        this.fpsLimit = 30;
        this.infection = new Infection();
        this.interactivity = new Interactivity();
        this.manualParticles = [];
        this.motion = new Motion();
        this.particles = new Particles();
        this.pauseOnBlur = true;
        this.pauseOnOutsideViewport = false;
        this.themes = [];
      }
    
      get fps_limit() {
        return this.fpsLimit;
      }
    
      set fps_limit(value) {
        this.fpsLimit = value;
      }
    
      get retina_detect() {
        return this.detectRetina;
      }
    
      set retina_detect(value) {
        this.detectRetina = value;
      }
    
      load(data) {
        var _a, _b;
    
        if (data === undefined) {
          return;
        }
    
        if (data.preset !== undefined) {
          if (data.preset instanceof Array) {
            for (const preset of data.preset) {
              this.importPreset(preset);
            }
          } else {
            this.importPreset(data.preset);
          }
        }
    
        if (data.autoPlay !== undefined) {
          this.autoPlay = data.autoPlay;
        }
    
        const detectRetina = (_a = data.detectRetina) !== null && _a !== void 0 ? _a : data.retina_detect;
    
        if (detectRetina !== undefined) {
          this.detectRetina = detectRetina;
        }
    
        const fpsLimit = (_b = data.fpsLimit) !== null && _b !== void 0 ? _b : data.fps_limit;
    
        if (fpsLimit !== undefined) {
          this.fpsLimit = fpsLimit;
        }
    
        if (data.pauseOnBlur !== undefined) {
          this.pauseOnBlur = data.pauseOnBlur;
        }
    
        if (data.pauseOnOutsideViewport !== undefined) {
          this.pauseOnOutsideViewport = data.pauseOnOutsideViewport;
        }
    
        this.background.load(data.background);
        this.backgroundMode.load(data.backgroundMode);
        this.backgroundMask.load(data.backgroundMask);
        this.infection.load(data.infection);
        this.interactivity.load(data.interactivity);
    
        if (data.manualParticles !== undefined) {
          this.manualParticles = data.manualParticles.map(t => {
            const tmp = new ManualParticle();
            tmp.load(t);
            return tmp;
          });
        }
    
        this.motion.load(data.motion);
        this.particles.load(data.particles);
        Plugins.loadOptions(this, data);
    
        if (data.themes !== undefined) {
          for (const theme of data.themes) {
            const optTheme = new Theme();
            optTheme.load(theme);
            this.themes.push(optTheme);
          }
        }
      }
    
      setTheme(name) {
        if (name) {
          const chosenTheme = this.themes.find(theme => theme.name === name);
    
          if (chosenTheme) {
            this.load(chosenTheme.options);
          }
        } else {
          const clientDarkMode = typeof matchMedia !== "undefined" && matchMedia("(prefers-color-scheme: dark)").matches;
          let defaultTheme = this.themes.find(theme => theme.default.value && (theme.default.mode === ThemeMode.dark && clientDarkMode || theme.default.mode === ThemeMode.light && !clientDarkMode));
    
          if (!defaultTheme) {
            defaultTheme = this.themes.find(theme => theme.default.value && theme.default.mode === ThemeMode.any);
          }
    
          if (defaultTheme) {
            this.load(defaultTheme.options);
          }
        }
      }
    
      importPreset(preset) {
        this.load(Plugins.getPreset(preset));
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Core/Container.js
    var Container_awaiter = undefined && undefined.__awaiter || function (thisArg, _arguments, P, generator) {
      function adopt(value) {
        return value instanceof P ? value : new P(function (resolve) {
          resolve(value);
        });
      }
    
      return new (P || (P = Promise))(function (resolve, reject) {
        function fulfilled(value) {
          try {
            step(generator.next(value));
          } catch (e) {
            reject(e);
          }
        }
    
        function rejected(value) {
          try {
            step(generator["throw"](value));
          } catch (e) {
            reject(e);
          }
        }
    
        function step(result) {
          result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);
        }
    
        step((generator = generator.apply(thisArg, _arguments || [])).next());
      });
    };
    
    
    
    
    
    
    
    class Container {
      constructor(id, sourceOptions, ...presets) {
        this.id = id;
        this.sourceOptions = sourceOptions;
        this.firstStart = true;
        this.started = false;
        this.destroyed = false;
        this.paused = true;
        this.lastFrameTime = 0;
        this.pageHidden = false;
        this.retina = new Retina(this);
        this.canvas = new Canvas(this);
        this.particles = new Particles_Particles(this);
        this.drawer = new FrameManager(this);
        this.noise = {
          generate: () => {
            return {
              angle: Math.random() * Math.PI * 2,
              length: Math.random()
            };
          },
          init: () => {},
          update: () => {}
        };
        this.interactivity = {
          mouse: {
            clicking: false,
            inside: false
          }
        };
        this.bubble = {};
        this.repulse = {
          particles: []
        };
        this.attract = {
          particles: []
        };
        this.plugins = new Map();
        this.drawers = new Map();
        this.density = 1;
        this.options = new Options();
    
        for (const preset of presets) {
          this.options.load(Plugins.getPreset(preset));
        }
    
        const shapes = Plugins.getSupportedShapes();
    
        for (const type of shapes) {
          const drawer = Plugins.getShapeDrawer(type);
    
          if (drawer) {
            this.drawers.set(type, drawer);
          }
        }
    
        if (this.sourceOptions) {
          this.options.load(this.sourceOptions);
        }
    
        this.fpsLimit = this.options.fpsLimit > 0 ? this.options.fpsLimit : 60;
        this.options.setTheme(undefined);
        this.eventListeners = new EventListeners(this);
    
        if (typeof IntersectionObserver !== "undefined" && IntersectionObserver) {
          this.intersectionObserver = new IntersectionObserver(entries => this.intersectionManager(entries));
        }
      }
    
      play(force) {
        const needsUpdate = this.paused || force;
    
        if (this.firstStart && !this.options.autoPlay) {
          this.firstStart = false;
          return;
        }
    
        if (this.paused) {
          this.paused = false;
        }
    
        if (needsUpdate) {
          for (const [, plugin] of this.plugins) {
            if (plugin.play) {
              plugin.play();
            }
          }
    
          this.lastFrameTime = performance.now();
        }
    
        this.draw();
      }
    
      pause() {
        if (this.drawAnimationFrame !== undefined) {
          Utils.cancelAnimation(this.drawAnimationFrame);
          delete this.drawAnimationFrame;
        }
    
        if (this.paused) {
          return;
        }
    
        for (const [, plugin] of this.plugins) {
          if (plugin.pause) {
            plugin.pause();
          }
        }
    
        if (!this.pageHidden) {
          this.paused = true;
        }
      }
    
      draw() {
        this.drawAnimationFrame = Utils.animate(timestamp => this.drawer.nextFrame(timestamp));
      }
    
      getAnimationStatus() {
        return !this.paused;
      }
    
      setNoise(noiseOrGenerator, init, update) {
        if (!noiseOrGenerator) {
          return;
        }
    
        if (typeof noiseOrGenerator === "function") {
          this.noise.generate = noiseOrGenerator;
    
          if (init) {
            this.noise.init = init;
          }
    
          if (update) {
            this.noise.update = update;
          }
        } else {
          if (noiseOrGenerator.generate) {
            this.noise.generate = noiseOrGenerator.generate;
          }
    
          if (noiseOrGenerator.init) {
            this.noise.init = noiseOrGenerator.init;
          }
    
          if (noiseOrGenerator.update) {
            this.noise.update = noiseOrGenerator.update;
          }
        }
      }
    
      destroy() {
        this.stop();
        this.canvas.destroy();
    
        for (const [, drawer] of this.drawers) {
          if (drawer.destroy) {
            drawer.destroy(this);
          }
        }
    
        for (const key of this.drawers.keys()) {
          this.drawers.delete(key);
        }
    
        this.destroyed = true;
      }
    
      exportImg(callback) {
        this.exportImage(callback);
      }
    
      exportImage(callback, type, quality) {
        var _a;
    
        return (_a = this.canvas.element) === null || _a === void 0 ? void 0 : _a.toBlob(callback, type !== null && type !== void 0 ? type : "image/png", quality);
      }
    
      exportConfiguration() {
        return JSON.stringify(this.options, undefined, 2);
      }
    
      refresh() {
        return Container_awaiter(this, void 0, void 0, function* () {
          this.stop();
          yield this.start();
        });
      }
    
      stop() {
        if (!this.started) {
          return;
        }
    
        this.firstStart = true;
        this.started = false;
        this.eventListeners.removeListeners();
        this.pause();
        this.particles.clear();
        this.canvas.clear();
    
        if (this.interactivity.element instanceof HTMLElement && this.intersectionObserver) {
          this.intersectionObserver.observe(this.interactivity.element);
        }
    
        for (const [, plugin] of this.plugins) {
          if (plugin.stop) {
            plugin.stop();
          }
        }
    
        for (const key of this.plugins.keys()) {
          this.plugins.delete(key);
        }
    
        this.particles.linksColors = new Map();
        delete this.particles.grabLineColor;
        delete this.particles.linksColor;
      }
    
      loadTheme(name) {
        return Container_awaiter(this, void 0, void 0, function* () {
          this.options.setTheme(name);
          yield this.refresh();
        });
      }
    
      start() {
        return Container_awaiter(this, void 0, void 0, function* () {
          if (this.started) {
            return;
          }
    
          yield this.init();
          this.started = true;
          this.eventListeners.addListeners();
    
          if (this.interactivity.element instanceof HTMLElement && this.intersectionObserver) {
            this.intersectionObserver.observe(this.interactivity.element);
          }
    
          for (const [, plugin] of this.plugins) {
            if (plugin.startAsync !== undefined) {
              yield plugin.startAsync();
            } else if (plugin.start !== undefined) {
              plugin.start();
            }
          }
    
          this.play();
        });
      }
    
      init() {
        return Container_awaiter(this, void 0, void 0, function* () {
          this.retina.init();
          this.canvas.init();
          this.fpsLimit = this.options.fpsLimit > 0 ? this.options.fpsLimit : 60;
          const availablePlugins = Plugins.getAvailablePlugins(this);
    
          for (const [id, plugin] of availablePlugins) {
            this.plugins.set(id, plugin);
          }
    
          for (const [, drawer] of this.drawers) {
            if (drawer.init) {
              yield drawer.init(this);
            }
          }
    
          for (const [, plugin] of this.plugins) {
            if (plugin.init) {
              plugin.init(this.options);
            } else if (plugin.initAsync !== undefined) {
              yield plugin.initAsync(this.options);
            }
          }
    
          this.canvas.initSize();
          this.particles.init();
          this.particles.setDensity();
        });
      }
    
      intersectionManager(entries) {
        if (!this.options.pauseOnOutsideViewport) {
          return;
        }
    
        for (const entry of entries) {
          if (entry.target !== this.interactivity.element) {
            continue;
          }
    
          if (entry.isIntersecting) {
            this.play();
          } else {
            this.pause();
          }
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Core/Loader.js
    var Loader_awaiter = undefined && undefined.__awaiter || function (thisArg, _arguments, P, generator) {
      function adopt(value) {
        return value instanceof P ? value : new P(function (resolve) {
          resolve(value);
        });
      }
    
      return new (P || (P = Promise))(function (resolve, reject) {
        function fulfilled(value) {
          try {
            step(generator.next(value));
          } catch (e) {
            reject(e);
          }
        }
    
        function rejected(value) {
          try {
            step(generator["throw"](value));
          } catch (e) {
            reject(e);
          }
        }
    
        function step(result) {
          result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);
        }
    
        step((generator = generator.apply(thisArg, _arguments || [])).next());
      });
    };
    
    
    
    const tsParticlesDom = [];
    
    function fetchError(statusCode) {
      console.error(`Error tsParticles - fetch status: ${statusCode}`);
      console.error("Error tsParticles - File config not found");
    }
    
    class Loader {
      static dom() {
        return tsParticlesDom;
      }
    
      static domItem(index) {
        const dom = Loader.dom();
        const item = dom[index];
    
        if (item && !item.destroyed) {
          return item;
        }
    
        dom.splice(index, 1);
      }
    
      static load(tagId, options, index) {
        return Loader_awaiter(this, void 0, void 0, function* () {
          const domContainer = document.getElementById(tagId);
    
          if (!domContainer) {
            return;
          }
    
          return Loader.set(tagId, domContainer, options, index);
        });
      }
    
      static set(id, domContainer, options, index) {
        return Loader_awaiter(this, void 0, void 0, function* () {
          const currentOptions = options instanceof Array ? Utils.itemFromArray(options, index) : options;
          const dom = Loader.dom();
          const oldIndex = dom.findIndex(v => v.id === id);
    
          if (oldIndex >= 0) {
            const old = Loader.domItem(oldIndex);
    
            if (old && !old.destroyed) {
              old.destroy();
              dom.splice(oldIndex, 1);
            }
          }
    
          let canvasEl;
          let generatedCanvas;
    
          if (domContainer.tagName.toLowerCase() === "canvas") {
            canvasEl = domContainer;
            generatedCanvas = false;
          } else {
            const existingCanvases = domContainer.getElementsByTagName("canvas");
    
            if (existingCanvases.length) {
              canvasEl = existingCanvases[0];
    
              if (!canvasEl.className) {
                canvasEl.className = Constants.canvasClass;
              }
    
              generatedCanvas = false;
            } else {
              generatedCanvas = true;
              canvasEl = document.createElement("canvas");
              canvasEl.className = Constants.canvasClass;
              canvasEl.style.width = "100%";
              canvasEl.style.height = "100%";
              domContainer.appendChild(canvasEl);
            }
          }
    
          const newItem = new Container(id, currentOptions);
    
          if (oldIndex >= 0) {
            dom.splice(oldIndex, 0, newItem);
          } else {
            dom.push(newItem);
          }
    
          newItem.canvas.loadCanvas(canvasEl, generatedCanvas);
          yield newItem.start();
          return newItem;
        });
      }
    
      static loadJSON(tagId, jsonUrl, index) {
        return Loader_awaiter(this, void 0, void 0, function* () {
          const url = jsonUrl instanceof Array ? Utils.itemFromArray(jsonUrl, index) : jsonUrl;
          const response = yield fetch(url);
    
          if (response.ok) {
            return Loader.load(tagId, yield response.json());
          } else {
            fetchError(response.status);
          }
        });
      }
    
      static setJSON(id, domContainer, jsonUrl) {
        return Loader_awaiter(this, void 0, void 0, function* () {
          const response = yield fetch(jsonUrl);
    
          if (response.ok) {
            const options = yield response.json();
            return Loader.set(id, domContainer, options);
          } else {
            fetchError(response.status);
          }
        });
      }
    
      static setOnClickHandler(callback) {
        const dom = Loader.dom();
    
        if (dom.length === 0) {
          throw new Error("Can only set click handlers after calling tsParticles.load() or tsParticles.loadJSON()");
        }
    
        for (const domItem of dom) {
          const el = domItem.interactivity.element;
    
          if (!el) {
            continue;
          }
    
          const clickOrTouchHandler = (e, pos) => {
            if (domItem.destroyed) {
              return;
            }
    
            const pxRatio = domItem.retina.pixelRatio;
            const posRetina = {
              x: pos.x * pxRatio,
              y: pos.y * pxRatio
            };
            const particles = domItem.particles.quadTree.queryCircle(posRetina, domItem.retina.sizeValue);
            callback(e, particles);
          };
    
          const clickHandler = e => {
            if (domItem.destroyed) {
              return;
            }
    
            const mouseEvent = e;
            const pos = {
              x: mouseEvent.offsetX || mouseEvent.clientX,
              y: mouseEvent.offsetY || mouseEvent.clientY
            };
            clickOrTouchHandler(e, pos);
          };
    
          const touchStartHandler = () => {
            if (domItem.destroyed) {
              return;
            }
    
            touched = true;
            touchMoved = false;
          };
    
          const touchMoveHandler = () => {
            if (domItem.destroyed) {
              return;
            }
    
            touchMoved = true;
          };
    
          const touchEndHandler = e => {
            var _a, _b, _c;
    
            if (domItem.destroyed) {
              return;
            }
    
            if (touched && !touchMoved) {
              const touchEvent = e;
              const lastTouch = touchEvent.touches[touchEvent.touches.length - 1];
              const canvasRect = (_a = domItem.canvas.element) === null || _a === void 0 ? void 0 : _a.getBoundingClientRect();
              const pos = {
                x: lastTouch.clientX - ((_b = canvasRect === null || canvasRect === void 0 ? void 0 : canvasRect.left) !== null && _b !== void 0 ? _b : 0),
                y: lastTouch.clientY - ((_c = canvasRect === null || canvasRect === void 0 ? void 0 : canvasRect.top) !== null && _c !== void 0 ? _c : 0)
              };
              clickOrTouchHandler(e, pos);
            }
    
            touched = false;
            touchMoved = false;
          };
    
          const touchCancelHandler = () => {
            if (domItem.destroyed) {
              return;
            }
    
            touched = false;
            touchMoved = false;
          };
    
          let touched = false;
          let touchMoved = false;
          el.addEventListener("click", clickHandler);
          el.addEventListener("touchstart", touchStartHandler);
          el.addEventListener("touchmove", touchMoveHandler);
          el.addEventListener("touchend", touchEndHandler);
          el.addEventListener("touchcancel", touchCancelHandler);
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/main.slim.js
    var main_slim_awaiter = undefined && undefined.__awaiter || function (thisArg, _arguments, P, generator) {
      function adopt(value) {
        return value instanceof P ? value : new P(function (resolve) {
          resolve(value);
        });
      }
    
      return new (P || (P = Promise))(function (resolve, reject) {
        function fulfilled(value) {
          try {
            step(generator.next(value));
          } catch (e) {
            reject(e);
          }
        }
    
        function rejected(value) {
          try {
            step(generator["throw"](value));
          } catch (e) {
            reject(e);
          }
        }
    
        function step(result) {
          result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);
        }
    
        step((generator = generator.apply(thisArg, _arguments || [])).next());
      });
    };
    
    
    
    
    
    
    
    
    
    
    
    
    class MainSlim {
      constructor() {
        this.initialized = false;
        const squareDrawer = new SquareDrawer();
        const textDrawer = new TextDrawer();
        const imageDrawer = new ImageDrawer();
        Plugins.addShapeDrawer(ShapeType.line, new LineDrawer());
        Plugins.addShapeDrawer(ShapeType.circle, new CircleDrawer());
        Plugins.addShapeDrawer(ShapeType.edge, squareDrawer);
        Plugins.addShapeDrawer(ShapeType.square, squareDrawer);
        Plugins.addShapeDrawer(ShapeType.triangle, new TriangleDrawer());
        Plugins.addShapeDrawer(ShapeType.star, new StarDrawer());
        Plugins.addShapeDrawer(ShapeType.polygon, new PolygonDrawer());
        Plugins.addShapeDrawer(ShapeType.char, textDrawer);
        Plugins.addShapeDrawer(ShapeType.character, textDrawer);
        Plugins.addShapeDrawer(ShapeType.image, imageDrawer);
        Plugins.addShapeDrawer(ShapeType.images, imageDrawer);
      }
    
      init() {
        if (!this.initialized) {
          this.initialized = true;
        }
      }
    
      loadFromArray(tagId, options, index) {
        return main_slim_awaiter(this, void 0, void 0, function* () {
          return Loader.load(tagId, options, index);
        });
      }
    
      load(tagId, options) {
        return main_slim_awaiter(this, void 0, void 0, function* () {
          return Loader.load(tagId, options);
        });
      }
    
      set(id, element, options) {
        return main_slim_awaiter(this, void 0, void 0, function* () {
          return Loader.set(id, element, options);
        });
      }
    
      loadJSON(tagId, pathConfigJson, index) {
        return Loader.loadJSON(tagId, pathConfigJson, index);
      }
    
      setOnClickHandler(callback) {
        Loader.setOnClickHandler(callback);
      }
    
      dom() {
        return Loader.dom();
      }
    
      domItem(index) {
        return Loader.domItem(index);
      }
    
      addShape(shape, drawer, init, afterEffect, destroy) {
        let customDrawer;
    
        if (typeof drawer === "function") {
          customDrawer = {
            afterEffect: afterEffect,
            destroy: destroy,
            draw: drawer,
            init: init
          };
        } else {
          customDrawer = drawer;
        }
    
        Plugins.addShapeDrawer(shape, customDrawer);
      }
    
      addPreset(preset, options) {
        Plugins.addPreset(preset, options);
      }
    
      addPlugin(plugin) {
        Plugins.addPlugin(plugin);
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Plugins/Absorbers/AbsorberInstance.js
    
    class AbsorberInstance {
      constructor(absorbers, container, options, position) {
        var _a, _b;
    
        this.absorbers = absorbers;
        this.container = container;
        this.initialPosition = position;
        this.options = options;
        this.dragging = false;
        this.opacity = this.options.opacity;
        this.size = NumberUtils.getValue(options.size) * container.retina.pixelRatio;
        this.mass = this.size * options.size.density * container.retina.reduceFactor;
        const limit = options.size.limit;
        this.limit = limit !== undefined ? limit * container.retina.pixelRatio * container.retina.reduceFactor : limit;
        const color = typeof options.color === "string" ? {
          value: options.color
        } : options.color;
        this.color = (_a = ColorUtils.colorToRgb(color)) !== null && _a !== void 0 ? _a : {
          b: 0,
          g: 0,
          r: 0
        };
        this.position = (_b = this.initialPosition) !== null && _b !== void 0 ? _b : this.calcPosition();
      }
    
      attract(particle) {
        const options = this.options;
    
        if (options.draggable) {
          const mouse = this.container.interactivity.mouse;
    
          if (mouse.clicking && mouse.downPosition) {
            const mouseDist = NumberUtils.getDistance(this.position, mouse.downPosition);
    
            if (mouseDist <= this.size) {
              this.dragging = true;
            }
          } else {
            this.dragging = false;
          }
    
          if (this.dragging && mouse.position) {
            this.position.x = mouse.position.x;
            this.position.y = mouse.position.y;
          }
        }
    
        const pos = particle.getPosition();
        const {
          dx,
          dy,
          distance
        } = NumberUtils.getDistances(this.position, pos);
        const angle = Math.atan2(dx, dy);
        const acceleration = this.mass / Math.pow(distance, 2) * this.container.retina.reduceFactor;
    
        if (distance < this.size + particle.getRadius()) {
          const sizeFactor = particle.getRadius() * 0.033 * this.container.retina.pixelRatio;
    
          if (this.size > particle.getRadius() && distance < this.size - particle.getRadius()) {
            if (options.destroy) {
              particle.destroy();
            } else {
              particle.needsNewPosition = true;
              this.updateParticlePosition(particle, angle, acceleration);
            }
          } else {
            if (options.destroy) {
              particle.size.value -= sizeFactor;
            }
    
            this.updateParticlePosition(particle, angle, acceleration);
          }
    
          if (this.limit === undefined || this.size < this.limit) {
            this.size += sizeFactor;
          }
    
          this.mass += sizeFactor * this.options.size.density * this.container.retina.reduceFactor;
        } else {
          this.updateParticlePosition(particle, angle, acceleration);
        }
      }
    
      resize() {
        const initialPosition = this.initialPosition;
        this.position = initialPosition && Utils.isPointInside(initialPosition, this.container.canvas.size) ? initialPosition : this.calcPosition();
      }
    
      draw(context) {
        context.translate(this.position.x, this.position.y);
        context.beginPath();
        context.arc(0, 0, this.size, 0, Math.PI * 2, false);
        context.closePath();
        context.fillStyle = ColorUtils.getStyleFromRgb(this.color, this.opacity);
        context.fill();
      }
    
      calcPosition() {
        var _a, _b;
    
        const container = this.container;
        const percentPosition = this.options.position;
        return {
          x: ((_a = percentPosition === null || percentPosition === void 0 ? void 0 : percentPosition.x) !== null && _a !== void 0 ? _a : Math.random() * 100) / 100 * container.canvas.size.width,
          y: ((_b = percentPosition === null || percentPosition === void 0 ? void 0 : percentPosition.y) !== null && _b !== void 0 ? _b : Math.random() * 100) / 100 * container.canvas.size.height
        };
      }
    
      updateParticlePosition(particle, angle, acceleration) {
        var _a;
    
        if (particle.destroyed) {
          return;
        }
    
        const canvasSize = this.container.canvas.size;
    
        if (particle.needsNewPosition) {
          const pSize = particle.getRadius();
          particle.position.x = Math.random() * (canvasSize.width - pSize * 2) + pSize;
          particle.position.y = Math.random() * (canvasSize.height - pSize * 2) + pSize;
          particle.needsNewPosition = false;
        }
    
        if (this.options.orbits) {
          if (particle.orbitRadius === undefined) {
            particle.orbitRadius = NumberUtils.getDistance(particle.getPosition(), this.position);
          }
    
          if (particle.orbitRadius <= this.size && !this.options.destroy) {
            particle.orbitRadius = Math.random() * Math.max(canvasSize.width, canvasSize.height);
          }
    
          if (particle.orbitAngle === undefined) {
            particle.orbitAngle = Math.random() * Math.PI * 2;
          }
    
          const orbitRadius = particle.orbitRadius;
          const orbitAngle = particle.orbitAngle;
          particle.velocity.horizontal = 0;
          particle.velocity.vertical = 0;
          particle.position.x = this.position.x + orbitRadius * Math.cos(orbitAngle);
          particle.position.y = this.position.y + orbitRadius * Math.sin(orbitAngle);
          particle.orbitRadius -= acceleration;
          particle.orbitAngle += ((_a = particle.moveSpeed) !== null && _a !== void 0 ? _a : this.container.retina.moveSpeed) / 100 * this.container.retina.reduceFactor;
        } else {
          particle.velocity.horizontal += Math.sin(angle) * acceleration;
          particle.velocity.vertical += Math.cos(angle) * acceleration;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Plugins/Absorbers/Options/Classes/AbsorberSize.js
    
    class AbsorberSize extends ValueWithRandom {
      constructor() {
        super();
        this.density = 5;
        this.random.minimumValue = 1;
        this.value = 50;
      }
    
      load(data) {
        if (!data) {
          return;
        }
    
        super.load(data);
    
        if (data.density !== undefined) {
          this.density = data.density;
        }
    
        if (data.limit !== undefined) {
          this.limit = data.limit;
        }
    
        if (data.limit !== undefined) {
          this.limit = data.limit;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Plugins/Absorbers/Options/Classes/Absorber.js
    
    
    class Absorber {
      constructor() {
        this.color = new OptionsColor();
        this.color.value = "#000000";
        this.draggable = false;
        this.opacity = 1;
        this.destroy = true;
        this.orbits = false;
        this.size = new AbsorberSize();
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.color !== undefined) {
          this.color = OptionsColor.create(this.color, data.color);
        }
    
        if (data.draggable !== undefined) {
          this.draggable = data.draggable;
        }
    
        if (data.opacity !== undefined) {
          this.opacity = data.opacity;
        }
    
        if (data.position !== undefined) {
          this.position = {
            x: data.position.x,
            y: data.position.y
          };
        }
    
        if (data.size !== undefined) {
          this.size.load(data.size);
        }
    
        if (data.destroy !== undefined) {
          this.destroy = data.destroy;
        }
    
        if (data.orbits !== undefined) {
          this.orbits = data.orbits;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Plugins/Absorbers/Enums/AbsorberClickMode.js
    var AbsorberClickMode;
    
    (function (AbsorberClickMode) {
      AbsorberClickMode["absorber"] = "absorber";
    })(AbsorberClickMode || (AbsorberClickMode = {}));
    // CONCATENATED MODULE: ./dist/browser/Plugins/Absorbers/Enums/index.js
    
    // CONCATENATED MODULE: ./dist/browser/Plugins/Absorbers/Absorbers.js
    
    
    
    
    class Absorbers {
      constructor(container) {
        this.container = container;
        this.array = [];
        this.absorbers = [];
        this.interactivityAbsorbers = [];
        const overridableContainer = container;
    
        overridableContainer.addAbsorber = (options, position) => this.addAbsorber(options, position);
      }
    
      init(options) {
        var _a, _b;
    
        if (!options) {
          return;
        }
    
        if (options.absorbers) {
          if (options.absorbers instanceof Array) {
            this.absorbers = options.absorbers.map(s => {
              const tmp = new Absorber();
              tmp.load(s);
              return tmp;
            });
          } else {
            if (this.absorbers instanceof Array) {
              this.absorbers = new Absorber();
            }
    
            this.absorbers.load(options.absorbers);
          }
        }
    
        const interactivityAbsorbers = (_b = (_a = options.interactivity) === null || _a === void 0 ? void 0 : _a.modes) === null || _b === void 0 ? void 0 : _b.absorbers;
    
        if (interactivityAbsorbers) {
          if (interactivityAbsorbers instanceof Array) {
            this.interactivityAbsorbers = interactivityAbsorbers.map(s => {
              const tmp = new Absorber();
              tmp.load(s);
              return tmp;
            });
          } else {
            if (this.interactivityAbsorbers instanceof Array) {
              this.interactivityAbsorbers = new Absorber();
            }
    
            this.interactivityAbsorbers.load(interactivityAbsorbers);
          }
        }
    
        if (this.absorbers instanceof Array) {
          for (const absorberOptions of this.absorbers) {
            this.addAbsorber(absorberOptions);
          }
        } else {
          this.addAbsorber(this.absorbers);
        }
      }
    
      particleUpdate(particle) {
        for (const absorber of this.array) {
          absorber.attract(particle);
    
          if (particle.destroyed) {
            break;
          }
        }
      }
    
      draw(context) {
        for (const absorber of this.array) {
          context.save();
          absorber.draw(context);
          context.restore();
        }
      }
    
      stop() {
        this.array = [];
      }
    
      resize() {
        for (const absorber of this.array) {
          absorber.resize();
        }
      }
    
      handleClickMode(mode) {
        const container = this.container;
        const absorberOptions = this.absorbers;
        const modeAbsorbers = this.interactivityAbsorbers;
    
        if (mode === AbsorberClickMode.absorber) {
          let absorbersModeOptions;
    
          if (modeAbsorbers instanceof Array) {
            if (modeAbsorbers.length > 0) {
              absorbersModeOptions = Utils.itemFromArray(modeAbsorbers);
            }
          } else {
            absorbersModeOptions = modeAbsorbers;
          }
    
          const absorbersOptions = absorbersModeOptions !== null && absorbersModeOptions !== void 0 ? absorbersModeOptions : absorberOptions instanceof Array ? Utils.itemFromArray(absorberOptions) : absorberOptions;
          const aPosition = container.interactivity.mouse.clickPosition;
          this.addAbsorber(absorbersOptions, aPosition);
        }
      }
    
      addAbsorber(options, position) {
        const absorber = new AbsorberInstance(this, this.container, options, position);
        this.array.push(absorber);
        return absorber;
      }
    
      removeAbsorber(absorber) {
        const index = this.array.indexOf(absorber);
    
        if (index >= 0) {
          this.array.splice(index, 1);
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Plugins/Absorbers/AbsorbersPlugin.js
    
    
    
    
    
    class AbsorbersPlugin {
      constructor() {
        this.id = "absorbers";
      }
    
      getPlugin(container) {
        return new Absorbers(container);
      }
    
      needsPlugin(options) {
        var _a, _b, _c;
    
        if (options === undefined) {
          return false;
        }
    
        const absorbers = options.absorbers;
        let loadAbsorbers = false;
    
        if (absorbers instanceof Array) {
          if (absorbers.length) {
            loadAbsorbers = true;
          }
        } else if (absorbers !== undefined) {
          loadAbsorbers = true;
        } else if (((_c = (_b = (_a = options.interactivity) === null || _a === void 0 ? void 0 : _a.events) === null || _b === void 0 ? void 0 : _b.onClick) === null || _c === void 0 ? void 0 : _c.mode) && Utils.isInArray(AbsorberClickMode.absorber, options.interactivity.events.onClick.mode)) {
          loadAbsorbers = true;
        }
    
        return loadAbsorbers;
      }
    
      loadOptions(options, source) {
        var _a, _b;
    
        if (!this.needsPlugin(options) && !this.needsPlugin(source)) {
          return;
        }
    
        const optionsCast = options;
    
        if (source === null || source === void 0 ? void 0 : source.absorbers) {
          if ((source === null || source === void 0 ? void 0 : source.absorbers) instanceof Array) {
            optionsCast.absorbers = source === null || source === void 0 ? void 0 : source.absorbers.map(s => {
              const tmp = new Absorber();
              tmp.load(s);
              return tmp;
            });
          } else {
            let absorberOptions = optionsCast.absorbers;
    
            if ((absorberOptions === null || absorberOptions === void 0 ? void 0 : absorberOptions.load) === undefined) {
              optionsCast.absorbers = absorberOptions = new Absorber();
            }
    
            absorberOptions.load(source === null || source === void 0 ? void 0 : source.absorbers);
          }
        }
    
        const interactivityAbsorbers = (_b = (_a = source === null || source === void 0 ? void 0 : source.interactivity) === null || _a === void 0 ? void 0 : _a.modes) === null || _b === void 0 ? void 0 : _b.absorbers;
    
        if (interactivityAbsorbers) {
          if (interactivityAbsorbers instanceof Array) {
            optionsCast.interactivity.modes.absorbers = interactivityAbsorbers.map(s => {
              const tmp = new Absorber();
              tmp.load(s);
              return tmp;
            });
          } else {
            let absorberOptions = optionsCast.interactivity.modes.absorbers;
    
            if ((absorberOptions === null || absorberOptions === void 0 ? void 0 : absorberOptions.load) === undefined) {
              optionsCast.interactivity.modes.absorbers = absorberOptions = new Absorber();
            }
    
            absorberOptions.load(interactivityAbsorbers);
          }
        }
      }
    
    }
    
    const AbsorbersPlugin_plugin = new AbsorbersPlugin();
    
    
    // CONCATENATED MODULE: ./dist/browser/Plugins/Emitters/Options/Classes/EmitterSize.js
    
    class EmitterSize {
      constructor() {
        this.mode = SizeMode.percent;
        this.height = 0;
        this.width = 0;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.mode !== undefined) {
          this.mode = data.mode;
        }
    
        if (data.height !== undefined) {
          this.height = data.height;
        }
    
        if (data.width !== undefined) {
          this.width = data.width;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Plugins/Emitters/EmitterInstance.js
    
    
    
    
    function randomCoordinate(position, offset) {
      return position + offset * (Math.random() - 0.5);
    }
    
    function randomPosition(position, offset) {
      return {
        x: randomCoordinate(position.x, offset.x),
        y: randomCoordinate(position.y, offset.y)
      };
    }
    
    class EmitterInstance {
      constructor(emitters, container, emitterOptions, position) {
        var _a, _b, _c;
    
        this.emitters = emitters;
        this.container = container;
        this.initialPosition = position;
        this.emitterOptions = Utils.deepExtend({}, emitterOptions);
        this.position = (_a = this.initialPosition) !== null && _a !== void 0 ? _a : this.calcPosition();
        let particlesOptions = Utils.deepExtend({}, this.emitterOptions.particles);
    
        if (particlesOptions === undefined) {
          particlesOptions = {};
        }
    
        if (particlesOptions.move === undefined) {
          particlesOptions.move = {};
        }
    
        if (particlesOptions.move.direction === undefined) {
          particlesOptions.move.direction = this.emitterOptions.direction;
        }
    
        this.particlesOptions = particlesOptions;
        this.size = (_b = this.emitterOptions.size) !== null && _b !== void 0 ? _b : (() => {
          const size = new EmitterSize();
          size.load({
            height: 0,
            mode: SizeMode.percent,
            width: 0
          });
          return size;
        })();
        this.lifeCount = (_c = this.emitterOptions.life.count) !== null && _c !== void 0 ? _c : -1;
        this.immortal = this.lifeCount <= 0;
        this.play();
      }
    
      play() {
        if (this.container.retina.reduceFactor && (this.lifeCount > 0 || this.immortal || !this.emitterOptions.life.count)) {
          if (this.startInterval === undefined) {
            const delay = 1000 * this.emitterOptions.rate.delay / this.container.retina.reduceFactor;
            this.startInterval = window.setInterval(() => {
              this.emit();
            }, delay);
          }
    
          if (this.lifeCount > 0 || this.immortal) {
            this.prepareToDie();
          }
        }
      }
    
      pause() {
        const interval = this.startInterval;
    
        if (interval !== undefined) {
          clearInterval(interval);
          delete this.startInterval;
        }
      }
    
      resize() {
        const initialPosition = this.initialPosition;
        this.position = initialPosition && Utils.isPointInside(initialPosition, this.container.canvas.size) ? initialPosition : this.calcPosition();
      }
    
      prepareToDie() {
        var _a;
    
        const duration = (_a = this.emitterOptions.life) === null || _a === void 0 ? void 0 : _a.duration;
    
        if (this.container.retina.reduceFactor && (this.lifeCount > 0 || this.immortal) && duration !== undefined && duration > 0) {
          setTimeout(() => {
            var _a;
    
            this.pause();
    
            if (!this.immortal) {
              this.lifeCount--;
            }
    
            if (this.lifeCount > 0 || this.immortal) {
              this.position = this.calcPosition();
              setTimeout(() => {
                this.play();
              }, ((_a = this.emitterOptions.life.delay) !== null && _a !== void 0 ? _a : 0) * 1000 / this.container.retina.reduceFactor);
            } else {
              this.destroy();
            }
          }, duration * 1000);
        }
      }
    
      destroy() {
        this.emitters.removeEmitter(this);
      }
    
      calcPosition() {
        var _a, _b;
    
        const container = this.container;
        const percentPosition = this.emitterOptions.position;
        return {
          x: ((_a = percentPosition === null || percentPosition === void 0 ? void 0 : percentPosition.x) !== null && _a !== void 0 ? _a : Math.random() * 100) / 100 * container.canvas.size.width,
          y: ((_b = percentPosition === null || percentPosition === void 0 ? void 0 : percentPosition.y) !== null && _b !== void 0 ? _b : Math.random() * 100) / 100 * container.canvas.size.height
        };
      }
    
      emit() {
        const container = this.container;
        const position = this.position;
        const offset = {
          x: this.size.mode === SizeMode.percent ? container.canvas.size.width * this.size.width / 100 : this.size.width,
          y: this.size.mode === SizeMode.percent ? container.canvas.size.height * this.size.height / 100 : this.size.height
        };
    
        for (let i = 0; i < this.emitterOptions.rate.quantity; i++) {
          container.particles.addParticle(randomPosition(position, offset), this.particlesOptions);
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Plugins/Emitters/Options/Classes/EmitterRate.js
    class EmitterRate {
      constructor() {
        this.quantity = 1;
        this.delay = 0.1;
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.quantity !== undefined) {
          this.quantity = data.quantity;
        }
    
        if (data.delay !== undefined) {
          this.delay = data.delay;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Plugins/Emitters/Options/Classes/EmitterLife.js
    class EmitterLife {
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.count !== undefined) {
          this.count = data.count;
        }
    
        if (data.delay !== undefined) {
          this.delay = data.delay;
        }
    
        if (data.duration !== undefined) {
          this.duration = data.duration;
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Plugins/Emitters/Options/Classes/Emitter.js
    
    
    
    
    
    class Emitter {
      constructor() {
        this.direction = MoveDirection.none;
        this.life = new EmitterLife();
        this.rate = new EmitterRate();
      }
    
      load(data) {
        if (data === undefined) {
          return;
        }
    
        if (data.size !== undefined) {
          if (this.size === undefined) {
            this.size = new EmitterSize();
          }
    
          this.size.load(data.size);
        }
    
        if (data.direction !== undefined) {
          this.direction = data.direction;
        }
    
        this.life.load(data.life);
    
        if (data.particles !== undefined) {
          this.particles = Utils.deepExtend({}, data.particles);
        }
    
        this.rate.load(data.rate);
    
        if (data.position !== undefined) {
          this.position = {
            x: data.position.x,
            y: data.position.y
          };
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Plugins/Emitters/Enums/EmitterClickMode.js
    var EmitterClickMode;
    
    (function (EmitterClickMode) {
      EmitterClickMode["emitter"] = "emitter";
    })(EmitterClickMode || (EmitterClickMode = {}));
    // CONCATENATED MODULE: ./dist/browser/Plugins/Emitters/Enums/index.js
    
    // CONCATENATED MODULE: ./dist/browser/Plugins/Emitters/Emitters.js
    
    
    
    
    class Emitters {
      constructor(container) {
        this.container = container;
        this.array = [];
        this.emitters = [];
        this.interactivityEmitters = [];
        const overridableContainer = container;
    
        overridableContainer.addEmitter = (options, position) => this.addEmitter(options, position);
      }
    
      init(options) {
        var _a, _b;
    
        if (!options) {
          return;
        }
    
        if (options.emitters) {
          if (options.emitters instanceof Array) {
            this.emitters = options.emitters.map(s => {
              const tmp = new Emitter();
              tmp.load(s);
              return tmp;
            });
          } else {
            if (this.emitters instanceof Array) {
              this.emitters = new Emitter();
            }
    
            this.emitters.load(options.emitters);
          }
        }
    
        const interactivityEmitters = (_b = (_a = options.interactivity) === null || _a === void 0 ? void 0 : _a.modes) === null || _b === void 0 ? void 0 : _b.emitters;
    
        if (interactivityEmitters) {
          if (interactivityEmitters instanceof Array) {
            this.interactivityEmitters = interactivityEmitters.map(s => {
              const tmp = new Emitter();
              tmp.load(s);
              return tmp;
            });
          } else {
            if (this.interactivityEmitters instanceof Array) {
              this.interactivityEmitters = new Emitter();
            }
    
            this.interactivityEmitters.load(interactivityEmitters);
          }
        }
    
        if (this.emitters instanceof Array) {
          for (const emitterOptions of this.emitters) {
            this.addEmitter(emitterOptions);
          }
        } else {
          this.addEmitter(this.emitters);
        }
      }
    
      play() {
        for (const emitter of this.array) {
          emitter.play();
        }
      }
    
      pause() {
        for (const emitter of this.array) {
          emitter.pause();
        }
      }
    
      stop() {
        this.array = [];
      }
    
      handleClickMode(mode) {
        const container = this.container;
        const emitterOptions = this.emitters;
        const modeEmitters = this.interactivityEmitters;
    
        if (mode === EmitterClickMode.emitter) {
          let emitterModeOptions;
    
          if (modeEmitters instanceof Array) {
            if (modeEmitters.length > 0) {
              emitterModeOptions = Utils.itemFromArray(modeEmitters);
            }
          } else {
            emitterModeOptions = modeEmitters;
          }
    
          const emittersOptions = emitterModeOptions !== null && emitterModeOptions !== void 0 ? emitterModeOptions : emitterOptions instanceof Array ? Utils.itemFromArray(emitterOptions) : emitterOptions;
          const ePosition = container.interactivity.mouse.clickPosition;
          this.addEmitter(Utils.deepExtend({}, emittersOptions), ePosition);
        }
      }
    
      resize() {
        for (const emitter of this.array) {
          emitter.resize();
        }
      }
    
      addEmitter(options, position) {
        const emitter = new EmitterInstance(this, this.container, options, position);
        this.array.push(emitter);
        return emitter;
      }
    
      removeEmitter(emitter) {
        const index = this.array.indexOf(emitter);
    
        if (index >= 0) {
          this.array.splice(index, 1);
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Plugins/Emitters/EmittersPlugin.js
    
    
    
    
    
    class EmittersPlugin {
      constructor() {
        this.id = "emitters";
      }
    
      getPlugin(container) {
        return new Emitters(container);
      }
    
      needsPlugin(options) {
        var _a, _b, _c;
    
        if (options === undefined) {
          return false;
        }
    
        const emitters = options.emitters;
        let loadEmitters = false;
    
        if (emitters instanceof Array) {
          if (emitters.length) {
            loadEmitters = true;
          }
        } else if (emitters !== undefined) {
          loadEmitters = true;
        } else if (((_c = (_b = (_a = options.interactivity) === null || _a === void 0 ? void 0 : _a.events) === null || _b === void 0 ? void 0 : _b.onClick) === null || _c === void 0 ? void 0 : _c.mode) && Utils.isInArray(EmitterClickMode.emitter, options.interactivity.events.onClick.mode)) {
          loadEmitters = true;
        }
    
        return loadEmitters;
      }
    
      loadOptions(options, source) {
        var _a, _b;
    
        if (!this.needsPlugin(options) && !this.needsPlugin(source)) {
          return;
        }
    
        const optionsCast = options;
    
        if (source === null || source === void 0 ? void 0 : source.emitters) {
          if ((source === null || source === void 0 ? void 0 : source.emitters) instanceof Array) {
            optionsCast.emitters = source === null || source === void 0 ? void 0 : source.emitters.map(s => {
              const tmp = new Emitter();
              tmp.load(s);
              return tmp;
            });
          } else {
            let emitterOptions = optionsCast.emitters;
    
            if ((emitterOptions === null || emitterOptions === void 0 ? void 0 : emitterOptions.load) === undefined) {
              optionsCast.emitters = emitterOptions = new Emitter();
            }
    
            emitterOptions.load(source === null || source === void 0 ? void 0 : source.emitters);
          }
        }
    
        const interactivityEmitters = (_b = (_a = source === null || source === void 0 ? void 0 : source.interactivity) === null || _a === void 0 ? void 0 : _a.modes) === null || _b === void 0 ? void 0 : _b.emitters;
    
        if (interactivityEmitters) {
          if (interactivityEmitters instanceof Array) {
            optionsCast.interactivity.modes.emitters = interactivityEmitters.map(s => {
              const tmp = new Emitter();
              tmp.load(s);
              return tmp;
            });
          } else {
            let emitterOptions = optionsCast.interactivity.modes.emitters;
    
            if ((emitterOptions === null || emitterOptions === void 0 ? void 0 : emitterOptions.load) === undefined) {
              optionsCast.interactivity.modes.emitters = emitterOptions = new Emitter();
            }
    
            emitterOptions.load(interactivityEmitters);
          }
        }
      }
    
    }
    
    const EmittersPlugin_plugin = new EmittersPlugin();
    
    
    // CONCATENATED MODULE: ./dist/browser/Plugins/PolygonMask/Enums/InlineArrangement.js
    var InlineArrangement;
    
    (function (InlineArrangement) {
      InlineArrangement["equidistant"] = "equidistant";
      InlineArrangement["onePerPoint"] = "one-per-point";
      InlineArrangement["perPoint"] = "per-point";
      InlineArrangement["randomLength"] = "random-length";
      InlineArrangement["randomPoint"] = "random-point";
    })(InlineArrangement || (InlineArrangement = {}));
    // CONCATENATED MODULE: ./dist/browser/Plugins/PolygonMask/Enums/MoveType.js
    var MoveType;
    
    (function (MoveType) {
      MoveType["path"] = "path";
      MoveType["radius"] = "radius";
    })(MoveType || (MoveType = {}));
    // CONCATENATED MODULE: ./dist/browser/Plugins/PolygonMask/Enums/Type.js
    var Type;
    
    (function (Type) {
      Type["inline"] = "inline";
      Type["inside"] = "inside";
      Type["outside"] = "outside";
      Type["none"] = "none";
    })(Type || (Type = {}));
    // CONCATENATED MODULE: ./dist/browser/Plugins/PolygonMask/Enums/index.js
    
    
    
    // CONCATENATED MODULE: ./dist/browser/Plugins/PolygonMask/Options/Classes/DrawStroke.js
    
    
    class DrawStroke {
      constructor() {
        this.color = new OptionsColor();
        this.width = 0.5;
        this.opacity = 1;
      }
    
      load(data) {
        var _a;
    
        if (data !== undefined) {
          this.color = OptionsColor.create(this.color, data.color);
    
          if (typeof this.color.value === "string") {
            this.opacity = (_a = ColorUtils.stringToAlpha(this.color.value)) !== null && _a !== void 0 ? _a : this.opacity;
          }
    
          if (data.opacity !== undefined) {
            this.opacity = data.opacity;
          }
    
          if (data.width !== undefined) {
            this.width = data.width;
          }
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Plugins/PolygonMask/Options/Classes/Draw.js
    
    
    class Draw {
      constructor() {
        this.enable = false;
        this.stroke = new DrawStroke();
      }
    
      get lineWidth() {
        return this.stroke.width;
      }
    
      set lineWidth(value) {
        this.stroke.width = value;
      }
    
      get lineColor() {
        return this.stroke.color;
      }
    
      set lineColor(value) {
        this.stroke.color = OptionsColor.create(this.stroke.color, value);
      }
    
      load(data) {
        var _a;
    
        if (data !== undefined) {
          if (data.enable !== undefined) {
            this.enable = data.enable;
          }
    
          const stroke = (_a = data.stroke) !== null && _a !== void 0 ? _a : {
            color: data.lineColor,
            width: data.lineWidth
          };
          this.stroke.load(stroke);
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Plugins/PolygonMask/Options/Classes/Move.js
    
    class Move_Move {
      constructor() {
        this.radius = 10;
        this.type = MoveType.path;
      }
    
      load(data) {
        if (data !== undefined) {
          if (data.radius !== undefined) {
            this.radius = data.radius;
          }
    
          if (data.type !== undefined) {
            this.type = data.type;
          }
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Plugins/PolygonMask/Options/Classes/Inline.js
    
    class Inline {
      constructor() {
        this.arrangement = InlineArrangement.onePerPoint;
      }
    
      load(data) {
        if (data !== undefined) {
          if (data.arrangement !== undefined) {
            this.arrangement = data.arrangement;
          }
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Plugins/PolygonMask/Options/Classes/LocalSvg.js
    class LocalSvg {
      constructor() {
        this.path = [];
        this.size = {
          height: 0,
          width: 0
        };
      }
    
      load(data) {
        if (data !== undefined) {
          if (data.path !== undefined) {
            this.path = data.path;
          }
    
          if (data.size !== undefined) {
            if (data.size.width !== undefined) {
              this.size.width = data.size.width;
            }
    
            if (data.size.height !== undefined) {
              this.size.height = data.size.height;
            }
          }
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Plugins/PolygonMask/Options/Classes/PolygonMask.js
    
    
    
    
    
    class PolygonMask {
      constructor() {
        this.draw = new Draw();
        this.enable = false;
        this.inline = new Inline();
        this.move = new Move_Move();
        this.scale = 1;
        this.type = Type.none;
      }
    
      get inlineArrangement() {
        return this.inline.arrangement;
      }
    
      set inlineArrangement(value) {
        this.inline.arrangement = value;
      }
    
      load(data) {
        var _a;
    
        if (data !== undefined) {
          this.draw.load(data.draw);
          const inline = (_a = data.inline) !== null && _a !== void 0 ? _a : {
            arrangement: data.inlineArrangement
          };
    
          if (inline !== undefined) {
            this.inline.load(inline);
          }
    
          this.move.load(data.move);
    
          if (data.scale !== undefined) {
            this.scale = data.scale;
          }
    
          if (data.type !== undefined) {
            this.type = data.type;
          }
    
          if (data.enable !== undefined) {
            this.enable = data.enable;
          } else {
            this.enable = this.type !== Type.none;
          }
    
          if (data.url !== undefined) {
            this.url = data.url;
          }
    
          if (data.data !== undefined) {
            if (typeof data.data === "string") {
              this.data = data.data;
            } else {
              this.data = new LocalSvg();
              this.data.load(data.data);
            }
          }
    
          if (data.position !== undefined) {
            this.position = {
              x: data.position.x,
              y: data.position.y
            };
          }
        }
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Plugins/PolygonMask/PolygonMaskInstance.js
    var PolygonMaskInstance_awaiter = undefined && undefined.__awaiter || function (thisArg, _arguments, P, generator) {
      function adopt(value) {
        return value instanceof P ? value : new P(function (resolve) {
          resolve(value);
        });
      }
    
      return new (P || (P = Promise))(function (resolve, reject) {
        function fulfilled(value) {
          try {
            step(generator.next(value));
          } catch (e) {
            reject(e);
          }
        }
    
        function rejected(value) {
          try {
            step(generator["throw"](value));
          } catch (e) {
            reject(e);
          }
        }
    
        function step(result) {
          result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);
        }
    
        step((generator = generator.apply(thisArg, _arguments || [])).next());
      });
    };
    
    
    
    
    
    function polygonBounce(particle) {
      particle.velocity.horizontal = particle.velocity.vertical / 2 - particle.velocity.horizontal;
      particle.velocity.vertical = particle.velocity.horizontal / 2 - particle.velocity.vertical;
    }
    
    function drawPolygonMask(context, rawData, stroke) {
      const color = ColorUtils.colorToRgb(stroke.color);
    
      if (!color) {
        return;
      }
    
      context.beginPath();
      context.moveTo(rawData[0].x, rawData[0].y);
    
      for (const item of rawData) {
        context.lineTo(item.x, item.y);
      }
    
      context.closePath();
      context.strokeStyle = ColorUtils.getStyleFromRgb(color);
      context.lineWidth = stroke.width;
      context.stroke();
    }
    
    function drawPolygonMaskPath(context, path, stroke, position) {
      context.translate(position.x, position.y);
      const color = ColorUtils.colorToRgb(stroke.color);
    
      if (!color) {
        return;
      }
    
      context.strokeStyle = ColorUtils.getStyleFromRgb(color, stroke.opacity);
      context.lineWidth = stroke.width;
      context.stroke(path);
    }
    
    function parsePaths(paths, scale, offset) {
      const res = [];
    
      for (const path of paths) {
        const segments = path.element.pathSegList;
        const len = segments.numberOfItems;
        const p = {
          x: 0,
          y: 0
        };
    
        for (let i = 0; i < len; i++) {
          const segment = segments.getItem(i);
          const svgPathSeg = window.SVGPathSeg;
    
          switch (segment.pathSegType) {
            case svgPathSeg.PATHSEG_MOVETO_ABS:
            case svgPathSeg.PATHSEG_LINETO_ABS:
            case svgPathSeg.PATHSEG_CURVETO_CUBIC_ABS:
            case svgPathSeg.PATHSEG_CURVETO_QUADRATIC_ABS:
            case svgPathSeg.PATHSEG_ARC_ABS:
            case svgPathSeg.PATHSEG_CURVETO_CUBIC_SMOOTH_ABS:
            case svgPathSeg.PATHSEG_CURVETO_QUADRATIC_SMOOTH_ABS:
              {
                const absSeg = segment;
                p.x = absSeg.x;
                p.y = absSeg.y;
                break;
              }
    
            case svgPathSeg.PATHSEG_LINETO_HORIZONTAL_ABS:
              p.x = segment.x;
              break;
    
            case svgPathSeg.PATHSEG_LINETO_VERTICAL_ABS:
              p.y = segment.y;
              break;
    
            case svgPathSeg.PATHSEG_LINETO_REL:
            case svgPathSeg.PATHSEG_MOVETO_REL:
            case svgPathSeg.PATHSEG_CURVETO_CUBIC_REL:
            case svgPathSeg.PATHSEG_CURVETO_QUADRATIC_REL:
            case svgPathSeg.PATHSEG_ARC_REL:
            case svgPathSeg.PATHSEG_CURVETO_CUBIC_SMOOTH_REL:
            case svgPathSeg.PATHSEG_CURVETO_QUADRATIC_SMOOTH_REL:
              {
                const relSeg = segment;
                p.x += relSeg.x;
                p.y += relSeg.y;
                break;
              }
    
            case svgPathSeg.PATHSEG_LINETO_HORIZONTAL_REL:
              p.x += segment.x;
              break;
    
            case svgPathSeg.PATHSEG_LINETO_VERTICAL_REL:
              p.y += segment.y;
              break;
    
            case svgPathSeg.PATHSEG_UNKNOWN:
            case svgPathSeg.PATHSEG_CLOSEPATH:
              continue;
          }
    
          res.push({
            x: p.x * scale + offset.x,
            y: p.y * scale + offset.y
          });
        }
      }
    
      return res;
    }
    
    class PolygonMaskInstance {
      constructor(container) {
        this.container = container;
        this.dimension = {
          height: 0,
          width: 0
        };
        this.path2DSupported = !!window.Path2D;
        this.options = new PolygonMask();
        this.polygonMaskMoveRadius = this.options.move.radius * container.retina.pixelRatio;
      }
    
      initAsync(options) {
        return PolygonMaskInstance_awaiter(this, void 0, void 0, function* () {
          this.options.load(options === null || options === void 0 ? void 0 : options.polygon);
          const polygonMaskOptions = this.options;
          this.polygonMaskMoveRadius = polygonMaskOptions.move.radius * this.container.retina.pixelRatio;
    
          if (polygonMaskOptions.enable) {
            yield this.initRawData();
          }
        });
      }
    
      resize() {
        const container = this.container;
        const options = this.options;
    
        if (!(options.enable && options.type !== Type.none)) {
          return;
        }
    
        if (this.redrawTimeout) {
          clearTimeout(this.redrawTimeout);
        }
    
        this.redrawTimeout = window.setTimeout(() => PolygonMaskInstance_awaiter(this, void 0, void 0, function* () {
          yield this.initRawData(true);
          container.particles.redraw();
        }), 250);
      }
    
      stop() {
        delete this.raw;
        delete this.paths;
      }
    
      particlesInitialization() {
        const options = this.options;
    
        if (options.enable && options.type === Type.inline && (options.inline.arrangement === InlineArrangement.onePerPoint || options.inline.arrangement === InlineArrangement.perPoint)) {
          this.drawPoints();
          return true;
        }
    
        return false;
      }
    
      particlePosition(position) {
        var _a, _b;
    
        const options = this.options;
    
        if (!(options.enable && ((_b = (_a = this.raw) === null || _a === void 0 ? void 0 : _a.length) !== null && _b !== void 0 ? _b : 0) > 0)) {
          return;
        }
    
        return Utils.deepExtend({}, position ? position : this.randomPoint());
      }
    
      particleBounce(particle) {
        const options = this.options;
    
        if (options.enable && options.type !== Type.none && options.type !== Type.inline) {
          if (!this.checkInsidePolygon(particle.getPosition())) {
            polygonBounce(particle);
            return true;
          }
        } else if (options.enable && options.type === Type.inline && particle.initialPosition) {
          const dist = NumberUtils.getDistance(particle.initialPosition, particle.getPosition());
    
          if (dist > this.polygonMaskMoveRadius) {
            polygonBounce(particle);
            return true;
          }
        }
    
        return false;
      }
    
      clickPositionValid(position) {
        const options = this.options;
        return options.enable && options.type !== Type.none && options.type !== Type.inline && this.checkInsidePolygon(position);
      }
    
      draw(context) {
        var _a;
    
        if (!((_a = this.paths) === null || _a === void 0 ? void 0 : _a.length)) {
          return;
        }
    
        const options = this.options;
        const polygonDraw = options.draw;
    
        if (!(options.enable && polygonDraw.enable)) {
          return;
        }
    
        const rawData = this.raw;
    
        for (const path of this.paths) {
          const path2d = path.path2d;
          const path2dSupported = this.path2DSupported;
    
          if (!context) {
            continue;
          }
    
          if (path2dSupported && path2d && this.offset) {
            drawPolygonMaskPath(context, path2d, polygonDraw.stroke, this.offset);
          } else if (rawData) {
            drawPolygonMask(context, rawData, polygonDraw.stroke);
          }
        }
      }
    
      checkInsidePolygon(position) {
        var _a, _b;
    
        const container = this.container;
        const options = this.options;
    
        if (!options.enable || options.type === Type.none || options.type === Type.inline) {
          return true;
        }
    
        if (!this.raw) {
          throw new Error(Constants.noPolygonFound);
        }
    
        const canvasSize = container.canvas.size;
        const x = (_a = position === null || position === void 0 ? void 0 : position.x) !== null && _a !== void 0 ? _a : Math.random() * canvasSize.width;
        const y = (_b = position === null || position === void 0 ? void 0 : position.y) !== null && _b !== void 0 ? _b : Math.random() * canvasSize.height;
        let inside = false;
    
        for (let i = 0, j = this.raw.length - 1; i < this.raw.length; j = i++) {
          const pi = this.raw[i];
          const pj = this.raw[j];
          const intersect = pi.y > y !== pj.y > y && x < (pj.x - pi.x) * (y - pi.y) / (pj.y - pi.y) + pi.x;
    
          if (intersect) {
            inside = !inside;
          }
        }
    
        return options.type === Type.inside ? inside : options.type === Type.outside ? !inside : false;
      }
    
      parseSvgPath(xml, force) {
        var _a, _b, _c;
    
        const forceDownload = force !== null && force !== void 0 ? force : false;
    
        if (this.paths !== undefined && !forceDownload) {
          return this.raw;
        }
    
        const container = this.container;
        const options = this.options;
        const parser = new DOMParser();
        const doc = parser.parseFromString(xml, "image/svg+xml");
        const svg = doc.getElementsByTagName("svg")[0];
        let svgPaths = svg.getElementsByTagName("path");
    
        if (!svgPaths.length) {
          svgPaths = doc.getElementsByTagName("path");
        }
    
        this.paths = [];
    
        for (let i = 0; i < svgPaths.length; i++) {
          const path = svgPaths.item(i);
    
          if (path) {
            this.paths.push({
              element: path,
              length: path.getTotalLength()
            });
          }
        }
    
        const pxRatio = container.retina.pixelRatio;
        const scale = options.scale / pxRatio;
        this.dimension.width = parseFloat((_a = svg.getAttribute("width")) !== null && _a !== void 0 ? _a : "0") * scale;
        this.dimension.height = parseFloat((_b = svg.getAttribute("height")) !== null && _b !== void 0 ? _b : "0") * scale;
        const position = (_c = options.position) !== null && _c !== void 0 ? _c : {
          x: 50,
          y: 50
        };
        this.offset = {
          x: container.canvas.size.width * position.x / (100 * pxRatio) - this.dimension.width / 2,
          y: container.canvas.size.height * position.y / (100 * pxRatio) - this.dimension.height / 2
        };
        return parsePaths(this.paths, scale, this.offset);
      }
    
      downloadSvgPath(svgUrl, force) {
        return PolygonMaskInstance_awaiter(this, void 0, void 0, function* () {
          const options = this.options;
          const url = svgUrl || options.url;
          const forceDownload = force !== null && force !== void 0 ? force : false;
    
          if (!url || this.paths !== undefined && !forceDownload) {
            return this.raw;
          }
    
          const req = yield fetch(url);
    
          if (!req.ok) {
            throw new Error("tsParticles Error - Error occurred during polygon mask download");
          }
    
          return this.parseSvgPath(yield req.text(), force);
        });
      }
    
      drawPoints() {
        if (!this.raw) {
          return;
        }
    
        for (const item of this.raw) {
          this.container.particles.addParticle({
            x: item.x,
            y: item.y
          });
        }
      }
    
      randomPoint() {
        const container = this.container;
        const options = this.options;
        let position;
    
        if (options.type === Type.inline) {
          switch (options.inline.arrangement) {
            case InlineArrangement.randomPoint:
              position = this.getRandomPoint();
              break;
    
            case InlineArrangement.randomLength:
              position = this.getRandomPointByLength();
              break;
    
            case InlineArrangement.equidistant:
              position = this.getEquidistantPointByIndex(container.particles.count);
              break;
    
            case InlineArrangement.onePerPoint:
            case InlineArrangement.perPoint:
            default:
              position = this.getPointByIndex(container.particles.count);
          }
        } else {
          position = {
            x: Math.random() * container.canvas.size.width,
            y: Math.random() * container.canvas.size.height
          };
        }
    
        if (this.checkInsidePolygon(position)) {
          return position;
        } else {
          return this.randomPoint();
        }
      }
    
      getRandomPoint() {
        if (!this.raw || !this.raw.length) {
          throw new Error(Constants.noPolygonDataLoaded);
        }
    
        const coords = Utils.itemFromArray(this.raw);
        return {
          x: coords.x,
          y: coords.y
        };
      }
    
      getRandomPointByLength() {
        var _a, _b, _c;
    
        const options = this.options;
    
        if (!this.raw || !this.raw.length || !((_a = this.paths) === null || _a === void 0 ? void 0 : _a.length)) {
          throw new Error(Constants.noPolygonDataLoaded);
        }
    
        const path = Utils.itemFromArray(this.paths);
        const distance = Math.floor(Math.random() * path.length) + 1;
        const point = path.element.getPointAtLength(distance);
        return {
          x: point.x * options.scale + (((_b = this.offset) === null || _b === void 0 ? void 0 : _b.x) || 0),
          y: point.y * options.scale + (((_c = this.offset) === null || _c === void 0 ? void 0 : _c.y) || 0)
        };
      }
    
      getEquidistantPointByIndex(index) {
        var _a, _b, _c, _d, _e, _f, _g;
    
        const options = this.container.options;
        const polygonMaskOptions = this.options;
        if (!this.raw || !this.raw.length || !((_a = this.paths) === null || _a === void 0 ? void 0 : _a.length)) throw new Error(Constants.noPolygonDataLoaded);
        let offset = 0;
        let point;
        const totalLength = this.paths.reduce((tot, path) => tot + path.length, 0);
        const distance = totalLength / options.particles.number.value;
    
        for (const path of this.paths) {
          const pathDistance = distance * index - offset;
    
          if (pathDistance <= path.length) {
            point = path.element.getPointAtLength(pathDistance);
            break;
          } else {
            offset += path.length;
          }
        }
    
        return {
          x: ((_b = point === null || point === void 0 ? void 0 : point.x) !== null && _b !== void 0 ? _b : 0) * polygonMaskOptions.scale + ((_d = (_c = this.offset) === null || _c === void 0 ? void 0 : _c.x) !== null && _d !== void 0 ? _d : 0),
          y: ((_e = point === null || point === void 0 ? void 0 : point.y) !== null && _e !== void 0 ? _e : 0) * polygonMaskOptions.scale + ((_g = (_f = this.offset) === null || _f === void 0 ? void 0 : _f.y) !== null && _g !== void 0 ? _g : 0)
        };
      }
    
      getPointByIndex(index) {
        if (!this.raw || !this.raw.length) {
          throw new Error(Constants.noPolygonDataLoaded);
        }
    
        const coords = this.raw[index % this.raw.length];
        return {
          x: coords.x,
          y: coords.y
        };
      }
    
      createPath2D() {
        var _a, _b;
    
        const options = this.options;
    
        if (!this.path2DSupported || !((_a = this.paths) === null || _a === void 0 ? void 0 : _a.length)) {
          return;
        }
    
        for (const path of this.paths) {
          const pathData = (_b = path.element) === null || _b === void 0 ? void 0 : _b.getAttribute("d");
    
          if (pathData) {
            const path2d = new Path2D(pathData);
            const matrix = document.createElementNS("http://www.w3.org/2000/svg", "svg").createSVGMatrix();
            const finalPath = new Path2D();
            const transform = matrix.scale(options.scale);
    
            if (finalPath.addPath) {
              finalPath.addPath(path2d, transform);
              path.path2d = finalPath;
            } else {
              delete path.path2d;
            }
          } else {
            delete path.path2d;
          }
    
          if (path.path2d || !this.raw) {
            continue;
          }
    
          path.path2d = new Path2D();
          path.path2d.moveTo(this.raw[0].x, this.raw[0].y);
          this.raw.forEach((pos, i) => {
            var _a;
    
            if (i > 0) {
              (_a = path.path2d) === null || _a === void 0 ? void 0 : _a.lineTo(pos.x, pos.y);
            }
          });
          path.path2d.closePath();
        }
      }
    
      initRawData(force) {
        return PolygonMaskInstance_awaiter(this, void 0, void 0, function* () {
          const options = this.options;
    
          if (options.url) {
            this.raw = yield this.downloadSvgPath(options.url, force);
          } else if (options.data) {
            const data = options.data;
            let svg;
    
            if (typeof data !== "string") {
              const path = data.path instanceof Array ? data.path.map(t => `<path d="${t}" />`).join("") : `<path d="${data.path}" />`;
              const namespaces = 'xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"';
              svg = `<svg ${namespaces} width="${data.size.width}" height="${data.size.height}">${path}</svg>`;
            } else {
              svg = data;
            }
    
            this.raw = this.parseSvgPath(svg, force);
          }
    
          this.createPath2D();
        });
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Plugins/PolygonMask/PolygonMaskPlugin.js
    
    
    
    
    class PolygonMaskPlugin {
      constructor() {
        this.id = "polygonMask";
      }
    
      getPlugin(container) {
        return new PolygonMaskInstance(container);
      }
    
      needsPlugin(options) {
        var _a, _b, _c;
    
        return (_b = (_a = options === null || options === void 0 ? void 0 : options.polygon) === null || _a === void 0 ? void 0 : _a.enable) !== null && _b !== void 0 ? _b : ((_c = options === null || options === void 0 ? void 0 : options.polygon) === null || _c === void 0 ? void 0 : _c.type) !== undefined && options.polygon.type !== Type.none;
      }
    
      loadOptions(options, source) {
        if (!this.needsPlugin(source)) {
          return;
        }
    
        const optionsCast = options;
        let polygonOptions = optionsCast.polygon;
    
        if ((polygonOptions === null || polygonOptions === void 0 ? void 0 : polygonOptions.load) === undefined) {
          optionsCast.polygon = polygonOptions = new PolygonMask();
        }
    
        polygonOptions.load(source === null || source === void 0 ? void 0 : source.polygon);
      }
    
    }
    
    const PolygonMaskPlugin_plugin = new PolygonMaskPlugin();
    
    
    // CONCATENATED MODULE: ./dist/browser/main.js
    
    
    
    
    class Main extends MainSlim {
      constructor() {
        super();
        this.addPlugin(AbsorbersPlugin_plugin);
        this.addPlugin(EmittersPlugin_plugin);
        this.addPlugin(PolygonMaskPlugin_plugin);
      }
    
    }
    // CONCATENATED MODULE: ./dist/browser/Types/index.js
    
    
    
    
    // CONCATENATED MODULE: ./dist/browser/index.js
    
    
    
    const tsParticles = new Main();
    tsParticles.init();
    const {
      particlesJS,
      pJSDom
    } = initPjs(tsParticles);
    
    
    
    
    
    
    
    
    
    /***/ })
    
    /******/  });
    /************************************************************************/
    /******/  // The module cache
    /******/  var __webpack_module_cache__ = {};
    /******/  
    /******/  // The require function
    /******/  function __webpack_require__(moduleId) {
    /******/    // Check if module is in cache
    /******/    if(__webpack_module_cache__[moduleId]) {
    /******/      return __webpack_module_cache__[moduleId].exports;
    /******/    }
    /******/    // Create a new module (and put it into the cache)
    /******/    var module = __webpack_module_cache__[moduleId] = {
    /******/      // no module.id needed
    /******/      // no module.loaded needed
    /******/      exports: {}
    /******/    };
    /******/  
    /******/    // Execute the module function
    /******/    __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
    /******/  
    /******/    // Return the exports of the module
    /******/    return module.exports;
    /******/  }
    /******/  
    /************************************************************************/
    /******/  /* webpack/runtime/define property getters */
    /******/  (() => {
    /******/    // define getter functions for harmony exports
    /******/    __webpack_require__.d = (exports, definition) => {
    /******/      for(var key in definition) {
    /******/        if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
    /******/          Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
    /******/        }
    /******/      }
    /******/    };
    /******/  })();
    /******/  
    /******/  /* webpack/runtime/hasOwnProperty shorthand */
    /******/  (() => {
    /******/    __webpack_require__.o = (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop)
    /******/  })();
    /******/  
    /******/  /* webpack/runtime/make namespace object */
    /******/  (() => {
    /******/    // define __esModule on exports
    /******/    __webpack_require__.r = (exports) => {
    /******/      if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
    /******/        Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
    /******/      }
    /******/      Object.defineProperty(exports, '__esModule', { value: true });
    /******/    };
    /******/  })();
    /******/  
    /************************************************************************/
    /******/  // module exports must be returned from runtime so entry inlining is disabled
    /******/  // startup
    /******/  // Load entry module and return exports
    /******/  return __webpack_require__(714);
    /******/ })()
    ;
    });
    
    } )( jQuery );
    

Youez - 2016 - github.com/yon3zu
LinuXploit