matrix-react-sdk
Version:
SDK for matrix.org using React
103 lines (100 loc) • 16.8 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _react = _interopRequireWildcard(require("react"));
var _logger = require("matrix-js-sdk/src/logger");
var _dispatcher = _interopRequireDefault(require("../../../dispatcher/dispatcher"));
var _effects = require("../../../effects");
var _UIStore = _interopRequireWildcard(require("../../../stores/UIStore"));
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } /*
Copyright 2024 New Vector Ltd.
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 EffectsOverlay = ({
roomWidth
}) => {
const canvasRef = (0, _react.useRef)(null);
const effectsRef = (0, _react.useRef)(new Map());
const lazyLoadEffectModule = async name => {
if (!name) return null;
let effect = effectsRef.current.get(name) || null;
if (effect === null) {
const options = _effects.CHAT_EFFECTS.find(e => e.command === name)?.options;
try {
const {
default: Effect
} = await (specifier => new Promise(r => r(specifier)).then(s => _interopRequireWildcard(require(s))))(`../../../effects/${name}`);
effect = new Effect(options);
effectsRef.current.set(name, effect);
} catch (err) {
_logger.logger.warn(`Unable to load effect module at '../../../effects/${name}.`, err);
}
}
return effect;
};
(0, _react.useEffect)(() => {
const resize = () => {
if (canvasRef.current && canvasRef.current?.height !== _UIStore.default.instance.windowHeight) {
canvasRef.current.height = _UIStore.default.instance.windowHeight;
}
};
const onAction = payload => {
const actionPrefix = "effects.";
const isOutdated = isEventOutdated(payload.event);
if (canvasRef.current && payload.action.startsWith(actionPrefix) && !isOutdated) {
const effect = payload.action.slice(actionPrefix.length);
lazyLoadEffectModule(effect).then(module => module?.start(canvasRef.current));
}
};
const dispatcherRef = _dispatcher.default.register(onAction);
const canvas = canvasRef.current;
if (canvas) canvas.height = _UIStore.default.instance.windowHeight;
_UIStore.default.instance.on(_UIStore.UI_EVENTS.Resize, resize);
return () => {
_dispatcher.default.unregister(dispatcherRef);
_UIStore.default.instance.off(_UIStore.UI_EVENTS.Resize, resize);
// eslint-disable-next-line react-hooks/exhaustive-deps
const currentEffects = effectsRef.current; // this is not a react node ref, warning can be safely ignored
for (const effect in currentEffects) {
const effectModule = currentEffects.get(effect);
if (effectModule && effectModule.isRunning) {
effectModule.stop();
}
}
};
}, []);
return /*#__PURE__*/_react.default.createElement("canvas", {
ref: canvasRef,
width: roomWidth,
style: {
display: "block",
zIndex: 999999,
pointerEvents: "none",
position: "fixed",
top: 0,
right: 0
},
"aria-hidden": true
});
};
var _default = exports.default = EffectsOverlay; // 48 hours
// 48h * 60m * 60s * 1000ms
const OUTDATED_EVENT_THRESHOLD = 48 * 60 * 60 * 1000;
/**
* Return true if the event is older than 48h.
* @param event
*/
function isEventOutdated(event) {
if (!event) return false;
const nowTs = Date.now();
const eventTs = event.getTs();
return nowTs - eventTs > OUTDATED_EVENT_THRESHOLD;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_logger","_dispatcher","_interopRequireDefault","_effects","_UIStore","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","EffectsOverlay","roomWidth","canvasRef","useRef","effectsRef","Map","lazyLoadEffectModule","name","effect","current","options","CHAT_EFFECTS","find","command","Effect","specifier","Promise","then","s","err","logger","warn","useEffect","resize","height","UIStore","instance","windowHeight","onAction","payload","actionPrefix","isOutdated","isEventOutdated","event","action","startsWith","slice","length","module","start","dispatcherRef","dis","register","canvas","on","UI_EVENTS","Resize","unregister","off","currentEffects","effectModule","isRunning","stop","createElement","ref","width","style","display","zIndex","pointerEvents","position","top","right","_default","exports","OUTDATED_EVENT_THRESHOLD","nowTs","Date","now","eventTs","getTs"],"sources":["../../../../src/components/views/elements/EffectsOverlay.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\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 React, { FunctionComponent, useEffect, useRef } from \"react\";\nimport { logger } from \"matrix-js-sdk/src/logger\";\nimport { MatrixEvent } from \"matrix-js-sdk/src/matrix\";\n\nimport dis from \"../../../dispatcher/dispatcher\";\nimport ICanvasEffect from \"../../../effects/ICanvasEffect\";\nimport { CHAT_EFFECTS } from \"../../../effects\";\nimport UIStore, { UI_EVENTS } from \"../../../stores/UIStore\";\n\ninterface IProps {\n    roomWidth: number;\n}\n\nconst EffectsOverlay: FunctionComponent<IProps> = ({ roomWidth }) => {\n    const canvasRef = useRef<HTMLCanvasElement>(null);\n    const effectsRef = useRef<Map<string, ICanvasEffect>>(new Map<string, ICanvasEffect>());\n\n    const lazyLoadEffectModule = async (name: string): Promise<ICanvasEffect | null> => {\n        if (!name) return null;\n        let effect: ICanvasEffect | null = effectsRef.current.get(name) || null;\n        if (effect === null) {\n            const options = CHAT_EFFECTS.find((e) => e.command === name)?.options;\n            try {\n                const { default: Effect } = await import(`../../../effects/${name}`);\n                effect = new Effect(options);\n                effectsRef.current.set(name, effect!);\n            } catch (err) {\n                logger.warn(`Unable to load effect module at '../../../effects/${name}.`, err);\n            }\n        }\n        return effect;\n    };\n\n    useEffect(() => {\n        const resize = (): void => {\n            if (canvasRef.current && canvasRef.current?.height !== UIStore.instance.windowHeight) {\n                canvasRef.current.height = UIStore.instance.windowHeight;\n            }\n        };\n        const onAction = (payload: { action: string; event?: MatrixEvent }): void => {\n            const actionPrefix = \"effects.\";\n            const isOutdated = isEventOutdated(payload.event);\n            if (canvasRef.current && payload.action.startsWith(actionPrefix) && !isOutdated) {\n                const effect = payload.action.slice(actionPrefix.length);\n                lazyLoadEffectModule(effect).then((module) => module?.start(canvasRef.current!));\n            }\n        };\n        const dispatcherRef = dis.register(onAction);\n        const canvas = canvasRef.current;\n        if (canvas) canvas.height = UIStore.instance.windowHeight;\n        UIStore.instance.on(UI_EVENTS.Resize, resize);\n\n        return () => {\n            dis.unregister(dispatcherRef);\n            UIStore.instance.off(UI_EVENTS.Resize, resize);\n            // eslint-disable-next-line react-hooks/exhaustive-deps\n            const currentEffects = effectsRef.current; // this is not a react node ref, warning can be safely ignored\n            for (const effect in currentEffects) {\n                const effectModule: ICanvasEffect = currentEffects.get(effect)!;\n                if (effectModule && effectModule.isRunning) {\n                    effectModule.stop();\n                }\n            }\n        };\n    }, []);\n\n    return (\n        <canvas\n            ref={canvasRef}\n            width={roomWidth}\n            style={{\n                display: \"block\",\n                zIndex: 999999,\n                pointerEvents: \"none\",\n                position: \"fixed\",\n                top: 0,\n                right: 0,\n            }}\n            aria-hidden={true}\n        />\n    );\n};\n\nexport default EffectsOverlay;\n\n// 48 hours\n// 48h * 60m * 60s * 1000ms\nconst OUTDATED_EVENT_THRESHOLD = 48 * 60 * 60 * 1000;\n\n/**\n * Return true if the event is older than 48h.\n * @param event\n */\nfunction isEventOutdated(event?: MatrixEvent): boolean {\n    if (!event) return false;\n\n    const nowTs = Date.now();\n    const eventTs = event.getTs();\n    return nowTs - eventTs > OUTDATED_EVENT_THRESHOLD;\n}\n"],"mappings":"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","ignoreList":[]}