@tsparticles/all 3.9.1 → 4.0.0-alpha.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (653) hide show
  1. package/1013.min.js +2 -0
  2. package/1013.min.js.LICENSE.txt +1 -0
  3. package/1080.min.js +2 -0
  4. package/1080.min.js.LICENSE.txt +1 -0
  5. package/1081.min.js +2 -0
  6. package/1081.min.js.LICENSE.txt +1 -0
  7. package/1143.min.js +2 -0
  8. package/1143.min.js.LICENSE.txt +1 -0
  9. package/1392.min.js +2 -0
  10. package/1392.min.js.LICENSE.txt +1 -0
  11. package/1406.min.js +2 -0
  12. package/1406.min.js.LICENSE.txt +1 -0
  13. package/1581.min.js +2 -0
  14. package/1581.min.js.LICENSE.txt +1 -0
  15. package/1761.min.js +2 -0
  16. package/1761.min.js.LICENSE.txt +1 -0
  17. package/1816.min.js +2 -0
  18. package/1816.min.js.LICENSE.txt +1 -0
  19. package/1842.min.js +2 -0
  20. package/1842.min.js.LICENSE.txt +1 -0
  21. package/1866.min.js +2 -0
  22. package/1866.min.js.LICENSE.txt +1 -0
  23. package/1872.min.js +2 -0
  24. package/1872.min.js.LICENSE.txt +1 -0
  25. package/1878.min.js +2 -0
  26. package/1878.min.js.LICENSE.txt +1 -0
  27. package/1887.min.js +2 -0
  28. package/1887.min.js.LICENSE.txt +1 -0
  29. package/1916.min.js +2 -0
  30. package/1916.min.js.LICENSE.txt +1 -0
  31. package/198.min.js +2 -0
  32. package/198.min.js.LICENSE.txt +1 -0
  33. package/201.min.js +2 -0
  34. package/201.min.js.LICENSE.txt +1 -0
  35. package/2058.min.js +2 -0
  36. package/2058.min.js.LICENSE.txt +1 -0
  37. package/2124.min.js +2 -0
  38. package/2124.min.js.LICENSE.txt +1 -0
  39. package/2126.min.js +2 -0
  40. package/2126.min.js.LICENSE.txt +1 -0
  41. package/2142.min.js +2 -0
  42. package/2142.min.js.LICENSE.txt +1 -0
  43. package/2164.min.js +2 -0
  44. package/2164.min.js.LICENSE.txt +1 -0
  45. package/2175.min.js +2 -0
  46. package/2175.min.js.LICENSE.txt +1 -0
  47. package/2201.min.js +2 -0
  48. package/2201.min.js.LICENSE.txt +1 -0
  49. package/2243.min.js +2 -0
  50. package/2243.min.js.LICENSE.txt +1 -0
  51. package/2264.min.js +2 -0
  52. package/2264.min.js.LICENSE.txt +1 -0
  53. package/2370.min.js +2 -0
  54. package/2370.min.js.LICENSE.txt +1 -0
  55. package/2399.min.js +2 -0
  56. package/2399.min.js.LICENSE.txt +1 -0
  57. package/2422.min.js +2 -0
  58. package/2422.min.js.LICENSE.txt +1 -0
  59. package/2534.min.js +2 -0
  60. package/2534.min.js.LICENSE.txt +1 -0
  61. package/2554.min.js +2 -0
  62. package/2554.min.js.LICENSE.txt +1 -0
  63. package/2572.min.js +2 -0
  64. package/2572.min.js.LICENSE.txt +1 -0
  65. package/262.min.js +2 -0
  66. package/262.min.js.LICENSE.txt +1 -0
  67. package/2636.min.js +2 -0
  68. package/2636.min.js.LICENSE.txt +1 -0
  69. package/2739.min.js +2 -0
  70. package/2739.min.js.LICENSE.txt +1 -0
  71. package/2745.min.js +2 -0
  72. package/2745.min.js.LICENSE.txt +1 -0
  73. package/276.min.js +2 -0
  74. package/276.min.js.LICENSE.txt +1 -0
  75. package/2819.min.js +2 -0
  76. package/2819.min.js.LICENSE.txt +1 -0
  77. package/2885.min.js +2 -0
  78. package/2885.min.js.LICENSE.txt +1 -0
  79. package/29.min.js +2 -0
  80. package/29.min.js.LICENSE.txt +1 -0
  81. package/2953.min.js +2 -0
  82. package/2953.min.js.LICENSE.txt +1 -0
  83. package/3017.min.js +2 -0
  84. package/3017.min.js.LICENSE.txt +1 -0
  85. package/303.min.js +2 -0
  86. package/303.min.js.LICENSE.txt +1 -0
  87. package/3089.min.js +2 -0
  88. package/3089.min.js.LICENSE.txt +1 -0
  89. package/3101.min.js +2 -0
  90. package/3101.min.js.LICENSE.txt +1 -0
  91. package/3156.min.js +2 -0
  92. package/3156.min.js.LICENSE.txt +1 -0
  93. package/3206.min.js +2 -0
  94. package/3206.min.js.LICENSE.txt +1 -0
  95. package/3214.min.js +2 -0
  96. package/3214.min.js.LICENSE.txt +1 -0
  97. package/3225.min.js +2 -0
  98. package/3225.min.js.LICENSE.txt +1 -0
  99. package/3241.min.js +2 -0
  100. package/3241.min.js.LICENSE.txt +1 -0
  101. package/3289.min.js +2 -0
  102. package/3289.min.js.LICENSE.txt +1 -0
  103. package/3309.min.js +2 -0
  104. package/3309.min.js.LICENSE.txt +1 -0
  105. package/3435.min.js +2 -0
  106. package/3435.min.js.LICENSE.txt +1 -0
  107. package/3465.min.js +2 -0
  108. package/3465.min.js.LICENSE.txt +1 -0
  109. package/3493.min.js +2 -0
  110. package/3493.min.js.LICENSE.txt +1 -0
  111. package/350.min.js +2 -0
  112. package/350.min.js.LICENSE.txt +1 -0
  113. package/3522.min.js +2 -0
  114. package/3522.min.js.LICENSE.txt +1 -0
  115. package/3561.min.js +2 -0
  116. package/3561.min.js.LICENSE.txt +1 -0
  117. package/3595.min.js +2 -0
  118. package/3595.min.js.LICENSE.txt +1 -0
  119. package/3636.min.js +2 -0
  120. package/3636.min.js.LICENSE.txt +1 -0
  121. package/3658.min.js +2 -0
  122. package/3658.min.js.LICENSE.txt +1 -0
  123. package/368.min.js +2 -0
  124. package/368.min.js.LICENSE.txt +1 -0
  125. package/3710.min.js +2 -0
  126. package/3710.min.js.LICENSE.txt +1 -0
  127. package/3753.min.js +2 -0
  128. package/3753.min.js.LICENSE.txt +1 -0
  129. package/3809.min.js +2 -0
  130. package/3809.min.js.LICENSE.txt +1 -0
  131. package/3828.min.js +2 -0
  132. package/3828.min.js.LICENSE.txt +1 -0
  133. package/3853.min.js +2 -0
  134. package/3853.min.js.LICENSE.txt +1 -0
  135. package/3872.min.js +2 -0
  136. package/3872.min.js.LICENSE.txt +1 -0
  137. package/3897.min.js +2 -0
  138. package/3897.min.js.LICENSE.txt +1 -0
  139. package/3920.min.js +2 -0
  140. package/3920.min.js.LICENSE.txt +1 -0
  141. package/3922.min.js +2 -0
  142. package/3922.min.js.LICENSE.txt +1 -0
  143. package/404.min.js +2 -0
  144. package/404.min.js.LICENSE.txt +1 -0
  145. package/408.min.js +2 -0
  146. package/408.min.js.LICENSE.txt +1 -0
  147. package/41.min.js +2 -0
  148. package/41.min.js.LICENSE.txt +1 -0
  149. package/4125.min.js +2 -0
  150. package/4125.min.js.LICENSE.txt +1 -0
  151. package/4159.min.js +2 -0
  152. package/4159.min.js.LICENSE.txt +1 -0
  153. package/4204.min.js +2 -0
  154. package/4204.min.js.LICENSE.txt +1 -0
  155. package/4231.min.js +2 -0
  156. package/4231.min.js.LICENSE.txt +1 -0
  157. package/4242.min.js +2 -0
  158. package/4242.min.js.LICENSE.txt +1 -0
  159. package/4339.min.js +2 -0
  160. package/4339.min.js.LICENSE.txt +1 -0
  161. package/4398.min.js +2 -0
  162. package/4398.min.js.LICENSE.txt +1 -0
  163. package/4469.min.js +2 -0
  164. package/4469.min.js.LICENSE.txt +1 -0
  165. package/4482.min.js +2 -0
  166. package/4482.min.js.LICENSE.txt +1 -0
  167. package/4493.min.js +2 -0
  168. package/4493.min.js.LICENSE.txt +1 -0
  169. package/4510.min.js +2 -0
  170. package/4510.min.js.LICENSE.txt +1 -0
  171. package/4565.min.js +2 -0
  172. package/4565.min.js.LICENSE.txt +1 -0
  173. package/458.min.js +2 -0
  174. package/458.min.js.LICENSE.txt +1 -0
  175. package/4606.min.js +2 -0
  176. package/4606.min.js.LICENSE.txt +1 -0
  177. package/4620.min.js +2 -0
  178. package/4620.min.js.LICENSE.txt +1 -0
  179. package/4688.min.js +2 -0
  180. package/4688.min.js.LICENSE.txt +1 -0
  181. package/4717.min.js +2 -0
  182. package/4717.min.js.LICENSE.txt +1 -0
  183. package/4743.min.js +2 -0
  184. package/4743.min.js.LICENSE.txt +1 -0
  185. package/4817.min.js +2 -0
  186. package/4817.min.js.LICENSE.txt +1 -0
  187. package/4894.min.js +2 -0
  188. package/4894.min.js.LICENSE.txt +1 -0
  189. package/491.min.js +2 -0
  190. package/491.min.js.LICENSE.txt +1 -0
  191. package/4915.min.js +2 -0
  192. package/4915.min.js.LICENSE.txt +1 -0
  193. package/508.min.js +2 -0
  194. package/508.min.js.LICENSE.txt +1 -0
  195. package/5082.min.js +2 -0
  196. package/5082.min.js.LICENSE.txt +1 -0
  197. package/5090.min.js +2 -0
  198. package/5090.min.js.LICENSE.txt +1 -0
  199. package/5169.min.js +2 -0
  200. package/5169.min.js.LICENSE.txt +1 -0
  201. package/5187.min.js +2 -0
  202. package/5187.min.js.LICENSE.txt +1 -0
  203. package/5202.min.js +2 -0
  204. package/5202.min.js.LICENSE.txt +1 -0
  205. package/5226.min.js +2 -0
  206. package/5226.min.js.LICENSE.txt +1 -0
  207. package/5243.min.js +2 -0
  208. package/5243.min.js.LICENSE.txt +1 -0
  209. package/5322.min.js +2 -0
  210. package/5322.min.js.LICENSE.txt +1 -0
  211. package/5367.min.js +2 -0
  212. package/5367.min.js.LICENSE.txt +1 -0
  213. package/5433.min.js +2 -0
  214. package/5433.min.js.LICENSE.txt +1 -0
  215. package/5504.min.js +2 -0
  216. package/5504.min.js.LICENSE.txt +1 -0
  217. package/5563.min.js +2 -0
  218. package/5563.min.js.LICENSE.txt +1 -0
  219. package/5627.min.js +2 -0
  220. package/5627.min.js.LICENSE.txt +1 -0
  221. package/5635.min.js +2 -0
  222. package/5635.min.js.LICENSE.txt +1 -0
  223. package/5689.min.js +2 -0
  224. package/5689.min.js.LICENSE.txt +1 -0
  225. package/5693.min.js +2 -0
  226. package/5693.min.js.LICENSE.txt +1 -0
  227. package/5711.min.js +2 -0
  228. package/5711.min.js.LICENSE.txt +1 -0
  229. package/5713.min.js +2 -0
  230. package/5713.min.js.LICENSE.txt +1 -0
  231. package/5727.min.js +2 -0
  232. package/5727.min.js.LICENSE.txt +1 -0
  233. package/5728.min.js +2 -0
  234. package/5728.min.js.LICENSE.txt +1 -0
  235. package/5749.min.js +2 -0
  236. package/5749.min.js.LICENSE.txt +1 -0
  237. package/5770.min.js +2 -0
  238. package/5770.min.js.LICENSE.txt +1 -0
  239. package/582.min.js +2 -0
  240. package/582.min.js.LICENSE.txt +1 -0
  241. package/5849.min.js +2 -0
  242. package/5849.min.js.LICENSE.txt +1 -0
  243. package/5885.min.js +2 -0
  244. package/5885.min.js.LICENSE.txt +1 -0
  245. package/5898.min.js +2 -0
  246. package/5898.min.js.LICENSE.txt +1 -0
  247. package/590.min.js +2 -0
  248. package/590.min.js.LICENSE.txt +1 -0
  249. package/5917.min.js +2 -0
  250. package/5917.min.js.LICENSE.txt +1 -0
  251. package/6024.min.js +2 -0
  252. package/6024.min.js.LICENSE.txt +1 -0
  253. package/6137.min.js +2 -0
  254. package/6137.min.js.LICENSE.txt +1 -0
  255. package/617.min.js +2 -0
  256. package/617.min.js.LICENSE.txt +1 -0
  257. package/6203.min.js +2 -0
  258. package/6203.min.js.LICENSE.txt +1 -0
  259. package/6284.min.js +2 -0
  260. package/6284.min.js.LICENSE.txt +1 -0
  261. package/6314.min.js +2 -0
  262. package/6314.min.js.LICENSE.txt +1 -0
  263. package/6315.min.js +2 -0
  264. package/6315.min.js.LICENSE.txt +1 -0
  265. package/6408.min.js +2 -0
  266. package/6408.min.js.LICENSE.txt +1 -0
  267. package/6416.min.js +2 -0
  268. package/6416.min.js.LICENSE.txt +1 -0
  269. package/6434.min.js +2 -0
  270. package/6434.min.js.LICENSE.txt +1 -0
  271. package/6528.min.js +2 -0
  272. package/6528.min.js.LICENSE.txt +1 -0
  273. package/6560.min.js +2 -0
  274. package/6560.min.js.LICENSE.txt +1 -0
  275. package/6573.min.js +2 -0
  276. package/6573.min.js.LICENSE.txt +1 -0
  277. package/6606.min.js +2 -0
  278. package/6606.min.js.LICENSE.txt +1 -0
  279. package/6625.min.js +2 -0
  280. package/6625.min.js.LICENSE.txt +1 -0
  281. package/6660.min.js +2 -0
  282. package/6660.min.js.LICENSE.txt +1 -0
  283. package/6674.min.js +2 -0
  284. package/6674.min.js.LICENSE.txt +1 -0
  285. package/6687.min.js +2 -0
  286. package/6687.min.js.LICENSE.txt +1 -0
  287. package/669.min.js +2 -0
  288. package/669.min.js.LICENSE.txt +1 -0
  289. package/6848.min.js +2 -0
  290. package/6848.min.js.LICENSE.txt +1 -0
  291. package/6866.min.js +2 -0
  292. package/6866.min.js.LICENSE.txt +1 -0
  293. package/7009.min.js +2 -0
  294. package/7009.min.js.LICENSE.txt +1 -0
  295. package/704.min.js +2 -0
  296. package/704.min.js.LICENSE.txt +1 -0
  297. package/7094.min.js +2 -0
  298. package/7094.min.js.LICENSE.txt +1 -0
  299. package/7146.min.js +2 -0
  300. package/7146.min.js.LICENSE.txt +1 -0
  301. package/7152.min.js +2 -0
  302. package/7152.min.js.LICENSE.txt +1 -0
  303. package/7278.min.js +2 -0
  304. package/7278.min.js.LICENSE.txt +1 -0
  305. package/7281.min.js +2 -0
  306. package/7281.min.js.LICENSE.txt +1 -0
  307. package/731.min.js +2 -0
  308. package/731.min.js.LICENSE.txt +1 -0
  309. package/7321.min.js +2 -0
  310. package/7321.min.js.LICENSE.txt +1 -0
  311. package/7342.min.js +2 -0
  312. package/7342.min.js.LICENSE.txt +1 -0
  313. package/7358.min.js +2 -0
  314. package/7358.min.js.LICENSE.txt +1 -0
  315. package/7406.min.js +2 -0
  316. package/7406.min.js.LICENSE.txt +1 -0
  317. package/7426.min.js +2 -0
  318. package/7426.min.js.LICENSE.txt +1 -0
  319. package/745.min.js +2 -0
  320. package/745.min.js.LICENSE.txt +1 -0
  321. package/7485.min.js +2 -0
  322. package/7485.min.js.LICENSE.txt +1 -0
  323. package/7489.min.js +2 -0
  324. package/7489.min.js.LICENSE.txt +1 -0
  325. package/7571.min.js +2 -0
  326. package/7571.min.js.LICENSE.txt +1 -0
  327. package/7586.min.js +2 -0
  328. package/7586.min.js.LICENSE.txt +1 -0
  329. package/7679.min.js +2 -0
  330. package/7679.min.js.LICENSE.txt +1 -0
  331. package/774.min.js +2 -0
  332. package/774.min.js.LICENSE.txt +1 -0
  333. package/7753.min.js +2 -0
  334. package/7753.min.js.LICENSE.txt +1 -0
  335. package/7839.min.js +2 -0
  336. package/7839.min.js.LICENSE.txt +1 -0
  337. package/7962.min.js +2 -0
  338. package/7962.min.js.LICENSE.txt +1 -0
  339. package/7998.min.js +2 -0
  340. package/7998.min.js.LICENSE.txt +1 -0
  341. package/8127.min.js +2 -0
  342. package/8127.min.js.LICENSE.txt +1 -0
  343. package/8182.min.js +2 -0
  344. package/8182.min.js.LICENSE.txt +1 -0
  345. package/8191.min.js +2 -0
  346. package/8191.min.js.LICENSE.txt +1 -0
  347. package/8204.min.js +2 -0
  348. package/8204.min.js.LICENSE.txt +1 -0
  349. package/8230.min.js +2 -0
  350. package/8230.min.js.LICENSE.txt +1 -0
  351. package/8245.min.js +2 -0
  352. package/8245.min.js.LICENSE.txt +1 -0
  353. package/8365.min.js +2 -0
  354. package/8365.min.js.LICENSE.txt +1 -0
  355. package/8404.min.js +2 -0
  356. package/8404.min.js.LICENSE.txt +1 -0
  357. package/8420.min.js +2 -0
  358. package/8420.min.js.LICENSE.txt +1 -0
  359. package/8440.min.js +2 -0
  360. package/8440.min.js.LICENSE.txt +1 -0
  361. package/8457.min.js +2 -0
  362. package/8457.min.js.LICENSE.txt +1 -0
  363. package/8470.min.js +2 -0
  364. package/8470.min.js.LICENSE.txt +1 -0
  365. package/8484.min.js +2 -0
  366. package/8484.min.js.LICENSE.txt +1 -0
  367. package/8520.min.js +2 -0
  368. package/8520.min.js.LICENSE.txt +1 -0
  369. package/8582.min.js +2 -0
  370. package/8582.min.js.LICENSE.txt +1 -0
  371. package/869.min.js +2 -0
  372. package/869.min.js.LICENSE.txt +1 -0
  373. package/8770.min.js +2 -0
  374. package/8770.min.js.LICENSE.txt +1 -0
  375. package/8848.min.js +2 -0
  376. package/8848.min.js.LICENSE.txt +1 -0
  377. package/8926.min.js +2 -0
  378. package/8926.min.js.LICENSE.txt +1 -0
  379. package/8930.min.js +2 -0
  380. package/8930.min.js.LICENSE.txt +1 -0
  381. package/8952.min.js +2 -0
  382. package/8952.min.js.LICENSE.txt +1 -0
  383. package/9076.min.js +2 -0
  384. package/9076.min.js.LICENSE.txt +1 -0
  385. package/9095.min.js +2 -0
  386. package/9095.min.js.LICENSE.txt +1 -0
  387. package/91.min.js +2 -0
  388. package/91.min.js.LICENSE.txt +1 -0
  389. package/9113.min.js +2 -0
  390. package/9113.min.js.LICENSE.txt +1 -0
  391. package/9149.min.js +2 -0
  392. package/9149.min.js.LICENSE.txt +1 -0
  393. package/917.min.js +2 -0
  394. package/917.min.js.LICENSE.txt +1 -0
  395. package/9213.min.js +2 -0
  396. package/9213.min.js.LICENSE.txt +1 -0
  397. package/9234.min.js +2 -0
  398. package/9234.min.js.LICENSE.txt +1 -0
  399. package/9287.min.js +2 -0
  400. package/9287.min.js.LICENSE.txt +1 -0
  401. package/9312.min.js +2 -0
  402. package/9312.min.js.LICENSE.txt +1 -0
  403. package/9438.min.js +2 -0
  404. package/9438.min.js.LICENSE.txt +1 -0
  405. package/9475.min.js +2 -0
  406. package/9475.min.js.LICENSE.txt +1 -0
  407. package/9648.min.js +2 -0
  408. package/9648.min.js.LICENSE.txt +1 -0
  409. package/9754.min.js +2 -0
  410. package/9754.min.js.LICENSE.txt +1 -0
  411. package/9825.min.js +2 -0
  412. package/9825.min.js.LICENSE.txt +1 -0
  413. package/986.min.js +2 -0
  414. package/986.min.js.LICENSE.txt +1 -0
  415. package/9907.min.js +2 -0
  416. package/9907.min.js.LICENSE.txt +1 -0
  417. package/9915.min.js +2 -0
  418. package/9915.min.js.LICENSE.txt +1 -0
  419. package/9944.min.js +2 -0
  420. package/9944.min.js.LICENSE.txt +1 -0
  421. package/9950.min.js +2 -0
  422. package/9950.min.js.LICENSE.txt +1 -0
  423. package/9965.min.js +2 -0
  424. package/9965.min.js.LICENSE.txt +1 -0
  425. package/9966.min.js +2 -0
  426. package/9966.min.js.LICENSE.txt +1 -0
  427. package/basic_dist_browser_index_js.js +30 -0
  428. package/browser/bundle.js +1 -1
  429. package/browser/index.js +62 -103
  430. package/cjs/bundle.js +3 -20
  431. package/cjs/index.js +62 -106
  432. package/effects_bubble_dist_browser_BubbleDrawer_js.js +30 -0
  433. package/effects_bubble_dist_browser_index_js.js +30 -0
  434. package/effects_shadow_dist_browser_ShadowDrawer_js.js +30 -0
  435. package/effects_shadow_dist_browser_index_js.js +30 -0
  436. package/effects_trail_dist_browser_TrailDrawer_js.js +30 -0
  437. package/effects_trail_dist_browser_index_js.js +30 -0
  438. package/engine_dist_browser_Core_Container_js.js +100 -0
  439. package/esm/bundle.js +1 -1
  440. package/esm/index.js +62 -103
  441. package/full_dist_browser_index_js.js +30 -0
  442. package/interactions_external_attract_dist_browser_Attractor_js.js +40 -0
  443. package/interactions_external_attract_dist_browser_index_js.js +40 -0
  444. package/interactions_external_bounce_dist_browser_Bouncer_js.js +40 -0
  445. package/interactions_external_bounce_dist_browser_index_js.js +40 -0
  446. package/interactions_external_bubble_dist_browser_Bubbler_js.js +50 -0
  447. package/interactions_external_bubble_dist_browser_index_js.js +60 -0
  448. package/interactions_external_connect_dist_browser_Connector_js.js +40 -0
  449. package/interactions_external_connect_dist_browser_index_js.js +50 -0
  450. package/interactions_external_grab_dist_browser_Grabber_js.js +40 -0
  451. package/interactions_external_grab_dist_browser_index_js.js +50 -0
  452. package/interactions_external_particle_dist_browser_InteractivityParticleMaker_js.js +40 -0
  453. package/interactions_external_particle_dist_browser_index_js.js +30 -0
  454. package/interactions_external_pause_dist_browser_Pauser_js.js +30 -0
  455. package/interactions_external_pause_dist_browser_index_js.js +30 -0
  456. package/interactions_external_pop_dist_browser_Popper_js.js +30 -0
  457. package/interactions_external_pop_dist_browser_index_js.js +30 -0
  458. package/interactions_external_push_dist_browser_Pusher_js.js +30 -0
  459. package/interactions_external_push_dist_browser_index_js.js +40 -0
  460. package/interactions_external_remove_dist_browser_Remover_js.js +30 -0
  461. package/interactions_external_remove_dist_browser_index_js.js +40 -0
  462. package/interactions_external_repulse_dist_browser_Repulser_js.js +30 -0
  463. package/interactions_external_repulse_dist_browser_index_js.js +60 -0
  464. package/interactions_external_slow_dist_browser_Slower_js.js +30 -0
  465. package/interactions_external_slow_dist_browser_index_js.js +40 -0
  466. package/interactions_external_trail_dist_browser_TrailMaker_js.js +30 -0
  467. package/interactions_external_trail_dist_browser_index_js.js +40 -0
  468. package/interactions_light_dist_browser_ExternalLighter_js.js +40 -0
  469. package/interactions_light_dist_browser_ParticlesLighter_js.js +40 -0
  470. package/interactions_light_dist_browser_index_js.js +70 -0
  471. package/interactions_particles_attract_dist_browser_Attractor_js.js +30 -0
  472. package/interactions_particles_attract_dist_browser_index_js.js +30 -0
  473. package/interactions_particles_collisions_dist_browser_Collider_js.js +110 -0
  474. package/interactions_particles_collisions_dist_browser_OverlapPlugin_js.js +40 -0
  475. package/interactions_particles_collisions_dist_browser_index_js.js +30 -0
  476. package/interactions_particles_links_dist_browser_Linker_js.js +40 -0
  477. package/interactions_particles_links_dist_browser_LinksPlugin_js.js +50 -0
  478. package/interactions_particles_links_dist_browser_index_js.js +60 -0
  479. package/interactions_particles_links_dist_browser_interaction_js.js +30 -0
  480. package/interactions_particles_links_dist_browser_plugin_js.js +30 -0
  481. package/interactions_particles_repulse_dist_browser_Repulser_js.js +40 -0
  482. package/interactions_particles_repulse_dist_browser_index_js.js +30 -0
  483. package/move_base_dist_browser_BaseMover_js.js +40 -0
  484. package/move_base_dist_browser_index_js.js +30 -0
  485. package/move_parallax_dist_browser_ParallaxMover_js.js +30 -0
  486. package/move_parallax_dist_browser_index_js.js +30 -0
  487. package/package.json +61 -53
  488. package/paths_curlNoise_dist_browser_CurlNoiseGenerator_js.js +30 -0
  489. package/paths_curlNoise_dist_browser_index_js.js +30 -0
  490. package/paths_curves_dist_browser_CurvesPathGenerator_js.js +40 -0
  491. package/paths_curves_dist_browser_index_js.js +30 -0
  492. package/paths_fractalNoise_dist_browser_FractalNoiseGenerator_js.js +90 -0
  493. package/paths_fractalNoise_dist_browser_index_js.js +30 -0
  494. package/paths_perlinNoise_dist_browser_PerlinNoiseGenerator_js.js +80 -0
  495. package/paths_perlinNoise_dist_browser_index_js.js +30 -0
  496. package/paths_polygon_dist_browser_PolygonPathGenerator_js.js +30 -0
  497. package/paths_polygon_dist_browser_index_js.js +30 -0
  498. package/paths_simplexNoise_dist_browser_SimplexNoiseGenerator_js.js +50 -0
  499. package/paths_simplexNoise_dist_browser_index_js.js +30 -0
  500. package/paths_svg_dist_browser_SVGPathGenerator_js.js +30 -0
  501. package/paths_svg_dist_browser_index_js.js +30 -0
  502. package/paths_zigzag_dist_browser_ZigZagPathGenerator_js.js +30 -0
  503. package/paths_zigzag_dist_browser_index_js.js +30 -0
  504. package/pjs_dist_browser_index_js.js +50 -0
  505. package/plugins_absorbers_dist_browser_AbsorbersPlugin_js.js +80 -0
  506. package/plugins_absorbers_dist_browser_index_js.js +40 -0
  507. package/plugins_backgroundMask_dist_browser_BackgroundMaskPlugin_js.js +60 -0
  508. package/plugins_backgroundMask_dist_browser_index_js.js +30 -0
  509. package/plugins_canvasMask_dist_browser_CanvasMaskPlugin_js.js +120 -0
  510. package/plugins_canvasMask_dist_browser_index_js.js +30 -0
  511. package/plugins_colors_hex_dist_browser_HexColorManager_js.js +30 -0
  512. package/plugins_colors_hex_dist_browser_index_js.js +30 -0
  513. package/plugins_colors_hsl_dist_browser_HslColorManager_js.js +30 -0
  514. package/plugins_colors_hsl_dist_browser_index_js.js +30 -0
  515. package/plugins_colors_hsv_dist_browser_HsvColorManager_js.js +40 -0
  516. package/plugins_colors_hsv_dist_browser_index_js.js +30 -0
  517. package/plugins_colors_hwb_dist_browser_HwbColorManager_js.js +30 -0
  518. package/plugins_colors_hwb_dist_browser_index_js.js +30 -0
  519. package/plugins_colors_lab_dist_browser_LabColorManager_js.js +40 -0
  520. package/plugins_colors_lab_dist_browser_index_js.js +30 -0
  521. package/plugins_colors_lch_dist_browser_LchColorManager_js.js +40 -0
  522. package/plugins_colors_lch_dist_browser_index_js.js +30 -0
  523. package/plugins_colors_named_dist_browser_NamedColorManager_js.js +30 -0
  524. package/plugins_colors_named_dist_browser_index_js.js +30 -0
  525. package/plugins_colors_oklab_dist_browser_OklabColorManager_js.js +40 -0
  526. package/plugins_colors_oklab_dist_browser_index_js.js +30 -0
  527. package/plugins_colors_oklch_dist_browser_OklchColorManager_js.js +40 -0
  528. package/plugins_colors_oklch_dist_browser_index_js.js +30 -0
  529. package/plugins_colors_rgb_dist_browser_RgbColorManager_js.js +30 -0
  530. package/plugins_colors_rgb_dist_browser_index_js.js +30 -0
  531. package/plugins_easings_back_dist_browser_index_js.js +30 -0
  532. package/plugins_easings_circ_dist_browser_index_js.js +30 -0
  533. package/plugins_easings_cubic_dist_browser_index_js.js +30 -0
  534. package/plugins_easings_expo_dist_browser_index_js.js +30 -0
  535. package/plugins_easings_linear_dist_browser_index_js.js +30 -0
  536. package/plugins_easings_quad_dist_browser_index_js.js +30 -0
  537. package/plugins_easings_quart_dist_browser_index_js.js +30 -0
  538. package/plugins_easings_quint_dist_browser_index_js.js +30 -0
  539. package/plugins_easings_sine_dist_browser_index_js.js +30 -0
  540. package/plugins_emittersShapes_canvas_dist_browser_EmittersCanvasShapeGenerator_js.js +130 -0
  541. package/plugins_emittersShapes_canvas_dist_browser_index_js.js +30 -0
  542. package/plugins_emittersShapes_circle_dist_browser_EmittersCircleShapeGenerator_js.js +70 -0
  543. package/plugins_emittersShapes_circle_dist_browser_index_js.js +30 -0
  544. package/plugins_emittersShapes_path_dist_browser_EmittersPathShapeGenerator_js.js +90 -0
  545. package/plugins_emittersShapes_path_dist_browser_index_js.js +30 -0
  546. package/plugins_emittersShapes_polygon_dist_browser_EmittersPolygonShapeGenerator_js.js +90 -0
  547. package/plugins_emittersShapes_polygon_dist_browser_index_js.js +30 -0
  548. package/plugins_emittersShapes_square_dist_browser_EmittersSquareShapeGenerator_js.js +70 -0
  549. package/plugins_emittersShapes_square_dist_browser_index_js.js +30 -0
  550. package/plugins_emitters_dist_browser_EmittersPlugin_js.js +110 -0
  551. package/plugins_emitters_dist_browser_ShapeManager_js.js +30 -0
  552. package/plugins_emitters_dist_browser_index_js.js +50 -0
  553. package/plugins_exports_image_dist_browser_ExportImagePlugin_js.js +40 -0
  554. package/plugins_exports_image_dist_browser_index_js.js +30 -0
  555. package/plugins_exports_json_dist_browser_ExportJSONPlugin_js.js +40 -0
  556. package/plugins_exports_json_dist_browser_index_js.js +30 -0
  557. package/plugins_exports_video_dist_browser_ExportVideoPlugin_js.js +40 -0
  558. package/plugins_exports_video_dist_browser_index_js.js +30 -0
  559. package/plugins_infection_dist_browser_InfectionPlugin_js.js +70 -0
  560. package/plugins_infection_dist_browser_ParticlesInfecter_js.js +30 -0
  561. package/plugins_infection_dist_browser_index_js.js +30 -0
  562. package/plugins_motion_dist_browser_MotionPlugin_js.js +60 -0
  563. package/plugins_motion_dist_browser_index_js.js +30 -0
  564. package/plugins_poisson_dist_browser_PoissonDiscPlugin_js.js +60 -0
  565. package/plugins_poisson_dist_browser_index_js.js +30 -0
  566. package/plugins_polygonMask_dist_browser_PolygonMaskPlugin_js.js +120 -0
  567. package/plugins_polygonMask_dist_browser_index_js.js +60 -0
  568. package/plugins_sounds_dist_browser_SoundsPlugin_js.js +140 -0
  569. package/plugins_sounds_dist_browser_index_js.js +30 -0
  570. package/plugins_trail_dist_browser_TrailPlugin_js.js +60 -0
  571. package/plugins_trail_dist_browser_index_js.js +30 -0
  572. package/report.html +5 -4
  573. package/shapes_arrow_dist_browser_ArrowDrawer_js.js +40 -0
  574. package/shapes_arrow_dist_browser_index_js.js +30 -0
  575. package/shapes_cards_dist_browser_clubs_ClubDrawer_js.js +40 -0
  576. package/shapes_cards_dist_browser_diamonds_DiamondDrawer_js.js +40 -0
  577. package/shapes_cards_dist_browser_hearts_HeartDrawer_js.js +40 -0
  578. package/shapes_cards_dist_browser_index_js.js +70 -0
  579. package/shapes_cards_dist_browser_spades_SpadeDrawer_js.js +40 -0
  580. package/shapes_circle_dist_browser_CircleDrawer_js.js +40 -0
  581. package/shapes_circle_dist_browser_index_js.js +30 -0
  582. package/shapes_cog_dist_browser_CogDrawer_js.js +40 -0
  583. package/shapes_cog_dist_browser_index_js.js +30 -0
  584. package/shapes_emoji_dist_browser_EmojiDrawer_js.js +40 -0
  585. package/shapes_emoji_dist_browser_index_js.js +30 -0
  586. package/shapes_heart_dist_browser_HeartDrawer_js.js +40 -0
  587. package/shapes_heart_dist_browser_index_js.js +30 -0
  588. package/shapes_image_dist_browser_GifUtils_Utils_js.js +80 -0
  589. package/shapes_image_dist_browser_ImageDrawer_js.js +30 -0
  590. package/shapes_image_dist_browser_ImagePreloader_js.js +40 -0
  591. package/shapes_image_dist_browser_Utils_js.js +30 -0
  592. package/shapes_image_dist_browser_index_js.js +30 -0
  593. package/shapes_infinity_dist_browser_InfinityDrawer_js.js +40 -0
  594. package/shapes_infinity_dist_browser_index_js.js +30 -0
  595. package/shapes_line_dist_browser_LineDrawer_js.js +40 -0
  596. package/shapes_line_dist_browser_index_js.js +30 -0
  597. package/shapes_path_dist_browser_PathDrawer_js.js +50 -0
  598. package/shapes_path_dist_browser_index_js.js +30 -0
  599. package/shapes_polygon_dist_browser_PolygonDrawer_js.js +50 -0
  600. package/shapes_polygon_dist_browser_TriangleDrawer_js.js +50 -0
  601. package/shapes_polygon_dist_browser_index_js.js +30 -0
  602. package/shapes_rounded-polygon_dist_browser_RoundedPolygonDrawer_js.js +40 -0
  603. package/shapes_rounded-polygon_dist_browser_index_js.js +30 -0
  604. package/shapes_rounded-rect_dist_browser_RoundedRectDrawer_js.js +40 -0
  605. package/shapes_rounded-rect_dist_browser_index_js.js +30 -0
  606. package/shapes_spiral_dist_browser_SpiralDrawer_js.js +40 -0
  607. package/shapes_spiral_dist_browser_index_js.js +30 -0
  608. package/shapes_square_dist_browser_SquareDrawer_js.js +40 -0
  609. package/shapes_square_dist_browser_index_js.js +30 -0
  610. package/shapes_star_dist_browser_StarDrawer_js.js +40 -0
  611. package/shapes_star_dist_browser_index_js.js +30 -0
  612. package/shapes_text_dist_browser_TextDrawer_js.js +40 -0
  613. package/shapes_text_dist_browser_index_js.js +30 -0
  614. package/slim_dist_browser_index_js.js +30 -0
  615. package/tsparticles.all.bundle.js +536 -5705
  616. package/tsparticles.all.bundle.min.js +1 -1
  617. package/tsparticles.all.bundle.min.js.LICENSE.txt +1 -1
  618. package/tsparticles.all.js +261 -167
  619. package/tsparticles.all.min.js +1 -1
  620. package/tsparticles.all.min.js.LICENSE.txt +1 -1
  621. package/types/bundle.d.ts +1 -1
  622. package/types/index.d.ts +1 -1
  623. package/umd/bundle.js +3 -3
  624. package/umd/index.js +97 -104
  625. package/updaters_color_dist_browser_ColorUpdater_js.js +30 -0
  626. package/updaters_color_dist_browser_index_js.js +30 -0
  627. package/updaters_destroy_dist_browser_DestroyUpdater_js.js +100 -0
  628. package/updaters_destroy_dist_browser_index_js.js +30 -0
  629. package/updaters_gradient_dist_browser_GradientUpdater_js.js +100 -0
  630. package/updaters_gradient_dist_browser_index_js.js +30 -0
  631. package/updaters_life_dist_browser_LifeUpdater_js.js +70 -0
  632. package/updaters_life_dist_browser_index_js.js +30 -0
  633. package/updaters_opacity_dist_browser_OpacityUpdater_js.js +30 -0
  634. package/updaters_opacity_dist_browser_index_js.js +30 -0
  635. package/updaters_orbit_dist_browser_OrbitUpdater_js.js +70 -0
  636. package/updaters_orbit_dist_browser_index_js.js +30 -0
  637. package/updaters_outModes_dist_browser_OutOfCanvasUpdater_js.js +80 -0
  638. package/updaters_outModes_dist_browser_index_js.js +30 -0
  639. package/updaters_roll_dist_browser_RollUpdater_js.js +70 -0
  640. package/updaters_roll_dist_browser_index_js.js +30 -0
  641. package/updaters_rotate_dist_browser_RotateUpdater_js.js +50 -0
  642. package/updaters_rotate_dist_browser_index_js.js +30 -0
  643. package/updaters_size_dist_browser_SizeUpdater_js.js +30 -0
  644. package/updaters_size_dist_browser_index_js.js +30 -0
  645. package/updaters_strokeColor_dist_browser_StrokeColorUpdater_js.js +30 -0
  646. package/updaters_strokeColor_dist_browser_index_js.js +30 -0
  647. package/updaters_tilt_dist_browser_TiltUpdater_js.js +60 -0
  648. package/updaters_tilt_dist_browser_index_js.js +30 -0
  649. package/updaters_twinkle_dist_browser_TwinkleUpdater_js.js +50 -0
  650. package/updaters_twinkle_dist_browser_index_js.js +30 -0
  651. package/updaters_wobble_dist_browser_WobbleUpdater_js.js +60 -0
  652. package/updaters_wobble_dist_browser_index_js.js +30 -0
  653. package/utils_simplexNoise_dist_browser_index_js.js +80 -0
@@ -0,0 +1,40 @@
1
+ /*!
2
+ * Author : Matteo Bruni
3
+ * MIT license: https://opensource.org/licenses/MIT
4
+ * Demo / Generator : https://particles.js.org/
5
+ * GitHub : https://www.github.com/matteobruni/tsparticles
6
+ * How to use? : Check the GitHub README
7
+ * v4.0.0-alpha.0
8
+ */
9
+ "use strict";
10
+ /*
11
+ * ATTENTION: The "eval" devtool has been used (maybe by default in mode: "development").
12
+ * This devtool is neither made for production nor for readable output files.
13
+ * It uses "eval()" calls to create a separate source file in the browser devtools.
14
+ * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
15
+ * or disable the default devtool with "devtool: false".
16
+ * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
17
+ */
18
+ (this["webpackChunk_tsparticles_all"] = this["webpackChunk_tsparticles_all"] || []).push([["paths_curves_dist_browser_CurvesPathGenerator_js"],{
19
+
20
+ /***/ "../../paths/curves/dist/browser/Curves.js"
21
+ /*!*************************************************!*\
22
+ !*** ../../paths/curves/dist/browser/Curves.js ***!
23
+ \*************************************************/
24
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
25
+
26
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ CurvesPathGen: () => (/* binding */ CurvesPathGen)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/engine */ \"../../engine/dist/browser/index.js\");\n\nfunction CurvesPathGen(rndFunc, period, nbHarmonics, attenHarmonics, lowValue = 0, highValue = 1) {\n const arP0 = [],\n arP1 = [],\n amplitudes = [],\n increments = [],\n phases = [],\n randomFunc = rndFunc ?? _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.getRandom;\n let globAmplitude = 0;\n if (nbHarmonics < 1) nbHarmonics = 1;\n for (let kh = 1; kh <= nbHarmonics; ++kh) {\n arP0[kh] = randomFunc();\n arP1[kh] = randomFunc();\n amplitudes[kh] = kh === 1 ? 1 : amplitudes[kh - 1] * attenHarmonics;\n globAmplitude += amplitudes[kh];\n increments[kh] = kh / period;\n phases[kh] = randomFunc();\n }\n amplitudes.forEach((value, kh) => amplitudes[kh] = value / globAmplitude * (highValue - lowValue));\n return () => {\n let pf,\n pfl,\n signal = 0;\n for (let kh = nbHarmonics; kh >= 1; --kh) {\n pf = phases[kh] += increments[kh];\n if (phases[kh] >= 1) {\n pf = phases[kh] -= 1;\n arP0[kh] = arP1[kh];\n arP1[kh] = randomFunc();\n }\n pfl = pf ** 2 * (3 - 2 * pf);\n signal += (arP0[kh] * (1 - pfl) + arP1[kh] * pfl) * amplitudes[kh];\n }\n return signal + lowValue;\n };\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../paths/curves/dist/browser/Curves.js?\n}");
27
+
28
+ /***/ },
29
+
30
+ /***/ "../../paths/curves/dist/browser/CurvesPathGenerator.js"
31
+ /*!**************************************************************!*\
32
+ !*** ../../paths/curves/dist/browser/CurvesPathGenerator.js ***!
33
+ \**************************************************************/
34
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
35
+
36
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ CurvesPathGenerator: () => (/* binding */ CurvesPathGenerator)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/engine */ \"../../engine/dist/browser/index.js\");\n/* harmony import */ var _Curves_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Curves.js */ \"../../paths/curves/dist/browser/Curves.js\");\n\n\nfunction randomVelocity() {\n const offset = 0.8,\n factor = 0.6;\n return (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.getRandom)() * factor + offset;\n}\nclass CurvesPathGenerator {\n constructor() {\n this.options = {\n rndFunc: null,\n period: 100,\n nbHarmonics: 2,\n attenHarmonics: 0.8,\n lowValue: -0.03,\n highValue: 0.03\n };\n }\n generate(p) {\n if (!p.pathGen) {\n const options = this.options;\n p.pathGen = (0,_Curves_js__WEBPACK_IMPORTED_MODULE_1__.CurvesPathGen)(options.rndFunc, options.period, options.nbHarmonics, options.attenHarmonics, options.lowValue, options.highValue);\n }\n if (!p.curveVelocity) {\n p.curveVelocity = _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.Vector.origin;\n p.curveVelocity.length = randomVelocity();\n p.curveVelocity.angle = (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.getRandom)() * _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.doublePI;\n } else {\n p.curveVelocity.length += 0.01;\n p.curveVelocity.angle = (p.curveVelocity.angle + p.pathGen()) % _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.doublePI;\n }\n p.velocity.x = 0;\n p.velocity.y = 0;\n return p.curveVelocity;\n }\n init(container) {\n const sourceOptions = container.actualOptions.particles.move.path.options,\n {\n options\n } = this;\n if ((0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.isFunction)(sourceOptions[\"rndFunc\"])) {\n options.rndFunc = sourceOptions[\"rndFunc\"];\n } else if ((0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.isString)(sourceOptions[\"rndFunc\"])) {\n options.rndFunc = globalThis[sourceOptions[\"rndFunc\"]] ?? this.options.rndFunc;\n }\n options.period = sourceOptions[\"period\"] ?? options.period;\n options.nbHarmonics = sourceOptions[\"nbHarmonics\"] ?? options.nbHarmonics;\n options.attenHarmonics = sourceOptions[\"attenHarmonics\"] ?? options.attenHarmonics;\n options.lowValue = sourceOptions[\"lowValue\"] ?? options.lowValue;\n options.highValue = sourceOptions[\"highValue\"] ?? options.highValue;\n }\n reset(particle) {\n delete particle.pathGen;\n delete particle.curveVelocity;\n }\n update() {}\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../paths/curves/dist/browser/CurvesPathGenerator.js?\n}");
37
+
38
+ /***/ }
39
+
40
+ }]);
@@ -0,0 +1,30 @@
1
+ /*!
2
+ * Author : Matteo Bruni
3
+ * MIT license: https://opensource.org/licenses/MIT
4
+ * Demo / Generator : https://particles.js.org/
5
+ * GitHub : https://www.github.com/matteobruni/tsparticles
6
+ * How to use? : Check the GitHub README
7
+ * v4.0.0-alpha.0
8
+ */
9
+ "use strict";
10
+ /*
11
+ * ATTENTION: The "eval" devtool has been used (maybe by default in mode: "development").
12
+ * This devtool is neither made for production nor for readable output files.
13
+ * It uses "eval()" calls to create a separate source file in the browser devtools.
14
+ * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
15
+ * or disable the default devtool with "devtool: false".
16
+ * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
17
+ */
18
+ (this["webpackChunk_tsparticles_all"] = this["webpackChunk_tsparticles_all"] || []).push([["paths_curves_dist_browser_index_js"],{
19
+
20
+ /***/ "../../paths/curves/dist/browser/index.js"
21
+ /*!************************************************!*\
22
+ !*** ../../paths/curves/dist/browser/index.js ***!
23
+ \************************************************/
24
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
25
+
26
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ curvesPathName: () => (/* binding */ curvesPathName),\n/* harmony export */ loadCurvesPath: () => (/* binding */ loadCurvesPath)\n/* harmony export */ });\nconst curvesPathName = \"curvesPathGenerator\";\nfunction loadCurvesPath(engine) {\n engine.checkVersion(\"4.0.0-alpha.0\");\n engine.register(async e => {\n const {\n CurvesPathGenerator\n } = await __webpack_require__.e(/*! import() */ \"paths_curves_dist_browser_CurvesPathGenerator_js\").then(__webpack_require__.bind(__webpack_require__, /*! ./CurvesPathGenerator.js */ \"../../paths/curves/dist/browser/CurvesPathGenerator.js\"));\n e.addPathGenerator(curvesPathName, new CurvesPathGenerator());\n });\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../paths/curves/dist/browser/index.js?\n}");
27
+
28
+ /***/ }
29
+
30
+ }]);
@@ -0,0 +1,90 @@
1
+ /*!
2
+ * Author : Matteo Bruni
3
+ * MIT license: https://opensource.org/licenses/MIT
4
+ * Demo / Generator : https://particles.js.org/
5
+ * GitHub : https://www.github.com/matteobruni/tsparticles
6
+ * How to use? : Check the GitHub README
7
+ * v4.0.0-alpha.0
8
+ */
9
+ "use strict";
10
+ /*
11
+ * ATTENTION: The "eval" devtool has been used (maybe by default in mode: "development").
12
+ * This devtool is neither made for production nor for readable output files.
13
+ * It uses "eval()" calls to create a separate source file in the browser devtools.
14
+ * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
15
+ * or disable the default devtool with "devtool: false".
16
+ * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
17
+ */
18
+ (this["webpackChunk_tsparticles_all"] = this["webpackChunk_tsparticles_all"] || []).push([["paths_fractalNoise_dist_browser_FractalNoiseGenerator_js"],{
19
+
20
+ /***/ "../../paths/fractalNoise/dist/browser/FractalNoiseGenerator.js"
21
+ /*!**********************************************************************!*\
22
+ !*** ../../paths/fractalNoise/dist/browser/FractalNoiseGenerator.js ***!
23
+ \**********************************************************************/
24
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
25
+
26
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ FractalNoiseGenerator: () => (/* binding */ FractalNoiseGenerator)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_fractal_noise__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/fractal-noise */ \"../../utils/fractalNoise/dist/browser/index.js\");\n/* harmony import */ var _tsparticles_noise_field__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @tsparticles/noise-field */ \"../../utils/noiseField/dist/browser/index.js\");\n\n\nclass FractalNoiseGenerator extends _tsparticles_noise_field__WEBPACK_IMPORTED_MODULE_1__.NoiseFieldGenerator {\n constructor() {\n const fractalNoise = new _tsparticles_fractal_noise__WEBPACK_IMPORTED_MODULE_0__.FractalNoise();\n super({\n noise4d: (x, y, z, w) => fractalNoise.noise4d(x, y, z, w),\n seed: seed => {\n fractalNoise.seed(seed);\n }\n });\n }\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../paths/fractalNoise/dist/browser/FractalNoiseGenerator.js?\n}");
27
+
28
+ /***/ },
29
+
30
+ /***/ "../../utils/fractalNoise/dist/browser/FractalNoise.js"
31
+ /*!*************************************************************!*\
32
+ !*** ../../utils/fractalNoise/dist/browser/FractalNoise.js ***!
33
+ \*************************************************************/
34
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
35
+
36
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ FractalNoise: () => (/* binding */ FractalNoise)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_smooth_value_noise__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/smooth-value-noise */ \"../../utils/smoothValueNoise/dist/browser/index.js\");\n\nclass FractalNoise {\n constructor() {\n this._smoothValueNoise = new _tsparticles_smooth_value_noise__WEBPACK_IMPORTED_MODULE_0__.SmoothValueNoise();\n }\n noise2d(x, y, octaves = 5, persistence = 0.5, lacunarity = 2.0) {\n let total = 0,\n frequency = 1,\n amplitude = 1,\n maxValue = 0;\n for (let i = 0; i < octaves; i++) {\n total += this._smoothValueNoise.noise2d(x * frequency, y * frequency) * amplitude;\n maxValue += amplitude;\n amplitude *= persistence;\n frequency *= lacunarity;\n }\n return total / maxValue;\n }\n noise3d(x, y, z, octaves = 5, persistence = 0.5, lacunarity = 2.0) {\n let total = 0,\n frequency = 1,\n amplitude = 1,\n maxValue = 0;\n for (let i = 0; i < octaves; i++) {\n total += this._smoothValueNoise.noise3d(x * frequency, y * frequency, z * frequency) * amplitude;\n maxValue += amplitude;\n amplitude *= persistence;\n frequency *= lacunarity;\n }\n return total / maxValue;\n }\n noise4d(x, y, z, w, octaves = 5, persistence = 0.5, lacunarity = 2.0) {\n let total = 0,\n frequency = 1,\n amplitude = 1,\n maxValue = 0;\n for (let i = 0; i < octaves; i++) {\n total += this._smoothValueNoise.noise4d(x * frequency, y * frequency, z * frequency, w * frequency) * amplitude;\n maxValue += amplitude;\n amplitude *= persistence;\n frequency *= lacunarity;\n }\n return total / maxValue;\n }\n seed(seed) {\n this._smoothValueNoise.seed(seed);\n }\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../utils/fractalNoise/dist/browser/FractalNoise.js?\n}");
37
+
38
+ /***/ },
39
+
40
+ /***/ "../../utils/fractalNoise/dist/browser/index.js"
41
+ /*!******************************************************!*\
42
+ !*** ../../utils/fractalNoise/dist/browser/index.js ***!
43
+ \******************************************************/
44
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
45
+
46
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ FractalNoise: () => (/* reexport safe */ _FractalNoise_js__WEBPACK_IMPORTED_MODULE_0__.FractalNoise)\n/* harmony export */ });\n/* harmony import */ var _FractalNoise_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./FractalNoise.js */ \"../../utils/fractalNoise/dist/browser/FractalNoise.js\");\n\n\n//# sourceURL=webpack://@tsparticles/all/../../utils/fractalNoise/dist/browser/index.js?\n}");
47
+
48
+ /***/ },
49
+
50
+ /***/ "../../utils/noiseField/dist/browser/NoiseFieldGenerator.js"
51
+ /*!******************************************************************!*\
52
+ !*** ../../utils/noiseField/dist/browser/NoiseFieldGenerator.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 */ NoiseFieldGenerator: () => (/* binding */ NoiseFieldGenerator)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/engine */ \"../../engine/dist/browser/index.js\");\n\nconst originCoordinate = 0,\n firstIndex = 0,\n empty = 0,\n optionsSizeOffset = 1,\n transformDefaultValues = {\n a: 1,\n b: 0,\n c: 0,\n d: 1,\n e: 0,\n f: 0\n },\n double = 2,\n doublePI = Math.PI * double,\n defaultOptions = {\n draw: false,\n size: 20,\n increment: 0.004,\n columns: 0,\n rows: 0,\n layers: 0,\n width: 0,\n height: 0,\n factor: {\n angle: 0.02,\n length: 0.01\n },\n offset: {\n x: 40000,\n y: 40000,\n z: 40000\n }\n };\nclass NoiseFieldGenerator {\n constructor(noiseGen) {\n this.noiseGen = noiseGen;\n this.field = [];\n this.noiseW = 0;\n this.options = (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.deepExtend)({}, defaultOptions);\n }\n generate(particle) {\n const pos = particle.getPosition(),\n {\n size\n } = this.options,\n point = {\n x: Math.max(Math.floor(pos.x / size), originCoordinate),\n y: Math.max(Math.floor(pos.y / size), originCoordinate),\n z: Math.max(Math.floor(pos.z / size), originCoordinate)\n },\n {\n field\n } = this,\n fieldPoint = field[point.x]?.[point.y]?.[point.z];\n return fieldPoint ? fieldPoint.copy() : _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.Vector.origin;\n }\n init(container) {\n this.container = container;\n this._setup();\n }\n reset() {}\n update() {\n if (!this.container) {\n return;\n }\n this._calculateField();\n this.noiseW += this.options.increment;\n if (!this.options.draw) {\n return;\n }\n this.container.canvas.draw(ctx => {\n this._drawField(ctx);\n });\n }\n _calculateField() {\n const {\n field,\n noiseGen,\n options,\n noiseW\n } = this,\n lengthFactor = options.factor.length,\n angleFactor = options.factor.angle;\n for (let x = 0; x < options.columns; x++) {\n const xColumn = field[x];\n if (!xColumn) {\n continue;\n }\n for (let y = 0; y < options.rows; y++) {\n const yColumn = xColumn[y];\n if (!yColumn) {\n continue;\n }\n for (let z = 0; z < options.layers; z++) {\n const cell = yColumn[z];\n if (!cell) {\n continue;\n }\n cell.length = noiseGen.noise4d(x * lengthFactor + options.offset.x, y * lengthFactor + options.offset.y, z * lengthFactor + options.offset.z, noiseW);\n cell.angle = noiseGen.noise4d(x * angleFactor, y * angleFactor, z * angleFactor, noiseW) * doublePI;\n }\n }\n }\n }\n _drawField(ctx) {\n const {\n field,\n options\n } = this;\n for (let x = 0; x < options.columns; x++) {\n const xColumn = field[x];\n if (!xColumn) {\n continue;\n }\n for (let y = 0; y < options.rows; y++) {\n const yColumn = xColumn[y];\n if (!yColumn) {\n continue;\n }\n const cell = yColumn[firstIndex];\n if (!cell) {\n continue;\n }\n const {\n angle,\n length\n } = cell;\n ctx.setTransform(transformDefaultValues.a, transformDefaultValues.b, transformDefaultValues.c, transformDefaultValues.d, x * this.options.size, y * this.options.size);\n ctx.rotate(angle);\n ctx.strokeStyle = \"white\";\n ctx.beginPath();\n ctx.moveTo(originCoordinate, originCoordinate);\n ctx.lineTo(originCoordinate, this.options.size * length);\n ctx.stroke();\n ctx.setTransform(transformDefaultValues.a, transformDefaultValues.b, transformDefaultValues.c, transformDefaultValues.d, transformDefaultValues.e, transformDefaultValues.f);\n }\n }\n }\n _initField() {\n const {\n columns,\n rows,\n layers\n } = this.options;\n this.field = new Array(columns);\n for (let x = 0; x < columns; x++) {\n const newX = new Array(rows);\n for (let y = 0; y < rows; y++) {\n const newY = new Array(layers);\n for (let z = 0; z < layers; z++) {\n newY[z] = _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.Vector.origin;\n }\n newX[y] = newY;\n }\n this.field[x] = newX;\n }\n }\n _resetField() {\n const container = this.container;\n if (!container) {\n return;\n }\n const sourceOptions = container.actualOptions.particles.move.path.options,\n {\n options\n } = this;\n options.width = container.canvas.size.width;\n options.height = container.canvas.size.height;\n options.size = sourceOptions[\"size\"] > empty ? sourceOptions[\"size\"] : defaultOptions.size;\n options.increment = sourceOptions[\"increment\"] > empty ? sourceOptions[\"increment\"] : defaultOptions.increment;\n options.draw = !!sourceOptions[\"draw\"];\n const offset = sourceOptions[\"offset\"];\n options.offset.x = offset?.x ?? defaultOptions.offset.x;\n options.offset.y = offset?.y ?? defaultOptions.offset.y;\n options.offset.z = offset?.z ?? defaultOptions.offset.z;\n const factor = sourceOptions[\"factor\"];\n options.factor.angle = factor?.angle ?? defaultOptions.factor.angle;\n options.factor.length = factor?.length ?? defaultOptions.factor.length;\n options.seed = sourceOptions[\"seed\"];\n this.noiseGen.seed(options.seed ?? (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.getRandom)());\n options.columns = Math.floor(options.width / options.size) + optionsSizeOffset;\n options.rows = Math.floor(options.height / options.size) + optionsSizeOffset;\n options.layers = Math.floor(container.zLayers / options.size) + optionsSizeOffset;\n this._initField();\n }\n _setup() {\n this.noiseW = 0;\n this._resetField();\n addEventListener(\"resize\", () => {\n this._resetField();\n });\n }\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../utils/noiseField/dist/browser/NoiseFieldGenerator.js?\n}");
57
+
58
+ /***/ },
59
+
60
+ /***/ "../../utils/noiseField/dist/browser/index.js"
61
+ /*!****************************************************!*\
62
+ !*** ../../utils/noiseField/dist/browser/index.js ***!
63
+ \****************************************************/
64
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
65
+
66
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ NoiseFieldGenerator: () => (/* reexport safe */ _NoiseFieldGenerator_js__WEBPACK_IMPORTED_MODULE_0__.NoiseFieldGenerator)\n/* harmony export */ });\n/* harmony import */ var _NoiseFieldGenerator_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./NoiseFieldGenerator.js */ \"../../utils/noiseField/dist/browser/NoiseFieldGenerator.js\");\n\n\n//# sourceURL=webpack://@tsparticles/all/../../utils/noiseField/dist/browser/index.js?\n}");
67
+
68
+ /***/ },
69
+
70
+ /***/ "../../utils/smoothValueNoise/dist/browser/SmoothValueNoise.js"
71
+ /*!*********************************************************************!*\
72
+ !*** ../../utils/smoothValueNoise/dist/browser/SmoothValueNoise.js ***!
73
+ \*********************************************************************/
74
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
75
+
76
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ SmoothValueNoise: () => (/* binding */ SmoothValueNoise)\n/* harmony export */ });\nconst lerp = (a, b, t) => {\n return a + t * (b - a);\n },\n smoothstep = t => {\n return t * t * (3 - 2 * t);\n },\n fract = x => {\n return x - Math.floor(x);\n };\nclass SmoothValueNoise {\n constructor() {\n this._coeffW = 29.537;\n this._coeffX = 127.1;\n this._coeffY = 311.7;\n this._coeffZ = 78.233;\n this._coeffZW = 37.719;\n this._scaleFactor = 43758.5453;\n }\n noise2d(x, y) {\n const x0 = Math.floor(x),\n y0 = Math.floor(y),\n x1 = x0 + 1,\n y1 = y0 + 1,\n sx = smoothstep(x - x0),\n sy = smoothstep(y - y0),\n n00 = this._valueNoise2D(x0, y0),\n n10 = this._valueNoise2D(x1, y0),\n n01 = this._valueNoise2D(x0, y1),\n n11 = this._valueNoise2D(x1, y1),\n ix0 = lerp(n00, n10, sx),\n ix1 = lerp(n01, n11, sx);\n return lerp(ix0, ix1, sy);\n }\n noise3d(x, y, z) {\n const x0 = Math.floor(x),\n y0 = Math.floor(y),\n z0 = Math.floor(z),\n x1 = x0 + 1,\n y1 = y0 + 1,\n z1 = z0 + 1,\n sx = smoothstep(x - x0),\n sy = smoothstep(y - y0),\n sz = smoothstep(z - z0),\n n000 = this._valueNoise3D(x0, y0, z0),\n n100 = this._valueNoise3D(x1, y0, z0),\n n010 = this._valueNoise3D(x0, y1, z0),\n n110 = this._valueNoise3D(x1, y1, z0),\n n001 = this._valueNoise3D(x0, y0, z1),\n n101 = this._valueNoise3D(x1, y0, z1),\n n011 = this._valueNoise3D(x0, y1, z1),\n n111 = this._valueNoise3D(x1, y1, z1),\n ix00 = lerp(n000, n100, sx),\n ix10 = lerp(n010, n110, sx),\n ix01 = lerp(n001, n101, sx),\n ix11 = lerp(n011, n111, sx),\n iy0 = lerp(ix00, ix10, sy),\n iy1 = lerp(ix01, ix11, sy);\n return lerp(iy0, iy1, sz);\n }\n noise4d(x, y, z, w) {\n const x0 = Math.floor(x),\n y0 = Math.floor(y),\n z0 = Math.floor(z),\n w0 = Math.floor(w),\n x1 = x0 + 1,\n y1 = y0 + 1,\n z1 = z0 + 1,\n w1 = w0 + 1,\n sx = smoothstep(x - x0),\n sy = smoothstep(y - y0),\n sz = smoothstep(z - z0),\n sw = smoothstep(w - w0),\n n0000 = this._valueNoise4D(x0, y0, z0, w0),\n n1000 = this._valueNoise4D(x1, y0, z0, w0),\n n0100 = this._valueNoise4D(x0, y1, z0, w0),\n n1100 = this._valueNoise4D(x1, y1, z0, w0),\n n0010 = this._valueNoise4D(x0, y0, z1, w0),\n n1010 = this._valueNoise4D(x1, y0, z1, w0),\n n0110 = this._valueNoise4D(x0, y1, z1, w0),\n n1110 = this._valueNoise4D(x1, y1, z1, w0),\n n0001 = this._valueNoise4D(x0, y0, z0, w1),\n n1001 = this._valueNoise4D(x1, y0, z0, w1),\n n0101 = this._valueNoise4D(x0, y1, z0, w1),\n n1101 = this._valueNoise4D(x1, y1, z0, w1),\n n0011 = this._valueNoise4D(x0, y0, z1, w1),\n n1011 = this._valueNoise4D(x1, y0, z1, w1),\n n0111 = this._valueNoise4D(x0, y1, z1, w1),\n n1111 = this._valueNoise4D(x1, y1, z1, w1),\n ix000 = lerp(n0000, n1000, sx),\n ix100 = lerp(n0100, n1100, sx),\n ix010 = lerp(n0010, n1010, sx),\n ix110 = lerp(n0110, n1110, sx),\n ix001 = lerp(n0001, n1001, sx),\n ix101 = lerp(n0101, n1101, sx),\n ix011 = lerp(n0011, n1011, sx),\n ix111 = lerp(n0111, n1111, sx),\n iy00 = lerp(ix000, ix100, sy),\n iy10 = lerp(ix010, ix110, sy),\n iy01 = lerp(ix001, ix101, sy),\n iy11 = lerp(ix011, ix111, sy),\n iz0 = lerp(iy00, iy10, sz),\n iz1 = lerp(iy01, iy11, sz);\n return lerp(iz0, iz1, sw);\n }\n seed(seed) {\n const s = Math.sin(seed) * 10000;\n this._coeffX = fract(s * 15731);\n this._coeffY = fract(s * 789221);\n this._coeffZ = fract(s * 1376312589);\n this._coeffZW = fract(s * 974634777);\n this._coeffW = fract(s * 592558533);\n this._scaleFactor = 43758.5453;\n }\n _valueNoise2D(x, y) {\n const n = Math.sin(x * this._coeffX + y * this._coeffY) * this._scaleFactor;\n return (n - Math.floor(n)) * 2 - 1;\n }\n _valueNoise3D(x, y, z) {\n const n = Math.sin(x * this._coeffX + y * this._coeffY + z * this._coeffZ) * this._scaleFactor;\n return (n - Math.floor(n)) * 2 - 1;\n }\n _valueNoise4D(x, y, z, w) {\n const n = Math.sin(x * this._coeffX + y * this._coeffY + z * this._coeffZW + w * this._coeffW) * this._scaleFactor;\n return (n - Math.floor(n)) * 2 - 1;\n }\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../utils/smoothValueNoise/dist/browser/SmoothValueNoise.js?\n}");
77
+
78
+ /***/ },
79
+
80
+ /***/ "../../utils/smoothValueNoise/dist/browser/index.js"
81
+ /*!**********************************************************!*\
82
+ !*** ../../utils/smoothValueNoise/dist/browser/index.js ***!
83
+ \**********************************************************/
84
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
85
+
86
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ SmoothValueNoise: () => (/* reexport safe */ _SmoothValueNoise_js__WEBPACK_IMPORTED_MODULE_0__.SmoothValueNoise)\n/* harmony export */ });\n/* harmony import */ var _SmoothValueNoise_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./SmoothValueNoise.js */ \"../../utils/smoothValueNoise/dist/browser/SmoothValueNoise.js\");\n\n\n//# sourceURL=webpack://@tsparticles/all/../../utils/smoothValueNoise/dist/browser/index.js?\n}");
87
+
88
+ /***/ }
89
+
90
+ }]);
@@ -0,0 +1,30 @@
1
+ /*!
2
+ * Author : Matteo Bruni
3
+ * MIT license: https://opensource.org/licenses/MIT
4
+ * Demo / Generator : https://particles.js.org/
5
+ * GitHub : https://www.github.com/matteobruni/tsparticles
6
+ * How to use? : Check the GitHub README
7
+ * v4.0.0-alpha.0
8
+ */
9
+ "use strict";
10
+ /*
11
+ * ATTENTION: The "eval" devtool has been used (maybe by default in mode: "development").
12
+ * This devtool is neither made for production nor for readable output files.
13
+ * It uses "eval()" calls to create a separate source file in the browser devtools.
14
+ * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
15
+ * or disable the default devtool with "devtool: false".
16
+ * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
17
+ */
18
+ (this["webpackChunk_tsparticles_all"] = this["webpackChunk_tsparticles_all"] || []).push([["paths_fractalNoise_dist_browser_index_js"],{
19
+
20
+ /***/ "../../paths/fractalNoise/dist/browser/index.js"
21
+ /*!******************************************************!*\
22
+ !*** ../../paths/fractalNoise/dist/browser/index.js ***!
23
+ \******************************************************/
24
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
25
+
26
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ fractalNoisePathName: () => (/* binding */ fractalNoisePathName),\n/* harmony export */ loadFractalNoisePath: () => (/* binding */ loadFractalNoisePath)\n/* harmony export */ });\nconst fractalNoisePathName = \"fractalNoise\";\nfunction loadFractalNoisePath(engine) {\n engine.checkVersion(\"4.0.0-alpha.0\");\n engine.register(async e => {\n const {\n FractalNoiseGenerator\n } = await __webpack_require__.e(/*! import() */ \"paths_fractalNoise_dist_browser_FractalNoiseGenerator_js\").then(__webpack_require__.bind(__webpack_require__, /*! ./FractalNoiseGenerator.js */ \"../../paths/fractalNoise/dist/browser/FractalNoiseGenerator.js\"));\n e.addPathGenerator(fractalNoisePathName, new FractalNoiseGenerator());\n });\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../paths/fractalNoise/dist/browser/index.js?\n}");
27
+
28
+ /***/ }
29
+
30
+ }]);
@@ -0,0 +1,80 @@
1
+ /*!
2
+ * Author : Matteo Bruni
3
+ * MIT license: https://opensource.org/licenses/MIT
4
+ * Demo / Generator : https://particles.js.org/
5
+ * GitHub : https://www.github.com/matteobruni/tsparticles
6
+ * How to use? : Check the GitHub README
7
+ * v4.0.0-alpha.0
8
+ */
9
+ "use strict";
10
+ /*
11
+ * ATTENTION: The "eval" devtool has been used (maybe by default in mode: "development").
12
+ * This devtool is neither made for production nor for readable output files.
13
+ * It uses "eval()" calls to create a separate source file in the browser devtools.
14
+ * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
15
+ * or disable the default devtool with "devtool: false".
16
+ * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
17
+ */
18
+ (this["webpackChunk_tsparticles_all"] = this["webpackChunk_tsparticles_all"] || []).push([["paths_perlinNoise_dist_browser_PerlinNoiseGenerator_js"],{
19
+
20
+ /***/ "../../paths/perlinNoise/dist/browser/PerlinNoiseGenerator.js"
21
+ /*!********************************************************************!*\
22
+ !*** ../../paths/perlinNoise/dist/browser/PerlinNoiseGenerator.js ***!
23
+ \********************************************************************/
24
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
25
+
26
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ PerlinNoiseGenerator: () => (/* binding */ PerlinNoiseGenerator)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_noise_field__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/noise-field */ \"../../utils/noiseField/dist/browser/index.js\");\n/* harmony import */ var _tsparticles_perlin_noise__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @tsparticles/perlin-noise */ \"../../utils/perlinNoise/dist/browser/index.js\");\n\n\nclass PerlinNoiseGenerator extends _tsparticles_noise_field__WEBPACK_IMPORTED_MODULE_0__.NoiseFieldGenerator {\n constructor() {\n const perlinNoise = new _tsparticles_perlin_noise__WEBPACK_IMPORTED_MODULE_1__.PerlinNoise();\n super({\n noise4d: (x, y, z, w) => perlinNoise.noise4d(x, y, z, w),\n seed: seed => {\n perlinNoise.seed(seed);\n }\n });\n }\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../paths/perlinNoise/dist/browser/PerlinNoiseGenerator.js?\n}");
27
+
28
+ /***/ },
29
+
30
+ /***/ "../../utils/noiseField/dist/browser/NoiseFieldGenerator.js"
31
+ /*!******************************************************************!*\
32
+ !*** ../../utils/noiseField/dist/browser/NoiseFieldGenerator.js ***!
33
+ \******************************************************************/
34
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
35
+
36
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ NoiseFieldGenerator: () => (/* binding */ NoiseFieldGenerator)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/engine */ \"../../engine/dist/browser/index.js\");\n\nconst originCoordinate = 0,\n firstIndex = 0,\n empty = 0,\n optionsSizeOffset = 1,\n transformDefaultValues = {\n a: 1,\n b: 0,\n c: 0,\n d: 1,\n e: 0,\n f: 0\n },\n double = 2,\n doublePI = Math.PI * double,\n defaultOptions = {\n draw: false,\n size: 20,\n increment: 0.004,\n columns: 0,\n rows: 0,\n layers: 0,\n width: 0,\n height: 0,\n factor: {\n angle: 0.02,\n length: 0.01\n },\n offset: {\n x: 40000,\n y: 40000,\n z: 40000\n }\n };\nclass NoiseFieldGenerator {\n constructor(noiseGen) {\n this.noiseGen = noiseGen;\n this.field = [];\n this.noiseW = 0;\n this.options = (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.deepExtend)({}, defaultOptions);\n }\n generate(particle) {\n const pos = particle.getPosition(),\n {\n size\n } = this.options,\n point = {\n x: Math.max(Math.floor(pos.x / size), originCoordinate),\n y: Math.max(Math.floor(pos.y / size), originCoordinate),\n z: Math.max(Math.floor(pos.z / size), originCoordinate)\n },\n {\n field\n } = this,\n fieldPoint = field[point.x]?.[point.y]?.[point.z];\n return fieldPoint ? fieldPoint.copy() : _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.Vector.origin;\n }\n init(container) {\n this.container = container;\n this._setup();\n }\n reset() {}\n update() {\n if (!this.container) {\n return;\n }\n this._calculateField();\n this.noiseW += this.options.increment;\n if (!this.options.draw) {\n return;\n }\n this.container.canvas.draw(ctx => {\n this._drawField(ctx);\n });\n }\n _calculateField() {\n const {\n field,\n noiseGen,\n options,\n noiseW\n } = this,\n lengthFactor = options.factor.length,\n angleFactor = options.factor.angle;\n for (let x = 0; x < options.columns; x++) {\n const xColumn = field[x];\n if (!xColumn) {\n continue;\n }\n for (let y = 0; y < options.rows; y++) {\n const yColumn = xColumn[y];\n if (!yColumn) {\n continue;\n }\n for (let z = 0; z < options.layers; z++) {\n const cell = yColumn[z];\n if (!cell) {\n continue;\n }\n cell.length = noiseGen.noise4d(x * lengthFactor + options.offset.x, y * lengthFactor + options.offset.y, z * lengthFactor + options.offset.z, noiseW);\n cell.angle = noiseGen.noise4d(x * angleFactor, y * angleFactor, z * angleFactor, noiseW) * doublePI;\n }\n }\n }\n }\n _drawField(ctx) {\n const {\n field,\n options\n } = this;\n for (let x = 0; x < options.columns; x++) {\n const xColumn = field[x];\n if (!xColumn) {\n continue;\n }\n for (let y = 0; y < options.rows; y++) {\n const yColumn = xColumn[y];\n if (!yColumn) {\n continue;\n }\n const cell = yColumn[firstIndex];\n if (!cell) {\n continue;\n }\n const {\n angle,\n length\n } = cell;\n ctx.setTransform(transformDefaultValues.a, transformDefaultValues.b, transformDefaultValues.c, transformDefaultValues.d, x * this.options.size, y * this.options.size);\n ctx.rotate(angle);\n ctx.strokeStyle = \"white\";\n ctx.beginPath();\n ctx.moveTo(originCoordinate, originCoordinate);\n ctx.lineTo(originCoordinate, this.options.size * length);\n ctx.stroke();\n ctx.setTransform(transformDefaultValues.a, transformDefaultValues.b, transformDefaultValues.c, transformDefaultValues.d, transformDefaultValues.e, transformDefaultValues.f);\n }\n }\n }\n _initField() {\n const {\n columns,\n rows,\n layers\n } = this.options;\n this.field = new Array(columns);\n for (let x = 0; x < columns; x++) {\n const newX = new Array(rows);\n for (let y = 0; y < rows; y++) {\n const newY = new Array(layers);\n for (let z = 0; z < layers; z++) {\n newY[z] = _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.Vector.origin;\n }\n newX[y] = newY;\n }\n this.field[x] = newX;\n }\n }\n _resetField() {\n const container = this.container;\n if (!container) {\n return;\n }\n const sourceOptions = container.actualOptions.particles.move.path.options,\n {\n options\n } = this;\n options.width = container.canvas.size.width;\n options.height = container.canvas.size.height;\n options.size = sourceOptions[\"size\"] > empty ? sourceOptions[\"size\"] : defaultOptions.size;\n options.increment = sourceOptions[\"increment\"] > empty ? sourceOptions[\"increment\"] : defaultOptions.increment;\n options.draw = !!sourceOptions[\"draw\"];\n const offset = sourceOptions[\"offset\"];\n options.offset.x = offset?.x ?? defaultOptions.offset.x;\n options.offset.y = offset?.y ?? defaultOptions.offset.y;\n options.offset.z = offset?.z ?? defaultOptions.offset.z;\n const factor = sourceOptions[\"factor\"];\n options.factor.angle = factor?.angle ?? defaultOptions.factor.angle;\n options.factor.length = factor?.length ?? defaultOptions.factor.length;\n options.seed = sourceOptions[\"seed\"];\n this.noiseGen.seed(options.seed ?? (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.getRandom)());\n options.columns = Math.floor(options.width / options.size) + optionsSizeOffset;\n options.rows = Math.floor(options.height / options.size) + optionsSizeOffset;\n options.layers = Math.floor(container.zLayers / options.size) + optionsSizeOffset;\n this._initField();\n }\n _setup() {\n this.noiseW = 0;\n this._resetField();\n addEventListener(\"resize\", () => {\n this._resetField();\n });\n }\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../utils/noiseField/dist/browser/NoiseFieldGenerator.js?\n}");
37
+
38
+ /***/ },
39
+
40
+ /***/ "../../utils/noiseField/dist/browser/index.js"
41
+ /*!****************************************************!*\
42
+ !*** ../../utils/noiseField/dist/browser/index.js ***!
43
+ \****************************************************/
44
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
45
+
46
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ NoiseFieldGenerator: () => (/* reexport safe */ _NoiseFieldGenerator_js__WEBPACK_IMPORTED_MODULE_0__.NoiseFieldGenerator)\n/* harmony export */ });\n/* harmony import */ var _NoiseFieldGenerator_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./NoiseFieldGenerator.js */ \"../../utils/noiseField/dist/browser/NoiseFieldGenerator.js\");\n\n\n//# sourceURL=webpack://@tsparticles/all/../../utils/noiseField/dist/browser/index.js?\n}");
47
+
48
+ /***/ },
49
+
50
+ /***/ "../../utils/perlinNoise/dist/browser/Grad.js"
51
+ /*!****************************************************!*\
52
+ !*** ../../utils/perlinNoise/dist/browser/Grad.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 */ Grad: () => (/* binding */ Grad)\n/* harmony export */ });\nclass Grad {\n constructor(x, y, z, w) {\n this.x = x;\n this.y = y;\n this.z = z;\n this.w = w;\n }\n dot2(x, y) {\n return this.x * x + this.y * y;\n }\n dot3(x, y, z) {\n return this.dot2(x, y) + this.z * z;\n }\n dot4(x, y, z, w) {\n return this.dot3(x, y, z) + this.w * w;\n }\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../utils/perlinNoise/dist/browser/Grad.js?\n}");
57
+
58
+ /***/ },
59
+
60
+ /***/ "../../utils/perlinNoise/dist/browser/PerlinNoise.js"
61
+ /*!***********************************************************!*\
62
+ !*** ../../utils/perlinNoise/dist/browser/PerlinNoise.js ***!
63
+ \***********************************************************/
64
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
65
+
66
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ PerlinNoise: () => (/* binding */ PerlinNoise)\n/* harmony export */ });\n/* harmony import */ var _Grad_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./Grad.js */ \"../../utils/perlinNoise/dist/browser/Grad.js\");\n\nclass PerlinNoise {\n constructor() {\n this._grad4 = [new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(0, 1, 1, 1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(0, 1, 1, -1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(0, 1, -1, 1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(0, 1, -1, -1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(0, -1, 1, 1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(0, -1, 1, -1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(0, -1, -1, 1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(0, -1, -1, -1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(1, 0, 1, 1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(1, 0, 1, -1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(1, 0, -1, 1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(1, 0, -1, -1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(-1, 0, 1, 1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(-1, 0, 1, -1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(-1, 0, -1, 1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(-1, 0, -1, -1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(1, 1, 0, 1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(1, 1, 0, -1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(1, -1, 0, 1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(1, -1, 0, -1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(-1, 1, 0, 1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(-1, 1, 0, -1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(-1, -1, 0, 1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(-1, -1, 0, -1), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(1, 1, 1, 0), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(1, 1, -1, 0), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(1, -1, 1, 0), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(1, -1, -1, 0), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(-1, 1, 1, 0), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(-1, 1, -1, 0), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(-1, -1, 1, 0), new _Grad_js__WEBPACK_IMPORTED_MODULE_0__.Grad(-1, -1, -1, 0)];\n this._p = [151, 160, 137, 91, 90, 15, 131, 13, 201, 95, 96, 53, 194, 233, 7, 225, 140, 36, 103, 30, 69, 142, 8, 99, 37, 240, 21, 10, 23, 190, 6, 148, 247, 120, 234, 75, 0, 26, 197, 62, 94, 252, 219, 203, 117, 35, 11, 32, 57, 177, 33, 88, 237, 149, 56, 87, 174, 20, 125, 136, 171, 168, 68, 175, 74, 165, 71, 134, 139, 48, 27, 166, 77, 146, 158, 231, 83, 111, 229, 122, 60, 211, 133, 230, 220, 105, 92, 41, 55, 46, 245, 40, 244, 102, 143, 54, 65, 25, 63, 161, 1, 216, 80, 73, 209, 76, 132, 187, 208, 89, 18, 169, 200, 196, 135, 130, 116, 188, 159, 86, 164, 100, 109, 198, 173, 186, 3, 64, 52, 217, 226, 250, 124, 123, 5, 202, 38, 147, 118, 126, 255, 82, 85, 212, 207, 206, 59, 227, 47, 16, 58, 17, 182, 189, 28, 42, 223, 183, 170, 213, 119, 248, 152, 2, 44, 154, 163, 70, 221, 153, 101, 155, 167, 43, 172, 9, 129, 22, 39, 253, 19, 98, 108, 110, 79, 113, 224, 232, 178, 185, 112, 104, 218, 246, 97, 228, 251, 34, 242, 193, 238, 210, 144, 12, 191, 179, 162, 241, 81, 51, 145, 235, 249, 14, 239, 107, 49, 192, 214, 31, 181, 199, 106, 157, 184, 84, 204, 176, 115, 121, 50, 45, 127, 4, 150, 254, 138, 236, 205, 93, 222, 114, 67, 29, 24, 72, 243, 141, 128, 195, 78, 66, 215, 61, 156, 180];\n this._gradP = new Array(512);\n this._perm = new Array(512);\n }\n noise2d(x, y) {\n const {\n _gradP,\n _perm\n } = this;\n let X = Math.floor(x),\n Y = Math.floor(y);\n x -= X;\n y -= Y;\n X &= 255;\n Y &= 255;\n const n00 = _gradP[X + _perm[Y]].dot2(x, y),\n n01 = _gradP[X + _perm[Y + 1]].dot2(x, y - 1),\n n10 = _gradP[X + 1 + _perm[Y]].dot2(x - 1, y),\n n11 = _gradP[X + 1 + _perm[Y + 1]].dot2(x - 1, y - 1),\n u = this._fade(x);\n return this._lerp(this._lerp(n00, n10, u), this._lerp(n01, n11, u), this._fade(y));\n }\n noise3d(x, y, z) {\n const {\n _gradP: gradP,\n _perm: perm\n } = this;\n let X = Math.floor(x),\n Y = Math.floor(y),\n Z = Math.floor(z);\n x = x - X;\n y = y - Y;\n z = z - Z;\n X = X & 255;\n Y = Y & 255;\n Z = Z & 255;\n const n000 = gradP[X + perm[Y + perm[Z]]].dot3(x, y, z),\n n001 = gradP[X + perm[Y + perm[Z + 1]]].dot3(x, y, z - 1),\n n010 = gradP[X + perm[Y + 1 + perm[Z]]].dot3(x, y - 1, z),\n n011 = gradP[X + perm[Y + 1 + perm[Z + 1]]].dot3(x, y - 1, z - 1),\n n100 = gradP[X + 1 + perm[Y + perm[Z]]].dot3(x - 1, y, z),\n n101 = gradP[X + 1 + perm[Y + perm[Z + 1]]].dot3(x - 1, y, z - 1),\n n110 = gradP[X + 1 + perm[Y + 1 + perm[Z]]].dot3(x - 1, y - 1, z),\n n111 = gradP[X + 1 + perm[Y + 1 + perm[Z + 1]]].dot3(x - 1, y - 1, z - 1),\n u = this._fade(x),\n v = this._fade(y),\n w = this._fade(z);\n return this._lerp(this._lerp(this._lerp(n000, n100, u), this._lerp(n001, n101, u), w), this._lerp(this._lerp(n010, n110, u), this._lerp(n011, n111, u), w), v);\n }\n noise4d(x, y, z, w) {\n const {\n _gradP: gradP,\n _perm: perm\n } = this;\n let X = Math.floor(x),\n Y = Math.floor(y),\n Z = Math.floor(z),\n W = Math.floor(w);\n x -= X;\n y -= Y;\n z -= Z;\n w -= W;\n X &= 255;\n Y &= 255;\n Z &= 255;\n W &= 255;\n const u = this._fade(x),\n v = this._fade(y),\n s = this._fade(z),\n t = this._fade(w),\n gi = (i, j, k, l) => gradP[X + i + perm[Y + j + perm[Z + k + perm[W + l]]]],\n n0000 = gi(0, 0, 0, 0).dot4(x, y, z, w),\n n0001 = gi(0, 0, 0, 1).dot4(x, y, z, w - 1),\n n0010 = gi(0, 0, 1, 0).dot4(x, y, z - 1, w),\n n0011 = gi(0, 0, 1, 1).dot4(x, y, z - 1, w - 1),\n n0100 = gi(0, 1, 0, 0).dot4(x, y - 1, z, w),\n n0101 = gi(0, 1, 0, 1).dot4(x, y - 1, z, w - 1),\n n0110 = gi(0, 1, 1, 0).dot4(x, y - 1, z - 1, w),\n n0111 = gi(0, 1, 1, 1).dot4(x, y - 1, z - 1, w - 1),\n n1000 = gi(1, 0, 0, 0).dot4(x - 1, y, z, w),\n n1001 = gi(1, 0, 0, 1).dot4(x - 1, y, z, w - 1),\n n1010 = gi(1, 0, 1, 0).dot4(x - 1, y, z - 1, w),\n n1011 = gi(1, 0, 1, 1).dot4(x - 1, y, z - 1, w - 1),\n n1100 = gi(1, 1, 0, 0).dot4(x - 1, y - 1, z, w),\n n1101 = gi(1, 1, 0, 1).dot4(x - 1, y - 1, z, w - 1),\n n1110 = gi(1, 1, 1, 0).dot4(x - 1, y - 1, z - 1, w),\n n1111 = gi(1, 1, 1, 1).dot4(x - 1, y - 1, z - 1, w - 1),\n x00 = this._lerp(n0000, n1000, u),\n x01 = this._lerp(n0001, n1001, u),\n x10 = this._lerp(n0010, n1010, u),\n x11 = this._lerp(n0011, n1011, u),\n y00 = this._lerp(x00, x10, s),\n y01 = this._lerp(x01, x11, s),\n x20 = this._lerp(n0100, n1100, u),\n x21 = this._lerp(n0101, n1101, u),\n x30 = this._lerp(n0110, n1110, u),\n x31 = this._lerp(n0111, n1111, u),\n y10 = this._lerp(x20, x30, s),\n y11 = this._lerp(x21, x31, s),\n z0 = this._lerp(y00, y10, v),\n z1 = this._lerp(y01, y11, v);\n return this._lerp(z0, z1, t);\n }\n seed(inputSeed) {\n const {\n _grad4: grad4,\n _gradP: gradP,\n _perm: perm,\n _p: p\n } = this;\n let seed = inputSeed;\n if (seed > 0 && seed < 1) {\n seed *= 65536;\n }\n seed = Math.floor(seed);\n if (seed < 256) {\n seed |= seed << 8;\n }\n const grad4Length = grad4.length;\n for (let i = 0; i < 256; i++) {\n const v = i & 1 ? p[i] ^ seed & 255 : p[i] ^ seed >> 8 & 255;\n perm[i] = perm[i + 256] = v;\n gradP[i] = gradP[i + 256] = grad4[v % grad4Length];\n }\n }\n _fade(t) {\n return t * t * t * (t * (t * 6 - 15) + 10);\n }\n _lerp(a, b, t) {\n return (1 - t) * a + t * b;\n }\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../utils/perlinNoise/dist/browser/PerlinNoise.js?\n}");
67
+
68
+ /***/ },
69
+
70
+ /***/ "../../utils/perlinNoise/dist/browser/index.js"
71
+ /*!*****************************************************!*\
72
+ !*** ../../utils/perlinNoise/dist/browser/index.js ***!
73
+ \*****************************************************/
74
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
75
+
76
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ PerlinNoise: () => (/* reexport safe */ _PerlinNoise_js__WEBPACK_IMPORTED_MODULE_0__.PerlinNoise)\n/* harmony export */ });\n/* harmony import */ var _PerlinNoise_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./PerlinNoise.js */ \"../../utils/perlinNoise/dist/browser/PerlinNoise.js\");\n\n\n//# sourceURL=webpack://@tsparticles/all/../../utils/perlinNoise/dist/browser/index.js?\n}");
77
+
78
+ /***/ }
79
+
80
+ }]);
@@ -0,0 +1,30 @@
1
+ /*!
2
+ * Author : Matteo Bruni
3
+ * MIT license: https://opensource.org/licenses/MIT
4
+ * Demo / Generator : https://particles.js.org/
5
+ * GitHub : https://www.github.com/matteobruni/tsparticles
6
+ * How to use? : Check the GitHub README
7
+ * v4.0.0-alpha.0
8
+ */
9
+ "use strict";
10
+ /*
11
+ * ATTENTION: The "eval" devtool has been used (maybe by default in mode: "development").
12
+ * This devtool is neither made for production nor for readable output files.
13
+ * It uses "eval()" calls to create a separate source file in the browser devtools.
14
+ * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
15
+ * or disable the default devtool with "devtool: false".
16
+ * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
17
+ */
18
+ (this["webpackChunk_tsparticles_all"] = this["webpackChunk_tsparticles_all"] || []).push([["paths_perlinNoise_dist_browser_index_js"],{
19
+
20
+ /***/ "../../paths/perlinNoise/dist/browser/index.js"
21
+ /*!*****************************************************!*\
22
+ !*** ../../paths/perlinNoise/dist/browser/index.js ***!
23
+ \*****************************************************/
24
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
25
+
26
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ loadPerlinNoisePath: () => (/* binding */ loadPerlinNoisePath),\n/* harmony export */ perlinNoisePathName: () => (/* binding */ perlinNoisePathName)\n/* harmony export */ });\nconst perlinNoisePathName = \"perlinNoise\";\nfunction loadPerlinNoisePath(engine) {\n engine.checkVersion(\"4.0.0-alpha.0\");\n engine.register(async e => {\n const {\n PerlinNoiseGenerator\n } = await __webpack_require__.e(/*! import() */ \"paths_perlinNoise_dist_browser_PerlinNoiseGenerator_js\").then(__webpack_require__.bind(__webpack_require__, /*! ./PerlinNoiseGenerator.js */ \"../../paths/perlinNoise/dist/browser/PerlinNoiseGenerator.js\"));\n e.addPathGenerator(perlinNoisePathName, new PerlinNoiseGenerator());\n });\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../paths/perlinNoise/dist/browser/index.js?\n}");
27
+
28
+ /***/ }
29
+
30
+ }]);
@@ -0,0 +1,30 @@
1
+ /*!
2
+ * Author : Matteo Bruni
3
+ * MIT license: https://opensource.org/licenses/MIT
4
+ * Demo / Generator : https://particles.js.org/
5
+ * GitHub : https://www.github.com/matteobruni/tsparticles
6
+ * How to use? : Check the GitHub README
7
+ * v4.0.0-alpha.0
8
+ */
9
+ "use strict";
10
+ /*
11
+ * ATTENTION: The "eval" devtool has been used (maybe by default in mode: "development").
12
+ * This devtool is neither made for production nor for readable output files.
13
+ * It uses "eval()" calls to create a separate source file in the browser devtools.
14
+ * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
15
+ * or disable the default devtool with "devtool: false".
16
+ * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
17
+ */
18
+ (this["webpackChunk_tsparticles_all"] = this["webpackChunk_tsparticles_all"] || []).push([["paths_polygon_dist_browser_PolygonPathGenerator_js"],{
19
+
20
+ /***/ "../../paths/polygon/dist/browser/PolygonPathGenerator.js"
21
+ /*!****************************************************************!*\
22
+ !*** ../../paths/polygon/dist/browser/PolygonPathGenerator.js ***!
23
+ \****************************************************************/
24
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
25
+
26
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ PolygonPathGenerator: () => (/* binding */ PolygonPathGenerator)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/engine */ \"../../engine/dist/browser/index.js\");\n\nclass PolygonPathGenerator {\n constructor() {\n this._createDirs = () => {\n this.dirsList = [];\n for (let i = 0; i < 360; i += 360 / this.options.sides) {\n const angle = this.options.angle + i;\n this.dirsList.push(_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.Vector.create(Math.cos(angle * Math.PI / 180), Math.sin(angle * Math.PI / 180)));\n }\n };\n this.dirsList = [];\n this.options = {\n sides: 6,\n turnSteps: 20,\n angle: 30\n };\n }\n generate(p) {\n const {\n sides\n } = this.options;\n p.hexStep ??= 0;\n p.hexDirection ??= sides === 6 ? ((0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.getRandom)() * 3 | 0) * 2 : (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.getRandom)() * sides | 0;\n p.hexSpeed ??= p.velocity.length;\n if (p.hexStep % this.options.turnSteps === 0) {\n p.hexDirection = (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.getRandom)() > 0.5 ? (p.hexDirection + 1) % sides : (p.hexDirection + sides - 1) % sides;\n }\n p.velocity.x = 0;\n p.velocity.y = 0;\n p.hexStep++;\n const direction = this.dirsList[p.hexDirection];\n return _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.Vector.create(direction.x * p.hexSpeed, direction.y * p.hexSpeed);\n }\n init(container) {\n const options = container.actualOptions.particles.move.path.options;\n this.options.sides = options[\"sides\"] > 0 ? options[\"sides\"] : 6;\n this.options.angle = options[\"angle\"] ?? 30;\n this.options.turnSteps = options[\"turnSteps\"] >= 0 ? options[\"turnSteps\"] : 20;\n this._createDirs();\n }\n reset(particle) {\n delete particle.hexStep;\n delete particle.hexDirection;\n delete particle.hexSpeed;\n }\n update() {}\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../paths/polygon/dist/browser/PolygonPathGenerator.js?\n}");
27
+
28
+ /***/ }
29
+
30
+ }]);
@@ -0,0 +1,30 @@
1
+ /*!
2
+ * Author : Matteo Bruni
3
+ * MIT license: https://opensource.org/licenses/MIT
4
+ * Demo / Generator : https://particles.js.org/
5
+ * GitHub : https://www.github.com/matteobruni/tsparticles
6
+ * How to use? : Check the GitHub README
7
+ * v4.0.0-alpha.0
8
+ */
9
+ "use strict";
10
+ /*
11
+ * ATTENTION: The "eval" devtool has been used (maybe by default in mode: "development").
12
+ * This devtool is neither made for production nor for readable output files.
13
+ * It uses "eval()" calls to create a separate source file in the browser devtools.
14
+ * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
15
+ * or disable the default devtool with "devtool: false".
16
+ * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
17
+ */
18
+ (this["webpackChunk_tsparticles_all"] = this["webpackChunk_tsparticles_all"] || []).push([["paths_polygon_dist_browser_index_js"],{
19
+
20
+ /***/ "../../paths/polygon/dist/browser/index.js"
21
+ /*!*************************************************!*\
22
+ !*** ../../paths/polygon/dist/browser/index.js ***!
23
+ \*************************************************/
24
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
25
+
26
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ loadPolygonPath: () => (/* binding */ loadPolygonPath),\n/* harmony export */ polygonPathName: () => (/* binding */ polygonPathName)\n/* harmony export */ });\nconst polygonPathName = \"polygonPathGenerator\";\nfunction loadPolygonPath(engine) {\n engine.checkVersion(\"4.0.0-alpha.0\");\n engine.register(async e => {\n const {\n PolygonPathGenerator\n } = await __webpack_require__.e(/*! import() */ \"paths_polygon_dist_browser_PolygonPathGenerator_js\").then(__webpack_require__.bind(__webpack_require__, /*! ./PolygonPathGenerator.js */ \"../../paths/polygon/dist/browser/PolygonPathGenerator.js\"));\n e.addPathGenerator(polygonPathName, new PolygonPathGenerator());\n });\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../paths/polygon/dist/browser/index.js?\n}");
27
+
28
+ /***/ }
29
+
30
+ }]);
@@ -0,0 +1,50 @@
1
+ /*!
2
+ * Author : Matteo Bruni
3
+ * MIT license: https://opensource.org/licenses/MIT
4
+ * Demo / Generator : https://particles.js.org/
5
+ * GitHub : https://www.github.com/matteobruni/tsparticles
6
+ * How to use? : Check the GitHub README
7
+ * v4.0.0-alpha.0
8
+ */
9
+ "use strict";
10
+ /*
11
+ * ATTENTION: The "eval" devtool has been used (maybe by default in mode: "development").
12
+ * This devtool is neither made for production nor for readable output files.
13
+ * It uses "eval()" calls to create a separate source file in the browser devtools.
14
+ * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
15
+ * or disable the default devtool with "devtool: false".
16
+ * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
17
+ */
18
+ (this["webpackChunk_tsparticles_all"] = this["webpackChunk_tsparticles_all"] || []).push([["paths_simplexNoise_dist_browser_SimplexNoiseGenerator_js"],{
19
+
20
+ /***/ "../../paths/simplexNoise/dist/browser/SimplexNoiseGenerator.js"
21
+ /*!**********************************************************************!*\
22
+ !*** ../../paths/simplexNoise/dist/browser/SimplexNoiseGenerator.js ***!
23
+ \**********************************************************************/
24
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
25
+
26
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ SimplexNoiseGenerator: () => (/* binding */ SimplexNoiseGenerator)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_noise_field__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/noise-field */ \"../../utils/noiseField/dist/browser/index.js\");\n/* harmony import */ var _tsparticles_simplex_noise__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @tsparticles/simplex-noise */ \"../../utils/simplexNoise/dist/browser/index.js\");\n\n\nclass SimplexNoiseGenerator extends _tsparticles_noise_field__WEBPACK_IMPORTED_MODULE_0__.NoiseFieldGenerator {\n constructor() {\n const simplex = new _tsparticles_simplex_noise__WEBPACK_IMPORTED_MODULE_1__.SimplexNoise();\n super({\n noise4d: (x, y, z, w) => simplex.noise4d.noise(x, y, z, w),\n seed: seed => {\n simplex.noise4d.seed(seed);\n }\n });\n }\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../paths/simplexNoise/dist/browser/SimplexNoiseGenerator.js?\n}");
27
+
28
+ /***/ },
29
+
30
+ /***/ "../../utils/noiseField/dist/browser/NoiseFieldGenerator.js"
31
+ /*!******************************************************************!*\
32
+ !*** ../../utils/noiseField/dist/browser/NoiseFieldGenerator.js ***!
33
+ \******************************************************************/
34
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
35
+
36
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ NoiseFieldGenerator: () => (/* binding */ NoiseFieldGenerator)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/engine */ \"../../engine/dist/browser/index.js\");\n\nconst originCoordinate = 0,\n firstIndex = 0,\n empty = 0,\n optionsSizeOffset = 1,\n transformDefaultValues = {\n a: 1,\n b: 0,\n c: 0,\n d: 1,\n e: 0,\n f: 0\n },\n double = 2,\n doublePI = Math.PI * double,\n defaultOptions = {\n draw: false,\n size: 20,\n increment: 0.004,\n columns: 0,\n rows: 0,\n layers: 0,\n width: 0,\n height: 0,\n factor: {\n angle: 0.02,\n length: 0.01\n },\n offset: {\n x: 40000,\n y: 40000,\n z: 40000\n }\n };\nclass NoiseFieldGenerator {\n constructor(noiseGen) {\n this.noiseGen = noiseGen;\n this.field = [];\n this.noiseW = 0;\n this.options = (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.deepExtend)({}, defaultOptions);\n }\n generate(particle) {\n const pos = particle.getPosition(),\n {\n size\n } = this.options,\n point = {\n x: Math.max(Math.floor(pos.x / size), originCoordinate),\n y: Math.max(Math.floor(pos.y / size), originCoordinate),\n z: Math.max(Math.floor(pos.z / size), originCoordinate)\n },\n {\n field\n } = this,\n fieldPoint = field[point.x]?.[point.y]?.[point.z];\n return fieldPoint ? fieldPoint.copy() : _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.Vector.origin;\n }\n init(container) {\n this.container = container;\n this._setup();\n }\n reset() {}\n update() {\n if (!this.container) {\n return;\n }\n this._calculateField();\n this.noiseW += this.options.increment;\n if (!this.options.draw) {\n return;\n }\n this.container.canvas.draw(ctx => {\n this._drawField(ctx);\n });\n }\n _calculateField() {\n const {\n field,\n noiseGen,\n options,\n noiseW\n } = this,\n lengthFactor = options.factor.length,\n angleFactor = options.factor.angle;\n for (let x = 0; x < options.columns; x++) {\n const xColumn = field[x];\n if (!xColumn) {\n continue;\n }\n for (let y = 0; y < options.rows; y++) {\n const yColumn = xColumn[y];\n if (!yColumn) {\n continue;\n }\n for (let z = 0; z < options.layers; z++) {\n const cell = yColumn[z];\n if (!cell) {\n continue;\n }\n cell.length = noiseGen.noise4d(x * lengthFactor + options.offset.x, y * lengthFactor + options.offset.y, z * lengthFactor + options.offset.z, noiseW);\n cell.angle = noiseGen.noise4d(x * angleFactor, y * angleFactor, z * angleFactor, noiseW) * doublePI;\n }\n }\n }\n }\n _drawField(ctx) {\n const {\n field,\n options\n } = this;\n for (let x = 0; x < options.columns; x++) {\n const xColumn = field[x];\n if (!xColumn) {\n continue;\n }\n for (let y = 0; y < options.rows; y++) {\n const yColumn = xColumn[y];\n if (!yColumn) {\n continue;\n }\n const cell = yColumn[firstIndex];\n if (!cell) {\n continue;\n }\n const {\n angle,\n length\n } = cell;\n ctx.setTransform(transformDefaultValues.a, transformDefaultValues.b, transformDefaultValues.c, transformDefaultValues.d, x * this.options.size, y * this.options.size);\n ctx.rotate(angle);\n ctx.strokeStyle = \"white\";\n ctx.beginPath();\n ctx.moveTo(originCoordinate, originCoordinate);\n ctx.lineTo(originCoordinate, this.options.size * length);\n ctx.stroke();\n ctx.setTransform(transformDefaultValues.a, transformDefaultValues.b, transformDefaultValues.c, transformDefaultValues.d, transformDefaultValues.e, transformDefaultValues.f);\n }\n }\n }\n _initField() {\n const {\n columns,\n rows,\n layers\n } = this.options;\n this.field = new Array(columns);\n for (let x = 0; x < columns; x++) {\n const newX = new Array(rows);\n for (let y = 0; y < rows; y++) {\n const newY = new Array(layers);\n for (let z = 0; z < layers; z++) {\n newY[z] = _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.Vector.origin;\n }\n newX[y] = newY;\n }\n this.field[x] = newX;\n }\n }\n _resetField() {\n const container = this.container;\n if (!container) {\n return;\n }\n const sourceOptions = container.actualOptions.particles.move.path.options,\n {\n options\n } = this;\n options.width = container.canvas.size.width;\n options.height = container.canvas.size.height;\n options.size = sourceOptions[\"size\"] > empty ? sourceOptions[\"size\"] : defaultOptions.size;\n options.increment = sourceOptions[\"increment\"] > empty ? sourceOptions[\"increment\"] : defaultOptions.increment;\n options.draw = !!sourceOptions[\"draw\"];\n const offset = sourceOptions[\"offset\"];\n options.offset.x = offset?.x ?? defaultOptions.offset.x;\n options.offset.y = offset?.y ?? defaultOptions.offset.y;\n options.offset.z = offset?.z ?? defaultOptions.offset.z;\n const factor = sourceOptions[\"factor\"];\n options.factor.angle = factor?.angle ?? defaultOptions.factor.angle;\n options.factor.length = factor?.length ?? defaultOptions.factor.length;\n options.seed = sourceOptions[\"seed\"];\n this.noiseGen.seed(options.seed ?? (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.getRandom)());\n options.columns = Math.floor(options.width / options.size) + optionsSizeOffset;\n options.rows = Math.floor(options.height / options.size) + optionsSizeOffset;\n options.layers = Math.floor(container.zLayers / options.size) + optionsSizeOffset;\n this._initField();\n }\n _setup() {\n this.noiseW = 0;\n this._resetField();\n addEventListener(\"resize\", () => {\n this._resetField();\n });\n }\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../utils/noiseField/dist/browser/NoiseFieldGenerator.js?\n}");
37
+
38
+ /***/ },
39
+
40
+ /***/ "../../utils/noiseField/dist/browser/index.js"
41
+ /*!****************************************************!*\
42
+ !*** ../../utils/noiseField/dist/browser/index.js ***!
43
+ \****************************************************/
44
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
45
+
46
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ NoiseFieldGenerator: () => (/* reexport safe */ _NoiseFieldGenerator_js__WEBPACK_IMPORTED_MODULE_0__.NoiseFieldGenerator)\n/* harmony export */ });\n/* harmony import */ var _NoiseFieldGenerator_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./NoiseFieldGenerator.js */ \"../../utils/noiseField/dist/browser/NoiseFieldGenerator.js\");\n\n\n//# sourceURL=webpack://@tsparticles/all/../../utils/noiseField/dist/browser/index.js?\n}");
47
+
48
+ /***/ }
49
+
50
+ }]);
@@ -0,0 +1,30 @@
1
+ /*!
2
+ * Author : Matteo Bruni
3
+ * MIT license: https://opensource.org/licenses/MIT
4
+ * Demo / Generator : https://particles.js.org/
5
+ * GitHub : https://www.github.com/matteobruni/tsparticles
6
+ * How to use? : Check the GitHub README
7
+ * v4.0.0-alpha.0
8
+ */
9
+ "use strict";
10
+ /*
11
+ * ATTENTION: The "eval" devtool has been used (maybe by default in mode: "development").
12
+ * This devtool is neither made for production nor for readable output files.
13
+ * It uses "eval()" calls to create a separate source file in the browser devtools.
14
+ * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
15
+ * or disable the default devtool with "devtool: false".
16
+ * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
17
+ */
18
+ (this["webpackChunk_tsparticles_all"] = this["webpackChunk_tsparticles_all"] || []).push([["paths_simplexNoise_dist_browser_index_js"],{
19
+
20
+ /***/ "../../paths/simplexNoise/dist/browser/index.js"
21
+ /*!******************************************************!*\
22
+ !*** ../../paths/simplexNoise/dist/browser/index.js ***!
23
+ \******************************************************/
24
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
25
+
26
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ loadSimplexNoisePath: () => (/* binding */ loadSimplexNoisePath),\n/* harmony export */ simplexNoisePathName: () => (/* binding */ simplexNoisePathName)\n/* harmony export */ });\nconst simplexNoisePathName = \"simplexNoise\";\nfunction loadSimplexNoisePath(engine) {\n engine.checkVersion(\"4.0.0-alpha.0\");\n engine.register(async e => {\n const {\n SimplexNoiseGenerator\n } = await Promise.all(/*! import() */[__webpack_require__.e(\"utils_simplexNoise_dist_browser_index_js\"), __webpack_require__.e(\"paths_simplexNoise_dist_browser_SimplexNoiseGenerator_js\")]).then(__webpack_require__.bind(__webpack_require__, /*! ./SimplexNoiseGenerator.js */ \"../../paths/simplexNoise/dist/browser/SimplexNoiseGenerator.js\"));\n e.addPathGenerator(simplexNoisePathName, new SimplexNoiseGenerator());\n });\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../paths/simplexNoise/dist/browser/index.js?\n}");
27
+
28
+ /***/ }
29
+
30
+ }]);
@@ -0,0 +1,30 @@
1
+ /*!
2
+ * Author : Matteo Bruni
3
+ * MIT license: https://opensource.org/licenses/MIT
4
+ * Demo / Generator : https://particles.js.org/
5
+ * GitHub : https://www.github.com/matteobruni/tsparticles
6
+ * How to use? : Check the GitHub README
7
+ * v4.0.0-alpha.0
8
+ */
9
+ "use strict";
10
+ /*
11
+ * ATTENTION: The "eval" devtool has been used (maybe by default in mode: "development").
12
+ * This devtool is neither made for production nor for readable output files.
13
+ * It uses "eval()" calls to create a separate source file in the browser devtools.
14
+ * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
15
+ * or disable the default devtool with "devtool: false".
16
+ * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
17
+ */
18
+ (this["webpackChunk_tsparticles_all"] = this["webpackChunk_tsparticles_all"] || []).push([["paths_svg_dist_browser_SVGPathGenerator_js"],{
19
+
20
+ /***/ "../../paths/svg/dist/browser/SVGPathGenerator.js"
21
+ /*!********************************************************!*\
22
+ !*** ../../paths/svg/dist/browser/SVGPathGenerator.js ***!
23
+ \********************************************************/
24
+ (__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) {
25
+
26
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ SVGPathGenerator: () => (/* binding */ SVGPathGenerator)\n/* harmony export */ });\n/* harmony import */ var _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @tsparticles/engine */ \"../../engine/dist/browser/index.js\");\n\nvar SVGPathDirection;\n(function (SVGPathDirection) {\n SVGPathDirection[SVGPathDirection[\"normal\"] = 0] = \"normal\";\n SVGPathDirection[SVGPathDirection[\"reverse\"] = 1] = \"reverse\";\n})(SVGPathDirection || (SVGPathDirection = {}));\nconst defaultSpeed = 1,\n minStep = 0,\n minIndex = 0,\n minWidth = 0,\n minScale = 1;\nclass SVGPathGenerator {\n constructor() {\n this._paths = [];\n this._reverse = false;\n this._size = {\n width: 0,\n height: 0\n };\n this._scale = 1;\n this._offset = {\n x: 0,\n y: 0,\n mode: _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.PixelMode.percent\n };\n this._width = 0;\n }\n generate(particle, delta) {\n const container = particle.container,\n pxRatio = container.retina.pixelRatio;\n particle.svgDirection ??= (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.getRandom)() > _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.half ? SVGPathDirection.normal : SVGPathDirection.reverse;\n particle.svgPathIndex ??= Math.floor((0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.getRandom)() * this._paths.length);\n particle.svgSpeed ??= particle.velocity.mult((particle.retina.moveSpeed ?? defaultSpeed) * _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.half).length;\n particle.svgStep ??= (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.randomInRangeValue)({\n min: 0,\n max: this._paths[particle.svgPathIndex].length\n }) * pxRatio;\n particle.svgOffset ??= {\n width: (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.randomInRangeValue)({\n min: -this._width * _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.half,\n max: this._width * _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.half\n }) * pxRatio,\n height: (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.randomInRangeValue)({\n min: -this._width * _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.half,\n max: this._width * _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.half\n }) * pxRatio\n };\n particle.svgInitialPosition ??= particle.position.copy();\n particle.velocity.x = 0;\n particle.velocity.y = 0;\n if (particle.svgDirection === SVGPathDirection.normal) {\n particle.svgStep += particle.svgSpeed * delta.factor;\n } else {\n particle.svgStep -= particle.svgSpeed * delta.factor;\n }\n let path = this._paths[particle.svgPathIndex];\n const pathLength = path.length,\n indexOffset = 1;\n if (particle.svgStep >= pathLength) {\n particle.svgPathIndex = particle.svgPathIndex + indexOffset;\n if (particle.svgPathIndex >= this._paths.length) {\n if (this._reverse) {\n particle.svgPathIndex = this._paths.length - indexOffset;\n particle.svgDirection = SVGPathDirection.reverse;\n } else {\n particle.svgPathIndex = 0;\n particle.svgStep = 0;\n }\n }\n } else if (particle.svgStep <= minStep) {\n particle.svgPathIndex = particle.svgPathIndex - indexOffset;\n if (particle.svgPathIndex < minIndex) {\n if (this._reverse) {\n particle.svgPathIndex = 0;\n particle.svgDirection = SVGPathDirection.normal;\n } else {\n particle.svgPathIndex = this._paths.length - indexOffset;\n path = this._paths[particle.svgPathIndex];\n particle.svgStep = path.length;\n }\n }\n }\n path = this._paths[particle.svgPathIndex];\n const pathElement = path.element,\n pos = pathElement.getPointAtLength(particle.svgStep),\n canvasSize = particle.container.canvas.size,\n offset = (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.getPosition)(this._offset, canvasSize),\n scale = this._scale * pxRatio;\n particle.position.x = (pos.x - this._size.width * _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.half) * scale + particle.svgInitialPosition.x + offset.x + particle.svgOffset.width;\n particle.position.y = (pos.y - this._size.height * _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.half) * scale + particle.svgInitialPosition.y + offset.y + particle.svgOffset.height;\n return _tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.Vector.origin;\n }\n init(container) {\n const options = container.actualOptions.particles.move.path.options,\n position = options.position ?? this._offset;\n this._reverse = options.reverse ?? this._reverse;\n this._scale = options.scale ?? minScale;\n this._offset.x = position.x;\n this._offset.y = position.y;\n this._offset.mode = position.mode;\n this._width = options.width ?? minWidth;\n if (options.url && !options.path) {\n const url = options.url;\n void (async () => {\n const response = await fetch(url),\n data = await response.text();\n const parser = new DOMParser(),\n doc = parser.parseFromString(data, \"image/svg+xml\"),\n firstIndex = 0,\n svg = doc.getElementsByTagName(\"svg\")[firstIndex];\n let svgPaths = svg.getElementsByTagName(\"path\");\n if (!svgPaths.length) {\n svgPaths = doc.getElementsByTagName(\"path\");\n }\n this._paths = [];\n for (let i = 0; i < svgPaths.length; i++) {\n const path = svgPaths.item(i);\n if (path) {\n this._paths.push({\n element: path,\n length: path.getTotalLength()\n });\n }\n }\n this._size.height = Number.parseFloat(svg.getAttribute(\"height\") ?? \"0\");\n this._size.width = Number.parseFloat(svg.getAttribute(\"width\") ?? \"0\");\n })();\n } else if (options.path) {\n const path = options.path;\n this._paths = [];\n for (const item of path.data) {\n const element = (0,_tsparticles_engine__WEBPACK_IMPORTED_MODULE_0__.safeDocument)().createElementNS(\"http://www.w3.org/2000/svg\", \"path\");\n element.setAttribute(\"d\", item);\n this._paths.push({\n element,\n length: element.getTotalLength()\n });\n }\n this._size.height = path.size.height;\n this._size.width = path.size.width;\n }\n }\n reset() {}\n update() {}\n}\n\n//# sourceURL=webpack://@tsparticles/all/../../paths/svg/dist/browser/SVGPathGenerator.js?\n}");
27
+
28
+ /***/ }
29
+
30
+ }]);