[![banner](https://particles.js.org/images/banner2.png)](https://particles.js.org) # tsParticles Full Bundle [![jsDelivr](https://data.jsdelivr.com/v1/package/npm/tsparticles/badge)](https://www.jsdelivr.com/package/npm/tsparticles) [![npmjs](https://badge.fury.io/js/tsparticles.svg)](https://www.npmjs.com/package/tsparticles) [![npmjs](https://img.shields.io/npm/dt/tsparticles)](https://www.npmjs.com/package/tsparticles) [![GitHub Sponsors](https://img.shields.io/github/sponsors/matteobruni)](https://github.com/sponsors/matteobruni) [tsParticles](https://github.com/matteobruni/tsparticles) full bundle loads all the v1 features to a `tsparticles-engine` instance. **Included Packages** - [tsparticles-engine](https://github.com/matteobruni/tsparticles/tree/main/engine) - [tsparticles-slim (and all its dependencies)](https://github.com/matteobruni/tsparticles/tree/main/bundles/slim) - [tsparticles-interaction-external-trail](https://github.com/matteobruni/tsparticles/tree/main/interactions/external/trail) - [tsparticles-plugin-absorbers](https://github.com/matteobruni/tsparticles/tree/main/plugins/absorbers) - [tsparticles-plugin-emitters](https://github.com/matteobruni/tsparticles/tree/main/plugins/emitters) - [tsparticles-updater-roll](https://github.com/matteobruni/tsparticles/tree/main/updaters/roll) - [tsparticles-updater-tilt](https://github.com/matteobruni/tsparticles/tree/main/updaters/tilt) - [tsparticles-updater-wobble](https://github.com/matteobruni/tsparticles/tree/main/updaters/wobble) ## How to use it ### CDN / Vanilla JS / jQuery The CDN/Vanilla version JS has two different files: - One is a bundle file with all the scripts included in a single file - One is a file including just the `loadFull` function to load the tsParticles full preset, all dependencies must be included manually #### Bundle Including the `tsparticles.bundle.min.js` file will work exactly like `v1`, you can start using the `tsParticles` instance in the same way. This is the easiest usage, since it's a single file with the same `v1` features. All new features will be added as external packages, this bundle is recommended for migrating from `v1` easily. #### Not Bundle This installation requires more work since all dependencies must be included in the page. Some lines above are all specified in the **Included Packages** section. A note about `tsparticles-slim` can be made: it's not mandatory to include all of its dependencies, the slim bundle file is enough, and if this is done the `tsparticles-engine` is not needed, since it's already bundled in the slim bundle. ### Usage Once the scripts are loaded you can set up `tsParticles` like this: ```javascript (async () => { await loadFull(tsParticles); // not needed if using the bundle script, required for any other installation await tsParticles.load("tsparticles", { /* options */ }); })(); ``` ### React.js / Preact / Inferno _The syntax for `React.js`, `Preact` and `Inferno` is the same_. This sample uses the class component syntax, but you can use hooks as well (if the library supports it). _Class Components_ ```typescript jsx import React from "react"; import Particles from "react-particles"; import type { Engine } from "tsparticles-engine"; import { loadFull } from "tsparticles"; export class ParticlesContainer extends PureComponent { // this customizes the component tsParticles installation async customInit(engine: Engine): Promise { // this adds the bundle to tsParticles await loadFull(engine); } render() { const options = { /* custom options */ }; return ; } } ``` _Hooks / Functional Components_ ```typescript jsx import React, { useCallback } from "react"; import Particles from "react-particles"; import type { Engine } from "tsparticles-engine"; import { loadFull } from "tsparticles"; export function ParticlesContainer(props: unknown) { // this customizes the component tsParticles installation const customInit = useCallback(async (engine: Engine) => { // this adds the bundle to tsParticles await loadFull(engine); }); const options = { /* custom options */ }; return ; } ``` ### Vue (2.x and 3.x) _The syntax for `Vue.js 2.x` and `3.x` is the same_ ```vue ``` ```js const options = { /* custom options */ }; async function particlesInit(engine: Engine): Promise { await loadFull(engine); } ``` ### Angular ```html ``` ```ts const options = { /* custom options */ }; async function particlesInit(engine: Engine): Promise { await loadFull(engine); } ``` ### Svelte ```sveltehtml ``` ```js let options = { /* custom options */ }; let particlesInit = async (engine) => { await loadFull(engine); }; ```