114 lines
4.8 KiB
JavaScript
114 lines
4.8 KiB
JavaScript
import { executeOnSingleOrMultiple, isInArray } from "tsparticles-engine";
|
|
import { CircleShape } from "./Shapes/Circle/CircleShape";
|
|
import { Emitter } from "./Options/Classes/Emitter";
|
|
import { Emitters } from "./Emitters";
|
|
import { ShapeManager } from "./ShapeManager";
|
|
import { SquareShape } from "./Shapes/Square/SquareShape";
|
|
class EmittersPlugin {
|
|
constructor(engine) {
|
|
this._engine = engine;
|
|
this.id = "emitters";
|
|
}
|
|
getPlugin(container) {
|
|
return new Emitters(this._engine, container);
|
|
}
|
|
loadOptions(options, source) {
|
|
var _a, _b, _c, _d, _e, _f;
|
|
if (!this.needsPlugin(options) && !this.needsPlugin(source)) {
|
|
return;
|
|
}
|
|
if (source === null || source === void 0 ? void 0 : source.emitters) {
|
|
options.emitters = executeOnSingleOrMultiple(source.emitters, (emitter) => {
|
|
const tmp = new Emitter();
|
|
tmp.load(emitter);
|
|
return tmp;
|
|
});
|
|
}
|
|
const interactivityEmitters = (_b = (_a = source === null || source === void 0 ? void 0 : source.interactivity) === null || _a === void 0 ? void 0 : _a.modes) === null || _b === void 0 ? void 0 : _b.emitters;
|
|
if (interactivityEmitters) {
|
|
if (interactivityEmitters instanceof Array) {
|
|
options.interactivity.modes.emitters = {
|
|
random: {
|
|
count: 1,
|
|
enable: true,
|
|
},
|
|
value: interactivityEmitters.map((s) => {
|
|
const tmp = new Emitter();
|
|
tmp.load(s);
|
|
return tmp;
|
|
}),
|
|
};
|
|
}
|
|
else {
|
|
const emitterMode = interactivityEmitters;
|
|
if (emitterMode.value !== undefined) {
|
|
if (emitterMode.value instanceof Array) {
|
|
options.interactivity.modes.emitters = {
|
|
random: {
|
|
count: (_c = emitterMode.random.count) !== null && _c !== void 0 ? _c : 1,
|
|
enable: (_d = emitterMode.random.enable) !== null && _d !== void 0 ? _d : false,
|
|
},
|
|
value: emitterMode.value.map((s) => {
|
|
const tmp = new Emitter();
|
|
tmp.load(s);
|
|
return tmp;
|
|
}),
|
|
};
|
|
}
|
|
else {
|
|
const tmp = new Emitter();
|
|
tmp.load(emitterMode.value);
|
|
options.interactivity.modes.emitters = {
|
|
random: {
|
|
count: (_e = emitterMode.random.count) !== null && _e !== void 0 ? _e : 1,
|
|
enable: (_f = emitterMode.random.enable) !== null && _f !== void 0 ? _f : false,
|
|
},
|
|
value: tmp,
|
|
};
|
|
}
|
|
}
|
|
else {
|
|
const emitterOptions = (options.interactivity.modes.emitters = {
|
|
random: {
|
|
count: 1,
|
|
enable: false,
|
|
},
|
|
value: new Emitter(),
|
|
});
|
|
emitterOptions.value.load(interactivityEmitters);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
needsPlugin(options) {
|
|
var _a, _b, _c;
|
|
if (!options) {
|
|
return false;
|
|
}
|
|
const emitters = options.emitters;
|
|
return ((emitters instanceof Array && !!emitters.length) ||
|
|
emitters !== undefined ||
|
|
(!!((_c = (_b = (_a = options.interactivity) === null || _a === void 0 ? void 0 : _a.events) === null || _b === void 0 ? void 0 : _b.onClick) === null || _c === void 0 ? void 0 : _c.mode) &&
|
|
isInArray("emitter", options.interactivity.events.onClick.mode)));
|
|
}
|
|
}
|
|
export async function loadEmittersPlugin(engine) {
|
|
if (!engine.emitterShapeManager) {
|
|
engine.emitterShapeManager = new ShapeManager(engine);
|
|
}
|
|
if (!engine.addEmitterShape) {
|
|
engine.addEmitterShape = (name, shape) => {
|
|
var _a;
|
|
(_a = engine.emitterShapeManager) === null || _a === void 0 ? void 0 : _a.addShape(name, shape);
|
|
};
|
|
}
|
|
const plugin = new EmittersPlugin(engine);
|
|
await engine.addPlugin(plugin);
|
|
engine.addEmitterShape("circle", new CircleShape());
|
|
engine.addEmitterShape("square", new SquareShape());
|
|
}
|
|
export * from "./EmitterContainer";
|
|
export * from "./EmittersEngine";
|
|
export * from "./Enums/EmitterClickMode";
|
|
export * from "./Enums/EmitterShapeType";
|