@tsparticles/all 4.0.0-alpha.8 → 4.0.0-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1129) hide show
  1. package/1028.min.js +1 -0
  2. package/1030.min.js +1 -0
  3. package/1048.min.js +1 -0
  4. package/1051.min.js +1 -0
  5. package/1061.min.js +1 -0
  6. package/1089.min.js +1 -0
  7. package/1120.min.js +1 -0
  8. package/1121.min.js +1 -0
  9. package/1160.min.js +1 -0
  10. package/1167.min.js +1 -0
  11. package/117.min.js +1 -0
  12. package/1201.min.js +1 -0
  13. package/1255.min.js +1 -0
  14. package/143.min.js +1 -0
  15. package/1510.min.js +1 -0
  16. package/1551.min.js +1 -0
  17. package/1605.min.js +1 -0
  18. package/1611.min.js +1 -0
  19. package/1661.min.js +1 -0
  20. package/1707.min.js +2 -0
  21. package/1744.min.js +1 -0
  22. package/1767.min.js +1 -0
  23. package/1818.min.js +2 -0
  24. package/1841.min.js +1 -0
  25. package/1860.min.js +1 -0
  26. package/2004.min.js +1 -0
  27. package/2093.min.js +1 -0
  28. package/2105.min.js +1 -0
  29. package/2158.min.js +1 -0
  30. package/2177.min.js +1 -0
  31. package/2253.min.js +1 -0
  32. package/2261.min.js +1 -0
  33. package/2265.min.js +1 -0
  34. package/2360.min.js +1 -0
  35. package/2405.min.js +1 -0
  36. package/2413.min.js +1 -0
  37. package/2425.min.js +1 -0
  38. package/2429.min.js +1 -0
  39. package/2454.min.js +1 -0
  40. package/2554.min.js +1 -0
  41. package/264.min.js +1 -0
  42. package/2643.min.js +1 -0
  43. package/2682.min.js +1 -0
  44. package/2784.min.js +1 -0
  45. package/2825.min.js +1 -0
  46. package/2866.min.js +1 -0
  47. package/2908.min.js +1 -0
  48. package/2930.min.js +1 -0
  49. package/2933.min.js +1 -0
  50. package/2964.min.js +1 -0
  51. package/2971.min.js +1 -0
  52. package/2975.min.js +1 -0
  53. package/301.min.js +1 -0
  54. package/3041.min.js +1 -0
  55. package/3057.min.js +1 -0
  56. package/3088.min.js +1 -0
  57. package/3089.min.js +1 -0
  58. package/31.min.js +1 -0
  59. package/3128.min.js +1 -0
  60. package/3150.min.js +1 -0
  61. package/3152.min.js +1 -2
  62. package/3210.min.js +1 -0
  63. package/3248.min.js +1 -0
  64. package/3256.min.js +1 -0
  65. package/3285.min.js +1 -0
  66. package/3304.min.js +1 -0
  67. package/3323.min.js +1 -0
  68. package/335.min.js +1 -0
  69. package/3362.min.js +1 -0
  70. package/3471.min.js +1 -0
  71. package/3477.min.js +1 -0
  72. package/349.min.js +1 -0
  73. package/350.min.js +1 -0
  74. package/3595.min.js +1 -0
  75. package/3693.min.js +1 -0
  76. package/370.min.js +2 -0
  77. package/3706.min.js +1 -0
  78. package/3719.min.js +1 -0
  79. package/3728.min.js +1 -0
  80. package/3737.min.js +1 -0
  81. package/3775.min.js +1 -0
  82. package/3861.min.js +1 -0
  83. package/3875.min.js +1 -0
  84. package/3895.min.js +1 -0
  85. package/394.min.js +1 -0
  86. package/3949.min.js +1 -0
  87. package/3961.min.js +1 -2
  88. package/3972.min.js +1 -0
  89. package/3983.min.js +1 -0
  90. package/4051.min.js +1 -0
  91. package/4054.min.js +1 -0
  92. package/4074.min.js +1 -0
  93. package/4075.min.js +1 -0
  94. package/4088.min.js +1 -0
  95. package/410.min.js +1 -0
  96. package/4117.min.js +1 -0
  97. package/4129.min.js +1 -0
  98. package/4159.min.js +1 -0
  99. package/4191.min.js +1 -0
  100. package/4198.min.js +1 -0
  101. package/4204.min.js +1 -0
  102. package/4258.min.js +1 -0
  103. package/4301.min.js +1 -0
  104. package/4306.min.js +1 -0
  105. package/4316.min.js +1 -0
  106. package/4376.min.js +1 -0
  107. package/4468.min.js +1 -0
  108. package/4473.min.js +1 -0
  109. package/4489.min.js +1 -0
  110. package/4537.min.js +1 -0
  111. package/4550.min.js +1 -0
  112. package/4567.min.js +1 -0
  113. package/4592.min.js +1 -0
  114. package/4601.min.js +1 -0
  115. package/465.min.js +1 -0
  116. package/4656.min.js +1 -0
  117. package/4701.min.js +1 -0
  118. package/4722.min.js +1 -0
  119. package/4726.min.js +1 -0
  120. package/4837.min.js +1 -2
  121. package/4839.min.js +1 -0
  122. package/4880.min.js +1 -0
  123. package/4887.min.js +1 -0
  124. package/4898.min.js +1 -0
  125. package/4917.min.js +1 -0
  126. package/4952.min.js +1 -0
  127. package/4991.min.js +1 -0
  128. package/5055.min.js +1 -0
  129. package/5056.min.js +1 -0
  130. package/5077.min.js +1 -0
  131. package/5095.min.js +1 -0
  132. package/5136.min.js +1 -0
  133. package/5174.min.js +1 -0
  134. package/5197.min.js +1 -0
  135. package/5212.min.js +1 -0
  136. package/5232.min.js +1 -0
  137. package/5260.min.js +1 -0
  138. package/5264.min.js +1 -0
  139. package/5275.min.js +1 -0
  140. package/5313.min.js +1 -0
  141. package/5325.min.js +1 -0
  142. package/5332.min.js +1 -0
  143. package/5341.min.js +1 -0
  144. package/5347.min.js +1 -0
  145. package/5352.min.js +1 -0
  146. package/5356.min.js +1 -0
  147. package/5402.min.js +1 -0
  148. package/5437.min.js +1 -0
  149. package/5447.min.js +1 -0
  150. package/5453.min.js +1 -0
  151. package/5532.min.js +1 -0
  152. package/5541.min.js +1 -0
  153. package/5589.min.js +1 -0
  154. package/5602.min.js +1 -0
  155. package/561.min.js +1 -0
  156. package/5641.min.js +1 -0
  157. package/5651.min.js +1 -0
  158. package/5668.min.js +1 -0
  159. package/5669.min.js +1 -0
  160. package/5686.min.js +1 -0
  161. package/5694.min.js +1 -0
  162. package/5700.min.js +1 -0
  163. package/5719.min.js +1 -0
  164. package/5732.min.js +1 -0
  165. package/5742.min.js +1 -0
  166. package/5816.min.js +1 -0
  167. package/5832.min.js +1 -0
  168. package/587.min.js +1 -0
  169. package/5976.min.js +1 -0
  170. package/6055.min.js +1 -0
  171. package/6056.min.js +1 -0
  172. package/607.min.js +1 -0
  173. package/6130.min.js +1 -0
  174. package/6202.min.js +1 -0
  175. package/6222.min.js +1 -0
  176. package/6227.min.js +1 -0
  177. package/6252.min.js +1 -0
  178. package/6280.min.js +1 -0
  179. package/6297.min.js +1 -0
  180. package/6340.min.js +1 -0
  181. package/6362.min.js +1 -0
  182. package/6364.min.js +1 -0
  183. package/6388.min.js +1 -2
  184. package/6412.min.js +1 -0
  185. package/649.min.js +1 -0
  186. package/6496.min.js +1 -0
  187. package/6502.min.js +1 -0
  188. package/6561.min.js +1 -0
  189. package/6598.min.js +1 -0
  190. package/6613.min.js +1 -0
  191. package/6693.min.js +1 -0
  192. package/6711.min.js +1 -2
  193. package/6808.min.js +1 -0
  194. package/6822.min.js +1 -0
  195. package/6827.min.js +1 -0
  196. package/686.min.js +1 -0
  197. package/6868.min.js +1 -0
  198. package/6897.min.js +1 -0
  199. package/6907.min.js +1 -0
  200. package/6938.min.js +1 -0
  201. package/6940.min.js +1 -0
  202. package/7017.min.js +1 -0
  203. package/7041.min.js +1 -0
  204. package/7050.min.js +1 -0
  205. package/706.min.js +1 -0
  206. package/7062.min.js +1 -0
  207. package/7079.min.js +1 -0
  208. package/7149.min.js +1 -0
  209. package/7157.min.js +1 -0
  210. package/719.min.js +1 -0
  211. package/7196.min.js +1 -0
  212. package/7203.min.js +1 -0
  213. package/7206.min.js +1 -0
  214. package/7218.min.js +1 -0
  215. package/7359.min.js +1 -0
  216. package/7374.min.js +1 -0
  217. package/7386.min.js +1 -0
  218. package/7403.min.js +1 -0
  219. package/746.min.js +1 -0
  220. package/7462.min.js +1 -0
  221. package/748.min.js +1 -0
  222. package/7520.min.js +1 -0
  223. package/7522.min.js +1 -0
  224. package/7590.min.js +1 -0
  225. package/7596.min.js +1 -0
  226. package/7604.min.js +1 -0
  227. package/762.min.js +1 -0
  228. package/7721.min.js +1 -0
  229. package/7788.min.js +1 -0
  230. package/7817.min.js +1 -0
  231. package/786.min.js +1 -0
  232. package/7921.min.js +1 -0
  233. package/803.min.js +1 -0
  234. package/8082.min.js +1 -0
  235. package/8096.min.js +1 -0
  236. package/8111.min.js +1 -0
  237. package/8173.min.js +1 -0
  238. package/8243.min.js +1 -0
  239. package/8272.min.js +1 -0
  240. package/8274.min.js +1 -0
  241. package/83.min.js +2 -2
  242. package/830.min.js +1 -0
  243. package/8319.min.js +1 -0
  244. package/8342.min.js +1 -0
  245. package/8360.min.js +1 -0
  246. package/8421.min.js +1 -0
  247. package/8446.min.js +1 -0
  248. package/8536.min.js +1 -0
  249. package/8553.min.js +33 -0
  250. package/8569.min.js +1 -0
  251. package/8626.min.js +1 -0
  252. package/8650.min.js +1 -0
  253. package/8684.min.js +1 -0
  254. package/8708.min.js +1 -0
  255. package/8775.min.js +1 -0
  256. package/8776.min.js +1 -0
  257. package/8796.min.js +1 -0
  258. package/8805.min.js +1 -0
  259. package/8808.min.js +1 -0
  260. package/886.min.js +1 -0
  261. package/8930.min.js +1 -0
  262. package/8957.min.js +1 -0
  263. package/8977.min.js +2 -0
  264. package/8989.min.js +1 -0
  265. package/9022.min.js +1 -0
  266. package/9027.min.js +1 -0
  267. package/9033.min.js +1 -0
  268. package/9072.min.js +1 -0
  269. package/9134.min.js +1 -0
  270. package/9165.min.js +1 -0
  271. package/9261.min.js +1 -0
  272. package/9293.min.js +1 -0
  273. package/9326.min.js +1 -0
  274. package/9368.min.js +1 -0
  275. package/938.min.js +1 -0
  276. package/9463.min.js +1 -0
  277. package/9479.min.js +1 -0
  278. package/951.min.js +1 -0
  279. package/9630.min.js +1 -0
  280. package/9643.min.js +1 -2
  281. package/9654.min.js +1 -0
  282. package/9673.min.js +1 -0
  283. package/9720.min.js +1 -0
  284. package/9748.min.js +1 -0
  285. package/9782.min.js +1 -0
  286. package/9838.min.js +1 -0
  287. package/9920.min.js +1 -0
  288. package/9950.min.js +1 -0
  289. package/9994.min.js +1 -0
  290. package/README.md +158 -4
  291. package/basic_dist_browser_index_js.js +2 -2
  292. package/browser/bundle.js +1 -2
  293. package/browser/index.js +162 -68
  294. package/cjs/bundle.js +1 -2
  295. package/cjs/index.js +162 -68
  296. package/effects_bubble_dist_browser_BubbleDrawer_js.js +2 -2
  297. package/effects_bubble_dist_browser_index_js.js +2 -2
  298. package/effects_particles_dist_browser_ParticlesDrawer_js.js +30 -0
  299. package/effects_particles_dist_browser_index_js.js +30 -0
  300. package/effects_shadow_dist_browser_ShadowDrawer_js.js +2 -2
  301. package/effects_shadow_dist_browser_index_js.js +2 -2
  302. package/effects_trail_dist_browser_TrailDrawer_js.js +2 -2
  303. package/effects_trail_dist_browser_index_js.js +2 -2
  304. package/engine_dist_browser_Core_Container_js.js +30 -20
  305. package/esm/bundle.js +1 -2
  306. package/esm/index.js +162 -68
  307. package/full_dist_browser_index_js.js +2 -2
  308. package/interactions_external_attract_dist_browser_Attractor_js.js +42 -42
  309. package/interactions_external_attract_dist_browser_index_js.js +3 -3
  310. package/interactions_external_bounce_dist_browser_Bouncer_js.js +42 -42
  311. package/interactions_external_bounce_dist_browser_index_js.js +3 -3
  312. package/interactions_external_bubble_dist_browser_Bubbler_js.js +43 -43
  313. package/interactions_external_bubble_dist_browser_index_js.js +5 -5
  314. package/interactions_external_cannon_dist_browser_Cannoner_js.js +130 -0
  315. package/interactions_external_cannon_dist_browser_index_js.js +40 -0
  316. package/interactions_external_connect_dist_browser_Connector_js.js +62 -42
  317. package/interactions_external_connect_dist_browser_index_js.js +4 -4
  318. package/interactions_external_drag_dist_browser_Dragger_js.js +130 -0
  319. package/interactions_external_drag_dist_browser_index_js.js +40 -0
  320. package/interactions_external_grab_dist_browser_Grabber_js.js +62 -42
  321. package/interactions_external_grab_dist_browser_index_js.js +4 -4
  322. package/interactions_external_parallax_dist_browser_Parallaxer_js.js +41 -41
  323. package/interactions_external_parallax_dist_browser_index_js.js +3 -3
  324. package/interactions_external_particle_dist_browser_InteractivityParticleMaker_js.js +42 -42
  325. package/interactions_external_particle_dist_browser_index_js.js +2 -2
  326. package/interactions_external_pause_dist_browser_Pauser_js.js +41 -41
  327. package/interactions_external_pause_dist_browser_index_js.js +2 -2
  328. package/interactions_external_pop_dist_browser_Popper_js.js +41 -41
  329. package/interactions_external_pop_dist_browser_index_js.js +2 -2
  330. package/interactions_external_push_dist_browser_Pusher_js.js +41 -41
  331. package/interactions_external_push_dist_browser_index_js.js +3 -3
  332. package/interactions_external_remove_dist_browser_Remover_js.js +41 -41
  333. package/interactions_external_remove_dist_browser_index_js.js +3 -3
  334. package/interactions_external_repulse_dist_browser_Repulser_js.js +41 -41
  335. package/interactions_external_repulse_dist_browser_index_js.js +5 -5
  336. package/interactions_external_slow_dist_browser_Slower_js.js +41 -41
  337. package/interactions_external_slow_dist_browser_index_js.js +3 -3
  338. package/interactions_external_trail_dist_browser_TrailMaker_js.js +41 -41
  339. package/interactions_external_trail_dist_browser_index_js.js +33 -3
  340. package/interactions_light_dist_browser_ExternalLighter_js.js +42 -42
  341. package/interactions_light_dist_browser_ParticlesLighter_js.js +42 -42
  342. package/interactions_light_dist_browser_index_js.js +6 -6
  343. package/interactions_particles_attract_dist_browser_Attractor_js.js +51 -41
  344. package/interactions_particles_attract_dist_browser_index_js.js +2 -2
  345. package/interactions_particles_collisions_dist_browser_Collider_js.js +49 -49
  346. package/interactions_particles_collisions_dist_browser_OverlapPluginInstance_js.js +2 -2
  347. package/interactions_particles_collisions_dist_browser_OverlapPlugin_js.js +2 -2
  348. package/interactions_particles_collisions_dist_browser_index_js.js +2 -2
  349. package/interactions_particles_links_dist_browser_LinkInstance_js.js +3 -3
  350. package/interactions_particles_links_dist_browser_Linker_js.js +42 -42
  351. package/interactions_particles_links_dist_browser_LinksPlugin_js.js +2 -2
  352. package/interactions_particles_links_dist_browser_index_js.js +5 -5
  353. package/interactions_particles_repulse_dist_browser_Repulser_js.js +42 -42
  354. package/interactions_particles_repulse_dist_browser_index_js.js +2 -2
  355. package/package.json +78 -67
  356. package/paths_branches_dist_browser_BranchesPathGenerator_js.js +30 -0
  357. package/paths_branches_dist_browser_index_js.js +30 -0
  358. package/paths_brownian_dist_browser_BrownianPathGenerator_js.js +30 -0
  359. package/paths_brownian_dist_browser_index_js.js +30 -0
  360. package/paths_curlNoise_dist_browser_CurlNoiseGenerator_js.js +2 -2
  361. package/paths_curlNoise_dist_browser_index_js.js +2 -2
  362. package/paths_curves_dist_browser_CurvesPathGenerator_js.js +3 -3
  363. package/paths_curves_dist_browser_index_js.js +2 -2
  364. package/paths_fractalNoise_dist_browser_FractalNoiseGenerator_js.js +8 -8
  365. package/paths_fractalNoise_dist_browser_index_js.js +2 -2
  366. package/paths_grid_dist_browser_GridPathGenerator_js.js +30 -0
  367. package/paths_grid_dist_browser_index_js.js +30 -0
  368. package/paths_levy_dist_browser_LevyPathGenerator_js.js +30 -0
  369. package/paths_levy_dist_browser_index_js.js +30 -0
  370. package/paths_perlinNoise_dist_browser_PerlinNoiseGenerator_js.js +7 -7
  371. package/paths_perlinNoise_dist_browser_index_js.js +2 -2
  372. package/paths_polygon_dist_browser_PolygonPathGenerator_js.js +2 -2
  373. package/paths_polygon_dist_browser_index_js.js +2 -2
  374. package/paths_random_dist_browser_RandomPathGenerator_js.js +30 -0
  375. package/paths_random_dist_browser_index_js.js +30 -0
  376. package/paths_simplexNoise_dist_browser_SimplexNoiseGenerator_js.js +4 -4
  377. package/paths_simplexNoise_dist_browser_index_js.js +2 -2
  378. package/paths_spiral_dist_browser_SpiralPathGenerator_js.js +40 -0
  379. package/paths_spiral_dist_browser_index_js.js +30 -0
  380. package/paths_svg_dist_browser_SVGPathGenerator_js.js +22 -2
  381. package/paths_svg_dist_browser_index_js.js +2 -2
  382. package/paths_zigzag_dist_browser_ZigZagPathGenerator_js.js +2 -2
  383. package/paths_zigzag_dist_browser_index_js.js +2 -2
  384. package/plugins_absorbers_dist_browser_AbsorberInstance_js.js +15 -5
  385. package/plugins_absorbers_dist_browser_AbsorbersInstancesManager_js.js +2 -2
  386. package/plugins_absorbers_dist_browser_AbsorbersInteractor_js.js +54 -44
  387. package/plugins_absorbers_dist_browser_AbsorbersPluginInstance_js.js +2 -2
  388. package/plugins_absorbers_dist_browser_AbsorbersPlugin_js.js +15 -5
  389. package/plugins_absorbers_dist_browser_index_js.js +2 -2
  390. package/plugins_backgroundMask_dist_browser_BackgroundMaskPluginInstance_js.js +2 -2
  391. package/plugins_backgroundMask_dist_browser_BackgroundMaskPlugin_js.js +4 -4
  392. package/plugins_backgroundMask_dist_browser_index_js.js +2 -2
  393. package/plugins_blend_dist_browser_BlendPluginInstance_js.js +2 -2
  394. package/plugins_blend_dist_browser_BlendPlugin_js.js +3 -3
  395. package/plugins_blend_dist_browser_index_js.js +2 -2
  396. package/plugins_canvasMask_dist_browser_CanvasMaskPluginInstance_js.js +23 -3
  397. package/plugins_canvasMask_dist_browser_CanvasMaskPlugin_js.js +9 -9
  398. package/plugins_canvasMask_dist_browser_index_js.js +2 -2
  399. package/plugins_colors_hex_dist_browser_HexColorManager_js.js +2 -2
  400. package/plugins_colors_hex_dist_browser_index_js.js +2 -2
  401. package/plugins_colors_hsl_dist_browser_HslColorManager_js.js +2 -2
  402. package/plugins_colors_hsl_dist_browser_index_js.js +2 -2
  403. package/plugins_colors_hsv_dist_browser_HsvColorManager_js.js +3 -3
  404. package/plugins_colors_hsv_dist_browser_index_js.js +2 -2
  405. package/plugins_colors_hwb_dist_browser_HwbColorManager_js.js +2 -2
  406. package/plugins_colors_hwb_dist_browser_index_js.js +2 -2
  407. package/plugins_colors_lab_dist_browser_LabColorManager_js.js +3 -3
  408. package/plugins_colors_lab_dist_browser_index_js.js +2 -2
  409. package/plugins_colors_lch_dist_browser_LchColorManager_js.js +3 -3
  410. package/plugins_colors_lch_dist_browser_index_js.js +2 -2
  411. package/plugins_colors_named_dist_browser_NamedColorManager_js.js +2 -2
  412. package/plugins_colors_named_dist_browser_index_js.js +2 -2
  413. package/plugins_colors_oklab_dist_browser_OklabColorManager_js.js +3 -3
  414. package/plugins_colors_oklab_dist_browser_index_js.js +2 -2
  415. package/plugins_colors_oklch_dist_browser_OklchColorManager_js.js +3 -3
  416. package/plugins_colors_oklch_dist_browser_index_js.js +2 -2
  417. package/plugins_colors_rgb_dist_browser_RgbColorManager_js.js +2 -2
  418. package/plugins_colors_rgb_dist_browser_index_js.js +2 -2
  419. package/plugins_easings_back_dist_browser_easingsFunctions_js.js +2 -2
  420. package/plugins_easings_back_dist_browser_index_js.js +2 -2
  421. package/plugins_easings_bounce_dist_browser_easingsFunctions_js.js +2 -2
  422. package/plugins_easings_bounce_dist_browser_index_js.js +2 -2
  423. package/plugins_easings_circ_dist_browser_easingsFunctions_js.js +2 -2
  424. package/plugins_easings_circ_dist_browser_index_js.js +2 -2
  425. package/plugins_easings_cubic_dist_browser_easingsFunctions_js.js +2 -2
  426. package/plugins_easings_cubic_dist_browser_index_js.js +2 -2
  427. package/plugins_easings_elastic_dist_browser_easingsFunctions_js.js +2 -2
  428. package/plugins_easings_elastic_dist_browser_index_js.js +2 -2
  429. package/plugins_easings_expo_dist_browser_easingsFunctions_js.js +2 -2
  430. package/plugins_easings_expo_dist_browser_index_js.js +2 -2
  431. package/plugins_easings_gaussian_dist_browser_easingsFunctions_js.js +2 -2
  432. package/plugins_easings_gaussian_dist_browser_index_js.js +2 -2
  433. package/plugins_easings_linear_dist_browser_easingsFunctions_js.js +2 -2
  434. package/plugins_easings_linear_dist_browser_index_js.js +2 -2
  435. package/plugins_easings_quad_dist_browser_easingsFunctions_js.js +2 -2
  436. package/plugins_easings_quad_dist_browser_index_js.js +2 -2
  437. package/plugins_easings_quart_dist_browser_easingsFunctions_js.js +2 -2
  438. package/plugins_easings_quart_dist_browser_index_js.js +2 -2
  439. package/plugins_easings_quint_dist_browser_easingsFunctions_js.js +2 -2
  440. package/plugins_easings_quint_dist_browser_index_js.js +2 -2
  441. package/plugins_easings_sigmoid_dist_browser_easingsFunctions_js.js +2 -2
  442. package/plugins_easings_sigmoid_dist_browser_index_js.js +2 -2
  443. package/plugins_easings_sine_dist_browser_easingsFunctions_js.js +2 -2
  444. package/plugins_easings_sine_dist_browser_index_js.js +2 -2
  445. package/plugins_easings_smoothstep_dist_browser_easingsFunctions_js.js +2 -2
  446. package/plugins_easings_smoothstep_dist_browser_index_js.js +2 -2
  447. package/plugins_emittersShapes_canvas_dist_browser_EmittersCanvasShapeGenerator_js.js +26 -16
  448. package/plugins_emittersShapes_canvas_dist_browser_index_js.js +2 -2
  449. package/plugins_emittersShapes_circle_dist_browser_EmittersCircleShapeGenerator_js.js +6 -6
  450. package/plugins_emittersShapes_circle_dist_browser_index_js.js +2 -2
  451. package/plugins_emittersShapes_path_dist_browser_EmittersPathShapeGenerator_js.js +8 -8
  452. package/plugins_emittersShapes_path_dist_browser_index_js.js +2 -2
  453. package/plugins_emittersShapes_polygon_dist_browser_EmittersPolygonShapeGenerator_js.js +8 -8
  454. package/plugins_emittersShapes_polygon_dist_browser_index_js.js +2 -2
  455. package/plugins_emittersShapes_square_dist_browser_EmittersSquareShapeGenerator_js.js +6 -6
  456. package/plugins_emittersShapes_square_dist_browser_index_js.js +2 -2
  457. package/plugins_emitters_dist_browser_EmitterInstance_js.js +2 -2
  458. package/plugins_emitters_dist_browser_EmittersInstancesManager_js.js +18 -8
  459. package/plugins_emitters_dist_browser_EmittersInteractor_js.js +58 -48
  460. package/plugins_emitters_dist_browser_EmittersPluginInstance_js.js +2 -2
  461. package/plugins_emitters_dist_browser_EmittersPlugin_js.js +18 -8
  462. package/plugins_emitters_dist_browser_ShapeManager_js.js +2 -2
  463. package/plugins_emitters_dist_browser_index_js.js +4 -4
  464. package/plugins_exports_image_dist_browser_ExportImagePluginInstance_js.js +2 -2
  465. package/plugins_exports_image_dist_browser_ExportImagePlugin_js.js +2 -2
  466. package/plugins_exports_image_dist_browser_index_js.js +2 -2
  467. package/plugins_exports_json_dist_browser_ExportJSONPluginInstance_js.js +2 -2
  468. package/plugins_exports_json_dist_browser_ExportJSONPlugin_js.js +2 -2
  469. package/plugins_exports_json_dist_browser_index_js.js +2 -2
  470. package/plugins_exports_video_dist_browser_ExportVideoPluginInstance_js.js +2 -2
  471. package/plugins_exports_video_dist_browser_ExportVideoPlugin_js.js +2 -2
  472. package/plugins_exports_video_dist_browser_index_js.js +2 -2
  473. package/plugins_infection_dist_browser_InfectionPluginInstance_js.js +3 -3
  474. package/plugins_infection_dist_browser_InfectionPlugin_js.js +4 -4
  475. package/plugins_infection_dist_browser_ParticlesInfecter_js.js +41 -41
  476. package/plugins_infection_dist_browser_index_js.js +2 -2
  477. package/plugins_interactivity_dist_browser_InteractivityPluginInstance_js.js +4 -4
  478. package/plugins_interactivity_dist_browser_InteractivityPlugin_js.js +6 -6
  479. package/plugins_interactivity_dist_browser_index_js.js +40 -40
  480. package/plugins_manualParticles_dist_browser_ManualParticlesPluginInstance_js.js +2 -2
  481. package/plugins_manualParticles_dist_browser_ManualParticlesPlugin_js.js +3 -3
  482. package/plugins_manualParticles_dist_browser_index_js.js +2 -2
  483. package/plugins_motion_dist_browser_MotionPluginInstance_js.js +2 -2
  484. package/plugins_motion_dist_browser_MotionPlugin_js.js +4 -4
  485. package/plugins_motion_dist_browser_index_js.js +2 -2
  486. package/plugins_move_dist_browser_MovePluginInstance_js.js +40 -0
  487. package/plugins_move_dist_browser_MovePlugin_js.js +30 -0
  488. package/plugins_move_dist_browser_index_js.js +30 -0
  489. package/plugins_poisson_dist_browser_PoissonDiscPluginInstance_js.js +2 -12
  490. package/plugins_poisson_dist_browser_PoissonDiscPlugin_js.js +3 -3
  491. package/plugins_poisson_dist_browser_PoissonDisc_js.js +30 -0
  492. package/plugins_poisson_dist_browser_index_js.js +2 -2
  493. package/plugins_polygonMask_dist_browser_PolygonMaskInstance_js.js +4 -4
  494. package/plugins_polygonMask_dist_browser_PolygonMaskPlugin_js.js +8 -8
  495. package/plugins_polygonMask_dist_browser_index_js.js +5 -5
  496. package/plugins_responsive_dist_browser_ResponsivePluginInstance_js.js +2 -2
  497. package/plugins_responsive_dist_browser_ResponsivePlugin_js.js +4 -4
  498. package/plugins_responsive_dist_browser_index_js.js +2 -2
  499. package/plugins_sounds_dist_browser_SoundsPluginInstance_js.js +3 -3
  500. package/plugins_sounds_dist_browser_SoundsPlugin_js.js +12 -12
  501. package/plugins_sounds_dist_browser_index_js.js +2 -2
  502. package/plugins_themes_dist_browser_ThemesPluginInstance_js.js +2 -2
  503. package/plugins_themes_dist_browser_ThemesPlugin_js.js +5 -5
  504. package/plugins_themes_dist_browser_index_js.js +2 -2
  505. package/plugins_trail_dist_browser_TrailPluginInstance_js.js +2 -2
  506. package/plugins_trail_dist_browser_TrailPlugin_js.js +4 -4
  507. package/plugins_trail_dist_browser_index_js.js +2 -2
  508. package/plugins_zoom_dist_browser_ZoomPluginInstance_js.js +40 -0
  509. package/plugins_zoom_dist_browser_ZoomPlugin_js.js +30 -0
  510. package/plugins_zoom_dist_browser_index_js.js +50 -0
  511. package/report.html +84 -29
  512. package/shapes_arrow_dist_browser_ArrowDrawer_js.js +3 -3
  513. package/shapes_arrow_dist_browser_index_js.js +2 -2
  514. package/shapes_cards_dist_browser_cards_CardDrawer_js.js +3 -53
  515. package/shapes_cards_dist_browser_clubs_ClubDrawer_js.js +2 -52
  516. package/shapes_cards_dist_browser_diamonds_DiamondDrawer_js.js +2 -52
  517. package/shapes_cards_dist_browser_hearts_HeartDrawer_js.js +2 -52
  518. package/shapes_cards_dist_browser_index_js.js +7 -7
  519. package/shapes_cards_dist_browser_paths_js.js +70 -0
  520. package/shapes_cards_dist_browser_spades_SpadeDrawer_js.js +2 -52
  521. package/shapes_circle_dist_browser_CircleDrawer_js.js +3 -3
  522. package/shapes_circle_dist_browser_index_js.js +2 -2
  523. package/shapes_cog_dist_browser_CogDrawer_js.js +3 -3
  524. package/shapes_cog_dist_browser_index_js.js +2 -2
  525. package/shapes_emoji_dist_browser_EmojiDrawer_js.js +17 -7
  526. package/shapes_emoji_dist_browser_index_js.js +12 -2
  527. package/shapes_heart_dist_browser_HeartDrawer_js.js +3 -3
  528. package/shapes_heart_dist_browser_index_js.js +2 -2
  529. package/shapes_image_dist_browser_GifUtils_Utils_js.js +6 -16
  530. package/shapes_image_dist_browser_ImageDrawer_js.js +2 -2
  531. package/shapes_image_dist_browser_ImagePreloaderInstance_js.js +30 -0
  532. package/shapes_image_dist_browser_ImagePreloader_js.js +3 -3
  533. package/shapes_image_dist_browser_index_js.js +12 -2
  534. package/shapes_infinity_dist_browser_InfinityDrawer_js.js +3 -3
  535. package/shapes_infinity_dist_browser_index_js.js +2 -2
  536. package/shapes_line_dist_browser_LineDrawer_js.js +3 -3
  537. package/shapes_line_dist_browser_index_js.js +2 -2
  538. package/shapes_matrix_dist_browser_MatrixDrawer_js.js +40 -0
  539. package/shapes_matrix_dist_browser_index_js.js +30 -0
  540. package/shapes_path_dist_browser_PathDrawer_js.js +5 -5
  541. package/shapes_path_dist_browser_index_js.js +2 -2
  542. package/shapes_polygon_dist_browser_PolygonDrawer_js.js +4 -4
  543. package/shapes_polygon_dist_browser_TriangleDrawer_js.js +4 -4
  544. package/shapes_polygon_dist_browser_index_js.js +2 -2
  545. package/shapes_rounded-polygon_dist_browser_RoundedPolygonDrawer_js.js +3 -3
  546. package/shapes_rounded-polygon_dist_browser_index_js.js +2 -2
  547. package/shapes_rounded-rect_dist_browser_RoundedRectDrawer_js.js +3 -3
  548. package/shapes_rounded-rect_dist_browser_index_js.js +2 -2
  549. package/shapes_spiral_dist_browser_SpiralDrawer_js.js +3 -3
  550. package/shapes_spiral_dist_browser_index_js.js +2 -2
  551. package/shapes_square_dist_browser_SquareDrawer_js.js +3 -3
  552. package/shapes_square_dist_browser_index_js.js +2 -2
  553. package/shapes_squircle_dist_browser_SquircleDrawer_js.js +40 -0
  554. package/shapes_squircle_dist_browser_index_js.js +30 -0
  555. package/shapes_star_dist_browser_StarDrawer_js.js +3 -3
  556. package/shapes_star_dist_browser_index_js.js +2 -2
  557. package/shapes_text_dist_browser_TextDrawer_js.js +17 -7
  558. package/shapes_text_dist_browser_index_js.js +12 -2
  559. package/slim_dist_browser_index_js.js +2 -2
  560. package/tsparticles.all.bundle.js +100 -88
  561. package/tsparticles.all.bundle.min.js +2 -2
  562. package/tsparticles.all.js +131 -21
  563. package/tsparticles.all.min.js +1 -2
  564. package/types/bundle.d.ts +1 -2
  565. package/umd/bundle.js +3 -3
  566. package/umd/index.js +162 -68
  567. package/updaters_destroy_dist_browser_DestroyUpdater_js.js +9 -9
  568. package/updaters_destroy_dist_browser_index_js.js +2 -2
  569. package/updaters_fillColor_dist_browser_FillColorUpdater_js.js +30 -0
  570. package/updaters_fillColor_dist_browser_index_js.js +30 -0
  571. package/updaters_gradient_dist_browser_GradientUpdater_js.js +9 -9
  572. package/updaters_gradient_dist_browser_index_js.js +2 -2
  573. package/updaters_life_dist_browser_LifeUpdater_js.js +6 -6
  574. package/updaters_life_dist_browser_index_js.js +2 -2
  575. package/updaters_opacity_dist_browser_OpacityUpdater_js.js +2 -2
  576. package/updaters_opacity_dist_browser_index_js.js +2 -2
  577. package/updaters_orbit_dist_browser_OrbitUpdater_js.js +6 -6
  578. package/updaters_orbit_dist_browser_index_js.js +2 -2
  579. package/updaters_outModes_dist_browser_OutOfCanvasUpdater_js.js +7 -7
  580. package/updaters_outModes_dist_browser_index_js.js +2 -2
  581. package/updaters_roll_dist_browser_RollUpdater_js.js +6 -6
  582. package/updaters_roll_dist_browser_index_js.js +2 -2
  583. package/updaters_rotate_dist_browser_RotateUpdater_js.js +4 -4
  584. package/updaters_rotate_dist_browser_index_js.js +2 -2
  585. package/updaters_size_dist_browser_SizeUpdater_js.js +2 -2
  586. package/updaters_size_dist_browser_index_js.js +2 -2
  587. package/updaters_strokeColor_dist_browser_StrokeColorUpdater_js.js +2 -2
  588. package/updaters_strokeColor_dist_browser_index_js.js +2 -2
  589. package/updaters_tilt_dist_browser_TiltUpdater_js.js +5 -5
  590. package/updaters_tilt_dist_browser_index_js.js +2 -2
  591. package/updaters_twinkle_dist_browser_TwinkleUpdater_js.js +18 -8
  592. package/updaters_twinkle_dist_browser_index_js.js +2 -2
  593. package/updaters_wobble_dist_browser_WobbleUpdater_js.js +5 -5
  594. package/updaters_wobble_dist_browser_index_js.js +2 -2
  595. package/utils_simplexNoise_dist_browser_index_js.js +7 -7
  596. package/1045.min.js +0 -2
  597. package/1045.min.js.LICENSE.txt +0 -1
  598. package/1049.min.js +0 -2
  599. package/1049.min.js.LICENSE.txt +0 -1
  600. package/1085.min.js +0 -2
  601. package/1085.min.js.LICENSE.txt +0 -1
  602. package/1112.min.js +0 -2
  603. package/1112.min.js.LICENSE.txt +0 -1
  604. package/1153.min.js +0 -2
  605. package/1153.min.js.LICENSE.txt +0 -1
  606. package/1183.min.js +0 -2
  607. package/1183.min.js.LICENSE.txt +0 -1
  608. package/1222.min.js +0 -2
  609. package/1222.min.js.LICENSE.txt +0 -1
  610. package/1278.min.js +0 -2
  611. package/1278.min.js.LICENSE.txt +0 -1
  612. package/1306.min.js +0 -2
  613. package/1306.min.js.LICENSE.txt +0 -1
  614. package/1350.min.js +0 -2
  615. package/1350.min.js.LICENSE.txt +0 -1
  616. package/1370.min.js +0 -2
  617. package/1370.min.js.LICENSE.txt +0 -1
  618. package/1446.min.js +0 -2
  619. package/1446.min.js.LICENSE.txt +0 -1
  620. package/15.min.js +0 -2
  621. package/15.min.js.LICENSE.txt +0 -1
  622. package/150.min.js +0 -2
  623. package/150.min.js.LICENSE.txt +0 -1
  624. package/151.min.js +0 -2
  625. package/151.min.js.LICENSE.txt +0 -1
  626. package/1542.min.js +0 -2
  627. package/1542.min.js.LICENSE.txt +0 -1
  628. package/1555.min.js +0 -2
  629. package/1555.min.js.LICENSE.txt +0 -1
  630. package/156.min.js +0 -2
  631. package/156.min.js.LICENSE.txt +0 -1
  632. package/1587.min.js +0 -2
  633. package/1587.min.js.LICENSE.txt +0 -1
  634. package/1608.min.js +0 -2
  635. package/1608.min.js.LICENSE.txt +0 -1
  636. package/1609.min.js +0 -2
  637. package/1609.min.js.LICENSE.txt +0 -1
  638. package/1678.min.js +0 -2
  639. package/1678.min.js.LICENSE.txt +0 -1
  640. package/1750.min.js +0 -2
  641. package/1750.min.js.LICENSE.txt +0 -1
  642. package/176.min.js +0 -2
  643. package/176.min.js.LICENSE.txt +0 -1
  644. package/1801.min.js +0 -2
  645. package/1801.min.js.LICENSE.txt +0 -1
  646. package/1804.min.js +0 -2
  647. package/1804.min.js.LICENSE.txt +0 -1
  648. package/1878.min.js +0 -2
  649. package/1878.min.js.LICENSE.txt +0 -1
  650. package/1887.min.js +0 -2
  651. package/1887.min.js.LICENSE.txt +0 -1
  652. package/1909.min.js +0 -2
  653. package/1909.min.js.LICENSE.txt +0 -1
  654. package/1968.min.js +0 -2
  655. package/1968.min.js.LICENSE.txt +0 -1
  656. package/1972.min.js +0 -2
  657. package/1972.min.js.LICENSE.txt +0 -1
  658. package/2006.min.js +0 -2
  659. package/2006.min.js.LICENSE.txt +0 -1
  660. package/2032.min.js +0 -2
  661. package/2032.min.js.LICENSE.txt +0 -1
  662. package/2192.min.js +0 -2
  663. package/2192.min.js.LICENSE.txt +0 -1
  664. package/2201.min.js +0 -2
  665. package/2201.min.js.LICENSE.txt +0 -1
  666. package/221.min.js +0 -2
  667. package/221.min.js.LICENSE.txt +0 -1
  668. package/2227.min.js +0 -2
  669. package/2227.min.js.LICENSE.txt +0 -1
  670. package/2291.min.js +0 -2
  671. package/2291.min.js.LICENSE.txt +0 -1
  672. package/2381.min.js +0 -2
  673. package/2381.min.js.LICENSE.txt +0 -1
  674. package/2387.min.js +0 -2
  675. package/2387.min.js.LICENSE.txt +0 -1
  676. package/2398.min.js +0 -2
  677. package/2398.min.js.LICENSE.txt +0 -1
  678. package/2461.min.js +0 -2
  679. package/2461.min.js.LICENSE.txt +0 -1
  680. package/2488.min.js +0 -2
  681. package/2488.min.js.LICENSE.txt +0 -1
  682. package/2495.min.js +0 -2
  683. package/2495.min.js.LICENSE.txt +0 -1
  684. package/2524.min.js +0 -2
  685. package/2524.min.js.LICENSE.txt +0 -1
  686. package/2583.min.js +0 -2
  687. package/2583.min.js.LICENSE.txt +0 -1
  688. package/2612.min.js +0 -2
  689. package/2612.min.js.LICENSE.txt +0 -1
  690. package/2615.min.js +0 -2
  691. package/2615.min.js.LICENSE.txt +0 -1
  692. package/2629.min.js +0 -2
  693. package/2629.min.js.LICENSE.txt +0 -1
  694. package/2679.min.js +0 -2
  695. package/2679.min.js.LICENSE.txt +0 -1
  696. package/2729.min.js +0 -2
  697. package/2729.min.js.LICENSE.txt +0 -1
  698. package/2752.min.js +0 -2
  699. package/2752.min.js.LICENSE.txt +0 -1
  700. package/2754.min.js +0 -2
  701. package/2754.min.js.LICENSE.txt +0 -1
  702. package/2827.min.js +0 -2
  703. package/2827.min.js.LICENSE.txt +0 -1
  704. package/2838.min.js +0 -2
  705. package/2838.min.js.LICENSE.txt +0 -1
  706. package/284.min.js +0 -2
  707. package/284.min.js.LICENSE.txt +0 -1
  708. package/2842.min.js +0 -2
  709. package/2842.min.js.LICENSE.txt +0 -1
  710. package/290.min.js +0 -2
  711. package/290.min.js.LICENSE.txt +0 -1
  712. package/2901.min.js +0 -2
  713. package/2901.min.js.LICENSE.txt +0 -1
  714. package/2923.min.js +0 -2
  715. package/2923.min.js.LICENSE.txt +0 -1
  716. package/2942.min.js +0 -2
  717. package/2942.min.js.LICENSE.txt +0 -1
  718. package/2970.min.js +0 -2
  719. package/2970.min.js.LICENSE.txt +0 -1
  720. package/3003.min.js +0 -2
  721. package/3003.min.js.LICENSE.txt +0 -1
  722. package/3067.min.js +0 -2
  723. package/3067.min.js.LICENSE.txt +0 -1
  724. package/3120.min.js +0 -2
  725. package/3120.min.js.LICENSE.txt +0 -1
  726. package/3148.min.js +0 -2
  727. package/3148.min.js.LICENSE.txt +0 -1
  728. package/3152.min.js.LICENSE.txt +0 -1
  729. package/3153.min.js +0 -2
  730. package/3153.min.js.LICENSE.txt +0 -1
  731. package/3182.min.js +0 -2
  732. package/3182.min.js.LICENSE.txt +0 -1
  733. package/3189.min.js +0 -2
  734. package/3189.min.js.LICENSE.txt +0 -1
  735. package/3209.min.js +0 -2
  736. package/3209.min.js.LICENSE.txt +0 -1
  737. package/3215.min.js +0 -2
  738. package/3215.min.js.LICENSE.txt +0 -1
  739. package/3306.min.js +0 -2
  740. package/3306.min.js.LICENSE.txt +0 -1
  741. package/3316.min.js +0 -2
  742. package/3316.min.js.LICENSE.txt +0 -1
  743. package/3396.min.js +0 -2
  744. package/3396.min.js.LICENSE.txt +0 -1
  745. package/3442.min.js +0 -2
  746. package/3442.min.js.LICENSE.txt +0 -1
  747. package/3445.min.js +0 -2
  748. package/3445.min.js.LICENSE.txt +0 -1
  749. package/3446.min.js +0 -2
  750. package/3446.min.js.LICENSE.txt +0 -1
  751. package/3451.min.js +0 -2
  752. package/3451.min.js.LICENSE.txt +0 -1
  753. package/346.min.js +0 -2
  754. package/346.min.js.LICENSE.txt +0 -1
  755. package/3598.min.js +0 -2
  756. package/3598.min.js.LICENSE.txt +0 -1
  757. package/3629.min.js +0 -2
  758. package/3629.min.js.LICENSE.txt +0 -1
  759. package/3643.min.js +0 -2
  760. package/3643.min.js.LICENSE.txt +0 -1
  761. package/3712.min.js +0 -2
  762. package/3712.min.js.LICENSE.txt +0 -1
  763. package/3722.min.js +0 -2
  764. package/3722.min.js.LICENSE.txt +0 -1
  765. package/3743.min.js +0 -2
  766. package/3743.min.js.LICENSE.txt +0 -1
  767. package/3744.min.js +0 -2
  768. package/3744.min.js.LICENSE.txt +0 -1
  769. package/3748.min.js +0 -2
  770. package/3748.min.js.LICENSE.txt +0 -1
  771. package/3759.min.js +0 -2
  772. package/3759.min.js.LICENSE.txt +0 -1
  773. package/3803.min.js +0 -2
  774. package/3803.min.js.LICENSE.txt +0 -1
  775. package/3804.min.js +0 -2
  776. package/3804.min.js.LICENSE.txt +0 -1
  777. package/3865.min.js +0 -2
  778. package/3865.min.js.LICENSE.txt +0 -1
  779. package/3925.min.js +0 -2
  780. package/3925.min.js.LICENSE.txt +0 -1
  781. package/3961.min.js.LICENSE.txt +0 -1
  782. package/3997.min.js +0 -2
  783. package/3997.min.js.LICENSE.txt +0 -1
  784. package/4007.min.js +0 -2
  785. package/4007.min.js.LICENSE.txt +0 -1
  786. package/4033.min.js +0 -2
  787. package/4033.min.js.LICENSE.txt +0 -1
  788. package/4091.min.js +0 -2
  789. package/4091.min.js.LICENSE.txt +0 -1
  790. package/4119.min.js +0 -2
  791. package/4119.min.js.LICENSE.txt +0 -1
  792. package/4235.min.js +0 -2
  793. package/4235.min.js.LICENSE.txt +0 -1
  794. package/4243.min.js +0 -2
  795. package/4243.min.js.LICENSE.txt +0 -1
  796. package/4324.min.js +0 -2
  797. package/4324.min.js.LICENSE.txt +0 -1
  798. package/4340.min.js +0 -2
  799. package/4340.min.js.LICENSE.txt +0 -1
  800. package/4427.min.js +0 -2
  801. package/4427.min.js.LICENSE.txt +0 -1
  802. package/4481.min.js +0 -2
  803. package/4481.min.js.LICENSE.txt +0 -1
  804. package/454.min.js +0 -2
  805. package/454.min.js.LICENSE.txt +0 -1
  806. package/4544.min.js +0 -2
  807. package/4544.min.js.LICENSE.txt +0 -1
  808. package/4545.min.js +0 -2
  809. package/4545.min.js.LICENSE.txt +0 -1
  810. package/4547.min.js +0 -2
  811. package/4547.min.js.LICENSE.txt +0 -1
  812. package/4571.min.js +0 -2
  813. package/4571.min.js.LICENSE.txt +0 -1
  814. package/4619.min.js +0 -2
  815. package/4619.min.js.LICENSE.txt +0 -1
  816. package/4675.min.js +0 -2
  817. package/4675.min.js.LICENSE.txt +0 -1
  818. package/4689.min.js +0 -2
  819. package/4689.min.js.LICENSE.txt +0 -1
  820. package/4698.min.js +0 -2
  821. package/4698.min.js.LICENSE.txt +0 -1
  822. package/4713.min.js +0 -2
  823. package/4713.min.js.LICENSE.txt +0 -1
  824. package/4744.min.js +0 -2
  825. package/4744.min.js.LICENSE.txt +0 -1
  826. package/4764.min.js +0 -2
  827. package/4764.min.js.LICENSE.txt +0 -1
  828. package/4813.min.js +0 -2
  829. package/4813.min.js.LICENSE.txt +0 -1
  830. package/4837.min.js.LICENSE.txt +0 -1
  831. package/4852.min.js +0 -2
  832. package/4852.min.js.LICENSE.txt +0 -1
  833. package/4873.min.js +0 -2
  834. package/4873.min.js.LICENSE.txt +0 -1
  835. package/4884.min.js +0 -2
  836. package/4884.min.js.LICENSE.txt +0 -1
  837. package/4962.min.js +0 -2
  838. package/4962.min.js.LICENSE.txt +0 -1
  839. package/4968.min.js +0 -2
  840. package/4968.min.js.LICENSE.txt +0 -1
  841. package/4983.min.js +0 -2
  842. package/4983.min.js.LICENSE.txt +0 -1
  843. package/4985.min.js +0 -2
  844. package/4985.min.js.LICENSE.txt +0 -1
  845. package/5010.min.js +0 -2
  846. package/5010.min.js.LICENSE.txt +0 -1
  847. package/5058.min.js +0 -2
  848. package/5058.min.js.LICENSE.txt +0 -1
  849. package/5113.min.js +0 -2
  850. package/5113.min.js.LICENSE.txt +0 -1
  851. package/5142.min.js +0 -2
  852. package/5142.min.js.LICENSE.txt +0 -1
  853. package/5152.min.js +0 -2
  854. package/5152.min.js.LICENSE.txt +0 -1
  855. package/5166.min.js +0 -2
  856. package/5166.min.js.LICENSE.txt +0 -1
  857. package/5182.min.js +0 -2
  858. package/5182.min.js.LICENSE.txt +0 -1
  859. package/521.min.js +0 -2
  860. package/521.min.js.LICENSE.txt +0 -1
  861. package/5273.min.js +0 -2
  862. package/5273.min.js.LICENSE.txt +0 -1
  863. package/5291.min.js +0 -2
  864. package/5291.min.js.LICENSE.txt +0 -1
  865. package/5302.min.js +0 -2
  866. package/5302.min.js.LICENSE.txt +0 -1
  867. package/5336.min.js +0 -2
  868. package/5336.min.js.LICENSE.txt +0 -1
  869. package/5460.min.js +0 -2
  870. package/5460.min.js.LICENSE.txt +0 -1
  871. package/5471.min.js +0 -2
  872. package/5471.min.js.LICENSE.txt +0 -1
  873. package/5475.min.js +0 -2
  874. package/5475.min.js.LICENSE.txt +0 -1
  875. package/5505.min.js +0 -2
  876. package/5505.min.js.LICENSE.txt +0 -1
  877. package/5516.min.js +0 -2
  878. package/5516.min.js.LICENSE.txt +0 -1
  879. package/5787.min.js +0 -2
  880. package/5787.min.js.LICENSE.txt +0 -1
  881. package/5913.min.js +0 -2
  882. package/5913.min.js.LICENSE.txt +0 -1
  883. package/5919.min.js +0 -2
  884. package/5919.min.js.LICENSE.txt +0 -1
  885. package/593.min.js +0 -2
  886. package/593.min.js.LICENSE.txt +0 -1
  887. package/5931.min.js +0 -2
  888. package/5931.min.js.LICENSE.txt +0 -1
  889. package/597.min.js +0 -2
  890. package/597.min.js.LICENSE.txt +0 -1
  891. package/5987.min.js +0 -2
  892. package/5987.min.js.LICENSE.txt +0 -1
  893. package/6048.min.js +0 -2
  894. package/6048.min.js.LICENSE.txt +0 -1
  895. package/6081.min.js +0 -2
  896. package/6081.min.js.LICENSE.txt +0 -1
  897. package/6181.min.js +0 -2
  898. package/6181.min.js.LICENSE.txt +0 -1
  899. package/6184.min.js +0 -2
  900. package/6184.min.js.LICENSE.txt +0 -1
  901. package/620.min.js +0 -2
  902. package/620.min.js.LICENSE.txt +0 -1
  903. package/6219.min.js +0 -2
  904. package/6219.min.js.LICENSE.txt +0 -1
  905. package/6249.min.js +0 -2
  906. package/6249.min.js.LICENSE.txt +0 -1
  907. package/6296.min.js +0 -2
  908. package/6296.min.js.LICENSE.txt +0 -1
  909. package/6361.min.js +0 -2
  910. package/6361.min.js.LICENSE.txt +0 -1
  911. package/6388.min.js.LICENSE.txt +0 -1
  912. package/6441.min.js +0 -2
  913. package/6441.min.js.LICENSE.txt +0 -1
  914. package/6548.min.js +0 -2
  915. package/6548.min.js.LICENSE.txt +0 -1
  916. package/6556.min.js +0 -2
  917. package/6556.min.js.LICENSE.txt +0 -1
  918. package/6580.min.js +0 -2
  919. package/6580.min.js.LICENSE.txt +0 -1
  920. package/6608.min.js +0 -2
  921. package/6608.min.js.LICENSE.txt +0 -1
  922. package/6640.min.js +0 -2
  923. package/6640.min.js.LICENSE.txt +0 -1
  924. package/671.min.js +0 -2
  925. package/671.min.js.LICENSE.txt +0 -1
  926. package/6711.min.js.LICENSE.txt +0 -1
  927. package/6720.min.js +0 -2
  928. package/6720.min.js.LICENSE.txt +0 -1
  929. package/6742.min.js +0 -2
  930. package/6742.min.js.LICENSE.txt +0 -1
  931. package/6753.min.js +0 -2
  932. package/6753.min.js.LICENSE.txt +0 -1
  933. package/6824.min.js +0 -2
  934. package/6824.min.js.LICENSE.txt +0 -1
  935. package/6890.min.js +0 -2
  936. package/6890.min.js.LICENSE.txt +0 -1
  937. package/6895.min.js +0 -2
  938. package/6895.min.js.LICENSE.txt +0 -1
  939. package/6905.min.js +0 -2
  940. package/6905.min.js.LICENSE.txt +0 -1
  941. package/6908.min.js +0 -2
  942. package/6908.min.js.LICENSE.txt +0 -1
  943. package/6911.min.js +0 -2
  944. package/6911.min.js.LICENSE.txt +0 -1
  945. package/6973.min.js +0 -2
  946. package/6973.min.js.LICENSE.txt +0 -1
  947. package/6983.min.js +0 -2
  948. package/6983.min.js.LICENSE.txt +0 -1
  949. package/6988.min.js +0 -2
  950. package/6988.min.js.LICENSE.txt +0 -1
  951. package/6992.min.js +0 -2
  952. package/6992.min.js.LICENSE.txt +0 -1
  953. package/6998.min.js +0 -2
  954. package/6998.min.js.LICENSE.txt +0 -1
  955. package/7012.min.js +0 -2
  956. package/7012.min.js.LICENSE.txt +0 -1
  957. package/7044.min.js +0 -2
  958. package/7044.min.js.LICENSE.txt +0 -1
  959. package/7056.min.js +0 -2
  960. package/7056.min.js.LICENSE.txt +0 -1
  961. package/7125.min.js +0 -2
  962. package/7125.min.js.LICENSE.txt +0 -1
  963. package/7134.min.js +0 -2
  964. package/7134.min.js.LICENSE.txt +0 -1
  965. package/7147.min.js +0 -2
  966. package/7147.min.js.LICENSE.txt +0 -1
  967. package/7160.min.js +0 -2
  968. package/7160.min.js.LICENSE.txt +0 -1
  969. package/718.min.js +0 -2
  970. package/718.min.js.LICENSE.txt +0 -1
  971. package/7188.min.js +0 -2
  972. package/7188.min.js.LICENSE.txt +0 -1
  973. package/7191.min.js +0 -2
  974. package/7191.min.js.LICENSE.txt +0 -1
  975. package/7245.min.js +0 -2
  976. package/7245.min.js.LICENSE.txt +0 -1
  977. package/7256.min.js +0 -2
  978. package/7256.min.js.LICENSE.txt +0 -1
  979. package/7259.min.js +0 -2
  980. package/7259.min.js.LICENSE.txt +0 -1
  981. package/7276.min.js +0 -2
  982. package/7276.min.js.LICENSE.txt +0 -1
  983. package/736.min.js +0 -2
  984. package/736.min.js.LICENSE.txt +0 -1
  985. package/7448.min.js +0 -2
  986. package/7448.min.js.LICENSE.txt +0 -1
  987. package/7569.min.js +0 -2
  988. package/7569.min.js.LICENSE.txt +0 -1
  989. package/76.min.js +0 -2
  990. package/76.min.js.LICENSE.txt +0 -1
  991. package/761.min.js +0 -2
  992. package/761.min.js.LICENSE.txt +0 -1
  993. package/7611.min.js +0 -2
  994. package/7611.min.js.LICENSE.txt +0 -1
  995. package/7613.min.js +0 -2
  996. package/7613.min.js.LICENSE.txt +0 -1
  997. package/7704.min.js +0 -2
  998. package/7704.min.js.LICENSE.txt +0 -1
  999. package/7746.min.js +0 -2
  1000. package/7746.min.js.LICENSE.txt +0 -1
  1001. package/7749.min.js +0 -2
  1002. package/7749.min.js.LICENSE.txt +0 -1
  1003. package/7774.min.js +0 -2
  1004. package/7774.min.js.LICENSE.txt +0 -1
  1005. package/7835.min.js +0 -2
  1006. package/7835.min.js.LICENSE.txt +0 -1
  1007. package/785.min.js +0 -2
  1008. package/785.min.js.LICENSE.txt +0 -1
  1009. package/7952.min.js +0 -2
  1010. package/7952.min.js.LICENSE.txt +0 -1
  1011. package/7983.min.js +0 -2
  1012. package/7983.min.js.LICENSE.txt +0 -1
  1013. package/8013.min.js +0 -2
  1014. package/8013.min.js.LICENSE.txt +0 -1
  1015. package/8018.min.js +0 -2
  1016. package/8018.min.js.LICENSE.txt +0 -1
  1017. package/8026.min.js +0 -2
  1018. package/8026.min.js.LICENSE.txt +0 -1
  1019. package/8084.min.js +0 -2
  1020. package/8084.min.js.LICENSE.txt +0 -1
  1021. package/8156.min.js +0 -2
  1022. package/8156.min.js.LICENSE.txt +0 -1
  1023. package/8182.min.js +0 -2
  1024. package/8182.min.js.LICENSE.txt +0 -1
  1025. package/8188.min.js +0 -2
  1026. package/8188.min.js.LICENSE.txt +0 -1
  1027. package/8296.min.js +0 -2
  1028. package/8296.min.js.LICENSE.txt +0 -1
  1029. package/83.min.js.LICENSE.txt +0 -1
  1030. package/8314.min.js +0 -2
  1031. package/8314.min.js.LICENSE.txt +0 -1
  1032. package/8320.min.js +0 -2
  1033. package/8320.min.js.LICENSE.txt +0 -1
  1034. package/8411.min.js +0 -2
  1035. package/8411.min.js.LICENSE.txt +0 -1
  1036. package/8445.min.js +0 -2
  1037. package/8445.min.js.LICENSE.txt +0 -1
  1038. package/8509.min.js +0 -2
  1039. package/8509.min.js.LICENSE.txt +0 -1
  1040. package/8526.min.js +0 -2
  1041. package/8526.min.js.LICENSE.txt +0 -1
  1042. package/8551.min.js +0 -2
  1043. package/8551.min.js.LICENSE.txt +0 -1
  1044. package/8644.min.js +0 -2
  1045. package/8644.min.js.LICENSE.txt +0 -1
  1046. package/8675.min.js +0 -2
  1047. package/8675.min.js.LICENSE.txt +0 -1
  1048. package/8799.min.js +0 -2
  1049. package/8799.min.js.LICENSE.txt +0 -1
  1050. package/8818.min.js +0 -2
  1051. package/8818.min.js.LICENSE.txt +0 -1
  1052. package/8827.min.js +0 -2
  1053. package/8827.min.js.LICENSE.txt +0 -1
  1054. package/8830.min.js +0 -2
  1055. package/8830.min.js.LICENSE.txt +0 -1
  1056. package/8847.min.js +0 -2
  1057. package/8847.min.js.LICENSE.txt +0 -1
  1058. package/8893.min.js +0 -2
  1059. package/8893.min.js.LICENSE.txt +0 -1
  1060. package/8951.min.js +0 -2
  1061. package/8951.min.js.LICENSE.txt +0 -1
  1062. package/8993.min.js +0 -2
  1063. package/8993.min.js.LICENSE.txt +0 -1
  1064. package/9039.min.js +0 -2
  1065. package/9039.min.js.LICENSE.txt +0 -1
  1066. package/9050.min.js +0 -2
  1067. package/9050.min.js.LICENSE.txt +0 -1
  1068. package/9052.min.js +0 -2
  1069. package/9052.min.js.LICENSE.txt +0 -1
  1070. package/9111.min.js +0 -2
  1071. package/9111.min.js.LICENSE.txt +0 -1
  1072. package/9127.min.js +0 -2
  1073. package/9127.min.js.LICENSE.txt +0 -1
  1074. package/917.min.js +0 -2
  1075. package/917.min.js.LICENSE.txt +0 -1
  1076. package/9216.min.js +0 -2
  1077. package/9216.min.js.LICENSE.txt +0 -1
  1078. package/9234.min.js +0 -2
  1079. package/9234.min.js.LICENSE.txt +0 -1
  1080. package/9273.min.js +0 -2
  1081. package/9273.min.js.LICENSE.txt +0 -1
  1082. package/9277.min.js +0 -2
  1083. package/9277.min.js.LICENSE.txt +0 -1
  1084. package/937.min.js +0 -2
  1085. package/937.min.js.LICENSE.txt +0 -1
  1086. package/9410.min.js +0 -2
  1087. package/9410.min.js.LICENSE.txt +0 -1
  1088. package/9447.min.js +0 -2
  1089. package/9447.min.js.LICENSE.txt +0 -1
  1090. package/9456.min.js +0 -2
  1091. package/9456.min.js.LICENSE.txt +0 -1
  1092. package/9467.min.js +0 -2
  1093. package/9467.min.js.LICENSE.txt +0 -1
  1094. package/9527.min.js +0 -2
  1095. package/9527.min.js.LICENSE.txt +0 -1
  1096. package/9563.min.js +0 -2
  1097. package/9563.min.js.LICENSE.txt +0 -1
  1098. package/9566.min.js +0 -2
  1099. package/9566.min.js.LICENSE.txt +0 -1
  1100. package/9591.min.js +0 -2
  1101. package/9591.min.js.LICENSE.txt +0 -1
  1102. package/9596.min.js +0 -2
  1103. package/9596.min.js.LICENSE.txt +0 -1
  1104. package/9639.min.js +0 -2
  1105. package/9639.min.js.LICENSE.txt +0 -1
  1106. package/9643.min.js.LICENSE.txt +0 -1
  1107. package/9665.min.js +0 -2
  1108. package/9665.min.js.LICENSE.txt +0 -1
  1109. package/9715.min.js +0 -2
  1110. package/9715.min.js.LICENSE.txt +0 -1
  1111. package/9765.min.js +0 -2
  1112. package/9765.min.js.LICENSE.txt +0 -1
  1113. package/979.min.js +0 -2
  1114. package/979.min.js.LICENSE.txt +0 -1
  1115. package/9839.min.js +0 -2
  1116. package/9839.min.js.LICENSE.txt +0 -1
  1117. package/987.min.js +0 -2
  1118. package/987.min.js.LICENSE.txt +0 -1
  1119. package/9902.min.js +0 -2
  1120. package/9902.min.js.LICENSE.txt +0 -1
  1121. package/9928.min.js +0 -2
  1122. package/9928.min.js.LICENSE.txt +0 -1
  1123. package/move_base_dist_browser_BaseMover_js.js +0 -40
  1124. package/move_base_dist_browser_index_js.js +0 -30
  1125. package/shapes_image_dist_browser_Utils_js.js +0 -30
  1126. package/tsparticles.all.bundle.min.js.LICENSE.txt +0 -1
  1127. package/tsparticles.all.min.js.LICENSE.txt +0 -1
  1128. package/updaters_color_dist_browser_ColorUpdater_js.js +0 -30
  1129. package/updaters_color_dist_browser_index_js.js +0 -30
@@ -4,7 +4,7 @@
4
4
  * Demo / Generator : https://particles.js.org/
5
5
  * GitHub : https://www.github.com/matteobruni/tsparticles
6
6
  * How to use? : Check the GitHub README
7
- * v4.0.0-alpha.8
7
+ * v4.0.0-beta.1
8
8
  */
9
9
  "use strict";
10
10
  /*
@@ -17,13 +17,13 @@
17
17
  */
18
18
  (this["webpackChunk_tsparticles_all"] = this["webpackChunk_tsparticles_all"] || []).push([["engine_dist_browser_Core_Container_js"],{
19
19
 
20
- /***/ "../../engine/dist/browser/Core/Canvas.js"
21
- /*!************************************************!*\
22
- !*** ../../engine/dist/browser/Core/Canvas.js ***!
23
- \************************************************/
20
+ /***/ "../../engine/dist/browser/Core/CanvasManager.js"
21
+ /*!*******************************************************!*\
22
+ !*** ../../engine/dist/browser/Core/CanvasManager.js ***!
23
+ \*******************************************************/
24
24
  (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
25
25
 
26
- eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Canvas: () => (/* binding */ Canvas)\n/* harmony export */ });\n/* harmony import */ var _Utils_CanvasUtils_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Utils/CanvasUtils.js */ \"../../engine/dist/browser/Utils/CanvasUtils.js\");\n/* harmony import */ var _Utils_Utils_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../Utils/Utils.js */ \"../../engine/dist/browser/Utils/Utils.js\");\n/* harmony import */ var _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./Utils/Constants.js */ \"../../engine/dist/browser/Core/Utils/Constants.js\");\n/* harmony import */ var _Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../Utils/ColorUtils.js */ \"../../engine/dist/browser/Utils/ColorUtils.js\");\n\n\n\n\nconst fColorIndex = 0,\n sColorIndex = 1;\nfunction setTransformValue(factor, newFactor, key) {\n const newValue = newFactor[key];\n if (newValue !== undefined) {\n factor[key] = (factor[key] ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.defaultTransformValue) * newValue;\n }\n}\nfunction setStyle(canvas, style, important = false) {\n if (!style) {\n return;\n }\n const element = canvas,\n elementStyle = element.style,\n keys = new Set();\n for (let i = 0; i < elementStyle.length; i++) {\n const key = elementStyle.item(i);\n if (!key) {\n continue;\n }\n keys.add(key);\n }\n for (let i = 0; i < style.length; i++) {\n const key = style.item(i);\n if (!key) {\n continue;\n }\n keys.add(key);\n }\n for (const key of keys) {\n const value = style.getPropertyValue(key);\n if (value) {\n elementStyle.setProperty(key, value, important ? \"important\" : \"\");\n } else {\n elementStyle.removeProperty(key);\n }\n }\n}\nclass Canvas {\n constructor(container, engine) {\n this.container = container;\n this._reusableColorStyles = {};\n this._reusablePluginColors = [undefined, undefined];\n this._reusableTransform = {};\n this._applyPostDrawUpdaters = particle => {\n for (const updater of this._postDrawUpdaters) {\n updater.afterDraw?.(particle);\n }\n };\n this._applyPreDrawUpdaters = (ctx, particle, radius, zOpacity, colorStyles, transform) => {\n for (const updater of this._preDrawUpdaters) {\n if (updater.getColorStyles) {\n const {\n fill,\n stroke\n } = updater.getColorStyles(particle, ctx, radius, zOpacity);\n if (fill) {\n colorStyles.fill = fill;\n }\n if (stroke) {\n colorStyles.stroke = stroke;\n }\n }\n if (updater.getTransformValues) {\n const updaterTransform = updater.getTransformValues(particle);\n for (const key in updaterTransform) {\n setTransformValue(transform, updaterTransform, key);\n }\n }\n updater.beforeDraw?.(particle);\n }\n };\n this._applyResizePlugins = () => {\n for (const plugin of this._resizePlugins) {\n plugin.resize?.();\n }\n };\n this._getPluginParticleColors = particle => {\n let fColor, sColor;\n for (const plugin of this._colorPlugins) {\n if (!fColor && plugin.particleFillColor) {\n fColor = (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_3__.rangeColorToHsl)(this._engine, plugin.particleFillColor(particle));\n }\n if (!sColor && plugin.particleStrokeColor) {\n sColor = (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_3__.rangeColorToHsl)(this._engine, plugin.particleStrokeColor(particle));\n }\n if (fColor && sColor) {\n break;\n }\n }\n this._reusablePluginColors[fColorIndex] = fColor;\n this._reusablePluginColors[sColorIndex] = sColor;\n return this._reusablePluginColors;\n };\n this._initStyle = () => {\n const element = this.element,\n options = this.container.actualOptions;\n if (!element) {\n return;\n }\n if (this._fullScreen) {\n this._setFullScreenStyle();\n } else {\n this._resetOriginalStyle();\n }\n for (const key in options.style) {\n if (!key || !Object.hasOwn(options.style, key)) {\n continue;\n }\n const value = options.style[key];\n if (!value) {\n continue;\n }\n element.style.setProperty(key, value, \"important\");\n }\n };\n this._repairStyle = () => {\n const element = this.element;\n if (!element) {\n return;\n }\n this._safeMutationObserver(observer => {\n observer.disconnect();\n });\n this._initStyle();\n this.initBackground();\n const pointerEvents = this._pointerEvents;\n element.style.pointerEvents = pointerEvents;\n element.setAttribute(\"pointer-events\", pointerEvents);\n this._safeMutationObserver(observer => {\n if (!(element instanceof Node)) {\n return;\n }\n observer.observe(element, {\n attributes: true\n });\n });\n };\n this._resetOriginalStyle = () => {\n const element = this.element,\n originalStyle = this._originalStyle;\n if (!element || !originalStyle) {\n return;\n }\n setStyle(element, originalStyle, true);\n };\n this._safeMutationObserver = callback => {\n if (!this._mutationObserver) {\n return;\n }\n callback(this._mutationObserver);\n };\n this._setFullScreenStyle = () => {\n const element = this.element;\n if (!element) {\n return;\n }\n setStyle(element, (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_1__.getFullScreenStyle)(this.container.actualOptions.fullScreen.zIndex), true);\n };\n this._engine = engine;\n this._standardSize = {\n height: 0,\n width: 0\n };\n const pxRatio = container.retina.pixelRatio,\n stdSize = this._standardSize;\n this.size = {\n height: stdSize.height * pxRatio,\n width: stdSize.width * pxRatio\n };\n this._context = null;\n this._generated = false;\n this._preDrawUpdaters = [];\n this._postDrawUpdaters = [];\n this._resizePlugins = [];\n this._colorPlugins = [];\n this._pointerEvents = \"none\";\n }\n get _fullScreen() {\n return this.container.actualOptions.fullScreen.enable;\n }\n canvasClear() {\n if (!this.container.actualOptions.clear) {\n return;\n }\n this.draw(ctx => {\n (0,_Utils_CanvasUtils_js__WEBPACK_IMPORTED_MODULE_0__.clear)(ctx, this.size);\n });\n }\n clear() {\n let pluginHandled = false;\n for (const plugin of this.container.plugins) {\n if (!pluginHandled && plugin.canvasClear) {\n pluginHandled = plugin.canvasClear();\n }\n }\n if (pluginHandled) {\n return;\n }\n this.canvasClear();\n }\n destroy() {\n this.stop();\n if (this._generated) {\n const element = this.element;\n element?.remove();\n this.element = undefined;\n } else {\n this._resetOriginalStyle();\n }\n this._preDrawUpdaters = [];\n this._postDrawUpdaters = [];\n this._resizePlugins = [];\n this._colorPlugins = [];\n }\n draw(cb) {\n const ctx = this._context;\n if (!ctx) {\n return;\n }\n return cb(ctx);\n }\n drawParticle(particle, delta) {\n if (particle.spawning || particle.destroyed) {\n return;\n }\n const radius = particle.getRadius();\n if (radius <= _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.minimumSize) {\n return;\n }\n const pfColor = particle.getFillColor(),\n psColor = particle.getStrokeColor() ?? pfColor;\n let [fColor, sColor] = this._getPluginParticleColors(particle);\n fColor ??= pfColor;\n sColor ??= psColor;\n if (!fColor && !sColor) {\n return;\n }\n const container = this.container,\n zIndexOptions = particle.options.zIndex,\n zIndexFactor = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.zIndexFactorOffset - particle.zIndexFactor,\n {\n opacity,\n strokeOpacity\n } = particle.getOpacity(),\n transform = this._reusableTransform,\n colorStyles = this._reusableColorStyles,\n fill = fColor ? (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_3__.getStyleFromHsl)(fColor, container.hdr, opacity) : undefined,\n stroke = sColor ? (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_3__.getStyleFromHsl)(sColor, container.hdr, strokeOpacity) : fill;\n transform.a = transform.b = transform.c = transform.d = undefined;\n colorStyles.fill = fill;\n colorStyles.stroke = stroke;\n this.draw(context => {\n for (const plugin of container.plugins) {\n if (plugin.drawParticleSetup) {\n plugin.drawParticleSetup(context, particle, delta);\n }\n }\n this._applyPreDrawUpdaters(context, particle, radius, opacity, colorStyles, transform);\n (0,_Utils_CanvasUtils_js__WEBPACK_IMPORTED_MODULE_0__.drawParticle)({\n container,\n context,\n particle,\n delta,\n colorStyles,\n radius: radius * zIndexFactor ** zIndexOptions.sizeRate,\n opacity: opacity,\n transform\n });\n this._applyPostDrawUpdaters(particle);\n for (const plugin of container.plugins) {\n if (plugin.drawParticleCleanup) {\n plugin.drawParticleCleanup(context, particle, delta);\n }\n }\n });\n }\n drawParticlePlugin(plugin, particle, delta) {\n this.draw(ctx => {\n (0,_Utils_CanvasUtils_js__WEBPACK_IMPORTED_MODULE_0__.drawParticlePlugin)(ctx, plugin, particle, delta);\n });\n }\n drawParticles(delta) {\n const {\n particles,\n plugins\n } = this.container;\n this.clear();\n particles.update(delta);\n this.draw(ctx => {\n for (const plugin of plugins) {\n plugin.drawSettingsSetup?.(ctx, delta);\n }\n for (const plugin of plugins) {\n plugin.draw?.(ctx, delta);\n }\n particles.drawParticles(delta);\n for (const plugin of plugins) {\n plugin.clearDraw?.(ctx, delta);\n }\n for (const plugin of plugins) {\n plugin.drawSettingsCleanup?.(ctx, delta);\n }\n });\n }\n init() {\n this._safeMutationObserver(obs => {\n obs.disconnect();\n });\n this._mutationObserver = (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_1__.safeMutationObserver)(records => {\n for (const record of records) {\n if (record.type === \"attributes\" && record.attributeName === \"style\") {\n this._repairStyle();\n }\n }\n });\n this.resize();\n this._initStyle();\n this.initBackground();\n this._safeMutationObserver(obs => {\n if (!this.element || !(this.element instanceof Node)) {\n return;\n }\n obs.observe(this.element, {\n attributes: true\n });\n });\n this.initUpdaters();\n this.initPlugins();\n this.paint();\n }\n initBackground() {\n const {\n container\n } = this,\n options = container.actualOptions,\n background = options.background,\n element = this.element;\n if (!element) {\n return;\n }\n const elementStyle = element.style,\n color = (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_3__.rangeColorToRgb)(this._engine, background.color);\n if (color) {\n elementStyle.backgroundColor = (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_3__.getStyleFromRgb)(color, container.hdr, background.opacity);\n } else {\n elementStyle.backgroundColor = \"\";\n }\n elementStyle.backgroundImage = background.image || \"\";\n elementStyle.backgroundPosition = background.position || \"\";\n elementStyle.backgroundRepeat = background.repeat || \"\";\n elementStyle.backgroundSize = background.size || \"\";\n }\n initPlugins() {\n this._resizePlugins = [];\n for (const plugin of this.container.plugins) {\n if (plugin.resize) {\n this._resizePlugins.push(plugin);\n }\n if (plugin.particleFillColor ?? plugin.particleStrokeColor) {\n this._colorPlugins.push(plugin);\n }\n }\n }\n initUpdaters() {\n this._preDrawUpdaters = [];\n this._postDrawUpdaters = [];\n for (const updater of this.container.particles.updaters) {\n if (updater.afterDraw) {\n this._postDrawUpdaters.push(updater);\n }\n if (updater.getColorStyles ?? updater.getTransformValues ?? updater.beforeDraw) {\n this._preDrawUpdaters.push(updater);\n }\n }\n }\n loadCanvas(canvas) {\n if (this._generated && this.element) {\n this.element.remove();\n }\n const container = this.container;\n this._generated = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.generatedAttribute in canvas.dataset ? canvas.dataset[_Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.generatedAttribute] === \"true\" : this._generated;\n this.element = canvas;\n this.element.ariaHidden = \"true\";\n this._originalStyle = (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_1__.cloneStyle)(this.element.style);\n const standardSize = this._standardSize;\n standardSize.height = canvas.offsetHeight;\n standardSize.width = canvas.offsetWidth;\n const pxRatio = this.container.retina.pixelRatio,\n retinaSize = this.size;\n canvas.height = retinaSize.height = standardSize.height * pxRatio;\n canvas.width = retinaSize.width = standardSize.width * pxRatio;\n const canSupportHdrQuery = (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_1__.safeMatchMedia)(\"(color-gamut: p3)\");\n this._context = this.element.getContext(\"2d\", {\n alpha: true,\n colorSpace: canSupportHdrQuery?.matches && container.hdr ? \"display-p3\" : \"srgb\",\n desynchronized: true,\n willReadFrequently: false\n });\n this._safeMutationObserver(obs => {\n obs.disconnect();\n });\n container.retina.init();\n this.initBackground();\n this._safeMutationObserver(obs => {\n if (!this.element || !(this.element instanceof Node)) {\n return;\n }\n obs.observe(this.element, {\n attributes: true\n });\n });\n }\n paint() {\n let handled = false;\n for (const plugin of this.container.plugins) {\n if (handled) {\n break;\n }\n handled = plugin.canvasPaint?.() ?? false;\n }\n if (handled) {\n return;\n }\n this.paintBase();\n }\n paintBase(baseColor) {\n this.draw(ctx => {\n (0,_Utils_CanvasUtils_js__WEBPACK_IMPORTED_MODULE_0__.paintBase)(ctx, this.size, baseColor);\n });\n }\n paintImage(image, opacity) {\n this.draw(ctx => {\n (0,_Utils_CanvasUtils_js__WEBPACK_IMPORTED_MODULE_0__.paintImage)(ctx, this.size, image, opacity);\n });\n }\n resize() {\n if (!this.element) {\n return false;\n }\n const container = this.container,\n currentSize = container.canvas._standardSize,\n newSize = {\n width: this.element.offsetWidth,\n height: this.element.offsetHeight\n },\n pxRatio = container.retina.pixelRatio,\n retinaSize = {\n width: newSize.width * pxRatio,\n height: newSize.height * pxRatio\n };\n if (newSize.height === currentSize.height && newSize.width === currentSize.width && retinaSize.height === this.element.height && retinaSize.width === this.element.width) {\n return false;\n }\n const oldSize = {\n ...currentSize\n };\n currentSize.height = newSize.height;\n currentSize.width = newSize.width;\n const canvasSize = this.size;\n this.element.width = canvasSize.width = retinaSize.width;\n this.element.height = canvasSize.height = retinaSize.height;\n if (this.container.started) {\n container.particles.setResizeFactor({\n width: currentSize.width / oldSize.width,\n height: currentSize.height / oldSize.height\n });\n }\n return true;\n }\n setPointerEvents(type) {\n const element = this.element;\n if (!element) {\n return;\n }\n this._pointerEvents = type;\n this._repairStyle();\n }\n stop() {\n this._safeMutationObserver(obs => {\n obs.disconnect();\n });\n this._mutationObserver = undefined;\n this.draw(ctx => {\n (0,_Utils_CanvasUtils_js__WEBPACK_IMPORTED_MODULE_0__.clear)(ctx, this.size);\n });\n }\n async windowResize() {\n if (!this.element || !this.resize()) {\n return;\n }\n const container = this.container,\n needsRefresh = container.updateActualOptions();\n container.particles.setDensity();\n this._applyResizePlugins();\n if (needsRefresh) {\n await container.refresh();\n }\n }\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../engine/dist/browser/Core/Canvas.js?\n}");
26
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ CanvasManager: () => (/* binding */ CanvasManager)\n/* harmony export */ });\n/* harmony import */ var _Utils_Utils_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Utils/Utils.js */ \"../../engine/dist/browser/Utils/Utils.js\");\n/* harmony import */ var _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Utils/Constants.js */ \"../../engine/dist/browser/Core/Utils/Constants.js\");\n/* harmony import */ var _Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../Utils/ColorUtils.js */ \"../../engine/dist/browser/Utils/ColorUtils.js\");\n/* harmony import */ var _RenderManager_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./RenderManager.js */ \"../../engine/dist/browser/Core/RenderManager.js\");\n\n\n\n\nfunction setStyle(canvas, style, important = false) {\n if (!style) {\n return;\n }\n const element = canvas, elementStyle = element.style, keys = new Set();\n for(let i = 0; i < elementStyle.length; i++){\n const key = elementStyle.item(i);\n if (!key) {\n continue;\n }\n keys.add(key);\n }\n for(let i = 0; i < style.length; i++){\n const key = style.item(i);\n if (!key) {\n continue;\n }\n keys.add(key);\n }\n for (const key of keys){\n const value = style.getPropertyValue(key);\n if (value) {\n elementStyle.setProperty(key, value, important ? \"important\" : \"\");\n } else {\n elementStyle.removeProperty(key);\n }\n }\n}\nclass CanvasManager {\n element;\n render;\n size;\n zoom = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.defaultZoom;\n _container;\n _generated;\n _mutationObserver;\n _originalStyle;\n _pluginManager;\n _pointerEvents;\n _resizePlugins;\n _standardSize;\n _zoomCenter;\n constructor(pluginManager, container){\n this._pluginManager = pluginManager;\n this._container = container;\n this.render = new _RenderManager_js__WEBPACK_IMPORTED_MODULE_3__.RenderManager(pluginManager, container, this);\n this._standardSize = {\n height: 0,\n width: 0\n };\n const pxRatio = container.retina.pixelRatio, stdSize = this._standardSize;\n this.size = {\n height: stdSize.height * pxRatio,\n width: stdSize.width * pxRatio\n };\n this._generated = false;\n this._resizePlugins = [];\n this._pointerEvents = \"none\";\n }\n get _fullScreen() {\n return this._container.actualOptions.fullScreen.enable;\n }\n destroy() {\n this.stop();\n if (this._generated) {\n const element = this.element;\n element?.remove();\n this.element = undefined;\n } else {\n this._resetOriginalStyle();\n }\n this.render.destroy();\n this._resizePlugins = [];\n }\n getZoomCenter() {\n const pxRatio = this._container.retina.pixelRatio, { width, height } = this.size;\n if (this._zoomCenter) {\n return this._zoomCenter;\n }\n return {\n x: width * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.half / pxRatio,\n y: height * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.half / pxRatio\n };\n }\n init() {\n this._safeMutationObserver((obs)=>{\n obs.disconnect();\n });\n this._mutationObserver = (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_0__.safeMutationObserver)((records)=>{\n for (const record of records){\n if (record.type === \"attributes\" && record.attributeName === \"style\") {\n this._repairStyle();\n }\n }\n });\n this.resize();\n this._initStyle();\n this.initBackground();\n this._safeMutationObserver((obs)=>{\n if (!this.element || !(this.element instanceof Node)) {\n return;\n }\n obs.observe(this.element, {\n attributes: true\n });\n });\n this.initPlugins();\n this.render.init();\n }\n initBackground() {\n const { _container } = this, options = _container.actualOptions, background = options.background, element = this.element;\n if (!element) {\n return;\n }\n const elementStyle = element.style, color = (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_2__.rangeColorToRgb)(this._pluginManager, background.color);\n if (color) {\n elementStyle.backgroundColor = (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_2__.getStyleFromRgb)(color, _container.hdr, background.opacity);\n } else {\n elementStyle.backgroundColor = \"\";\n }\n elementStyle.backgroundImage = background.image || \"\";\n elementStyle.backgroundPosition = background.position || \"\";\n elementStyle.backgroundRepeat = background.repeat || \"\";\n elementStyle.backgroundSize = background.size || \"\";\n }\n initPlugins() {\n this._resizePlugins = [];\n for (const plugin of this._container.plugins){\n if (plugin.resize) {\n this._resizePlugins.push(plugin);\n }\n }\n }\n loadCanvas(canvas) {\n if (this._generated && this.element) {\n this.element.remove();\n }\n const container = this._container;\n this._generated = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.generatedAttribute in canvas.dataset ? canvas.dataset[_Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.generatedAttribute] === \"true\" : this._generated;\n this.element = canvas;\n this.element.ariaHidden = \"true\";\n this._originalStyle = (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_0__.cloneStyle)(this.element.style);\n const standardSize = this._standardSize;\n standardSize.height = canvas.offsetHeight;\n standardSize.width = canvas.offsetWidth;\n const pxRatio = this._container.retina.pixelRatio, retinaSize = this.size;\n canvas.height = retinaSize.height = standardSize.height * pxRatio;\n canvas.width = retinaSize.width = standardSize.width * pxRatio;\n const canSupportHdrQuery = (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_0__.safeMatchMedia)(\"(color-gamut: p3)\");\n this.render.setContextSettings({\n alpha: true,\n colorSpace: canSupportHdrQuery?.matches && container.hdr ? \"display-p3\" : \"srgb\",\n desynchronized: true,\n willReadFrequently: false\n });\n this.render.setContext(this.element.getContext(\"2d\", this.render.settings));\n this._safeMutationObserver((obs)=>{\n obs.disconnect();\n });\n container.retina.init();\n this.initBackground();\n this._safeMutationObserver((obs)=>{\n if (!this.element || !(this.element instanceof Node)) {\n return;\n }\n obs.observe(this.element, {\n attributes: true\n });\n });\n }\n resize() {\n if (!this.element) {\n return false;\n }\n const container = this._container, currentSize = container.canvas._standardSize, newSize = {\n width: this.element.offsetWidth,\n height: this.element.offsetHeight\n }, pxRatio = container.retina.pixelRatio, retinaSize = {\n width: newSize.width * pxRatio,\n height: newSize.height * pxRatio\n };\n if (newSize.height === currentSize.height && newSize.width === currentSize.width && retinaSize.height === this.element.height && retinaSize.width === this.element.width) {\n return false;\n }\n const oldSize = {\n ...currentSize\n };\n currentSize.height = newSize.height;\n currentSize.width = newSize.width;\n const canvasSize = this.size;\n this.element.width = canvasSize.width = retinaSize.width;\n this.element.height = canvasSize.height = retinaSize.height;\n if (this._container.started) {\n container.particles.setResizeFactor({\n width: currentSize.width / oldSize.width,\n height: currentSize.height / oldSize.height\n });\n }\n return true;\n }\n setPointerEvents(type) {\n const element = this.element;\n if (!element) {\n return;\n }\n this._pointerEvents = type;\n this._repairStyle();\n }\n setZoom(zoomLevel, center) {\n this.zoom = zoomLevel;\n this._zoomCenter = center;\n }\n stop() {\n this._safeMutationObserver((obs)=>{\n obs.disconnect();\n });\n this._mutationObserver = undefined;\n this.render.stop();\n }\n async windowResize() {\n if (!this.element || !this.resize()) {\n return;\n }\n const container = this._container, needsRefresh = container.updateActualOptions();\n container.particles.setDensity();\n this._applyResizePlugins();\n if (needsRefresh) {\n await container.refresh();\n }\n }\n _applyResizePlugins = ()=>{\n for (const plugin of this._resizePlugins){\n plugin.resize?.();\n }\n };\n _initStyle = ()=>{\n const element = this.element, options = this._container.actualOptions;\n if (!element) {\n return;\n }\n if (this._fullScreen) {\n this._setFullScreenStyle();\n } else {\n this._resetOriginalStyle();\n }\n for(const key in options.style){\n if (!key || !(key in options.style)) {\n continue;\n }\n const value = options.style[key];\n if (!value) {\n continue;\n }\n element.style.setProperty(key, value, \"important\");\n }\n };\n _repairStyle = ()=>{\n const element = this.element;\n if (!element) {\n return;\n }\n this._safeMutationObserver((observer)=>{\n observer.disconnect();\n });\n this._initStyle();\n this.initBackground();\n const pointerEvents = this._pointerEvents;\n element.style.pointerEvents = pointerEvents;\n element.setAttribute(\"pointer-events\", pointerEvents);\n this._safeMutationObserver((observer)=>{\n if (!(element instanceof Node)) {\n return;\n }\n observer.observe(element, {\n attributes: true\n });\n });\n };\n _resetOriginalStyle = ()=>{\n const element = this.element, originalStyle = this._originalStyle;\n if (!element || !originalStyle) {\n return;\n }\n setStyle(element, originalStyle, true);\n };\n _safeMutationObserver = (callback)=>{\n if (!this._mutationObserver) {\n return;\n }\n callback(this._mutationObserver);\n };\n _setFullScreenStyle = ()=>{\n const element = this.element;\n if (!element) {\n return;\n }\n setStyle(element, (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_0__.getFullScreenStyle)(this._container.actualOptions.fullScreen.zIndex), true);\n };\n}\n\n\n//# sourceURL=webpack://@tsparticles/all/../../engine/dist/browser/Core/CanvasManager.js?\n}");
27
27
 
28
28
  /***/ },
29
29
 
@@ -33,7 +33,7 @@ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpa
33
33
  \***************************************************/
34
34
  (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
35
35
 
36
- eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Container: () => (/* binding */ Container)\n/* harmony export */ });\n/* harmony import */ var _Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Utils/MathUtils.js */ \"../../engine/dist/browser/Utils/MathUtils.js\");\n/* harmony import */ var _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Utils/Constants.js */ \"../../engine/dist/browser/Core/Utils/Constants.js\");\n/* harmony import */ var _Canvas_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./Canvas.js */ \"../../engine/dist/browser/Core/Canvas.js\");\n/* harmony import */ var _Utils_EventListeners_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./Utils/EventListeners.js */ \"../../engine/dist/browser/Core/Utils/EventListeners.js\");\n/* harmony import */ var _Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../Enums/Types/EventType.js */ \"../../engine/dist/browser/Enums/Types/EventType.js\");\n/* harmony import */ var _Options_Classes_Options_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../Options/Classes/Options.js */ \"../../engine/dist/browser/Options/Classes/Options.js\");\n/* harmony import */ var _Particles_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./Particles.js */ \"../../engine/dist/browser/Core/Particles.js\");\n/* harmony import */ var _Retina_js__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./Retina.js */ \"../../engine/dist/browser/Core/Retina.js\");\n/* harmony import */ var _Utils_LogUtils_js__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../Utils/LogUtils.js */ \"../../engine/dist/browser/Utils/LogUtils.js\");\n/* harmony import */ var _Utils_OptionsUtils_js__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../Utils/OptionsUtils.js */ \"../../engine/dist/browser/Utils/OptionsUtils.js\");\n\n\n\n\n\n\n\n\n\n\nfunction guardCheck(container) {\n return !container.destroyed;\n}\nfunction updateDelta(delta, value, fpsLimit = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.defaultFps, smooth = false) {\n delta.value = value;\n delta.factor = smooth ? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.defaultFps / fpsLimit : _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.defaultFps * value / _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.millisecondsToSeconds;\n}\nfunction loadContainerOptions(engine, container, ...sourceOptionsArr) {\n const options = new _Options_Classes_Options_js__WEBPACK_IMPORTED_MODULE_5__.Options(engine, container);\n (0,_Utils_OptionsUtils_js__WEBPACK_IMPORTED_MODULE_9__.loadOptions)(options, ...sourceOptionsArr);\n return options;\n}\nclass Container {\n constructor(engine, id, sourceOptions) {\n this._delta = {\n value: 0,\n factor: 0\n };\n this._nextFrame = timestamp => {\n try {\n if (!this._smooth && this._lastFrameTime !== undefined && timestamp < this._lastFrameTime + _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.millisecondsToSeconds / this.fpsLimit) {\n this.draw(false);\n return;\n }\n this._lastFrameTime ??= timestamp;\n updateDelta(this._delta, timestamp - this._lastFrameTime, this.fpsLimit, this._smooth);\n this.addLifeTime(this._delta.value);\n this._lastFrameTime = timestamp;\n if (this._delta.value > _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.millisecondsToSeconds) {\n this.draw(false);\n return;\n }\n this.canvas.drawParticles(this._delta);\n if (!this.alive()) {\n this.destroy();\n return;\n }\n if (this.animationStatus) {\n this.draw(false);\n }\n } catch (e) {\n (0,_Utils_LogUtils_js__WEBPACK_IMPORTED_MODULE_8__.getLogger)().error(\"error in animation loop\", e);\n }\n };\n this._engine = engine;\n this.id = Symbol(id);\n this.fpsLimit = 120;\n this.hdr = false;\n this._smooth = false;\n this._delay = 0;\n this._duration = 0;\n this._lifeTime = 0;\n this._firstStart = true;\n this.started = false;\n this.destroyed = false;\n this._paused = true;\n this._lastFrameTime = 0;\n this.zLayers = 100;\n this.pageHidden = false;\n this._sourceOptions = sourceOptions;\n this._initialSourceOptions = sourceOptions;\n this.retina = new _Retina_js__WEBPACK_IMPORTED_MODULE_7__.Retina(this);\n this.canvas = new _Canvas_js__WEBPACK_IMPORTED_MODULE_2__.Canvas(this, this._engine);\n this.particles = new _Particles_js__WEBPACK_IMPORTED_MODULE_6__.Particles(this._engine, this);\n this.pathGenerators = new Map();\n this.plugins = [];\n this.effectDrawers = new Map();\n this.shapeDrawers = new Map();\n this._options = loadContainerOptions(this._engine, this);\n this.actualOptions = loadContainerOptions(this._engine, this);\n this._eventListeners = new _Utils_EventListeners_js__WEBPACK_IMPORTED_MODULE_3__.EventListeners(this);\n this._engine.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.containerBuilt, {\n container: this\n });\n }\n get animationStatus() {\n return !this._paused && !this.pageHidden && guardCheck(this);\n }\n get options() {\n return this._options;\n }\n get sourceOptions() {\n return this._sourceOptions;\n }\n addLifeTime(value) {\n this._lifeTime += value;\n }\n addPath(key, generator, override = false) {\n if (!guardCheck(this) || !override && this.pathGenerators.has(key)) {\n return false;\n }\n this.pathGenerators.set(key, generator);\n return true;\n }\n alive() {\n return !this._duration || this._lifeTime <= this._duration;\n }\n destroy(remove = true) {\n if (!guardCheck(this)) {\n return;\n }\n this.stop();\n this.particles.destroy();\n this.canvas.destroy();\n for (const effectDrawer of this.effectDrawers.values()) {\n effectDrawer.destroy?.(this);\n }\n this.effectDrawers.clear();\n for (const shapeDrawer of this.shapeDrawers.values()) {\n shapeDrawer.destroy?.(this);\n }\n this.shapeDrawers.clear();\n for (const plugin of this.plugins) {\n plugin.destroy?.();\n }\n this.plugins.length = 0;\n this._engine.clearPlugins(this);\n this.destroyed = true;\n if (remove) {\n const mainArr = this._engine.items,\n idx = mainArr.indexOf(this);\n if (idx >= _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.removeMinIndex) {\n mainArr.splice(idx, _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.removeDeleteCount);\n }\n }\n this._engine.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.containerDestroyed, {\n container: this\n });\n }\n draw(force) {\n if (!guardCheck(this)) {\n return;\n }\n let refreshTime = force;\n const frame = timestamp => {\n if (refreshTime) {\n this._lastFrameTime = undefined;\n refreshTime = false;\n }\n this._nextFrame(timestamp);\n };\n this._drawAnimationFrame = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_0__.animate)(timestamp => {\n frame(timestamp);\n });\n }\n async export(type, options = {}) {\n for (const plugin of this.plugins) {\n if (!plugin.export) {\n continue;\n }\n const res = await plugin.export(type, options);\n if (!res.supported) {\n continue;\n }\n return res.blob;\n }\n (0,_Utils_LogUtils_js__WEBPACK_IMPORTED_MODULE_8__.getLogger)().error(`Export plugin with type ${type} not found`);\n return undefined;\n }\n async init() {\n if (!guardCheck(this)) {\n return;\n }\n const effects = this._engine.getSupportedEffects();\n for (const type of effects) {\n const drawer = this._engine.getEffectDrawer(type);\n if (drawer) {\n this.effectDrawers.set(type, drawer);\n }\n }\n const shapes = this._engine.getSupportedShapes();\n for (const type of shapes) {\n const drawer = this._engine.getShapeDrawer(type);\n if (drawer) {\n this.shapeDrawers.set(type, drawer);\n }\n }\n const allContainerPlugins = new Map();\n for (const plugin of this._engine.plugins) {\n const containerPlugin = await plugin.getPlugin(this);\n if (containerPlugin.preInit) {\n await containerPlugin.preInit();\n }\n allContainerPlugins.set(plugin, containerPlugin);\n }\n await this.particles.initPlugins();\n this._options = loadContainerOptions(this._engine, this, this._initialSourceOptions, this.sourceOptions);\n this.actualOptions = loadContainerOptions(this._engine, this, this._options);\n for (const [plugin, containerPlugin] of allContainerPlugins) {\n if (plugin.needsPlugin(this.actualOptions)) {\n this.plugins.push(containerPlugin);\n }\n }\n this.retina.init();\n this.canvas.init();\n this.updateActualOptions();\n this.canvas.initBackground();\n this.canvas.resize();\n const {\n delay,\n duration,\n fpsLimit,\n hdr,\n smooth,\n zLayers\n } = this.actualOptions;\n this.hdr = hdr;\n this.zLayers = zLayers;\n this._duration = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_0__.getRangeValue)(duration) * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.millisecondsToSeconds;\n this._delay = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_0__.getRangeValue)(delay) * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.millisecondsToSeconds;\n this._lifeTime = 0;\n this.fpsLimit = fpsLimit > _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.minFpsLimit ? fpsLimit : _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.defaultFpsLimit;\n this._smooth = smooth;\n for (const plugin of this.plugins) {\n await plugin.init?.();\n }\n for (const drawer of this.effectDrawers.values()) {\n await drawer.init?.(this);\n }\n for (const drawer of this.shapeDrawers.values()) {\n await drawer.init?.(this);\n }\n this._engine.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.containerInit, {\n container: this\n });\n await this.particles.init();\n this.particles.setDensity();\n for (const plugin of this.plugins) {\n plugin.particlesSetup?.();\n }\n this._engine.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.particlesSetup, {\n container: this\n });\n }\n pause() {\n if (!guardCheck(this)) {\n return;\n }\n if (this._drawAnimationFrame !== undefined) {\n (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_0__.cancelAnimation)(this._drawAnimationFrame);\n delete this._drawAnimationFrame;\n }\n if (this._paused) {\n return;\n }\n for (const plugin of this.plugins) {\n plugin.pause?.();\n }\n if (!this.pageHidden) {\n this._paused = true;\n }\n this._engine.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.containerPaused, {\n container: this\n });\n }\n play(force) {\n if (!guardCheck(this)) {\n return;\n }\n const needsUpdate = this._paused || force;\n if (this._firstStart && !this.actualOptions.autoPlay) {\n this._firstStart = false;\n return;\n }\n if (this._paused) {\n this._paused = false;\n }\n if (needsUpdate) {\n for (const plugin of this.plugins) {\n if (plugin.play) {\n plugin.play();\n }\n }\n }\n this._engine.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.containerPlay, {\n container: this\n });\n this.draw(needsUpdate ?? false);\n }\n async refresh() {\n if (!guardCheck(this)) {\n return;\n }\n this.stop();\n return this.start();\n }\n async reset(sourceOptions) {\n if (!guardCheck(this)) {\n return;\n }\n this._initialSourceOptions = sourceOptions;\n this._sourceOptions = sourceOptions;\n this._options = loadContainerOptions(this._engine, this, this._initialSourceOptions, this.sourceOptions);\n this.actualOptions = loadContainerOptions(this._engine, this, this._options);\n return this.refresh();\n }\n async start() {\n if (!guardCheck(this) || this.started) {\n return;\n }\n await this.init();\n this.started = true;\n await new Promise(resolve => {\n const start = async () => {\n this._eventListeners.addListeners();\n for (const plugin of this.plugins) {\n await plugin.start?.();\n }\n this._engine.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.containerStarted, {\n container: this\n });\n this.play();\n resolve();\n };\n this._delayTimeout = setTimeout(() => void start(), this._delay);\n });\n }\n stop() {\n if (!guardCheck(this) || !this.started) {\n return;\n }\n if (this._delayTimeout) {\n clearTimeout(this._delayTimeout);\n delete this._delayTimeout;\n }\n this._firstStart = true;\n this.started = false;\n this._eventListeners.removeListeners();\n this.pause();\n this.particles.clear();\n this.canvas.stop();\n for (const plugin of this.plugins) {\n plugin.stop?.();\n }\n this.plugins.length = 0;\n this._sourceOptions = this._options;\n this._engine.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.containerStopped, {\n container: this\n });\n }\n updateActualOptions() {\n let refresh = false;\n for (const plugin of this.plugins) {\n if (plugin.updateActualOptions) {\n refresh = plugin.updateActualOptions() || refresh;\n }\n }\n return refresh;\n }\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../engine/dist/browser/Core/Container.js?\n}");
36
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Container: () => (/* binding */ Container)\n/* harmony export */ });\n/* harmony import */ var _Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Utils/MathUtils.js */ \"../../engine/dist/browser/Utils/MathUtils.js\");\n/* harmony import */ var _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Utils/Constants.js */ \"../../engine/dist/browser/Core/Utils/Constants.js\");\n/* harmony import */ var _CanvasManager_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./CanvasManager.js */ \"../../engine/dist/browser/Core/CanvasManager.js\");\n/* harmony import */ var _Utils_EventListeners_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./Utils/EventListeners.js */ \"../../engine/dist/browser/Core/Utils/EventListeners.js\");\n/* harmony import */ var _Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../Enums/Types/EventType.js */ \"../../engine/dist/browser/Enums/Types/EventType.js\");\n/* harmony import */ var _Options_Classes_Options_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../Options/Classes/Options.js */ \"../../engine/dist/browser/Options/Classes/Options.js\");\n/* harmony import */ var _ParticlesManager_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./ParticlesManager.js */ \"../../engine/dist/browser/Core/ParticlesManager.js\");\n/* harmony import */ var _Retina_js__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./Retina.js */ \"../../engine/dist/browser/Core/Retina.js\");\n/* harmony import */ var _Utils_LogUtils_js__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../Utils/LogUtils.js */ \"../../engine/dist/browser/Utils/LogUtils.js\");\n/* harmony import */ var _Utils_OptionsUtils_js__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../Utils/OptionsUtils.js */ \"../../engine/dist/browser/Utils/OptionsUtils.js\");\n\n\n\n\n\n\n\n\n\n\nfunction guardCheck(container) {\n return !container.destroyed;\n}\nfunction updateDelta(delta, value, fpsLimit = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.defaultFps, smooth = false) {\n delta.value = value;\n delta.factor = smooth ? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.defaultFps / fpsLimit : _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.defaultFps * value / _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.millisecondsToSeconds;\n}\nfunction loadContainerOptions(pluginManager, container, ...sourceOptionsArr) {\n const options = new _Options_Classes_Options_js__WEBPACK_IMPORTED_MODULE_5__.Options(pluginManager, container);\n (0,_Utils_OptionsUtils_js__WEBPACK_IMPORTED_MODULE_9__.loadOptions)(options, ...sourceOptionsArr);\n return options;\n}\nclass Container {\n actualOptions;\n canvas;\n destroyed;\n effectDrawers;\n fpsLimit;\n hdr;\n id;\n pageHidden;\n particleCreatedPlugins;\n particleDestroyedPlugins;\n particlePositionPlugins;\n particleUpdaters;\n particles;\n plugins;\n retina;\n shapeDrawers;\n started;\n zLayers;\n _delay;\n _delayTimeout;\n _delta = {\n value: 0,\n factor: 0\n };\n _dispatchCallback;\n _drawAnimationFrame;\n _duration;\n _eventListeners;\n _firstStart;\n _initialSourceOptions;\n _lastFrameTime;\n _lifeTime;\n _onDestroy;\n _options;\n _paused;\n _pluginManager;\n _smooth;\n _sourceOptions;\n constructor(params){\n const { dispatchCallback, pluginManager, id, onDestroy, sourceOptions } = params;\n this._pluginManager = pluginManager;\n this._dispatchCallback = dispatchCallback;\n this._onDestroy = onDestroy;\n this.id = Symbol(id);\n this.fpsLimit = 120;\n this.hdr = false;\n this._smooth = false;\n this._delay = 0;\n this._duration = 0;\n this._lifeTime = 0;\n this._firstStart = true;\n this.started = false;\n this.destroyed = false;\n this._paused = true;\n this._lastFrameTime = 0;\n this.zLayers = 100;\n this.pageHidden = false;\n this._sourceOptions = sourceOptions;\n this._initialSourceOptions = sourceOptions;\n this.effectDrawers = new Map();\n this.shapeDrawers = new Map();\n this.particleUpdaters = [];\n this.retina = new _Retina_js__WEBPACK_IMPORTED_MODULE_7__.Retina(this);\n this.canvas = new _CanvasManager_js__WEBPACK_IMPORTED_MODULE_2__.CanvasManager(this._pluginManager, this);\n this.particles = new _ParticlesManager_js__WEBPACK_IMPORTED_MODULE_6__.ParticlesManager(this._pluginManager, this);\n this.plugins = [];\n this.particleDestroyedPlugins = [];\n this.particleCreatedPlugins = [];\n this.particlePositionPlugins = [];\n this._options = loadContainerOptions(this._pluginManager, this);\n this.actualOptions = loadContainerOptions(this._pluginManager, this);\n this._eventListeners = new _Utils_EventListeners_js__WEBPACK_IMPORTED_MODULE_3__.EventListeners(this);\n this.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.containerBuilt);\n }\n get animationStatus() {\n return !this._paused && !this.pageHidden && guardCheck(this);\n }\n get options() {\n return this._options;\n }\n get sourceOptions() {\n return this._sourceOptions;\n }\n addLifeTime(value) {\n this._lifeTime += value;\n }\n alive() {\n return !this._duration || this._lifeTime <= this._duration;\n }\n destroy(remove = true) {\n if (!guardCheck(this)) {\n return;\n }\n this.stop();\n this.particles.destroy();\n this.canvas.destroy();\n for (const [, effectDrawer] of this.effectDrawers){\n effectDrawer.destroy?.(this);\n }\n for (const [, shapeDrawer] of this.shapeDrawers){\n shapeDrawer.destroy?.(this);\n }\n for (const plugin of this.plugins){\n plugin.destroy?.();\n }\n this.effectDrawers = new Map();\n this.shapeDrawers = new Map();\n this.particleUpdaters = [];\n this.plugins.length = 0;\n this._pluginManager.clearPlugins(this);\n this.destroyed = true;\n this._onDestroy(remove);\n this.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.containerDestroyed);\n }\n dispatchEvent(type, data) {\n this._dispatchCallback(type, {\n container: this,\n data\n });\n }\n draw(force) {\n if (!guardCheck(this)) {\n return;\n }\n let refreshTime = force;\n this._drawAnimationFrame = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_0__.animate)((timestamp)=>{\n if (refreshTime) {\n this._lastFrameTime = undefined;\n refreshTime = false;\n }\n this._nextFrame(timestamp);\n });\n }\n async export(type, options = {}) {\n for (const plugin of this.plugins){\n if (!plugin.export) {\n continue;\n }\n const res = await plugin.export(type, options);\n if (!res.supported) {\n continue;\n }\n return res.blob;\n }\n (0,_Utils_LogUtils_js__WEBPACK_IMPORTED_MODULE_8__.getLogger)().error(`Export plugin with type ${type} not found`);\n return undefined;\n }\n async init() {\n if (!guardCheck(this)) {\n return;\n }\n const allContainerPlugins = new Map();\n for (const plugin of this._pluginManager.plugins){\n const containerPlugin = await plugin.getPlugin(this);\n if (containerPlugin.preInit) {\n await containerPlugin.preInit();\n }\n allContainerPlugins.set(plugin, containerPlugin);\n }\n await this.initDrawersAndUpdaters();\n this._options = loadContainerOptions(this._pluginManager, this, this._initialSourceOptions, this.sourceOptions);\n this.actualOptions = loadContainerOptions(this._pluginManager, this, this._options);\n this.plugins.length = 0;\n this.particleDestroyedPlugins.length = 0;\n this.particleCreatedPlugins.length = 0;\n this.particlePositionPlugins.length = 0;\n for (const [plugin, containerPlugin] of allContainerPlugins){\n if (plugin.needsPlugin(this.actualOptions)) {\n this.plugins.push(containerPlugin);\n if (containerPlugin.particleCreated) {\n this.particleCreatedPlugins.push(containerPlugin);\n }\n if (containerPlugin.particleDestroyed) {\n this.particleDestroyedPlugins.push(containerPlugin);\n }\n if (containerPlugin.particlePosition) {\n this.particlePositionPlugins.push(containerPlugin);\n }\n }\n }\n this.retina.init();\n this.canvas.init();\n this.updateActualOptions();\n this.canvas.initBackground();\n this.canvas.resize();\n const { delay, duration, fpsLimit, hdr, smooth, zLayers } = this.actualOptions;\n this.hdr = hdr;\n this.zLayers = zLayers;\n this._duration = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_0__.getRangeValue)(duration) * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.millisecondsToSeconds;\n this._delay = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_0__.getRangeValue)(delay) * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.millisecondsToSeconds;\n this._lifeTime = 0;\n this.fpsLimit = fpsLimit > _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.minFpsLimit ? fpsLimit : _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.defaultFpsLimit;\n this._smooth = smooth;\n for (const plugin of this.plugins){\n await plugin.init?.();\n }\n await this.particles.init();\n this.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.containerInit);\n this.particles.setDensity();\n for (const plugin of this.plugins){\n plugin.particlesSetup?.();\n }\n this.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.particlesSetup);\n }\n async initDrawersAndUpdaters() {\n const pluginManager = this._pluginManager;\n this.effectDrawers = await pluginManager.getEffectDrawers(this, true);\n this.shapeDrawers = await pluginManager.getShapeDrawers(this, true);\n this.particleUpdaters = await pluginManager.getUpdaters(this, true);\n }\n pause() {\n if (!guardCheck(this)) {\n return;\n }\n if (this._drawAnimationFrame !== undefined) {\n (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_0__.cancelAnimation)(this._drawAnimationFrame);\n delete this._drawAnimationFrame;\n }\n if (this._paused) {\n return;\n }\n for (const plugin of this.plugins){\n plugin.pause?.();\n }\n if (!this.pageHidden) {\n this._paused = true;\n }\n this.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.containerPaused);\n }\n play(force) {\n if (!guardCheck(this)) {\n return;\n }\n const needsUpdate = this._paused || force;\n if (this._firstStart && !this.actualOptions.autoPlay) {\n this._firstStart = false;\n return;\n }\n if (this._paused) {\n this._paused = false;\n }\n if (needsUpdate) {\n for (const plugin of this.plugins){\n if (plugin.play) {\n plugin.play();\n }\n }\n }\n this.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.containerPlay);\n this.draw(needsUpdate ?? false);\n }\n async refresh() {\n if (!guardCheck(this)) {\n return;\n }\n this.stop();\n return this.start();\n }\n async reset(sourceOptions) {\n if (!guardCheck(this)) {\n return;\n }\n this._initialSourceOptions = sourceOptions;\n this._sourceOptions = sourceOptions;\n this._options = loadContainerOptions(this._pluginManager, this, this._initialSourceOptions, this.sourceOptions);\n this.actualOptions = loadContainerOptions(this._pluginManager, this, this._options);\n return this.refresh();\n }\n async start() {\n if (!guardCheck(this) || this.started) {\n return;\n }\n await this.init();\n this.started = true;\n await new Promise((resolve)=>{\n const start = async ()=>{\n this._eventListeners.addListeners();\n for (const plugin of this.plugins){\n await plugin.start?.();\n }\n this.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.containerStarted);\n this.play();\n resolve();\n };\n this._delayTimeout = setTimeout(()=>void start(), this._delay);\n });\n }\n stop() {\n if (!guardCheck(this) || !this.started) {\n return;\n }\n if (this._delayTimeout) {\n clearTimeout(this._delayTimeout);\n delete this._delayTimeout;\n }\n this._firstStart = true;\n this.started = false;\n this._eventListeners.removeListeners();\n this.pause();\n this.particles.clear();\n this.canvas.stop();\n for (const plugin of this.plugins){\n plugin.stop?.();\n }\n this.particleCreatedPlugins.length = 0;\n this.particleDestroyedPlugins.length = 0;\n this.particlePositionPlugins.length = 0;\n this._sourceOptions = this._options;\n this.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.containerStopped);\n }\n updateActualOptions() {\n let refresh = false;\n for (const plugin of this.plugins){\n if (plugin.updateActualOptions) {\n refresh = plugin.updateActualOptions() || refresh;\n }\n }\n return refresh;\n }\n _nextFrame = (timestamp)=>{\n try {\n if (!this._smooth && this._lastFrameTime !== undefined && timestamp < this._lastFrameTime + _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.millisecondsToSeconds / this.fpsLimit) {\n this.draw(false);\n return;\n }\n this._lastFrameTime ??= timestamp;\n updateDelta(this._delta, timestamp - this._lastFrameTime, this.fpsLimit, this._smooth);\n this.addLifeTime(this._delta.value);\n this._lastFrameTime = timestamp;\n if (this._delta.value > _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.millisecondsToSeconds) {\n this.draw(false);\n return;\n }\n this.canvas.render.drawParticles(this._delta);\n if (!this.alive()) {\n this.destroy();\n return;\n }\n if (this.animationStatus) {\n this.draw(false);\n }\n } catch (e) {\n (0,_Utils_LogUtils_js__WEBPACK_IMPORTED_MODULE_8__.getLogger)().error(\"error in animation loop\", e);\n }\n };\n}\n\n\n//# sourceURL=webpack://@tsparticles/all/../../engine/dist/browser/Core/Container.js?\n}");
37
37
 
38
38
  /***/ },
39
39
 
@@ -43,17 +43,27 @@ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpa
43
43
  \**************************************************/
44
44
  (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
45
45
 
46
- eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Particle: () => (/* binding */ Particle)\n/* harmony export */ });\n/* harmony import */ var _Utils_Vectors_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./Utils/Vectors.js */ \"../../engine/dist/browser/Core/Utils/Vectors.js\");\n/* harmony import */ var _Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../Utils/MathUtils.js */ \"../../engine/dist/browser/Utils/MathUtils.js\");\n/* harmony import */ var _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./Utils/Constants.js */ \"../../engine/dist/browser/Core/Utils/Constants.js\");\n/* harmony import */ var _Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../Utils/Utils.js */ \"../../engine/dist/browser/Utils/Utils.js\");\n/* harmony import */ var _Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../Enums/Types/EventType.js */ \"../../engine/dist/browser/Enums/Types/EventType.js\");\n/* harmony import */ var _Enums_Directions_MoveDirection_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../Enums/Directions/MoveDirection.js */ \"../../engine/dist/browser/Enums/Directions/MoveDirection.js\");\n/* harmony import */ var _Enums_Modes_OutMode_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../Enums/Modes/OutMode.js */ \"../../engine/dist/browser/Enums/Modes/OutMode.js\");\n/* harmony import */ var _Enums_Types_ParticleOutType_js__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../Enums/Types/ParticleOutType.js */ \"../../engine/dist/browser/Enums/Types/ParticleOutType.js\");\n/* harmony import */ var _Utils_CanvasUtils_js__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../Utils/CanvasUtils.js */ \"../../engine/dist/browser/Utils/CanvasUtils.js\");\n/* harmony import */ var _Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../Utils/ColorUtils.js */ \"../../engine/dist/browser/Utils/ColorUtils.js\");\n/* harmony import */ var _Utils_OptionsUtils_js__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ../Utils/OptionsUtils.js */ \"../../engine/dist/browser/Utils/OptionsUtils.js\");\n\n\n\n\n\n\n\n\n\n\n\nfunction loadEffectData(effect, effectOptions, id, reduceDuplicates) {\n const effectData = effectOptions.options[effect];\n return (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.deepExtend)({\n close: effectOptions.close,\n fill: effectOptions.fill\n }, (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.itemFromSingleOrMultiple)(effectData, id, reduceDuplicates));\n}\nfunction loadShapeData(shape, shapeOptions, id, reduceDuplicates) {\n const shapeData = shapeOptions.options[shape];\n return (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.deepExtend)({\n close: shapeOptions.close,\n fill: shapeOptions.fill\n }, (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.itemFromSingleOrMultiple)(shapeData, id, reduceDuplicates));\n}\nfunction fixOutMode(data) {\n if (!(0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.isInArray)(data.outMode, data.checkModes)) {\n return;\n }\n const diameter = data.radius * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.double;\n if (data.coord > data.maxCoord - diameter) {\n data.setCb(-data.radius);\n } else if (data.coord < diameter) {\n data.setCb(data.radius);\n }\n}\nclass Particle {\n constructor(engine, container) {\n this.container = container;\n this._cachedOpacityData = {\n opacity: _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.defaultOpacity,\n strokeOpacity: _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.defaultOpacity\n };\n this._cachedPosition = _Utils_Vectors_js__WEBPACK_IMPORTED_MODULE_0__.Vector3d.origin;\n this._cachedRotateData = {\n sin: 0,\n cos: 0\n };\n this._cachedTransform = {\n a: 1,\n b: 0,\n c: 0,\n d: 1\n };\n this._calcPosition = (position, zIndex) => {\n let tryCount = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.defaultRetryCount,\n posVec = position ? _Utils_Vectors_js__WEBPACK_IMPORTED_MODULE_0__.Vector3d.create(position.x, position.y, zIndex) : undefined;\n const container = this.container,\n plugins = Array.from(container.plugins),\n outModes = this.options.move.outModes,\n radius = this.getRadius(),\n canvasSize = container.canvas.size,\n abortController = new AbortController(),\n {\n signal\n } = abortController;\n while (!signal.aborted) {\n for (const plugin of plugins) {\n const pluginPos = plugin.particlePosition?.(posVec, this);\n if (pluginPos) {\n return _Utils_Vectors_js__WEBPACK_IMPORTED_MODULE_0__.Vector3d.create(pluginPos.x, pluginPos.y, zIndex);\n }\n }\n const exactPosition = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.calcExactPositionOrRandomFromSize)({\n size: canvasSize,\n position: posVec\n }),\n pos = _Utils_Vectors_js__WEBPACK_IMPORTED_MODULE_0__.Vector3d.create(exactPosition.x, exactPosition.y, zIndex);\n this._fixHorizontal(pos, radius, outModes.left ?? outModes.default);\n this._fixHorizontal(pos, radius, outModes.right ?? outModes.default);\n this._fixVertical(pos, radius, outModes.top ?? outModes.default);\n this._fixVertical(pos, radius, outModes.bottom ?? outModes.default);\n let isValidPosition = true;\n for (const plugin of plugins) {\n isValidPosition = plugin.checkParticlePosition?.(this, pos, tryCount) ?? true;\n if (!isValidPosition) {\n break;\n }\n }\n if (isValidPosition) {\n return pos;\n }\n tryCount += _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.tryCountIncrement;\n posVec = undefined;\n }\n return posVec;\n };\n this._calculateVelocity = () => {\n const baseVelocity = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getParticleBaseVelocity)(this.direction),\n res = baseVelocity.copy(),\n moveOptions = this.options.move;\n if (moveOptions.direction === _Enums_Directions_MoveDirection_js__WEBPACK_IMPORTED_MODULE_5__.MoveDirection.inside || moveOptions.direction === _Enums_Directions_MoveDirection_js__WEBPACK_IMPORTED_MODULE_5__.MoveDirection.outside) {\n return res;\n }\n const rad = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.degToRad)((0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getRangeValue)(moveOptions.angle.value)),\n radOffset = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.degToRad)((0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getRangeValue)(moveOptions.angle.offset)),\n range = {\n left: radOffset - rad * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.half,\n right: radOffset + rad * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.half\n };\n if (!moveOptions.straight) {\n res.angle += (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.randomInRangeValue)((0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.setRangeValue)(range.left, range.right));\n }\n if (moveOptions.random && typeof moveOptions.speed === \"number\") {\n res.length *= (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getRandom)();\n }\n return res;\n };\n this._fixHorizontal = (pos, radius, outMode) => {\n fixOutMode({\n outMode,\n checkModes: [_Enums_Modes_OutMode_js__WEBPACK_IMPORTED_MODULE_6__.OutMode.bounce],\n coord: pos.x,\n maxCoord: this.container.canvas.size.width,\n setCb: value => pos.x += value,\n radius\n });\n };\n this._fixVertical = (pos, radius, outMode) => {\n fixOutMode({\n outMode,\n checkModes: [_Enums_Modes_OutMode_js__WEBPACK_IMPORTED_MODULE_6__.OutMode.bounce],\n coord: pos.y,\n maxCoord: this.container.canvas.size.height,\n setCb: value => pos.y += value,\n radius\n });\n };\n this._getRollColor = color => {\n if (!color || !this.roll || !this.backColor && !this.roll.alter) {\n return color;\n }\n if (!this.isShowingBack()) {\n return color;\n }\n if (this.backColor) {\n return this.backColor;\n }\n if (this.roll.alter) {\n return (0,_Utils_CanvasUtils_js__WEBPACK_IMPORTED_MODULE_8__.alterHsl)(color, this.roll.alter.type, this.roll.alter.value);\n }\n return color;\n };\n this._initPosition = position => {\n const container = this.container,\n zIndexValue = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getRangeValue)(this.options.zIndex.value);\n const initialPosition = this._calcPosition(position, (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.clamp)(zIndexValue, _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.minZ, container.zLayers));\n if (!initialPosition) {\n throw new Error(\"a valid position cannot be found for particle\");\n }\n this.position = initialPosition;\n this.initialPosition = this.position.copy();\n const canvasSize = container.canvas.size;\n this.moveCenter = {\n ...(0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.getPosition)(this.options.move.center, canvasSize),\n radius: this.options.move.center.radius,\n mode: this.options.move.center.mode\n };\n this.direction = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getParticleDirectionAngle)(this.options.move.direction, this.position, this.moveCenter);\n switch (this.options.move.direction) {\n case _Enums_Directions_MoveDirection_js__WEBPACK_IMPORTED_MODULE_5__.MoveDirection.inside:\n this.outType = _Enums_Types_ParticleOutType_js__WEBPACK_IMPORTED_MODULE_7__.ParticleOutType.inside;\n break;\n case _Enums_Directions_MoveDirection_js__WEBPACK_IMPORTED_MODULE_5__.MoveDirection.outside:\n this.outType = _Enums_Types_ParticleOutType_js__WEBPACK_IMPORTED_MODULE_7__.ParticleOutType.outside;\n break;\n }\n this.offset = _Utils_Vectors_js__WEBPACK_IMPORTED_MODULE_0__.Vector.origin;\n };\n this._engine = engine;\n }\n destroy(override) {\n if (this.unbreakable || this.destroyed) {\n return;\n }\n this.destroyed = true;\n this.bubble.inRange = false;\n this.slow.inRange = false;\n const container = this.container,\n pathGenerator = this.pathGenerator,\n shapeDrawer = this.shape ? container.shapeDrawers.get(this.shape) : undefined;\n shapeDrawer?.particleDestroy?.(this);\n for (const plugin of container.plugins) {\n plugin.particleDestroyed?.(this, override);\n }\n for (const updater of container.particles.updaters) {\n updater.particleDestroyed?.(this, override);\n }\n pathGenerator?.reset(this);\n this._engine.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_4__.EventType.particleDestroyed, {\n container: this.container,\n data: {\n particle: this\n }\n });\n }\n draw(delta) {\n const container = this.container,\n canvas = container.canvas;\n for (const plugin of container.plugins) {\n canvas.drawParticlePlugin(plugin, this, delta);\n }\n canvas.drawParticle(this, delta);\n }\n getAngle() {\n return this.rotation + (this.pathRotation ? this.velocity.angle : _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.defaultAngle);\n }\n getFillColor() {\n return this._getRollColor(this.bubble.color ?? (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_9__.getHslFromAnimation)(this.color));\n }\n getMass() {\n return this.getRadius() ** _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.squareExp * Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.half;\n }\n getOpacity() {\n const zIndexOptions = this.options.zIndex,\n zIndexFactor = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.zIndexFactorOffset - this.zIndexFactor,\n zOpacityFactor = zIndexFactor ** zIndexOptions.opacityRate,\n opacity = this.bubble.opacity ?? (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getRangeValue)(this.opacity?.value ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.defaultOpacity),\n strokeOpacity = this.strokeOpacity ?? opacity;\n this._cachedOpacityData.opacity = opacity * zOpacityFactor;\n this._cachedOpacityData.strokeOpacity = strokeOpacity * zOpacityFactor;\n return this._cachedOpacityData;\n }\n getPosition() {\n this._cachedPosition.x = this.position.x + this.offset.x;\n this._cachedPosition.y = this.position.y + this.offset.y;\n this._cachedPosition.z = this.position.z;\n return this._cachedPosition;\n }\n getRadius() {\n return this.bubble.radius ?? this.size.value;\n }\n getRotateData() {\n const angle = this.getAngle();\n this._cachedRotateData.sin = Math.sin(angle);\n this._cachedRotateData.cos = Math.cos(angle);\n return this._cachedRotateData;\n }\n getStrokeColor() {\n return this._getRollColor(this.bubble.color ?? (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_9__.getHslFromAnimation)(this.strokeColor));\n }\n getTransformData(externalTransform) {\n const rotateData = this.getRotateData(),\n rotating = this.isRotating;\n this._cachedTransform.a = rotateData.cos * (externalTransform.a ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.defaultTransform.a);\n this._cachedTransform.b = rotating ? rotateData.sin * (externalTransform.b ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.identity) : externalTransform.b ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.defaultTransform.b;\n this._cachedTransform.c = rotating ? -rotateData.sin * (externalTransform.c ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.identity) : externalTransform.c ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.defaultTransform.c;\n this._cachedTransform.d = rotateData.cos * (externalTransform.d ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.defaultTransform.d);\n return this._cachedTransform;\n }\n init(id, position, overrideOptions, group) {\n const container = this.container;\n this.id = id;\n this.group = group;\n this.effectClose = true;\n this.effectFill = true;\n this.shapeClose = true;\n this.shapeFill = true;\n this.pathRotation = false;\n this.lastPathTime = 0;\n this.destroyed = false;\n this.unbreakable = false;\n this.isRotating = false;\n this.rotation = 0;\n this.misplaced = false;\n this.retina = {\n maxDistance: {}\n };\n this.outType = _Enums_Types_ParticleOutType_js__WEBPACK_IMPORTED_MODULE_7__.ParticleOutType.normal;\n this.ignoresResizeRatio = true;\n const pxRatio = container.retina.pixelRatio,\n mainOptions = container.actualOptions,\n particlesOptions = (0,_Utils_OptionsUtils_js__WEBPACK_IMPORTED_MODULE_10__.loadParticlesOptions)(this._engine, container, mainOptions.particles),\n reduceDuplicates = particlesOptions.reduceDuplicates,\n effectType = particlesOptions.effect.type,\n shapeType = particlesOptions.shape.type;\n this.effect = (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.itemFromSingleOrMultiple)(effectType, this.id, reduceDuplicates);\n this.shape = (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.itemFromSingleOrMultiple)(shapeType, this.id, reduceDuplicates);\n const effectOptions = particlesOptions.effect,\n shapeOptions = particlesOptions.shape;\n if (overrideOptions) {\n if (overrideOptions.effect?.type) {\n const overrideEffectType = overrideOptions.effect.type,\n effect = (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.itemFromSingleOrMultiple)(overrideEffectType, this.id, reduceDuplicates);\n if (effect) {\n this.effect = effect;\n effectOptions.load(overrideOptions.effect);\n }\n }\n if (overrideOptions.shape?.type) {\n const overrideShapeType = overrideOptions.shape.type,\n shape = (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.itemFromSingleOrMultiple)(overrideShapeType, this.id, reduceDuplicates);\n if (shape) {\n this.shape = shape;\n shapeOptions.load(overrideOptions.shape);\n }\n }\n }\n if (this.effect === _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.randomColorValue) {\n const availableEffects = [...this.container.effectDrawers.keys()];\n this.effect = availableEffects[Math.floor((0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getRandom)() * availableEffects.length)];\n }\n if (this.shape === _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.randomColorValue) {\n const availableShapes = [...this.container.shapeDrawers.keys()];\n this.shape = availableShapes[Math.floor((0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getRandom)() * availableShapes.length)];\n }\n this.effectData = this.effect ? loadEffectData(this.effect, effectOptions, this.id, reduceDuplicates) : undefined;\n this.shapeData = this.shape ? loadShapeData(this.shape, shapeOptions, this.id, reduceDuplicates) : undefined;\n particlesOptions.load(overrideOptions);\n const effectData = this.effectData;\n if (effectData) {\n particlesOptions.load(effectData.particles);\n }\n const shapeData = this.shapeData;\n if (shapeData) {\n particlesOptions.load(shapeData.particles);\n }\n this.effectFill = effectData?.fill ?? particlesOptions.effect.fill;\n this.effectClose = effectData?.close ?? particlesOptions.effect.close;\n this.shapeFill = shapeData?.fill ?? particlesOptions.shape.fill;\n this.shapeClose = shapeData?.close ?? particlesOptions.shape.close;\n this.options = particlesOptions;\n const pathOptions = this.options.move.path;\n this.pathDelay = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getRangeValue)(pathOptions.delay.value) * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.millisecondsToSeconds;\n if (pathOptions.generator) {\n this.pathGenerator = this._engine.getPathGenerator(pathOptions.generator);\n if (this.pathGenerator && container.addPath(pathOptions.generator, this.pathGenerator)) {\n this.pathGenerator.init(container);\n }\n }\n container.retina.initParticle(this);\n this.size = (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.initParticleNumericAnimationValue)(this.options.size, pxRatio);\n this.bubble = {\n inRange: false\n };\n this.slow = {\n inRange: false,\n factor: 1\n };\n this._initPosition(position);\n this.initialVelocity = this._calculateVelocity();\n this.velocity = this.initialVelocity.copy();\n this.moveDecay = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.decayOffset - (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getRangeValue)(this.options.move.decay);\n const particles = container.particles;\n particles.setLastZIndex(this.position.z);\n this.zIndexFactor = this.position.z / container.zLayers;\n this.sides = 24;\n let effectDrawer, shapeDrawer;\n if (this.effect) {\n effectDrawer = container.effectDrawers.get(this.effect);\n if (!effectDrawer) {\n effectDrawer = this._engine.getEffectDrawer(this.effect);\n if (effectDrawer) {\n container.effectDrawers.set(this.effect, effectDrawer);\n }\n }\n }\n if (effectDrawer?.loadEffect) {\n effectDrawer.loadEffect(this);\n }\n if (this.shape) {\n shapeDrawer = container.shapeDrawers.get(this.shape);\n if (!shapeDrawer) {\n shapeDrawer = this._engine.getShapeDrawer(this.shape);\n if (shapeDrawer) {\n container.shapeDrawers.set(this.shape, shapeDrawer);\n }\n }\n }\n if (shapeDrawer?.loadShape) {\n shapeDrawer.loadShape(this);\n }\n const sideCountFunc = shapeDrawer?.getSidesCount;\n if (sideCountFunc) {\n this.sides = sideCountFunc(this);\n }\n this.spawning = false;\n for (const updater of particles.updaters) {\n updater.init(this);\n }\n for (const mover of particles.movers) {\n mover.init(this);\n }\n effectDrawer?.particleInit?.(container, this);\n shapeDrawer?.particleInit?.(container, this);\n for (const plugin of container.plugins) {\n plugin.particleCreated?.(this);\n }\n }\n isInsideCanvas() {\n const radius = this.getRadius(),\n canvasSize = this.container.canvas.size,\n position = this.position;\n return position.x >= -radius && position.y >= -radius && position.y <= canvasSize.height + radius && position.x <= canvasSize.width + radius;\n }\n isShowingBack() {\n if (!this.roll) {\n return false;\n }\n const angle = this.roll.angle;\n if (this.roll.horizontal && this.roll.vertical) {\n const normalizedAngle = angle % _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.doublePI,\n adjustedAngle = normalizedAngle < _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.defaultAngle ? normalizedAngle + _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.doublePI : normalizedAngle;\n return adjustedAngle >= Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.half && adjustedAngle < Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.triple * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.half;\n }\n if (this.roll.horizontal) {\n const normalizedAngle = (angle + Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.half) % (Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.double),\n adjustedAngle = normalizedAngle < _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.defaultAngle ? normalizedAngle + Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.double : normalizedAngle;\n return adjustedAngle >= Math.PI && adjustedAngle < Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.double;\n }\n if (this.roll.vertical) {\n const normalizedAngle = angle % (Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.double),\n adjustedAngle = normalizedAngle < _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.defaultAngle ? normalizedAngle + Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.double : normalizedAngle;\n return adjustedAngle >= Math.PI && adjustedAngle < Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_2__.double;\n }\n return false;\n }\n isVisible() {\n return !this.destroyed && !this.spawning && this.isInsideCanvas();\n }\n reset() {\n for (const updater of this.container.particles.updaters) {\n updater.reset?.(this);\n }\n }\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../engine/dist/browser/Core/Particle.js?\n}");
46
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Particle: () => (/* binding */ Particle)\n/* harmony export */ });\n/* harmony import */ var _Utils_Vectors_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./Utils/Vectors.js */ \"../../engine/dist/browser/Core/Utils/Vectors.js\");\n/* harmony import */ var _Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../Utils/ColorUtils.js */ \"../../engine/dist/browser/Utils/ColorUtils.js\");\n/* harmony import */ var _Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../Utils/MathUtils.js */ \"../../engine/dist/browser/Utils/MathUtils.js\");\n/* harmony import */ var _Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../Utils/Utils.js */ \"../../engine/dist/browser/Utils/Utils.js\");\n/* harmony import */ var _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./Utils/Constants.js */ \"../../engine/dist/browser/Core/Utils/Constants.js\");\n/* harmony import */ var _Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../Enums/Types/EventType.js */ \"../../engine/dist/browser/Enums/Types/EventType.js\");\n/* harmony import */ var _Enums_Directions_MoveDirection_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../Enums/Directions/MoveDirection.js */ \"../../engine/dist/browser/Enums/Directions/MoveDirection.js\");\n/* harmony import */ var _Enums_Modes_OutMode_js__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../Enums/Modes/OutMode.js */ \"../../engine/dist/browser/Enums/Modes/OutMode.js\");\n/* harmony import */ var _Enums_Types_ParticleOutType_js__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../Enums/Types/ParticleOutType.js */ \"../../engine/dist/browser/Enums/Types/ParticleOutType.js\");\n/* harmony import */ var _Utils_OptionsUtils_js__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../Utils/OptionsUtils.js */ \"../../engine/dist/browser/Utils/OptionsUtils.js\");\n\n\n\n\n\n\n\n\n\n\nfunction loadEffectData(effect, effectOptions, id, reduceDuplicates) {\n const effectData = effectOptions.options[effect];\n return (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.deepExtend)({\n close: effectOptions.close\n }, (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.itemFromSingleOrMultiple)(effectData, id, reduceDuplicates));\n}\nfunction loadShapeData(shape, shapeOptions, id, reduceDuplicates) {\n const shapeData = shapeOptions.options[shape];\n return (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.deepExtend)({\n close: shapeOptions.close\n }, (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.itemFromSingleOrMultiple)(shapeData, id, reduceDuplicates));\n}\nfunction fixOutMode(data) {\n if (!(0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.isInArray)(data.outMode, data.checkModes)) {\n return;\n }\n const diameter = data.radius * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.double;\n if (data.coord > data.maxCoord - diameter) {\n data.setCb(-data.radius);\n } else if (data.coord < diameter) {\n data.setCb(data.radius);\n }\n}\nclass Particle {\n backColor;\n bubble;\n destroyed;\n direction;\n effect;\n effectClose;\n effectData;\n fillColor;\n fillEnabled;\n fillOpacity;\n group;\n id;\n ignoresResizeRatio;\n initialPosition;\n initialVelocity;\n isRotating;\n lastPathTime;\n misplaced;\n moveCenter;\n offset;\n opacity;\n options;\n outType;\n pathRotation;\n position;\n randomIndexData;\n retina;\n roll;\n rotation;\n shape;\n shapeClose;\n shapeData;\n sides;\n size;\n slow;\n spawning;\n strokeColor;\n strokeOpacity;\n strokeWidth;\n unbreakable;\n velocity;\n zIndexFactor;\n _cachedOpacityData = {\n fillOpacity: _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultOpacity,\n opacity: _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultOpacity,\n strokeOpacity: _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultOpacity\n };\n _cachedPosition = _Utils_Vectors_js__WEBPACK_IMPORTED_MODULE_0__.Vector3d.origin;\n _cachedRotateData = {\n sin: 0,\n cos: 0\n };\n _cachedTransform = {\n a: 1,\n b: 0,\n c: 0,\n d: 1\n };\n _container;\n _pluginManager;\n constructor(pluginManager, container){\n this._pluginManager = pluginManager;\n this._container = container;\n }\n destroy(override) {\n if (this.unbreakable || this.destroyed) {\n return;\n }\n this.destroyed = true;\n this.bubble.inRange = false;\n this.slow.inRange = false;\n const container = this._container, shapeDrawer = this.shape ? container.shapeDrawers.get(this.shape) : undefined;\n shapeDrawer?.particleDestroy?.(this);\n for (const plugin of container.particleDestroyedPlugins){\n plugin.particleDestroyed?.(this, override);\n }\n for (const updater of container.particleUpdaters){\n updater.particleDestroyed?.(this, override);\n }\n this._container.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_5__.EventType.particleDestroyed, {\n particle: this\n });\n }\n draw(delta) {\n const container = this._container, render = container.canvas.render;\n render.drawParticlePlugins(this, delta);\n render.drawParticle(this, delta);\n }\n getAngle() {\n return this.rotation + (this.pathRotation ? this.velocity.angle : _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultAngle);\n }\n getFillColor() {\n return this._getRollColor(this.bubble.color ?? (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_1__.getHslFromAnimation)(this.fillColor));\n }\n getMass() {\n return this.getRadius() ** _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.squareExp * Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.half;\n }\n getOpacity() {\n const zIndexOptions = this.options.zIndex, zIndexFactor = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.zIndexFactorOffset - this.zIndexFactor, zOpacityFactor = zIndexFactor ** zIndexOptions.opacityRate, opacity = this.bubble.opacity ?? (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.getRangeValue)(this.opacity?.value ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultOpacity), fillOpacity = this.fillOpacity ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultOpacity, strokeOpacity = this.strokeOpacity ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultOpacity;\n this._cachedOpacityData.fillOpacity = opacity * fillOpacity * zOpacityFactor;\n this._cachedOpacityData.opacity = opacity * zOpacityFactor;\n this._cachedOpacityData.strokeOpacity = opacity * strokeOpacity * zOpacityFactor;\n return this._cachedOpacityData;\n }\n getPosition() {\n this._cachedPosition.x = this.position.x + this.offset.x;\n this._cachedPosition.y = this.position.y + this.offset.y;\n this._cachedPosition.z = this.position.z;\n return this._cachedPosition;\n }\n getRadius() {\n return this.bubble.radius ?? this.size.value;\n }\n getRotateData() {\n const angle = this.getAngle();\n this._cachedRotateData.sin = Math.sin(angle);\n this._cachedRotateData.cos = Math.cos(angle);\n return this._cachedRotateData;\n }\n getStrokeColor() {\n return this._getRollColor(this.bubble.color ?? (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_1__.getHslFromAnimation)(this.strokeColor));\n }\n getTransformData(externalTransform) {\n const rotateData = this.getRotateData(), rotating = this.isRotating;\n this._cachedTransform.a = rotateData.cos * (externalTransform.a ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultTransform.a);\n this._cachedTransform.b = rotating ? rotateData.sin * (externalTransform.b ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.identity) : externalTransform.b ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultTransform.b;\n this._cachedTransform.c = rotating ? -rotateData.sin * (externalTransform.c ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.identity) : externalTransform.c ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultTransform.c;\n this._cachedTransform.d = rotateData.cos * (externalTransform.d ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultTransform.d);\n return this._cachedTransform;\n }\n init(id, position, overrideOptions, group) {\n const container = this._container;\n this.id = id;\n this.group = group;\n this.effectClose = true;\n this.shapeClose = true;\n this.pathRotation = false;\n this.lastPathTime = 0;\n this.destroyed = false;\n this.unbreakable = false;\n this.isRotating = false;\n this.rotation = 0;\n this.misplaced = false;\n this.retina = {\n maxDistance: {},\n maxSpeed: 0,\n moveDrift: 0,\n moveSpeed: 0,\n sizeAnimationSpeed: 0\n };\n this.outType = _Enums_Types_ParticleOutType_js__WEBPACK_IMPORTED_MODULE_8__.ParticleOutType.normal;\n this.ignoresResizeRatio = true;\n const pxRatio = container.retina.pixelRatio, mainOptions = container.actualOptions, particlesOptions = (0,_Utils_OptionsUtils_js__WEBPACK_IMPORTED_MODULE_9__.loadParticlesOptions)(this._pluginManager, container, mainOptions.particles), reduceDuplicates = particlesOptions.reduceDuplicates, effectType = particlesOptions.effect.type, shapeType = particlesOptions.shape.type;\n this.effect = (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.itemFromSingleOrMultiple)(effectType, this.id, reduceDuplicates);\n this.shape = (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.itemFromSingleOrMultiple)(shapeType, this.id, reduceDuplicates);\n const effectOptions = particlesOptions.effect, shapeOptions = particlesOptions.shape;\n if (overrideOptions) {\n if (overrideOptions.effect?.type) {\n const overrideEffectType = overrideOptions.effect.type, effect = (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.itemFromSingleOrMultiple)(overrideEffectType, this.id, reduceDuplicates);\n if (effect) {\n this.effect = effect;\n effectOptions.load(overrideOptions.effect);\n }\n }\n if (overrideOptions.shape?.type) {\n const overrideShapeType = overrideOptions.shape.type, shape = (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.itemFromSingleOrMultiple)(overrideShapeType, this.id, reduceDuplicates);\n if (shape) {\n this.shape = shape;\n shapeOptions.load(overrideOptions.shape);\n }\n }\n }\n if (this.effect === _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.randomColorValue) {\n const availableEffects = [\n ...this._container.effectDrawers.keys()\n ];\n this.effect = availableEffects[Math.floor((0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.getRandom)() * availableEffects.length)];\n }\n if (this.shape === _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.randomColorValue) {\n const availableShapes = [\n ...this._container.shapeDrawers.keys()\n ];\n this.shape = availableShapes[Math.floor((0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.getRandom)() * availableShapes.length)];\n }\n this.effectData = this.effect ? loadEffectData(this.effect, effectOptions, this.id, reduceDuplicates) : undefined;\n this.shapeData = this.shape ? loadShapeData(this.shape, shapeOptions, this.id, reduceDuplicates) : undefined;\n particlesOptions.load(overrideOptions);\n const effectData = this.effectData;\n if (effectData) {\n particlesOptions.load(effectData.particles);\n }\n const shapeData = this.shapeData;\n if (shapeData) {\n particlesOptions.load(shapeData.particles);\n }\n this.effectClose = effectData?.close ?? particlesOptions.effect.close;\n this.shapeClose = shapeData?.close ?? particlesOptions.shape.close;\n this.options = particlesOptions;\n container.retina.initParticle(this);\n this.size = (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.initParticleNumericAnimationValue)(this.options.size, pxRatio);\n this.bubble = {\n inRange: false\n };\n this.slow = {\n inRange: false,\n factor: 1\n };\n this._initPosition(position);\n this.initialVelocity = this._calculateVelocity();\n this.velocity = this.initialVelocity.copy();\n const particles = container.particles;\n particles.setLastZIndex(this.position.z);\n this.zIndexFactor = this.position.z / container.zLayers;\n this.sides = 24;\n let effectDrawer, shapeDrawer;\n if (this.effect) {\n effectDrawer = container.effectDrawers.get(this.effect);\n }\n if (effectDrawer?.loadEffect) {\n effectDrawer.loadEffect(this);\n }\n if (this.shape) {\n shapeDrawer = container.shapeDrawers.get(this.shape);\n }\n if (shapeDrawer?.loadShape) {\n shapeDrawer.loadShape(this);\n }\n const sideCountFunc = shapeDrawer?.getSidesCount;\n if (sideCountFunc) {\n this.sides = sideCountFunc(this);\n }\n this.spawning = false;\n for (const updater of container.particleUpdaters){\n updater.init(this);\n }\n effectDrawer?.particleInit?.(container, this);\n shapeDrawer?.particleInit?.(container, this);\n for (const plugin of container.particleCreatedPlugins){\n plugin.particleCreated?.(this);\n }\n }\n isInsideCanvas() {\n const radius = this.getRadius(), canvasSize = this._container.canvas.size, position = this.position;\n return position.x >= -radius && position.y >= -radius && position.y <= canvasSize.height + radius && position.x <= canvasSize.width + radius;\n }\n isShowingBack() {\n if (!this.roll) {\n return false;\n }\n const angle = this.roll.angle;\n if (this.roll.horizontal && this.roll.vertical) {\n const normalizedAngle = angle % _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.doublePI, adjustedAngle = normalizedAngle < _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultAngle ? normalizedAngle + _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.doublePI : normalizedAngle;\n return adjustedAngle >= Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.half && adjustedAngle < Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.triple * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.half;\n }\n if (this.roll.horizontal) {\n const normalizedAngle = (angle + Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.half) % (Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.double), adjustedAngle = normalizedAngle < _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultAngle ? normalizedAngle + Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.double : normalizedAngle;\n return adjustedAngle >= Math.PI && adjustedAngle < Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.double;\n }\n if (this.roll.vertical) {\n const normalizedAngle = angle % (Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.double), adjustedAngle = normalizedAngle < _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultAngle ? normalizedAngle + Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.double : normalizedAngle;\n return adjustedAngle >= Math.PI && adjustedAngle < Math.PI * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.double;\n }\n return false;\n }\n isVisible() {\n return !this.destroyed && !this.spawning && this.isInsideCanvas();\n }\n reset() {\n for (const updater of this._container.particleUpdaters){\n updater.reset?.(this);\n }\n }\n _calcPosition = (position, zIndex)=>{\n let tryCount = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.defaultRetryCount, posVec = position ? _Utils_Vectors_js__WEBPACK_IMPORTED_MODULE_0__.Vector3d.create(position.x, position.y, zIndex) : undefined;\n const container = this._container, plugins = container.particlePositionPlugins, outModes = this.options.move.outModes, radius = this.getRadius(), canvasSize = container.canvas.size, abortController = new AbortController(), { signal } = abortController;\n while(!signal.aborted){\n for (const plugin of plugins){\n const pluginPos = plugin.particlePosition?.(posVec, this);\n if (pluginPos) {\n return _Utils_Vectors_js__WEBPACK_IMPORTED_MODULE_0__.Vector3d.create(pluginPos.x, pluginPos.y, zIndex);\n }\n }\n const exactPosition = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.calcExactPositionOrRandomFromSize)({\n size: canvasSize,\n position: posVec\n }), pos = _Utils_Vectors_js__WEBPACK_IMPORTED_MODULE_0__.Vector3d.create(exactPosition.x, exactPosition.y, zIndex);\n this._fixHorizontal(pos, radius, outModes.left ?? outModes.default);\n this._fixHorizontal(pos, radius, outModes.right ?? outModes.default);\n this._fixVertical(pos, radius, outModes.top ?? outModes.default);\n this._fixVertical(pos, radius, outModes.bottom ?? outModes.default);\n let isValidPosition = true;\n for (const plugin of container.particles.checkParticlePositionPlugins){\n isValidPosition = plugin.checkParticlePosition?.(this, pos, tryCount) ?? true;\n if (!isValidPosition) {\n break;\n }\n }\n if (isValidPosition) {\n return pos;\n }\n tryCount += _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.tryCountIncrement;\n posVec = undefined;\n }\n return posVec;\n };\n _calculateVelocity = ()=>{\n const baseVelocity = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.getParticleBaseVelocity)(this.direction), res = baseVelocity.copy(), moveOptions = this.options.move;\n if (moveOptions.direction === _Enums_Directions_MoveDirection_js__WEBPACK_IMPORTED_MODULE_6__.MoveDirection.inside || moveOptions.direction === _Enums_Directions_MoveDirection_js__WEBPACK_IMPORTED_MODULE_6__.MoveDirection.outside) {\n return res;\n }\n const rad = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.degToRad)((0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.getRangeValue)(moveOptions.angle.value)), radOffset = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.degToRad)((0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.getRangeValue)(moveOptions.angle.offset)), range = {\n left: radOffset - rad * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.half,\n right: radOffset + rad * _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.half\n };\n if (!moveOptions.straight) {\n res.angle += (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.randomInRangeValue)((0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.setRangeValue)(range.left, range.right));\n }\n if (moveOptions.random && typeof moveOptions.speed === \"number\") {\n res.length *= (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.getRandom)();\n }\n return res;\n };\n _fixHorizontal = (pos, radius, outMode)=>{\n fixOutMode({\n outMode,\n checkModes: [\n _Enums_Modes_OutMode_js__WEBPACK_IMPORTED_MODULE_7__.OutMode.bounce\n ],\n coord: pos.x,\n maxCoord: this._container.canvas.size.width,\n setCb: (value)=>pos.x += value,\n radius\n });\n };\n _fixVertical = (pos, radius, outMode)=>{\n fixOutMode({\n outMode,\n checkModes: [\n _Enums_Modes_OutMode_js__WEBPACK_IMPORTED_MODULE_7__.OutMode.bounce\n ],\n coord: pos.y,\n maxCoord: this._container.canvas.size.height,\n setCb: (value)=>pos.y += value,\n radius\n });\n };\n _getRollColor = (color)=>{\n if (!color || !this.roll || !this.backColor && !this.roll.alter) {\n return color;\n }\n if (!this.isShowingBack()) {\n return color;\n }\n if (this.backColor) {\n return this.backColor;\n }\n if (this.roll.alter) {\n return (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_1__.alterHsl)(color, this.roll.alter.type, this.roll.alter.value);\n }\n return color;\n };\n _initPosition = (position)=>{\n const container = this._container, zIndexValue = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.getRangeValue)(this.options.zIndex.value), initialPosition = this._calcPosition(position, (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.clamp)(zIndexValue, _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_4__.minZ, container.zLayers));\n if (!initialPosition) {\n throw new Error(\"a valid position cannot be found for particle\");\n }\n this.position = initialPosition;\n this.initialPosition = this.position.copy();\n const canvasSize = container.canvas.size;\n this.moveCenter = {\n ...(0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_3__.getPosition)(this.options.move.center, canvasSize),\n radius: this.options.move.center.radius,\n mode: this.options.move.center.mode\n };\n this.direction = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.getParticleDirectionAngle)(this.options.move.direction, this.position, this.moveCenter);\n switch(this.options.move.direction){\n case _Enums_Directions_MoveDirection_js__WEBPACK_IMPORTED_MODULE_6__.MoveDirection.inside:\n this.outType = _Enums_Types_ParticleOutType_js__WEBPACK_IMPORTED_MODULE_8__.ParticleOutType.inside;\n break;\n case _Enums_Directions_MoveDirection_js__WEBPACK_IMPORTED_MODULE_6__.MoveDirection.outside:\n this.outType = _Enums_Types_ParticleOutType_js__WEBPACK_IMPORTED_MODULE_8__.ParticleOutType.outside;\n break;\n default:\n break;\n }\n this.offset = _Utils_Vectors_js__WEBPACK_IMPORTED_MODULE_0__.Vector.origin;\n };\n}\n\n\n//# sourceURL=webpack://@tsparticles/all/../../engine/dist/browser/Core/Particle.js?\n}");
47
47
 
48
48
  /***/ },
49
49
 
50
- /***/ "../../engine/dist/browser/Core/Particles.js"
51
- /*!***************************************************!*\
52
- !*** ../../engine/dist/browser/Core/Particles.js ***!
53
- \***************************************************/
50
+ /***/ "../../engine/dist/browser/Core/ParticlesManager.js"
51
+ /*!**********************************************************!*\
52
+ !*** ../../engine/dist/browser/Core/ParticlesManager.js ***!
53
+ \**********************************************************/
54
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
55
+
56
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ ParticlesManager: () => (/* binding */ ParticlesManager)\n/* harmony export */ });\n/* harmony import */ var _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./Utils/Constants.js */ \"../../engine/dist/browser/Core/Utils/Constants.js\");\n/* harmony import */ var _Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../Enums/Types/EventType.js */ \"../../engine/dist/browser/Enums/Types/EventType.js\");\n/* harmony import */ var _Enums_Modes_LimitMode_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../Enums/Modes/LimitMode.js */ \"../../engine/dist/browser/Enums/Modes/LimitMode.js\");\n/* harmony import */ var _Particle_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./Particle.js */ \"../../engine/dist/browser/Core/Particle.js\");\n/* harmony import */ var _Utils_SpatialHashGrid_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./Utils/SpatialHashGrid.js */ \"../../engine/dist/browser/Core/Utils/SpatialHashGrid.js\");\n/* harmony import */ var _Utils_LogUtils_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../Utils/LogUtils.js */ \"../../engine/dist/browser/Utils/LogUtils.js\");\n/* harmony import */ var _Utils_OptionsUtils_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../Utils/OptionsUtils.js */ \"../../engine/dist/browser/Utils/OptionsUtils.js\");\n\n\n\n\n\n\n\nclass ParticlesManager {\n checkParticlePositionPlugins;\n grid;\n _array;\n _container;\n _groupLimits;\n _limit;\n _maxZIndex;\n _minZIndex;\n _needsSort;\n _nextId;\n _particleResetPlugins;\n _particleUpdatePlugins;\n _pluginManager;\n _pool;\n _postParticleUpdatePlugins;\n _postUpdatePlugins;\n _resizeFactor;\n _updatePlugins;\n _zArray;\n constructor(pluginManager, container){\n this._pluginManager = pluginManager;\n this._container = container;\n this._nextId = 0;\n this._array = [];\n this._zArray = [];\n this._pool = [];\n this._limit = 0;\n this._groupLimits = new Map();\n this._needsSort = false;\n this._minZIndex = 0;\n this._maxZIndex = 0;\n this.grid = new _Utils_SpatialHashGrid_js__WEBPACK_IMPORTED_MODULE_4__.SpatialHashGrid(_Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.spatialHashGridCellSize);\n this.checkParticlePositionPlugins = [];\n this._particleResetPlugins = [];\n this._particleUpdatePlugins = [];\n this._postUpdatePlugins = [];\n this._postParticleUpdatePlugins = [];\n this._updatePlugins = [];\n }\n get count() {\n return this._array.length;\n }\n addParticle(position, overrideOptions, group, initializer) {\n const limitMode = this._container.actualOptions.particles.number.limit.mode, limit = group === undefined ? this._limit : this._groupLimits.get(group) ?? this._limit, currentCount = this.count;\n if (limit > _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.minLimit) {\n switch(limitMode){\n case _Enums_Modes_LimitMode_js__WEBPACK_IMPORTED_MODULE_2__.LimitMode.delete:\n {\n const countToRemove = currentCount + _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.countOffset - limit;\n if (countToRemove > _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.minCount) {\n this.removeQuantity(countToRemove);\n }\n break;\n }\n case _Enums_Modes_LimitMode_js__WEBPACK_IMPORTED_MODULE_2__.LimitMode.wait:\n if (currentCount >= limit) {\n return;\n }\n break;\n default:\n break;\n }\n }\n try {\n const particle = this._pool.pop() ?? new _Particle_js__WEBPACK_IMPORTED_MODULE_3__.Particle(this._pluginManager, this._container);\n particle.init(this._nextId, position, overrideOptions, group);\n let canAdd = true;\n if (initializer) {\n canAdd = initializer(particle);\n }\n if (!canAdd) {\n this._pool.push(particle);\n return;\n }\n this._array.push(particle);\n this._zArray.push(particle);\n this._nextId++;\n this._container.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_1__.EventType.particleAdded, {\n particle\n });\n return particle;\n } catch (e) {\n (0,_Utils_LogUtils_js__WEBPACK_IMPORTED_MODULE_5__.getLogger)().warning(`error adding particle: ${e}`);\n }\n return undefined;\n }\n clear() {\n this._array = [];\n this._zArray = [];\n }\n destroy() {\n this._array = [];\n this._pool.length = 0;\n this._zArray = [];\n this.checkParticlePositionPlugins = [];\n this._particleResetPlugins = [];\n this._particleUpdatePlugins = [];\n this._postUpdatePlugins = [];\n this._postParticleUpdatePlugins = [];\n this._updatePlugins = [];\n }\n drawParticles(delta) {\n for (const particle of this._zArray){\n particle.draw(delta);\n }\n }\n filter(condition) {\n return this._array.filter(condition);\n }\n find(condition) {\n return this._array.find(condition);\n }\n get(index) {\n return this._array[index];\n }\n async init() {\n const container = this._container, options = container.actualOptions;\n this._minZIndex = 0;\n this._maxZIndex = 0;\n this._needsSort = false;\n this.checkParticlePositionPlugins = [];\n this._updatePlugins = [];\n this._particleUpdatePlugins = [];\n this._postUpdatePlugins = [];\n this._particleResetPlugins = [];\n this._postParticleUpdatePlugins = [];\n this.grid = new _Utils_SpatialHashGrid_js__WEBPACK_IMPORTED_MODULE_4__.SpatialHashGrid(_Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.spatialHashGridCellSize * container.retina.pixelRatio);\n for (const plugin of container.plugins){\n if (plugin.redrawInit) {\n await plugin.redrawInit();\n }\n if (plugin.checkParticlePosition) {\n this.checkParticlePositionPlugins.push(plugin);\n }\n if (plugin.update) {\n this._updatePlugins.push(plugin);\n }\n if (plugin.particleUpdate) {\n this._particleUpdatePlugins.push(plugin);\n }\n if (plugin.postUpdate) {\n this._postUpdatePlugins.push(plugin);\n }\n if (plugin.particleReset) {\n this._particleResetPlugins.push(plugin);\n }\n if (plugin.postParticleUpdate) {\n this._postParticleUpdatePlugins.push(plugin);\n }\n }\n await this._container.initDrawersAndUpdaters();\n for (const drawer of this._container.effectDrawers.values()){\n await drawer.init?.(container);\n }\n for (const drawer of this._container.shapeDrawers.values()){\n await drawer.init?.(container);\n }\n let handled = false;\n for (const plugin of container.plugins){\n handled = plugin.particlesInitialization?.() ?? handled;\n if (handled) {\n break;\n }\n }\n if (!handled) {\n const particlesOptions = options.particles, groups = particlesOptions.groups;\n for(const group in groups){\n const groupOptions = groups[group];\n if (!groupOptions) {\n continue;\n }\n for(let i = this.count, j = 0; j < groupOptions.number.value && i < particlesOptions.number.value; i++, j++){\n this.addParticle(undefined, groupOptions, group);\n }\n }\n for(let i = this.count; i < particlesOptions.number.value; i++){\n this.addParticle();\n }\n }\n }\n push(nb, position, overrideOptions, group) {\n for(let i = 0; i < nb; i++){\n this.addParticle(position, overrideOptions, group);\n }\n }\n async redraw() {\n this.clear();\n await this.init();\n this._container.canvas.render.drawParticles({\n value: 0,\n factor: 0\n });\n }\n remove(particle, group, override) {\n this.removeAt(this._array.indexOf(particle), undefined, group, override);\n }\n removeAt(index, quantity = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.defaultRemoveQuantity, group, override) {\n if (index < _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.minIndex || index > this.count) {\n return;\n }\n let deleted = 0;\n for(let i = index; deleted < quantity && i < this.count; i++){\n if (this._removeParticle(i, group, override)) {\n i--;\n deleted++;\n }\n }\n }\n removeQuantity(quantity, group) {\n this.removeAt(_Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.minIndex, quantity, group);\n }\n setDensity() {\n const options = this._container.actualOptions, groups = options.particles.groups;\n let pluginsCount = 0;\n for (const plugin of this._container.plugins){\n if (plugin.particlesDensityCount) {\n pluginsCount += plugin.particlesDensityCount();\n }\n }\n for(const group in groups){\n const groupData = groups[group];\n if (!groupData) {\n continue;\n }\n const groupDataOptions = (0,_Utils_OptionsUtils_js__WEBPACK_IMPORTED_MODULE_6__.loadParticlesOptions)(this._pluginManager, this._container, groupData);\n this._applyDensity(groupDataOptions, pluginsCount, group);\n }\n this._applyDensity(options.particles, pluginsCount);\n }\n setLastZIndex(zIndex) {\n this._needsSort ||= zIndex >= this._maxZIndex || zIndex > this._minZIndex && zIndex < this._maxZIndex;\n }\n setResizeFactor(factor) {\n this._resizeFactor = factor;\n }\n update(delta) {\n const particlesToDelete = new Set();\n this.grid.clear();\n for (const plugin of this._updatePlugins){\n plugin.update?.(delta);\n }\n const resizeFactor = this._resizeFactor;\n for (const particle of this._array){\n if (resizeFactor && !particle.ignoresResizeRatio) {\n particle.position.x *= resizeFactor.width;\n particle.position.y *= resizeFactor.height;\n particle.initialPosition.x *= resizeFactor.width;\n particle.initialPosition.y *= resizeFactor.height;\n }\n particle.ignoresResizeRatio = false;\n for (const plugin of this._particleResetPlugins){\n plugin.particleReset?.(particle);\n }\n for (const plugin of this._particleUpdatePlugins){\n if (particle.destroyed) {\n break;\n }\n plugin.particleUpdate?.(particle, delta);\n }\n if (particle.destroyed) {\n particlesToDelete.add(particle);\n continue;\n }\n this.grid.insert(particle);\n }\n for (const plugin of this._postUpdatePlugins){\n plugin.postUpdate?.(delta);\n }\n for (const particle of this._array){\n if (particle.destroyed) {\n particlesToDelete.add(particle);\n continue;\n }\n for (const updater of this._container.particleUpdaters){\n updater.update(particle, delta);\n }\n if (!particle.destroyed && !particle.spawning) {\n for (const plugin of this._postParticleUpdatePlugins){\n plugin.postParticleUpdate?.(particle, delta);\n }\n } else if (particle.destroyed) {\n particlesToDelete.add(particle);\n }\n }\n if (particlesToDelete.size) {\n for (const particle of particlesToDelete){\n this.remove(particle);\n }\n }\n delete this._resizeFactor;\n if (this._needsSort) {\n const zArray = this._zArray;\n zArray.sort((a, b)=>b.position.z - a.position.z || a.id - b.id);\n const firstItem = zArray[_Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.minIndex], lastItem = zArray[zArray.length - _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.lengthOffset];\n if (!firstItem || !lastItem) {\n return;\n }\n this._maxZIndex = firstItem.position.z;\n this._minZIndex = lastItem.position.z;\n this._needsSort = false;\n }\n }\n _addToPool = (...particles)=>{\n this._pool.push(...particles);\n };\n _applyDensity = (options, pluginsCount, group, groupOptions)=>{\n const numberOptions = options.number;\n if (!numberOptions.density.enable) {\n if (group === undefined) {\n this._limit = numberOptions.limit.value;\n } else if (groupOptions?.number.limit.value ?? numberOptions.limit.value) {\n this._groupLimits.set(group, groupOptions?.number.limit.value ?? numberOptions.limit.value);\n }\n return;\n }\n const densityFactor = this._initDensityFactor(numberOptions.density), optParticlesNumber = numberOptions.value, optParticlesLimit = numberOptions.limit.value > _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.minLimit ? numberOptions.limit.value : optParticlesNumber, particlesNumber = Math.min(optParticlesNumber, optParticlesLimit) * densityFactor + pluginsCount, particlesCount = Math.min(this.count, this.filter((t)=>t.group === group).length);\n if (group === undefined) {\n this._limit = numberOptions.limit.value * densityFactor;\n } else {\n this._groupLimits.set(group, numberOptions.limit.value * densityFactor);\n }\n if (particlesCount < particlesNumber) {\n this.push(Math.abs(particlesNumber - particlesCount), undefined, options, group);\n } else if (particlesCount > particlesNumber) {\n this.removeQuantity(particlesCount - particlesNumber, group);\n }\n };\n _initDensityFactor = (densityOptions)=>{\n const container = this._container;\n if (!container.canvas.element || !densityOptions.enable) {\n return _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.defaultDensityFactor;\n }\n const canvas = container.canvas.element, pxRatio = container.retina.pixelRatio;\n return canvas.width * canvas.height / (densityOptions.height * densityOptions.width * pxRatio ** _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.squareExp);\n };\n _removeParticle = (index, group, override)=>{\n const particle = this._array[index];\n if (!particle) {\n return false;\n }\n if (particle.group !== group) {\n return false;\n }\n const zIdx = this._zArray.indexOf(particle);\n this._array.splice(index, _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.deleteCount);\n this._zArray.splice(zIdx, _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.deleteCount);\n particle.destroy(override);\n this._container.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_1__.EventType.particleRemoved, {\n particle\n });\n this._addToPool(particle);\n return true;\n };\n}\n\n\n//# sourceURL=webpack://@tsparticles/all/../../engine/dist/browser/Core/ParticlesManager.js?\n}");
57
+
58
+ /***/ },
59
+
60
+ /***/ "../../engine/dist/browser/Core/RenderManager.js"
61
+ /*!*******************************************************!*\
62
+ !*** ../../engine/dist/browser/Core/RenderManager.js ***!
63
+ \*******************************************************/
54
64
  (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
55
65
 
56
- eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Particles: () => (/* binding */ Particles)\n/* harmony export */ });\n/* harmony import */ var _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./Utils/Constants.js */ \"../../engine/dist/browser/Core/Utils/Constants.js\");\n/* harmony import */ var _Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../Enums/Types/EventType.js */ \"../../engine/dist/browser/Enums/Types/EventType.js\");\n/* harmony import */ var _Enums_Modes_LimitMode_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../Enums/Modes/LimitMode.js */ \"../../engine/dist/browser/Enums/Modes/LimitMode.js\");\n/* harmony import */ var _Particle_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./Particle.js */ \"../../engine/dist/browser/Core/Particle.js\");\n/* harmony import */ var _Utils_Point_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./Utils/Point.js */ \"../../engine/dist/browser/Core/Utils/Point.js\");\n/* harmony import */ var _Utils_QuadTree_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./Utils/QuadTree.js */ \"../../engine/dist/browser/Core/Utils/QuadTree.js\");\n/* harmony import */ var _Utils_Ranges_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./Utils/Ranges.js */ \"../../engine/dist/browser/Core/Utils/Ranges.js\");\n/* harmony import */ var _Utils_LogUtils_js__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../Utils/LogUtils.js */ \"../../engine/dist/browser/Utils/LogUtils.js\");\n/* harmony import */ var _Utils_OptionsUtils_js__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../Utils/OptionsUtils.js */ \"../../engine/dist/browser/Utils/OptionsUtils.js\");\n\n\n\n\n\n\n\n\n\nconst qTreeRectangle = canvasSize => {\n const {\n height,\n width\n } = canvasSize;\n return new _Utils_Ranges_js__WEBPACK_IMPORTED_MODULE_6__.Rectangle(_Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.posOffset * width, _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.posOffset * height, _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.sizeFactor * width, _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.sizeFactor * height);\n};\nclass Particles {\n constructor(engine, container) {\n this._addToPool = (...particles) => {\n this._pool.push(...particles);\n };\n this._applyDensity = (options, pluginsCount, group, groupOptions) => {\n const numberOptions = options.number;\n if (!numberOptions.density.enable) {\n if (group === undefined) {\n this._limit = numberOptions.limit.value;\n } else if (groupOptions?.number.limit.value ?? numberOptions.limit.value) {\n this._groupLimits.set(group, groupOptions?.number.limit.value ?? numberOptions.limit.value);\n }\n return;\n }\n const densityFactor = this._initDensityFactor(numberOptions.density),\n optParticlesNumber = numberOptions.value,\n optParticlesLimit = numberOptions.limit.value > _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.minLimit ? numberOptions.limit.value : optParticlesNumber,\n particlesNumber = Math.min(optParticlesNumber, optParticlesLimit) * densityFactor + pluginsCount,\n particlesCount = Math.min(this.count, this.filter(t => t.group === group).length);\n if (group === undefined) {\n this._limit = numberOptions.limit.value * densityFactor;\n } else {\n this._groupLimits.set(group, numberOptions.limit.value * densityFactor);\n }\n if (particlesCount < particlesNumber) {\n this.push(Math.abs(particlesNumber - particlesCount), undefined, options, group);\n } else if (particlesCount > particlesNumber) {\n this.removeQuantity(particlesCount - particlesNumber, group);\n }\n };\n this._initDensityFactor = densityOptions => {\n const container = this._container;\n if (!container.canvas.element || !densityOptions.enable) {\n return _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.defaultDensityFactor;\n }\n const canvas = container.canvas.element,\n pxRatio = container.retina.pixelRatio;\n return canvas.width * canvas.height / (densityOptions.height * densityOptions.width * pxRatio ** _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.squareExp);\n };\n this._pushParticle = (position, overrideOptions, group, initializer) => {\n try {\n const particle = this._pool.pop() ?? new _Particle_js__WEBPACK_IMPORTED_MODULE_3__.Particle(this._engine, this._container);\n particle.init(this._nextId, position, overrideOptions, group);\n let canAdd = true;\n if (initializer) {\n canAdd = initializer(particle);\n }\n if (!canAdd) {\n return;\n }\n this._array.push(particle);\n this._zArray.push(particle);\n this._nextId++;\n this._engine.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_1__.EventType.particleAdded, {\n container: this._container,\n data: {\n particle\n }\n });\n return particle;\n } catch (e) {\n (0,_Utils_LogUtils_js__WEBPACK_IMPORTED_MODULE_7__.getLogger)().warning(`error adding particle: ${e}`);\n }\n return undefined;\n };\n this._removeParticle = (index, group, override) => {\n const particle = this._array[index];\n if (!particle) {\n return false;\n }\n if (particle.group !== group) {\n return false;\n }\n const zIdx = this._zArray.indexOf(particle);\n this._array.splice(index, _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.deleteCount);\n this._zArray.splice(zIdx, _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.deleteCount);\n particle.destroy(override);\n this._engine.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_1__.EventType.particleRemoved, {\n container: this._container,\n data: {\n particle\n }\n });\n this._addToPool(particle);\n return true;\n };\n this._engine = engine;\n this._container = container;\n this._nextId = 0;\n this._array = [];\n this._zArray = [];\n this._pool = [];\n this._limit = 0;\n this._groupLimits = new Map();\n this._needsSort = false;\n this._lastZIndex = 0;\n this._pluginsInitialized = false;\n const canvasSize = container.canvas.size;\n this.quadTree = new _Utils_QuadTree_js__WEBPACK_IMPORTED_MODULE_5__.QuadTree(qTreeRectangle(canvasSize), _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.qTreeCapacity);\n this.movers = [];\n this.updaters = [];\n }\n get count() {\n return this._array.length;\n }\n addParticle(position, overrideOptions, group, initializer) {\n const limitMode = this._container.actualOptions.particles.number.limit.mode,\n limit = group === undefined ? this._limit : this._groupLimits.get(group) ?? this._limit,\n currentCount = this.count;\n if (limit > _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.minLimit) {\n switch (limitMode) {\n case _Enums_Modes_LimitMode_js__WEBPACK_IMPORTED_MODULE_2__.LimitMode.delete:\n {\n const countToRemove = currentCount + _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.countOffset - limit;\n if (countToRemove > _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.minCount) {\n this.removeQuantity(countToRemove);\n }\n break;\n }\n case _Enums_Modes_LimitMode_js__WEBPACK_IMPORTED_MODULE_2__.LimitMode.wait:\n if (currentCount >= limit) {\n return;\n }\n break;\n }\n }\n return this._pushParticle(position, overrideOptions, group, initializer);\n }\n clear() {\n this._array = [];\n this._zArray = [];\n this._pluginsInitialized = false;\n }\n destroy() {\n this._array = [];\n this._zArray = [];\n this.movers = [];\n this.updaters = [];\n }\n drawParticles(delta) {\n for (const particle of this._zArray) {\n particle.draw(delta);\n }\n }\n filter(condition) {\n return this._array.filter(condition);\n }\n find(condition) {\n return this._array.find(condition);\n }\n get(index) {\n return this._array[index];\n }\n async init() {\n const container = this._container,\n options = container.actualOptions;\n this._lastZIndex = 0;\n this._needsSort = false;\n for (const plugin of container.plugins) {\n if (plugin.redrawInit) {\n await plugin.redrawInit();\n }\n }\n await this.initPlugins();\n let handled = false;\n for (const plugin of container.plugins) {\n handled = plugin.particlesInitialization?.() ?? handled;\n if (handled) {\n break;\n }\n }\n if (!handled) {\n const particlesOptions = options.particles,\n groups = particlesOptions.groups;\n for (const group in groups) {\n const groupOptions = groups[group];\n if (!groupOptions) {\n continue;\n }\n for (let i = this.count, j = 0; j < groupOptions.number.value && i < particlesOptions.number.value; i++, j++) {\n this.addParticle(undefined, groupOptions, group);\n }\n }\n for (let i = this.count; i < particlesOptions.number.value; i++) {\n this.addParticle();\n }\n }\n }\n async initPlugins() {\n if (this._pluginsInitialized) {\n return;\n }\n const container = this._container;\n this.movers = await this._engine.getMovers(container, true);\n this.updaters = await this._engine.getUpdaters(container, true);\n for (const pathGenerator of container.pathGenerators.values()) {\n pathGenerator.init(container);\n }\n }\n push(nb, position, overrideOptions, group) {\n for (let i = 0; i < nb; i++) {\n this.addParticle(position, overrideOptions, group);\n }\n }\n async redraw() {\n this.clear();\n await this.init();\n this._container.canvas.drawParticles({\n value: 0,\n factor: 0\n });\n }\n remove(particle, group, override) {\n this.removeAt(this._array.indexOf(particle), undefined, group, override);\n }\n removeAt(index, quantity = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.defaultRemoveQuantity, group, override) {\n if (index < _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.minIndex || index > this.count) {\n return;\n }\n let deleted = 0;\n for (let i = index; deleted < quantity && i < this.count; i++) {\n if (this._removeParticle(i, group, override)) {\n i--;\n deleted++;\n }\n }\n }\n removeQuantity(quantity, group) {\n this.removeAt(_Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.minIndex, quantity, group);\n }\n setDensity() {\n const options = this._container.actualOptions,\n groups = options.particles.groups;\n let pluginsCount = 0;\n for (const plugin of this._container.plugins) {\n if (plugin.particlesDensityCount) {\n pluginsCount += plugin.particlesDensityCount();\n }\n }\n for (const group in groups) {\n const groupData = groups[group];\n if (!groupData) {\n continue;\n }\n const groupDataOptions = (0,_Utils_OptionsUtils_js__WEBPACK_IMPORTED_MODULE_8__.loadParticlesOptions)(this._engine, this._container, groupData);\n this._applyDensity(groupDataOptions, pluginsCount, group);\n }\n this._applyDensity(options.particles, pluginsCount);\n }\n setLastZIndex(zIndex) {\n this._lastZIndex = zIndex;\n this._needsSort = this._needsSort || this._lastZIndex < zIndex;\n }\n setResizeFactor(factor) {\n this._resizeFactor = factor;\n }\n update(delta) {\n const container = this._container,\n particlesToDelete = new Set();\n this.quadTree = new _Utils_QuadTree_js__WEBPACK_IMPORTED_MODULE_5__.QuadTree(qTreeRectangle(container.canvas.size), _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.qTreeCapacity);\n for (const pathGenerator of container.pathGenerators.values()) {\n pathGenerator.update();\n }\n for (const plugin of container.plugins) {\n plugin.update?.(delta);\n }\n const resizeFactor = this._resizeFactor;\n for (const particle of this._array) {\n if (resizeFactor && !particle.ignoresResizeRatio) {\n particle.position.x *= resizeFactor.width;\n particle.position.y *= resizeFactor.height;\n particle.initialPosition.x *= resizeFactor.width;\n particle.initialPosition.y *= resizeFactor.height;\n }\n particle.ignoresResizeRatio = false;\n for (const plugin of this._container.plugins) {\n if (plugin.particleReset) {\n plugin.particleReset(particle);\n }\n }\n for (const plugin of this._container.plugins) {\n if (particle.destroyed) {\n break;\n }\n plugin.particleUpdate?.(particle, delta);\n }\n for (const mover of this.movers) {\n if (mover.isEnabled(particle)) {\n mover.move(particle, delta);\n }\n }\n if (particle.destroyed) {\n particlesToDelete.add(particle);\n continue;\n }\n this.quadTree.insert(new _Utils_Point_js__WEBPACK_IMPORTED_MODULE_4__.Point(particle.getPosition(), particle));\n }\n if (particlesToDelete.size) {\n const checkDelete = p => !particlesToDelete.has(p);\n this._array = this.filter(checkDelete);\n this._zArray = this._zArray.filter(checkDelete);\n for (const particle of particlesToDelete) {\n this._engine.dispatchEvent(_Enums_Types_EventType_js__WEBPACK_IMPORTED_MODULE_1__.EventType.particleRemoved, {\n container: this._container,\n data: {\n particle\n }\n });\n }\n this._addToPool(...particlesToDelete);\n }\n for (const plugin of container.plugins) {\n if (plugin.postUpdate) {\n plugin.postUpdate(delta);\n }\n }\n for (const particle of this._array) {\n for (const updater of this.updaters) {\n updater.update(particle, delta);\n }\n if (!particle.destroyed && !particle.spawning) {\n for (const plugin of container.plugins) {\n if (plugin.postParticleUpdate) {\n plugin.postParticleUpdate(particle, delta);\n }\n }\n }\n }\n delete this._resizeFactor;\n if (this._needsSort) {\n const zArray = this._zArray;\n zArray.sort((a, b) => b.position.z - a.position.z || a.id - b.id);\n const lastItem = zArray[zArray.length - _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.lengthOffset];\n if (!lastItem) {\n return;\n }\n this._lastZIndex = lastItem.position.z;\n this._needsSort = false;\n }\n }\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../engine/dist/browser/Core/Particles.js?\n}");
66
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ RenderManager: () => (/* binding */ RenderManager)\n/* harmony export */ });\n/* harmony import */ var _Utils_CanvasUtils_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../Utils/CanvasUtils.js */ \"../../engine/dist/browser/Utils/CanvasUtils.js\");\n/* harmony import */ var _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Utils/Constants.js */ \"../../engine/dist/browser/Core/Utils/Constants.js\");\n/* harmony import */ var _Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../Utils/ColorUtils.js */ \"../../engine/dist/browser/Utils/ColorUtils.js\");\n\n\n\nconst fColorIndex = 0, sColorIndex = 1;\nfunction setTransformValue(factor, newFactor, key) {\n const newValue = newFactor[key];\n if (newValue !== undefined) {\n factor[key] = (factor[key] ?? _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.defaultTransformValue) * newValue;\n }\n}\nclass RenderManager {\n _canvasClearPlugins;\n _canvasManager;\n _canvasPaintPlugins;\n _clearDrawPlugins;\n _colorPlugins;\n _container;\n _context;\n _contextSettings;\n _drawParticlePlugins;\n _drawParticlesCleanupPlugins;\n _drawParticlesSetupPlugins;\n _drawPlugins;\n _drawSettingsCleanupPlugins;\n _drawSettingsSetupPlugins;\n _pluginManager;\n _postDrawUpdaters;\n _preDrawUpdaters;\n _reusableColorStyles = {};\n _reusablePluginColors = [\n undefined,\n undefined\n ];\n _reusableTransform = {};\n constructor(pluginManager, container, canvasManager){\n this._pluginManager = pluginManager;\n this._container = container;\n this._canvasManager = canvasManager;\n this._context = null;\n this._preDrawUpdaters = [];\n this._postDrawUpdaters = [];\n this._colorPlugins = [];\n this._canvasClearPlugins = [];\n this._canvasPaintPlugins = [];\n this._clearDrawPlugins = [];\n this._drawParticlePlugins = [];\n this._drawParticlesCleanupPlugins = [];\n this._drawParticlesSetupPlugins = [];\n this._drawPlugins = [];\n this._drawSettingsSetupPlugins = [];\n this._drawSettingsCleanupPlugins = [];\n }\n get settings() {\n return this._contextSettings;\n }\n canvasClear() {\n if (!this._container.actualOptions.clear) {\n return;\n }\n this.draw((ctx)=>{\n (0,_Utils_CanvasUtils_js__WEBPACK_IMPORTED_MODULE_0__.clear)(ctx, this._canvasManager.size);\n });\n }\n clear() {\n let pluginHandled = false;\n for (const plugin of this._canvasClearPlugins){\n pluginHandled = plugin.canvasClear?.() ?? false;\n if (pluginHandled) {\n break;\n }\n }\n if (pluginHandled) {\n return;\n }\n this.canvasClear();\n }\n destroy() {\n this.stop();\n this._preDrawUpdaters = [];\n this._postDrawUpdaters = [];\n this._colorPlugins = [];\n this._canvasClearPlugins = [];\n this._canvasPaintPlugins = [];\n this._clearDrawPlugins = [];\n this._drawParticlePlugins = [];\n this._drawParticlesCleanupPlugins = [];\n this._drawParticlesSetupPlugins = [];\n this._drawPlugins = [];\n this._drawSettingsSetupPlugins = [];\n this._drawSettingsCleanupPlugins = [];\n }\n draw(cb) {\n const ctx = this._context;\n if (!ctx) {\n return;\n }\n return cb(ctx);\n }\n drawParticle(particle, delta) {\n if (particle.spawning || particle.destroyed) {\n return;\n }\n const radius = particle.getRadius();\n if (radius <= _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.minimumSize) {\n return;\n }\n const pfColor = particle.getFillColor(), psColor = particle.getStrokeColor();\n let [fColor, sColor] = this._getPluginParticleColors(particle);\n fColor ??= pfColor;\n sColor ??= psColor;\n if (!fColor && !sColor) {\n return;\n }\n const container = this._container, zIndexOptions = particle.options.zIndex, zIndexFactor = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.zIndexFactorOffset - particle.zIndexFactor, { fillOpacity, opacity, strokeOpacity } = particle.getOpacity(), transform = this._reusableTransform, colorStyles = this._reusableColorStyles, fill = fColor ? (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_2__.getStyleFromHsl)(fColor, container.hdr, fillOpacity * opacity) : undefined, stroke = sColor ? (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_2__.getStyleFromHsl)(sColor, container.hdr, strokeOpacity * opacity) : fill;\n transform.a = transform.b = transform.c = transform.d = undefined;\n colorStyles.fill = fill;\n colorStyles.stroke = stroke;\n this.draw((context)=>{\n for (const plugin of this._drawParticlesSetupPlugins){\n plugin.drawParticleSetup?.(context, particle, delta);\n }\n this._applyPreDrawUpdaters(context, particle, radius, opacity, colorStyles, transform);\n (0,_Utils_CanvasUtils_js__WEBPACK_IMPORTED_MODULE_0__.drawParticle)({\n container,\n context,\n particle,\n delta,\n colorStyles,\n radius: radius * zIndexFactor ** zIndexOptions.sizeRate,\n opacity: opacity,\n transform\n });\n this._applyPostDrawUpdaters(particle);\n for (const plugin of this._drawParticlesCleanupPlugins){\n plugin.drawParticleCleanup?.(context, particle, delta);\n }\n });\n }\n drawParticlePlugins(particle, delta) {\n this.draw((ctx)=>{\n for (const plugin of this._drawParticlePlugins){\n (0,_Utils_CanvasUtils_js__WEBPACK_IMPORTED_MODULE_0__.drawParticlePlugin)(ctx, plugin, particle, delta);\n }\n });\n }\n drawParticles(delta) {\n const { particles } = this._container;\n this.clear();\n particles.update(delta);\n this.draw((ctx)=>{\n for (const plugin of this._drawSettingsSetupPlugins){\n plugin.drawSettingsSetup?.(ctx, delta);\n }\n for (const plugin of this._drawPlugins){\n plugin.draw?.(ctx, delta);\n }\n particles.drawParticles(delta);\n for (const plugin of this._clearDrawPlugins){\n plugin.clearDraw?.(ctx, delta);\n }\n for (const plugin of this._drawSettingsCleanupPlugins){\n plugin.drawSettingsCleanup?.(ctx, delta);\n }\n });\n }\n init() {\n this.initUpdaters();\n this.initPlugins();\n this.paint();\n }\n initPlugins() {\n this._colorPlugins = [];\n this._canvasClearPlugins = [];\n this._canvasPaintPlugins = [];\n this._clearDrawPlugins = [];\n this._drawParticlePlugins = [];\n this._drawParticlesSetupPlugins = [];\n this._drawParticlesCleanupPlugins = [];\n this._drawPlugins = [];\n this._drawSettingsSetupPlugins = [];\n this._drawSettingsCleanupPlugins = [];\n for (const plugin of this._container.plugins){\n if (plugin.particleFillColor ?? plugin.particleStrokeColor) {\n this._colorPlugins.push(plugin);\n }\n if (plugin.canvasClear) {\n this._canvasClearPlugins.push(plugin);\n }\n if (plugin.canvasPaint) {\n this._canvasPaintPlugins.push(plugin);\n }\n if (plugin.drawParticle) {\n this._drawParticlePlugins.push(plugin);\n }\n if (plugin.drawParticleSetup) {\n this._drawParticlesSetupPlugins.push(plugin);\n }\n if (plugin.drawParticleCleanup) {\n this._drawParticlesCleanupPlugins.push(plugin);\n }\n if (plugin.draw) {\n this._drawPlugins.push(plugin);\n }\n if (plugin.drawSettingsSetup) {\n this._drawSettingsSetupPlugins.push(plugin);\n }\n if (plugin.drawSettingsCleanup) {\n this._drawSettingsCleanupPlugins.push(plugin);\n }\n if (plugin.clearDraw) {\n this._clearDrawPlugins.push(plugin);\n }\n }\n }\n initUpdaters() {\n this._preDrawUpdaters = [];\n this._postDrawUpdaters = [];\n for (const updater of this._container.particleUpdaters){\n if (updater.afterDraw) {\n this._postDrawUpdaters.push(updater);\n }\n if (updater.getColorStyles ?? updater.getTransformValues ?? updater.beforeDraw) {\n this._preDrawUpdaters.push(updater);\n }\n }\n }\n paint() {\n let handled = false;\n for (const plugin of this._canvasPaintPlugins){\n handled = plugin.canvasPaint?.() ?? false;\n if (handled) {\n break;\n }\n }\n if (handled) {\n return;\n }\n this.paintBase();\n }\n paintBase(baseColor) {\n this.draw((ctx)=>{\n (0,_Utils_CanvasUtils_js__WEBPACK_IMPORTED_MODULE_0__.paintBase)(ctx, this._canvasManager.size, baseColor);\n });\n }\n paintImage(image, opacity) {\n this.draw((ctx)=>{\n (0,_Utils_CanvasUtils_js__WEBPACK_IMPORTED_MODULE_0__.paintImage)(ctx, this._canvasManager.size, image, opacity);\n });\n }\n setContext(context) {\n this._context = context;\n if (this._context) {\n this._context.globalCompositeOperation = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_1__.defaultCompositeValue;\n }\n }\n setContextSettings(settings) {\n this._contextSettings = settings;\n }\n stop() {\n this.draw((ctx)=>{\n (0,_Utils_CanvasUtils_js__WEBPACK_IMPORTED_MODULE_0__.clear)(ctx, this._canvasManager.size);\n });\n }\n _applyPostDrawUpdaters = (particle)=>{\n for (const updater of this._postDrawUpdaters){\n updater.afterDraw?.(particle);\n }\n };\n _applyPreDrawUpdaters = (ctx, particle, radius, zOpacity, colorStyles, transform)=>{\n for (const updater of this._preDrawUpdaters){\n if (updater.getColorStyles) {\n const { fill, stroke } = updater.getColorStyles(particle, ctx, radius, zOpacity);\n if (fill) {\n colorStyles.fill = fill;\n }\n if (stroke) {\n colorStyles.stroke = stroke;\n }\n }\n if (updater.getTransformValues) {\n const updaterTransform = updater.getTransformValues(particle);\n for(const key in updaterTransform){\n setTransformValue(transform, updaterTransform, key);\n }\n }\n updater.beforeDraw?.(particle);\n }\n };\n _getPluginParticleColors = (particle)=>{\n let fColor, sColor;\n for (const plugin of this._colorPlugins){\n if (!fColor && plugin.particleFillColor) {\n fColor = (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_2__.rangeColorToHsl)(this._pluginManager, plugin.particleFillColor(particle));\n }\n if (!sColor && plugin.particleStrokeColor) {\n sColor = (0,_Utils_ColorUtils_js__WEBPACK_IMPORTED_MODULE_2__.rangeColorToHsl)(this._pluginManager, plugin.particleStrokeColor(particle));\n }\n if (fColor && sColor) {\n break;\n }\n }\n this._reusablePluginColors[fColorIndex] = fColor;\n this._reusablePluginColors[sColorIndex] = sColor;\n return this._reusablePluginColors;\n };\n}\n\n\n//# sourceURL=webpack://@tsparticles/all/../../engine/dist/browser/Core/RenderManager.js?\n}");
57
67
 
58
68
  /***/ },
59
69
 
@@ -63,7 +73,7 @@ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpa
63
73
  \************************************************/
64
74
  (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
65
75
 
66
- eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Retina: () => (/* binding */ Retina)\n/* harmony export */ });\n/* harmony import */ var _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./Utils/Constants.js */ \"../../engine/dist/browser/Core/Utils/Constants.js\");\n/* harmony import */ var _Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../Utils/MathUtils.js */ \"../../engine/dist/browser/Utils/MathUtils.js\");\n\n\nclass Retina {\n constructor(container) {\n this.container = container;\n this.pixelRatio = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.defaultRatio;\n this.reduceFactor = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.defaultReduceFactor;\n }\n init() {\n const container = this.container,\n options = container.actualOptions;\n this.pixelRatio = options.detectRetina ? devicePixelRatio : _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.defaultRatio;\n this.reduceFactor = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.defaultReduceFactor;\n const ratio = this.pixelRatio,\n canvas = container.canvas;\n if (canvas.element) {\n const element = canvas.element;\n canvas.size.width = element.offsetWidth * ratio;\n canvas.size.height = element.offsetHeight * ratio;\n }\n const particles = options.particles,\n moveOptions = particles.move;\n this.maxSpeed = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getRangeValue)(moveOptions.gravity.maxSpeed) * ratio;\n this.sizeAnimationSpeed = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getRangeValue)(particles.size.animation.speed) * ratio;\n }\n initParticle(particle) {\n const options = particle.options,\n ratio = this.pixelRatio,\n moveOptions = options.move,\n moveDistance = moveOptions.distance,\n props = particle.retina;\n props.moveDrift = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getRangeValue)(moveOptions.drift) * ratio;\n props.moveSpeed = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getRangeValue)(moveOptions.speed) * ratio;\n props.sizeAnimationSpeed = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getRangeValue)(options.size.animation.speed) * ratio;\n const maxDistance = props.maxDistance;\n maxDistance.horizontal = moveDistance.horizontal !== undefined ? moveDistance.horizontal * ratio : undefined;\n maxDistance.vertical = moveDistance.vertical !== undefined ? moveDistance.vertical * ratio : undefined;\n props.maxSpeed = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getRangeValue)(moveOptions.gravity.maxSpeed) * ratio;\n }\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../engine/dist/browser/Core/Retina.js?\n}");
76
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Retina: () => (/* binding */ Retina)\n/* harmony export */ });\n/* harmony import */ var _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./Utils/Constants.js */ \"../../engine/dist/browser/Core/Utils/Constants.js\");\n/* harmony import */ var _Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../Utils/MathUtils.js */ \"../../engine/dist/browser/Utils/MathUtils.js\");\n\n\nclass Retina {\n container;\n pixelRatio;\n reduceFactor;\n constructor(container){\n this.container = container;\n this.pixelRatio = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.defaultRatio;\n this.reduceFactor = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.defaultReduceFactor;\n }\n init() {\n const container = this.container, options = container.actualOptions;\n this.pixelRatio = options.detectRetina ? devicePixelRatio : _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.defaultRatio;\n this.reduceFactor = _Utils_Constants_js__WEBPACK_IMPORTED_MODULE_0__.defaultReduceFactor;\n const ratio = this.pixelRatio, canvas = container.canvas;\n if (canvas.element) {\n const element = canvas.element;\n canvas.size.width = element.offsetWidth * ratio;\n canvas.size.height = element.offsetHeight * ratio;\n }\n }\n initParticle(particle) {\n const options = particle.options, ratio = this.pixelRatio, moveOptions = options.move, moveDistance = moveOptions.distance, props = particle.retina;\n props.maxSpeed = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getRangeValue)(moveOptions.gravity.maxSpeed) * ratio;\n props.moveDrift = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getRangeValue)(moveOptions.drift) * ratio;\n props.moveSpeed = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getRangeValue)(moveOptions.speed) * ratio;\n props.sizeAnimationSpeed = (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_1__.getRangeValue)(options.size.animation.speed) * ratio;\n const maxDistance = props.maxDistance;\n maxDistance.horizontal = moveDistance.horizontal === undefined ? undefined : moveDistance.horizontal * ratio;\n maxDistance.vertical = moveDistance.vertical === undefined ? undefined : moveDistance.vertical * ratio;\n }\n}\n\n\n//# sourceURL=webpack://@tsparticles/all/../../engine/dist/browser/Core/Retina.js?\n}");
67
77
 
68
78
  /***/ },
69
79
 
@@ -73,17 +83,17 @@ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpa
73
83
  \**************************************************************/
74
84
  (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
75
85
 
76
- eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ EventListeners: () => (/* binding */ EventListeners)\n/* harmony export */ });\n/* harmony import */ var _Utils_Utils_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../Utils/Utils.js */ \"../../engine/dist/browser/Utils/Utils.js\");\n/* harmony import */ var _Constants_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Constants.js */ \"../../engine/dist/browser/Core/Utils/Constants.js\");\n\n\nclass EventListeners {\n constructor(container) {\n this.container = container;\n this._handleVisibilityChange = () => {\n const container = this.container,\n options = container.actualOptions;\n if (!options.pauseOnBlur) {\n return;\n }\n if ((0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_0__.safeDocument)().hidden) {\n container.pageHidden = true;\n container.pause();\n } else {\n container.pageHidden = false;\n if (container.animationStatus) {\n container.play(true);\n } else {\n container.draw(true);\n }\n }\n };\n this._handleWindowResize = () => {\n if (this._resizeTimeout) {\n clearTimeout(this._resizeTimeout);\n delete this._resizeTimeout;\n }\n const handleResize = async () => {\n const canvas = this.container.canvas;\n await canvas.windowResize();\n };\n this._resizeTimeout = setTimeout(() => void handleResize(), this.container.actualOptions.resize.delay * _Constants_js__WEBPACK_IMPORTED_MODULE_1__.millisecondsToSeconds);\n };\n this._manageListeners = add => {\n const handlers = this._handlers;\n this._manageResize(add);\n (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_0__.manageListener)(document, _Constants_js__WEBPACK_IMPORTED_MODULE_1__.visibilityChangeEvent, handlers.visibilityChange, add, false);\n };\n this._manageResize = add => {\n const handlers = this._handlers,\n container = this.container,\n options = container.actualOptions;\n if (!options.resize.enable) {\n return;\n }\n if (typeof ResizeObserver === \"undefined\") {\n (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_0__.manageListener)(globalThis, _Constants_js__WEBPACK_IMPORTED_MODULE_1__.resizeEvent, handlers.resize, add);\n return;\n }\n const canvasEl = container.canvas.element;\n if (this._resizeObserver && !add) {\n if (canvasEl) {\n this._resizeObserver.unobserve(canvasEl);\n }\n this._resizeObserver.disconnect();\n delete this._resizeObserver;\n } else if (!this._resizeObserver && add && canvasEl) {\n this._resizeObserver = new ResizeObserver(entries => {\n const entry = entries.find(e => e.target === canvasEl);\n if (!entry) {\n return;\n }\n this._handleWindowResize();\n });\n this._resizeObserver.observe(canvasEl);\n }\n };\n this._handlers = {\n visibilityChange: () => {\n this._handleVisibilityChange();\n },\n resize: () => {\n this._handleWindowResize();\n }\n };\n }\n addListeners() {\n this._manageListeners(true);\n }\n removeListeners() {\n this._manageListeners(false);\n }\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../engine/dist/browser/Core/Utils/EventListeners.js?\n}");
86
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ EventListeners: () => (/* binding */ EventListeners)\n/* harmony export */ });\n/* harmony import */ var _Utils_Utils_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../Utils/Utils.js */ \"../../engine/dist/browser/Utils/Utils.js\");\n/* harmony import */ var _Constants_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Constants.js */ \"../../engine/dist/browser/Core/Utils/Constants.js\");\n\n\nclass EventListeners {\n container;\n _handlers;\n _resizeObserver;\n _resizeTimeout;\n constructor(container){\n this.container = container;\n this._handlers = {\n visibilityChange: ()=>{\n this._handleVisibilityChange();\n },\n resize: ()=>{\n this._handleWindowResize();\n }\n };\n }\n addListeners() {\n this._manageListeners(true);\n }\n removeListeners() {\n this._manageListeners(false);\n }\n _handleVisibilityChange = ()=>{\n const container = this.container, options = container.actualOptions;\n if (!options.pauseOnBlur) {\n return;\n }\n if ((0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_0__.safeDocument)().hidden) {\n container.pageHidden = true;\n container.pause();\n } else {\n container.pageHidden = false;\n if (container.animationStatus) {\n container.play(true);\n } else {\n container.draw(true);\n }\n }\n };\n _handleWindowResize = ()=>{\n if (this._resizeTimeout) {\n clearTimeout(this._resizeTimeout);\n delete this._resizeTimeout;\n }\n const handleResize = async ()=>{\n const canvas = this.container.canvas;\n await canvas.windowResize();\n };\n this._resizeTimeout = setTimeout(()=>void handleResize(), this.container.actualOptions.resize.delay * _Constants_js__WEBPACK_IMPORTED_MODULE_1__.millisecondsToSeconds);\n };\n _manageListeners = (add)=>{\n const handlers = this._handlers;\n this._manageResize(add);\n (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_0__.manageListener)(document, _Constants_js__WEBPACK_IMPORTED_MODULE_1__.visibilityChangeEvent, handlers.visibilityChange, add, false);\n };\n _manageResize = (add)=>{\n const handlers = this._handlers, container = this.container, options = container.actualOptions;\n if (!options.resize.enable) {\n return;\n }\n if (typeof ResizeObserver === \"undefined\") {\n (0,_Utils_Utils_js__WEBPACK_IMPORTED_MODULE_0__.manageListener)(globalThis, _Constants_js__WEBPACK_IMPORTED_MODULE_1__.resizeEvent, handlers.resize, add);\n return;\n }\n const canvasEl = container.canvas.element;\n if (this._resizeObserver && !add) {\n if (canvasEl) {\n this._resizeObserver.unobserve(canvasEl);\n }\n this._resizeObserver.disconnect();\n delete this._resizeObserver;\n } else if (!this._resizeObserver && add && canvasEl) {\n this._resizeObserver = new ResizeObserver((entries)=>{\n const entry = entries.find((e)=>e.target === canvasEl);\n if (!entry) {\n return;\n }\n this._handleWindowResize();\n });\n this._resizeObserver.observe(canvasEl);\n }\n };\n}\n\n\n//# sourceURL=webpack://@tsparticles/all/../../engine/dist/browser/Core/Utils/EventListeners.js?\n}");
77
87
 
78
88
  /***/ },
79
89
 
80
- /***/ "../../engine/dist/browser/Core/Utils/QuadTree.js"
81
- /*!********************************************************!*\
82
- !*** ../../engine/dist/browser/Core/Utils/QuadTree.js ***!
83
- \********************************************************/
90
+ /***/ "../../engine/dist/browser/Core/Utils/SpatialHashGrid.js"
91
+ /*!***************************************************************!*\
92
+ !*** ../../engine/dist/browser/Core/Utils/SpatialHashGrid.js ***!
93
+ \***************************************************************/
84
94
  (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
85
95
 
86
- eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ QuadTree: () => (/* binding */ QuadTree)\n/* harmony export */ });\n/* harmony import */ var _Ranges_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./Ranges.js */ \"../../engine/dist/browser/Core/Utils/Ranges.js\");\n/* harmony import */ var _Constants_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Constants.js */ \"../../engine/dist/browser/Core/Utils/Constants.js\");\n/* harmony import */ var _Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../Utils/MathUtils.js */ \"../../engine/dist/browser/Utils/MathUtils.js\");\n\n\n\nclass QuadTree {\n constructor(rectangle, capacity) {\n this.rectangle = rectangle;\n this.capacity = capacity;\n this._subdivide = () => {\n const {\n x,\n y\n } = this.rectangle.position,\n {\n width,\n height\n } = this.rectangle.size,\n {\n capacity\n } = this;\n for (let i = 0; i < _Constants_js__WEBPACK_IMPORTED_MODULE_1__.subdivideCount; i++) {\n const fixedIndex = i % _Constants_js__WEBPACK_IMPORTED_MODULE_1__.double;\n this._subs.push(new QuadTree(new _Ranges_js__WEBPACK_IMPORTED_MODULE_0__.Rectangle(x + width * _Constants_js__WEBPACK_IMPORTED_MODULE_1__.half * fixedIndex, y + height * _Constants_js__WEBPACK_IMPORTED_MODULE_1__.half * (Math.round(i * _Constants_js__WEBPACK_IMPORTED_MODULE_1__.half) - fixedIndex), width * _Constants_js__WEBPACK_IMPORTED_MODULE_1__.half, height * _Constants_js__WEBPACK_IMPORTED_MODULE_1__.half), capacity));\n }\n this._divided = true;\n };\n this._points = [];\n this._divided = false;\n this._subs = [];\n }\n insert(point) {\n if (!this.rectangle.contains(point.position)) {\n return false;\n }\n if (this._points.length < this.capacity) {\n this._points.push(point);\n return true;\n }\n if (!this._divided) {\n this._subdivide();\n }\n return this._subs.some(sub => sub.insert(point));\n }\n query(range, check) {\n const res = [];\n if (!range.intersects(this.rectangle)) {\n return [];\n }\n for (const p of this._points) {\n if (!range.contains(p.position) && (0,_Utils_MathUtils_js__WEBPACK_IMPORTED_MODULE_2__.getDistance)(range.position, p.position) > p.particle.getRadius() && (!check || check(p.particle))) {\n continue;\n }\n res.push(p.particle);\n }\n if (this._divided) {\n for (const sub of this._subs) {\n res.push(...sub.query(range, check));\n }\n }\n return res;\n }\n queryCircle(position, radius, check) {\n return this.query(new _Ranges_js__WEBPACK_IMPORTED_MODULE_0__.Circle(position.x, position.y, radius), check);\n }\n queryRectangle(position, size, check) {\n return this.query(new _Ranges_js__WEBPACK_IMPORTED_MODULE_0__.Rectangle(position.x, position.y, size.width, size.height), check);\n }\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../engine/dist/browser/Core/Utils/QuadTree.js?\n}");
96
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ SpatialHashGrid: () => (/* binding */ SpatialHashGrid)\n/* harmony export */ });\n/* harmony import */ var _Ranges_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./Ranges.js */ \"../../engine/dist/browser/Core/Utils/Ranges.js\");\n\nclass SpatialHashGrid {\n _cellSize;\n _cells = new Map();\n _circlePool = [];\n _circlePoolIdx;\n _pendingCellSize;\n _rectanglePool = [];\n _rectanglePoolIdx;\n constructor(cellSize){\n this._cellSize = cellSize;\n this._circlePoolIdx = 0;\n this._rectanglePoolIdx = 0;\n }\n clear() {\n this._cells.clear();\n const pendingCellSize = this._pendingCellSize;\n if (pendingCellSize) {\n this._cellSize = pendingCellSize;\n }\n this._pendingCellSize = undefined;\n }\n insert(particle) {\n const { x, y } = particle.getPosition(), key = this._cellKeyFromCoords(x, y);\n if (!this._cells.has(key)) {\n this._cells.set(key, []);\n }\n this._cells.get(key)?.push(particle);\n }\n query(range, check, out = []) {\n const bounds = this._getRangeBounds(range);\n if (!bounds) {\n return out;\n }\n const minCellX = Math.floor(bounds.minX / this._cellSize), maxCellX = Math.floor(bounds.maxX / this._cellSize), minCellY = Math.floor(bounds.minY / this._cellSize), maxCellY = Math.floor(bounds.maxY / this._cellSize);\n for(let cx = minCellX; cx <= maxCellX; cx++){\n for(let cy = minCellY; cy <= maxCellY; cy++){\n const key = `${cx}_${cy}`, cellParticles = this._cells.get(key);\n if (!cellParticles) {\n continue;\n }\n for (const p of cellParticles){\n if (check && !check(p)) {\n continue;\n }\n if (range.contains(p.getPosition())) {\n out.push(p);\n }\n }\n }\n }\n return out;\n }\n queryCircle(position, radius, check, out = []) {\n const circle = this._acquireCircle(position.x, position.y, radius), result = this.query(circle, check, out);\n this._releaseShapes();\n return result;\n }\n queryRectangle(position, size, check, out = []) {\n const rect = this._acquireRectangle(position.x, position.y, size.width, size.height), result = this.query(rect, check, out);\n this._releaseShapes();\n return result;\n }\n setCellSize(cellSize) {\n this._pendingCellSize = cellSize;\n }\n _acquireCircle(x, y, r) {\n return (this._circlePool[this._circlePoolIdx++] ??= new _Ranges_js__WEBPACK_IMPORTED_MODULE_0__.Circle(x, y, r)).reset(x, y, r);\n }\n _acquireRectangle(x, y, w, h) {\n return (this._rectanglePool[this._rectanglePoolIdx++] ??= new _Ranges_js__WEBPACK_IMPORTED_MODULE_0__.Rectangle(x, y, w, h)).reset(x, y, w, h);\n }\n _cellKeyFromCoords(x, y) {\n const cellX = Math.floor(x / this._cellSize), cellY = Math.floor(y / this._cellSize);\n return `${cellX}_${cellY}`;\n }\n _getRangeBounds(range) {\n if (range instanceof _Ranges_js__WEBPACK_IMPORTED_MODULE_0__.Circle) {\n const r = range.radius, { x, y } = range.position;\n return {\n minX: x - r,\n maxX: x + r,\n minY: y - r,\n maxY: y + r\n };\n }\n if (range instanceof _Ranges_js__WEBPACK_IMPORTED_MODULE_0__.Rectangle) {\n const { x, y } = range.position, { width, height } = range.size;\n return {\n minX: x,\n maxX: x + width,\n minY: y,\n maxY: y + height\n };\n }\n return null;\n }\n _releaseShapes() {\n this._circlePoolIdx = 0;\n this._rectanglePoolIdx = 0;\n }\n}\n\n\n//# sourceURL=webpack://@tsparticles/all/../../engine/dist/browser/Core/Utils/SpatialHashGrid.js?\n}");
87
97
 
88
98
  /***/ }
89
99
 
package/esm/bundle.js CHANGED
@@ -1,3 +1,2 @@
1
- import { loadAll } from "./index.js";
2
- export { loadAll };
3
1
  export * from "@tsparticles/engine";
2
+ export { loadAll } from "./index.js";