matrix-react-sdk
Version:
SDK for matrix.org using React
123 lines (120 loc) • 21 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = exports.DefaultOptions = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2.default)(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
/*
Copyright 2024 New Vector Ltd.
Copyright 2023 The Matrix.org Foundation C.I.C.
Copyright 2020 Nurjin Jafar
Copyright 2020 Nordeck IT + Consulting GmbH.
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
Please see LICENSE files in the repository root for full details.
*/
const DefaultOptions = exports.DefaultOptions = {
maxCount: 500,
gravity: 0.05
};
class Fireworks {
constructor(options) {
(0, _defineProperty2.default)(this, "options", void 0);
(0, _defineProperty2.default)(this, "context", null);
(0, _defineProperty2.default)(this, "supportsAnimationFrame", window.requestAnimationFrame);
(0, _defineProperty2.default)(this, "particles", []);
(0, _defineProperty2.default)(this, "isRunning", false);
(0, _defineProperty2.default)(this, "start", async (canvas, timeout = 3000) => {
if (!canvas) {
return;
}
this.isRunning = true;
this.context = canvas.getContext("2d");
this.supportsAnimationFrame.call(window, this.updateWorld);
if (timeout) {
window.setTimeout(this.stop, timeout);
}
});
(0, _defineProperty2.default)(this, "updateWorld", () => {
if (!this.isRunning && this.particles.length === 0) return;
this.update();
this.paint();
this.supportsAnimationFrame.call(window, this.updateWorld);
});
(0, _defineProperty2.default)(this, "update", () => {
if (this.particles.length < this.options.maxCount && this.isRunning) {
this.createFirework();
}
const alive = [];
for (let i = 0; i < this.particles.length; i++) {
if (this.move(this.particles[i])) {
alive.push(this.particles[i]);
}
}
this.particles = alive;
});
(0, _defineProperty2.default)(this, "paint", () => {
if (!this.context || !this.context.canvas) return;
this.context.globalCompositeOperation = "destination-out";
this.context.fillStyle = "rgba(0,0,0,0.5)";
this.context.fillRect(0, 0, this.context.canvas.width, this.context.canvas.height);
this.context.globalCompositeOperation = "lighter";
for (let i = 0; i < this.particles.length; i++) {
this.drawParticle(this.particles[i]);
}
});
(0, _defineProperty2.default)(this, "createFirework", () => {
if (!this.context || !this.context.canvas) return;
const width = this.context.canvas.width;
const height = this.context.canvas.height;
const xPoint = Math.random() * (width - 200) + 100;
const yPoint = Math.random() * (height - 200) + 100;
const nFire = Math.random() * 50 + 100;
const color = "rgb(" + ~~(Math.random() * 200 + 55) + "," + ~~(Math.random() * 200 + 55) + "," + ~~(Math.random() * 200 + 55) + ")";
for (let i = 0; i < nFire; i++) {
const particle = {};
particle.color = color;
particle.w = particle.h = Math.random() * 4 + 1;
particle.x = xPoint - particle.w / 2;
particle.y = yPoint - particle.h / 2;
particle.vx = (Math.random() - 0.5) * 10;
particle.vy = (Math.random() - 0.5) * 10;
particle.alpha = Math.random() * 0.5 + 0.5;
const vy = Math.sqrt(25 - particle.vx * particle.vx);
if (Math.abs(particle.vy) > vy) {
particle.vy = particle.vy > 0 ? vy : -vy;
}
this.particles.push(particle);
}
});
(0, _defineProperty2.default)(this, "stop", async () => {
this.isRunning = false;
});
(0, _defineProperty2.default)(this, "drawParticle", particle => {
if (!this.context || !this.context.canvas) {
return;
}
this.context.save();
this.context.beginPath();
this.context.translate(particle.x + particle.w / 2, particle.y + particle.h / 2);
this.context.arc(0, 0, particle.w, 0, Math.PI * 2);
this.context.fillStyle = particle.color;
this.context.globalAlpha = particle.alpha;
this.context.closePath();
this.context.fill();
this.context.restore();
});
(0, _defineProperty2.default)(this, "move", particle => {
particle.x += particle.vx;
particle.vy += this.options.gravity;
particle.y += particle.vy;
particle.alpha -= 0.01;
return !(particle.x <= -particle.w || particle.x >= screen.width || particle.y >= screen.height || particle.alpha <= 0);
});
this.options = _objectSpread(_objectSpread({}, DefaultOptions), options);
}
}
exports.default = Fireworks;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["DefaultOptions","exports","maxCount","gravity","Fireworks","constructor","options","_defineProperty2","default","window","requestAnimationFrame","canvas","timeout","isRunning","context","getContext","supportsAnimationFrame","call","updateWorld","setTimeout","stop","particles","length","update","paint","createFirework","alive","i","move","push","globalCompositeOperation","fillStyle","fillRect","width","height","drawParticle","xPoint","Math","random","yPoint","nFire","color","particle","w","h","x","y","vx","vy","alpha","sqrt","abs","save","beginPath","translate","arc","PI","globalAlpha","closePath","fill","restore","screen","_objectSpread"],"sources":["../../../src/effects/fireworks/index.ts"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2023 The Matrix.org Foundation C.I.C.\nCopyright 2020 Nurjin Jafar\nCopyright 2020 Nordeck IT + Consulting GmbH.\n\nSPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only\nPlease see LICENSE files in the repository root for full details.\n */\n\nimport ICanvasEffect from \"../ICanvasEffect\";\n\nexport type FireworksOptions = {\n    /**\n     * max fireworks count\n     */\n    maxCount: number;\n    /**\n     * gravity value that firework adds to shift from it's start position\n     */\n    gravity: number;\n};\n\ntype FireworksParticle = {\n    /**\n     * color\n     */\n    color: string;\n    /**\n     * x,y are the point where the particle starts to position on canvas\n     */\n    x: number;\n    y: number;\n    /**\n     * vx,vy shift values from x and y\n     */\n    vx: number;\n    vy: number;\n    /**\n     * the alpha opacity of the firework particle (between 0 and 1, where 1 is opaque and 0 is invisible)\n     */\n    alpha: number;\n    /**\n     * w,h width and height\n     */\n    w: number;\n    h: number;\n};\n\nexport const DefaultOptions: FireworksOptions = {\n    maxCount: 500,\n    gravity: 0.05,\n};\n\nexport default class Fireworks implements ICanvasEffect {\n    private readonly options: FireworksOptions;\n\n    public constructor(options: { [key: string]: any }) {\n        this.options = { ...DefaultOptions, ...options };\n    }\n\n    private context: CanvasRenderingContext2D | null = null;\n    private supportsAnimationFrame = window.requestAnimationFrame;\n    private particles: Array<FireworksParticle> = [];\n    public isRunning = false;\n\n    public start = async (canvas: HTMLCanvasElement, timeout = 3000): Promise<void> => {\n        if (!canvas) {\n            return;\n        }\n        this.isRunning = true;\n        this.context = canvas.getContext(\"2d\");\n        this.supportsAnimationFrame.call(window, this.updateWorld);\n        if (timeout) {\n            window.setTimeout(this.stop, timeout);\n        }\n    };\n\n    private updateWorld = (): void => {\n        if (!this.isRunning && this.particles.length === 0) return;\n        this.update();\n        this.paint();\n        this.supportsAnimationFrame.call(window, this.updateWorld);\n    };\n\n    private update = (): void => {\n        if (this.particles.length < this.options.maxCount && this.isRunning) {\n            this.createFirework();\n        }\n        const alive: FireworksParticle[] = [];\n        for (let i = 0; i < this.particles.length; i++) {\n            if (this.move(this.particles[i])) {\n                alive.push(this.particles[i]);\n            }\n        }\n        this.particles = alive;\n    };\n\n    private paint = (): void => {\n        if (!this.context || !this.context.canvas) return;\n        this.context.globalCompositeOperation = \"destination-out\";\n        this.context.fillStyle = \"rgba(0,0,0,0.5)\";\n        this.context.fillRect(0, 0, this.context.canvas.width, this.context.canvas.height);\n        this.context.globalCompositeOperation = \"lighter\";\n        for (let i = 0; i < this.particles.length; i++) {\n            this.drawParticle(this.particles[i]);\n        }\n    };\n\n    private createFirework = (): void => {\n        if (!this.context || !this.context.canvas) return;\n        const width = this.context.canvas.width;\n        const height = this.context.canvas.height;\n        const xPoint = Math.random() * (width - 200) + 100;\n        const yPoint = Math.random() * (height - 200) + 100;\n        const nFire = Math.random() * 50 + 100;\n        const color =\n            \"rgb(\" +\n            ~~(Math.random() * 200 + 55) +\n            \",\" +\n            ~~(Math.random() * 200 + 55) +\n            \",\" +\n            ~~(Math.random() * 200 + 55) +\n            \")\";\n        for (let i = 0; i < nFire; i++) {\n            const particle = <FireworksParticle>{};\n            particle.color = color;\n            particle.w = particle.h = Math.random() * 4 + 1;\n            particle.x = xPoint - particle.w / 2;\n            particle.y = yPoint - particle.h / 2;\n            particle.vx = (Math.random() - 0.5) * 10;\n            particle.vy = (Math.random() - 0.5) * 10;\n            particle.alpha = Math.random() * 0.5 + 0.5;\n            const vy = Math.sqrt(25 - particle.vx * particle.vx);\n            if (Math.abs(particle.vy) > vy) {\n                particle.vy = particle.vy > 0 ? vy : -vy;\n            }\n            this.particles.push(particle);\n        }\n    };\n\n    public stop = async (): Promise<void> => {\n        this.isRunning = false;\n    };\n\n    private drawParticle = (particle: FireworksParticle): void => {\n        if (!this.context || !this.context.canvas) {\n            return;\n        }\n        this.context.save();\n        this.context.beginPath();\n\n        this.context.translate(particle.x + particle.w / 2, particle.y + particle.h / 2);\n        this.context.arc(0, 0, particle.w, 0, Math.PI * 2);\n        this.context.fillStyle = particle.color;\n        this.context.globalAlpha = particle.alpha;\n\n        this.context.closePath();\n        this.context.fill();\n        this.context.restore();\n    };\n\n    private move = (particle: FireworksParticle): boolean => {\n        particle.x += particle.vx;\n        particle.vy += this.options.gravity;\n        particle.y += particle.vy;\n        particle.alpha -= 0.01;\n        return !(\n            particle.x <= -particle.w ||\n            particle.x >= screen.width ||\n            particle.y >= screen.height ||\n            particle.alpha <= 0\n        );\n    };\n}\n"],"mappings":"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","ignoreList":[]}