tsparticles/vue3

docs are incorrect

OguzcanKarakoc opened this issue · 3 comments

The docs state that you have to do

import Particles from "vue3-particles";
const app = createApp(App).use(Particles)

however this shows an error from ts.

(alias) const Particles: (app: App, options: unknown) => void
import Particles
Argument of type '(app: App<any>, options: unknown) => void' is not assignable to parameter of type 'Plugin_2<[]>'.
  Type '(app: App<any>, options: unknown) => void' is not assignable to type '((app: App<any>) => any) & { install?: ((app: App<any>) => any) | undefined; }'.
    Type '(app: App<any>, options: unknown) => void' is not assignable to type '(app: App<any>) => any'.ts(2345)

The proper way to do it is:

import Particles from "vue3-particles";

const app = createApp(App)

Particles(app, {})

because the function Particles seems to take care of it,

src/components/index.ts

import type { App } from "vue";
import particles from "./Particles.vue";

const VueParticles = (app: App, options: unknown) => {
    app.component("Particles", particles);
};

export { particles as ParticlesComponent };
export default VueParticles;

Also it would be nice to add that this library requires tsparticles

npm i tsparticles

The docs state that you have to do

import Particles from "vue3-particles";
const app = createApp(App).use(Particles)

however this shows an error from ts.

(alias) const Particles: (app: App, options: unknown) => void
import Particles
Argument of type '(app: App<any>, options: unknown) => void' is not assignable to parameter of type 'Plugin_2<[]>'.
  Type '(app: App<any>, options: unknown) => void' is not assignable to type '((app: App<any>) => any) & { install?: ((app: App<any>) => any) | undefined; }'.
    Type '(app: App<any>, options: unknown) => void' is not assignable to type '(app: App<any>) => any'.ts(2345)

The proper way to do it is:

import Particles from "vue3-particles";

const app = createApp(App)

Particles(app, {})

because the function Particles seems to take care of it,

src/components/index.ts

import type { App } from "vue";
import particles from "./Particles.vue";

const VueParticles = (app: App, options: unknown) => {
    app.component("Particles", particles);
};

export { particles as ParticlesComponent };
export default VueParticles;

Also it would be nice to add that this library requires tsparticles

npm i tsparticles

There's a type issue in the latest vue 3.x version that break compatibility, I will publish an update when ready.

About tsparticles dependency, it's not mandatory since you can install any other preset or tsparticles-slim or add plugins manually.

emerg commented

Hi @matteobruni, I'm also having a hard time following the docs. I think that it would be helpful to make them a little more clear in terms of where/what files to add some of this code to. For instance, as a plugin file and then configured throught the nuxt.config.ts file? I'm having a hard time getting things to work, but I feel I am missing something simple. I am using Vue/Nuxt 3. (nuxt 3.5.2 & vue3-particles 2.10.1) I was getting a page with the particles component, but no particles, and no error logs to understand why it wasnt working. Any help would be deeply appreciated!

Hi @matteobruni, I'm also having a hard time following the docs. I think that it would be helpful to make them a little more clear in terms of where/what files to add some of this code to. For instance, as a plugin file and then configured throught the nuxt.config.ts file? I'm having a hard time getting things to work, but I feel I am missing something simple. I am using Vue/Nuxt 3. (nuxt 3.5.2 & vue3-particles 2.10.1) I was getting a page with the particles component, but no particles, and no error logs to understand why it wasnt working. Any help would be deeply appreciated!

This is unrelated to this issue, please open a new one. This issue was solved with the release of 2.10.