UNPKG

matrix-react-sdk

Version:
148 lines (145 loc) 24.5 kB
"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: 150, speed: 3, frameInterval: 15, alpha: 1.0, gradient: false }; class Confetti { 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, "colors", ["rgba(30,144,255,", "rgba(107,142,35,", "rgba(255,215,0,", "rgba(255,192,203,", "rgba(106,90,205,", "rgba(173,216,230,", "rgba(238,130,238,", "rgba(152,251,152,", "rgba(70,130,180,", "rgba(244,164,96,", "rgba(210,105,30,", "rgba(220,20,60,"]); (0, _defineProperty2.default)(this, "lastFrameTime", Date.now()); (0, _defineProperty2.default)(this, "particles", []); (0, _defineProperty2.default)(this, "waveAngle", 0); (0, _defineProperty2.default)(this, "isRunning", false); (0, _defineProperty2.default)(this, "start", async (canvas, timeout = 3000) => { if (!canvas) { return; } this.context = canvas.getContext("2d"); this.particles = []; const count = this.options.maxCount; while (this.particles.length < count) { this.particles.push(this.resetParticle({}, canvas.width, canvas.height)); } this.isRunning = true; this.runAnimation(); if (timeout) { window.setTimeout(this.stop, timeout); } }); (0, _defineProperty2.default)(this, "stop", async () => { this.isRunning = false; }); (0, _defineProperty2.default)(this, "resetParticle", (particle, width, height) => { particle.color = this.colors[Math.random() * this.colors.length | 0] + (this.options.alpha + ")"); if (this.options.gradient) { particle.color2 = this.colors[Math.random() * this.colors.length | 0] + (this.options.alpha + ")"); } else { particle.color2 = particle.color; } particle.x = Math.random() * width; particle.y = Math.random() * -height; particle.diameter = Math.random() * 10 + 5; particle.tilt = Math.random() * -10; particle.tiltAngleIncrement = Math.random() * 0.07 + 0.05; particle.tiltAngle = Math.random() * Math.PI; return particle; }); (0, _defineProperty2.default)(this, "runAnimation", () => { if (!this.context || !this.context.canvas) { return; } if (this.particles.length === 0) { this.context.clearRect(0, 0, this.context.canvas.width, this.context.canvas.height); } else { const now = Date.now(); const delta = now - this.lastFrameTime; if (!this.supportsAnimationFrame || delta > this.options.frameInterval) { this.context.clearRect(0, 0, this.context.canvas.width, this.context.canvas.height); this.updateParticles(); this.drawParticles(this.context); this.lastFrameTime = now - delta % this.options.frameInterval; } requestAnimationFrame(this.runAnimation); } }); (0, _defineProperty2.default)(this, "drawParticles", context => { if (!this.context || !this.context.canvas) { return; } let x; let x2; let y2; for (const particle of this.particles) { this.context.beginPath(); context.lineWidth = particle.diameter; x2 = particle.x + particle.tilt; x = x2 + particle.diameter / 2; y2 = particle.y + particle.tilt + particle.diameter / 2; if (this.options.gradient) { const gradient = context.createLinearGradient(x, particle.y, x2, y2); gradient.addColorStop(0, particle.color); gradient.addColorStop(1.0, particle.color2); context.strokeStyle = gradient; } else { context.strokeStyle = particle.color; } context.moveTo(x, particle.y); context.lineTo(x2, y2); context.stroke(); } }); (0, _defineProperty2.default)(this, "updateParticles", () => { if (!this.context || !this.context.canvas) { return; } const width = this.context.canvas.width; const height = this.context.canvas.height; let particle; this.waveAngle += 0.01; for (let i = 0; i < this.particles.length; i++) { particle = this.particles[i]; if (!this.isRunning && particle.y < -15) { particle.y = height + 100; } else { particle.tiltAngle += particle.tiltAngleIncrement; particle.x += Math.sin(this.waveAngle) - 0.5; particle.y += (Math.cos(this.waveAngle) + particle.diameter + this.options.speed) * 0.5; particle.tilt = Math.sin(particle.tiltAngle) * 15; } if (particle.x > width + 20 || particle.x < -20 || particle.y > height) { if (this.isRunning && this.particles.length <= this.options.maxCount) { this.resetParticle(particle, width, height); } else { this.particles.splice(i, 1); i--; } } } }); this.options = _objectSpread(_objectSpread({}, DefaultOptions), options); } } exports.default = Confetti; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["DefaultOptions","exports","maxCount","speed","frameInterval","alpha","gradient","Confetti","constructor","options","_defineProperty2","default","window","requestAnimationFrame","Date","now","canvas","timeout","context","getContext","particles","count","length","push","resetParticle","width","height","isRunning","runAnimation","setTimeout","stop","particle","color","colors","Math","random","color2","x","y","diameter","tilt","tiltAngleIncrement","tiltAngle","PI","clearRect","delta","lastFrameTime","supportsAnimationFrame","updateParticles","drawParticles","x2","y2","beginPath","lineWidth","createLinearGradient","addColorStop","strokeStyle","moveTo","lineTo","stroke","waveAngle","i","sin","cos","splice","_objectSpread"],"sources":["../../../src/effects/confetti/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 */\nimport ICanvasEffect from \"../ICanvasEffect\";\n\nexport type ConfettiOptions = {\n    /**\n     * max confetti count\n     */\n    maxCount: number;\n    /**\n     * particle animation speed\n     */\n    speed: number;\n    /**\n     * the confetti animation frame interval in milliseconds\n     */\n    frameInterval: number;\n    /**\n     * the alpha opacity of the confetti (between 0 and 1, where 1 is opaque and 0 is invisible)\n     */\n    alpha: number;\n    /**\n     * use gradient instead of solid particle color\n     */\n    gradient: boolean;\n};\n\ntype ConfettiParticle = {\n    color: string;\n    color2: string;\n    x: number;\n    y: number;\n    diameter: number;\n    tilt: number;\n    tiltAngleIncrement: number;\n    tiltAngle: number;\n};\n\nexport const DefaultOptions: ConfettiOptions = {\n    maxCount: 150,\n    speed: 3,\n    frameInterval: 15,\n    alpha: 1.0,\n    gradient: false,\n};\n\nexport default class Confetti implements ICanvasEffect {\n    private readonly options: ConfettiOptions;\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 colors = [\n        \"rgba(30,144,255,\",\n        \"rgba(107,142,35,\",\n        \"rgba(255,215,0,\",\n        \"rgba(255,192,203,\",\n        \"rgba(106,90,205,\",\n        \"rgba(173,216,230,\",\n        \"rgba(238,130,238,\",\n        \"rgba(152,251,152,\",\n        \"rgba(70,130,180,\",\n        \"rgba(244,164,96,\",\n        \"rgba(210,105,30,\",\n        \"rgba(220,20,60,\",\n    ];\n\n    private lastFrameTime = Date.now();\n    private particles: Array<ConfettiParticle> = [];\n    private waveAngle = 0;\n\n    public isRunning = false;\n\n    public start = async (canvas: HTMLCanvasElement, timeout = 3000): Promise<void> => {\n        if (!canvas) {\n            return;\n        }\n        this.context = canvas.getContext(\"2d\");\n        this.particles = [];\n        const count = this.options.maxCount;\n        while (this.particles.length < count) {\n            this.particles.push(this.resetParticle({} as ConfettiParticle, canvas.width, canvas.height));\n        }\n        this.isRunning = true;\n        this.runAnimation();\n        if (timeout) {\n            window.setTimeout(this.stop, timeout);\n        }\n    };\n\n    public stop = async (): Promise<void> => {\n        this.isRunning = false;\n    };\n\n    private resetParticle = (particle: ConfettiParticle, width: number, height: number): ConfettiParticle => {\n        particle.color = this.colors[(Math.random() * this.colors.length) | 0] + (this.options.alpha + \")\");\n        if (this.options.gradient) {\n            particle.color2 = this.colors[(Math.random() * this.colors.length) | 0] + (this.options.alpha + \")\");\n        } else {\n            particle.color2 = particle.color;\n        }\n        particle.x = Math.random() * width;\n        particle.y = Math.random() * -height;\n        particle.diameter = Math.random() * 10 + 5;\n        particle.tilt = Math.random() * -10;\n        particle.tiltAngleIncrement = Math.random() * 0.07 + 0.05;\n        particle.tiltAngle = Math.random() * Math.PI;\n        return particle;\n    };\n\n    private runAnimation = (): void => {\n        if (!this.context || !this.context.canvas) {\n            return;\n        }\n        if (this.particles.length === 0) {\n            this.context.clearRect(0, 0, this.context.canvas.width, this.context.canvas.height);\n        } else {\n            const now = Date.now();\n            const delta = now - this.lastFrameTime;\n            if (!this.supportsAnimationFrame || delta > this.options.frameInterval) {\n                this.context.clearRect(0, 0, this.context.canvas.width, this.context.canvas.height);\n                this.updateParticles();\n                this.drawParticles(this.context);\n                this.lastFrameTime = now - (delta % this.options.frameInterval);\n            }\n            requestAnimationFrame(this.runAnimation);\n        }\n    };\n\n    private drawParticles = (context: CanvasRenderingContext2D): void => {\n        if (!this.context || !this.context.canvas) {\n            return;\n        }\n        let x;\n        let x2;\n        let y2;\n        for (const particle of this.particles) {\n            this.context.beginPath();\n            context.lineWidth = particle.diameter;\n            x2 = particle.x + particle.tilt;\n            x = x2 + particle.diameter / 2;\n            y2 = particle.y + particle.tilt + particle.diameter / 2;\n            if (this.options.gradient) {\n                const gradient = context.createLinearGradient(x, particle.y, x2, y2);\n                gradient.addColorStop(0, particle.color);\n                gradient.addColorStop(1.0, particle.color2);\n                context.strokeStyle = gradient;\n            } else {\n                context.strokeStyle = particle.color;\n            }\n            context.moveTo(x, particle.y);\n            context.lineTo(x2, y2);\n            context.stroke();\n        }\n    };\n\n    private updateParticles = (): void => {\n        if (!this.context || !this.context.canvas) {\n            return;\n        }\n        const width = this.context.canvas.width;\n        const height = this.context.canvas.height;\n        let particle: ConfettiParticle;\n        this.waveAngle += 0.01;\n        for (let i = 0; i < this.particles.length; i++) {\n            particle = this.particles[i];\n            if (!this.isRunning && particle.y < -15) {\n                particle.y = height + 100;\n            } else {\n                particle.tiltAngle += particle.tiltAngleIncrement;\n                particle.x += Math.sin(this.waveAngle) - 0.5;\n                particle.y += (Math.cos(this.waveAngle) + particle.diameter + this.options.speed) * 0.5;\n                particle.tilt = Math.sin(particle.tiltAngle) * 15;\n            }\n            if (particle.x > width + 20 || particle.x < -20 || particle.y > height) {\n                if (this.isRunning && this.particles.length <= this.options.maxCount) {\n                    this.resetParticle(particle, width, height);\n                } else {\n                    this.particles.splice(i, 1);\n                    i--;\n                }\n            }\n        }\n    };\n}\n"],"mappings":"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","ignoreList":[]}