UNPKG

matrix-react-sdk

Version:
102 lines (99 loc) 17 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")); var _arrays = require("../../utils/arrays"); 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 2020-2023 The Matrix.org Foundation C.I.C. Copyright 2021 Josias Allestad 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: 600, speed: 12 }; const KEY_FRAME_INTERVAL = 15; class Rainfall { constructor(options) { (0, _defineProperty2.default)(this, "options", void 0); (0, _defineProperty2.default)(this, "context", null); (0, _defineProperty2.default)(this, "particles", []); (0, _defineProperty2.default)(this, "lastAnimationTime", 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; requestAnimationFrame(this.renderLoop); 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.x = Math.random() * width; particle.y = Math.random() * -height; particle.width = Math.random() * 1.5; particle.height = particle.width * 15 + 4; particle.speed = Math.random() * this.options.speed * 4 / 5 + this.options.speed; return particle; }); (0, _defineProperty2.default)(this, "renderLoop", () => { 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 timeDelta = Date.now() - this.lastAnimationTime; if (timeDelta >= KEY_FRAME_INTERVAL || !this.lastAnimationTime) { // Clear the screen first this.context.clearRect(0, 0, this.context.canvas.width, this.context.canvas.height); this.lastAnimationTime = Date.now(); this.animateAndRenderRaindrops(); } requestAnimationFrame(this.renderLoop); } }); (0, _defineProperty2.default)(this, "animateAndRenderRaindrops", () => { if (!this.context || !this.context.canvas) { return; } const height = this.context.canvas.height; for (const particle of (0, _arrays.arrayFastClone)(this.particles)) { particle.y += particle.speed; this.context.save(); this.context.beginPath(); this.context.rect(particle.x, particle.y, particle.width, particle.height); this.context.fillStyle = "#5dadec"; // light blue this.context.fill(); this.context.closePath(); this.context.restore(); // Remove dead raindrops const maxBounds = height * 2; if (particle.y > height + maxBounds) { const idx = this.particles.indexOf(particle); this.particles.splice(idx, 1); } } }); this.options = _objectSpread(_objectSpread({}, DefaultOptions), options); } } exports.default = Rainfall; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_arrays","require","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","default","getOwnPropertyDescriptors","defineProperties","defineProperty","DefaultOptions","exports","maxCount","speed","KEY_FRAME_INTERVAL","Rainfall","constructor","options","canvas","timeout","context","getContext","particles","count","resetParticle","width","height","isRunning","requestAnimationFrame","renderLoop","window","setTimeout","stop","particle","x","Math","random","y","clearRect","timeDelta","Date","now","lastAnimationTime","animateAndRenderRaindrops","arrayFastClone","save","beginPath","rect","fillStyle","fill","closePath","restore","maxBounds","idx","indexOf","splice"],"sources":["../../../src/effects/rainfall/index.ts"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2020-2023 The Matrix.org Foundation C.I.C.\nCopyright 2021 Josias Allestad\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\";\nimport { arrayFastClone } from \"../../utils/arrays\";\n\nexport type RainfallOptions = {\n    /**\n     * The maximum number of raindrops to render at a given time\n     */\n    maxCount: number;\n    /**\n     * The speed of the raindrops\n     */\n    speed: number;\n};\n\ntype Raindrop = {\n    x: number;\n    y: number;\n    height: number;\n    width: number;\n    speed: number;\n};\n\nexport const DefaultOptions: RainfallOptions = {\n    maxCount: 600,\n    speed: 12,\n};\n\nconst KEY_FRAME_INTERVAL = 15;\n\nexport default class Rainfall implements ICanvasEffect {\n    private readonly options: RainfallOptions;\n\n    public constructor(options: { [key: string]: any }) {\n        this.options = { ...DefaultOptions, ...options };\n    }\n\n    private context: CanvasRenderingContext2D | null = null;\n    private particles: Array<Raindrop> = [];\n    private lastAnimationTime = 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 Raindrop, canvas.width, canvas.height));\n        }\n        this.isRunning = true;\n        requestAnimationFrame(this.renderLoop);\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: Raindrop, width: number, height: number): Raindrop => {\n        particle.x = Math.random() * width;\n        particle.y = Math.random() * -height;\n        particle.width = Math.random() * 1.5;\n        particle.height = particle.width * 15 + 4;\n        particle.speed = (Math.random() * this.options.speed * 4) / 5 + this.options.speed;\n        return particle;\n    };\n\n    private renderLoop = (): 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 timeDelta = Date.now() - this.lastAnimationTime;\n            if (timeDelta >= KEY_FRAME_INTERVAL || !this.lastAnimationTime) {\n                // Clear the screen first\n                this.context.clearRect(0, 0, this.context.canvas.width, this.context.canvas.height);\n                this.lastAnimationTime = Date.now();\n                this.animateAndRenderRaindrops();\n            }\n            requestAnimationFrame(this.renderLoop);\n        }\n    };\n\n    private animateAndRenderRaindrops = (): void => {\n        if (!this.context || !this.context.canvas) {\n            return;\n        }\n        const height = this.context.canvas.height;\n        for (const particle of arrayFastClone(this.particles)) {\n            particle.y += particle.speed;\n\n            this.context.save();\n            this.context.beginPath();\n            this.context.rect(particle.x, particle.y, particle.width, particle.height);\n            this.context.fillStyle = \"#5dadec\"; // light blue\n            this.context.fill();\n            this.context.closePath();\n            this.context.restore();\n\n            // Remove dead raindrops\n            const maxBounds = height * 2;\n            if (particle.y > height + maxBounds) {\n                const idx = this.particles.indexOf(particle);\n                this.particles.splice(idx, 1);\n            }\n        }\n    };\n}\n"],"mappings":";;;;;;;;AASA,IAAAA,OAAA,GAAAC,OAAA;AAAoD,SAAAC,QAAAC,CAAA,EAAAC,CAAA,QAAAC,CAAA,GAAAC,MAAA,CAAAC,IAAA,CAAAJ,CAAA,OAAAG,MAAA,CAAAE,qBAAA,QAAAC,CAAA,GAAAH,MAAA,CAAAE,qBAAA,CAAAL,CAAA,GAAAC,CAAA,KAAAK,CAAA,GAAAA,CAAA,CAAAC,MAAA,WAAAN,CAAA,WAAAE,MAAA,CAAAK,wBAAA,CAAAR,CAAA,EAAAC,CAAA,EAAAQ,UAAA,OAAAP,CAAA,CAAAQ,IAAA,CAAAC,KAAA,CAAAT,CAAA,EAAAI,CAAA,YAAAJ,CAAA;AAAA,SAAAU,cAAAZ,CAAA,aAAAC,CAAA,MAAAA,CAAA,GAAAY,SAAA,CAAAC,MAAA,EAAAb,CAAA,UAAAC,CAAA,WAAAW,SAAA,CAAAZ,CAAA,IAAAY,SAAA,CAAAZ,CAAA,QAAAA,CAAA,OAAAF,OAAA,CAAAI,MAAA,CAAAD,CAAA,OAAAa,OAAA,WAAAd,CAAA,QAAAe,gBAAA,CAAAC,OAAA,EAAAjB,CAAA,EAAAC,CAAA,EAAAC,CAAA,CAAAD,CAAA,SAAAE,MAAA,CAAAe,yBAAA,GAAAf,MAAA,CAAAgB,gBAAA,CAAAnB,CAAA,EAAAG,MAAA,CAAAe,yBAAA,CAAAhB,CAAA,KAAAH,OAAA,CAAAI,MAAA,CAAAD,CAAA,GAAAa,OAAA,WAAAd,CAAA,IAAAE,MAAA,CAAAiB,cAAA,CAAApB,CAAA,EAAAC,CAAA,EAAAE,MAAA,CAAAK,wBAAA,CAAAN,CAAA,EAAAD,CAAA,iBAAAD,CAAA,IATpD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAuBO,MAAMqB,cAA+B,GAAAC,OAAA,CAAAD,cAAA,GAAG;EAC3CE,QAAQ,EAAE,GAAG;EACbC,KAAK,EAAE;AACX,CAAC;AAED,MAAMC,kBAAkB,GAAG,EAAE;AAEd,MAAMC,QAAQ,CAA0B;EAG5CC,WAAWA,CAACC,OAA+B,EAAE;IAAA,IAAAZ,gBAAA,CAAAC,OAAA;IAAA,IAAAD,gBAAA,CAAAC,OAAA,mBAID,IAAI;IAAA,IAAAD,gBAAA,CAAAC,OAAA,qBAClB,EAAE;IAAA,IAAAD,gBAAA,CAAAC,OAAA,6BACX,CAAC;IAAA,IAAAD,gBAAA,CAAAC,OAAA,qBAEV,KAAK;IAAA,IAAAD,gBAAA,CAAAC,OAAA,iBAET,OAAOY,MAAyB,EAAEC,OAAO,GAAG,IAAI,KAAoB;MAC/E,IAAI,CAACD,MAAM,EAAE;QACT;MACJ;MACA,IAAI,CAACE,OAAO,GAAGF,MAAM,CAACG,UAAU,CAAC,IAAI,CAAC;MACtC,IAAI,CAACC,SAAS,GAAG,EAAE;MACnB,MAAMC,KAAK,GAAG,IAAI,CAACN,OAAO,CAACL,QAAQ;MACnC,OAAO,IAAI,CAACU,SAAS,CAACnB,MAAM,GAAGoB,KAAK,EAAE;QAClC,IAAI,CAACD,SAAS,CAACvB,IAAI,CAAC,IAAI,CAACyB,aAAa,CAAC,CAAC,CAAC,EAAcN,MAAM,CAACO,KAAK,EAAEP,MAAM,CAACQ,MAAM,CAAC,CAAC;MACxF;MACA,IAAI,CAACC,SAAS,GAAG,IAAI;MACrBC,qBAAqB,CAAC,IAAI,CAACC,UAAU,CAAC;MACtC,IAAIV,OAAO,EAAE;QACTW,MAAM,CAACC,UAAU,CAAC,IAAI,CAACC,IAAI,EAAEb,OAAO,CAAC;MACzC;IACJ,CAAC;IAAA,IAAAd,gBAAA,CAAAC,OAAA,gBAEa,YAA2B;MACrC,IAAI,CAACqB,SAAS,GAAG,KAAK;IAC1B,CAAC;IAAA,IAAAtB,gBAAA,CAAAC,OAAA,yBAEuB,CAAC2B,QAAkB,EAAER,KAAa,EAAEC,MAAc,KAAe;MACrFO,QAAQ,CAACC,CAAC,GAAGC,IAAI,CAACC,MAAM,CAAC,CAAC,GAAGX,KAAK;MAClCQ,QAAQ,CAACI,CAAC,GAAGF,IAAI,CAACC,MAAM,CAAC,CAAC,GAAG,CAACV,MAAM;MACpCO,QAAQ,CAACR,KAAK,GAAGU,IAAI,CAACC,MAAM,CAAC,CAAC,GAAG,GAAG;MACpCH,QAAQ,CAACP,MAAM,GAAGO,QAAQ,CAACR,KAAK,GAAG,EAAE,GAAG,CAAC;MACzCQ,QAAQ,CAACpB,KAAK,GAAIsB,IAAI,CAACC,MAAM,CAAC,CAAC,GAAG,IAAI,CAACnB,OAAO,CAACJ,KAAK,GAAG,CAAC,GAAI,CAAC,GAAG,IAAI,CAACI,OAAO,CAACJ,KAAK;MAClF,OAAOoB,QAAQ;IACnB,CAAC;IAAA,IAAA5B,gBAAA,CAAAC,OAAA,sBAEoB,MAAY;MAC7B,IAAI,CAAC,IAAI,CAACc,OAAO,IAAI,CAAC,IAAI,CAACA,OAAO,CAACF,MAAM,EAAE;QACvC;MACJ;MACA,IAAI,IAAI,CAACI,SAAS,CAACnB,MAAM,KAAK,CAAC,EAAE;QAC7B,IAAI,CAACiB,OAAO,CAACkB,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,CAAClB,OAAO,CAACF,MAAM,CAACO,KAAK,EAAE,IAAI,CAACL,OAAO,CAACF,MAAM,CAACQ,MAAM,CAAC;MACvF,CAAC,MAAM;QACH,MAAMa,SAAS,GAAGC,IAAI,CAACC,GAAG,CAAC,CAAC,GAAG,IAAI,CAACC,iBAAiB;QACrD,IAAIH,SAAS,IAAIzB,kBAAkB,IAAI,CAAC,IAAI,CAAC4B,iBAAiB,EAAE;UAC5D;UACA,IAAI,CAACtB,OAAO,CAACkB,SAAS,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,CAAClB,OAAO,CAACF,MAAM,CAACO,KAAK,EAAE,IAAI,CAACL,OAAO,CAACF,MAAM,CAACQ,MAAM,CAAC;UACnF,IAAI,CAACgB,iBAAiB,GAAGF,IAAI,CAACC,GAAG,CAAC,CAAC;UACnC,IAAI,CAACE,yBAAyB,CAAC,CAAC;QACpC;QACAf,qBAAqB,CAAC,IAAI,CAACC,UAAU,CAAC;MAC1C;IACJ,CAAC;IAAA,IAAAxB,gBAAA,CAAAC,OAAA,qCAEmC,MAAY;MAC5C,IAAI,CAAC,IAAI,CAACc,OAAO,IAAI,CAAC,IAAI,CAACA,OAAO,CAACF,MAAM,EAAE;QACvC;MACJ;MACA,MAAMQ,MAAM,GAAG,IAAI,CAACN,OAAO,CAACF,MAAM,CAACQ,MAAM;MACzC,KAAK,MAAMO,QAAQ,IAAI,IAAAW,sBAAc,EAAC,IAAI,CAACtB,SAAS,CAAC,EAAE;QACnDW,QAAQ,CAACI,CAAC,IAAIJ,QAAQ,CAACpB,KAAK;QAE5B,IAAI,CAACO,OAAO,CAACyB,IAAI,CAAC,CAAC;QACnB,IAAI,CAACzB,OAAO,CAAC0B,SAAS,CAAC,CAAC;QACxB,IAAI,CAAC1B,OAAO,CAAC2B,IAAI,CAACd,QAAQ,CAACC,CAAC,EAAED,QAAQ,CAACI,CAAC,EAAEJ,QAAQ,CAACR,KAAK,EAAEQ,QAAQ,CAACP,MAAM,CAAC;QAC1E,IAAI,CAACN,OAAO,CAAC4B,SAAS,GAAG,SAAS,CAAC,CAAC;QACpC,IAAI,CAAC5B,OAAO,CAAC6B,IAAI,CAAC,CAAC;QACnB,IAAI,CAAC7B,OAAO,CAAC8B,SAAS,CAAC,CAAC;QACxB,IAAI,CAAC9B,OAAO,CAAC+B,OAAO,CAAC,CAAC;;QAEtB;QACA,MAAMC,SAAS,GAAG1B,MAAM,GAAG,CAAC;QAC5B,IAAIO,QAAQ,CAACI,CAAC,GAAGX,MAAM,GAAG0B,SAAS,EAAE;UACjC,MAAMC,GAAG,GAAG,IAAI,CAAC/B,SAAS,CAACgC,OAAO,CAACrB,QAAQ,CAAC;UAC5C,IAAI,CAACX,SAAS,CAACiC,MAAM,CAACF,GAAG,EAAE,CAAC,CAAC;QACjC;MACJ;IACJ,CAAC;IAhFG,IAAI,CAACpC,OAAO,GAAAhB,aAAA,CAAAA,aAAA,KAAQS,cAAc,GAAKO,OAAO,CAAE;EACpD;AAgFJ;AAACN,OAAA,CAAAL,OAAA,GAAAS,QAAA","ignoreList":[]}