matrix-react-sdk
Version:
SDK for matrix.org using React
172 lines (166 loc) • 29.7 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 _matrix = require("matrix-js-sdk/src/matrix");
var _randomstring = require("matrix-js-sdk/src/randomstring");
var _classnames = _interopRequireDefault(require("classnames"));
var _MatrixClientContext = _interopRequireDefault(require("../../../contexts/MatrixClientContext"));
var _useEventEmitter = require("../../../hooks/useEventEmitter");
var _languageHandler = require("../../../languageHandler");
var _Modal = _interopRequireDefault(require("../../../Modal"));
var _beacon = require("../../../utils/beacon");
var _location = require("../../../utils/location");
var _displayStatus = require("../beacon/displayStatus");
var _BeaconStatus = _interopRequireDefault(require("../beacon/BeaconStatus"));
var _OwnBeaconStatus = _interopRequireDefault(require("../beacon/OwnBeaconStatus"));
var _location2 = require("../location");
var _MapError = require("../location/MapError");
var _MapFallback = _interopRequireDefault(require("../location/MapFallback"));
var _beacon2 = require("../beacon");
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 2022 The Matrix.org Foundation C.I.C.
SPDX-License-Identifier: AGPL-3.0-only OR GPL-3.0-only
Please see LICENSE files in the repository root for full details.
*/
const useBeaconState = beaconInfoEvent => {
const beacon = (0, _beacon.useBeacon)(beaconInfoEvent);
const isLive = (0, _useEventEmitter.useEventEmitterState)(beacon, _matrix.BeaconEvent.LivenessChange, () => beacon?.isLive);
const latestLocationState = (0, _useEventEmitter.useEventEmitterState)(beacon, _matrix.BeaconEvent.LocationUpdate, () => beacon?.latestLocationState);
if (!beacon) {
return {};
}
// a beacon's starting timestamp can be in the future
// (either from small deviations in system clock times, or on purpose from another client)
// a beacon is only live between its start timestamp and expiry
// detect when a beacon is waiting to become live
// and display a loading state
const waitingToStart = !!beacon && (0, _beacon.isBeaconWaitingToStart)(beacon);
const {
description
} = beacon.beaconInfo;
return {
beacon,
description,
isLive,
waitingToStart,
latestLocationState
};
};
// multiple instances of same map might be in document
// eg thread and main timeline, reply
// maplibregl needs a unique id to attach the map instance to
const useUniqueId = eventId => {
const [id, setId] = (0, _react.useState)(`${eventId}_${(0, _randomstring.randomString)(8)}`);
(0, _react.useEffect)(() => {
setId(`${eventId}_${(0, _randomstring.randomString)(8)}`);
}, [eventId]);
return id;
};
// remove related beacon locations on beacon redaction
const useHandleBeaconRedaction = (event, matrixClient, getRelationsForEvent) => {
const onBeforeBeaconInfoRedaction = (0, _react.useCallback)((_event, redactionEvent) => {
const relations = getRelationsForEvent ? getRelationsForEvent(event.getId(), _matrix.RelationType.Reference, _matrix.M_BEACON.name) : undefined;
relations?.getRelations()?.forEach(locationEvent => {
matrixClient.redactEvent(locationEvent.getRoomId(), locationEvent.getId(), undefined, redactionEvent.getContent());
});
}, [event, matrixClient, getRelationsForEvent]);
(0, _react.useEffect)(() => {
event.addListener(_matrix.MatrixEventEvent.BeforeRedaction, onBeforeBeaconInfoRedaction);
return () => {
event.removeListener(_matrix.MatrixEventEvent.BeforeRedaction, onBeforeBeaconInfoRedaction);
};
}, [event, onBeforeBeaconInfoRedaction]);
};
const MBeaconBody = /*#__PURE__*/_react.default.forwardRef(({
mxEvent,
getRelationsForEvent
}, ref) => {
const {
beacon,
isLive,
latestLocationState,
waitingToStart
} = useBeaconState(mxEvent);
const mapId = useUniqueId(mxEvent.getId());
const matrixClient = (0, _react.useContext)(_MatrixClientContext.default);
const [error, setError] = (0, _react.useState)();
const isMapDisplayError = error?.message === _location.LocationShareError.MapStyleUrlNotConfigured || error?.message === _location.LocationShareError.MapStyleUrlNotReachable;
const displayStatus = (0, _displayStatus.getBeaconDisplayStatus)(!!isLive, latestLocationState,
// if we are unable to display maps because it is not configured for the server
// don't display an error
isMapDisplayError ? undefined : error, waitingToStart);
const markerRoomMember = (0, _location.isSelfLocation)(mxEvent.getContent()) ? mxEvent.sender : undefined;
const isOwnBeacon = beacon?.beaconInfoOwner === matrixClient.getUserId();
useHandleBeaconRedaction(mxEvent, matrixClient, getRelationsForEvent);
const onClick = () => {
if (displayStatus !== _displayStatus.BeaconDisplayStatus.Active) {
return;
}
_Modal.default.createDialog(_beacon2.BeaconViewDialog, {
roomId: mxEvent.getRoomId(),
matrixClient,
initialFocusedBeacon: beacon
}, "mx_BeaconViewDialog_wrapper", false,
// isPriority
true // isStatic
);
};
let map;
if (displayStatus === _displayStatus.BeaconDisplayStatus.Active && !isMapDisplayError && latestLocationState?.uri) {
map = /*#__PURE__*/_react.default.createElement(_location2.Map, {
id: mapId,
centerGeoUri: latestLocationState.uri,
onError: setError,
onClick: onClick,
className: "mx_MBeaconBody_map"
}, ({
map
}) => /*#__PURE__*/_react.default.createElement(_location2.SmartMarker, {
map: map,
id: `${mapId}-marker`,
geoUri: latestLocationState.uri,
roomMember: markerRoomMember ?? undefined,
useMemberColor: true
}));
} else if (isMapDisplayError) {
map = /*#__PURE__*/_react.default.createElement(_MapError.MapError, {
error: error.message,
onClick: onClick,
className: (0, _classnames.default)("mx_MBeaconBody_mapError",
// set interactive class when maximised map can be opened
{
mx_MBeaconBody_mapErrorInteractive: displayStatus === _displayStatus.BeaconDisplayStatus.Active
}),
isMinimised: true
});
} else {
map = /*#__PURE__*/_react.default.createElement(_MapFallback.default, {
isLoading: displayStatus === _displayStatus.BeaconDisplayStatus.Loading,
className: "mx_MBeaconBody_map mx_MBeaconBody_mapFallback"
});
}
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_MBeaconBody",
ref: ref
}, map, isOwnBeacon ? /*#__PURE__*/_react.default.createElement(_OwnBeaconStatus.default, {
className: "mx_MBeaconBody_chin",
beacon: beacon,
displayStatus: displayStatus,
withIcon: true
}) : /*#__PURE__*/_react.default.createElement(_BeaconStatus.default, {
className: "mx_MBeaconBody_chin",
beacon: beacon,
displayStatus: displayStatus,
label: (0, _languageHandler._t)("timeline|m.beacon_info|view_live_location"),
withIcon: true
}));
});
var _default = exports.default = MBeaconBody;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_matrix","_randomstring","_classnames","_interopRequireDefault","_MatrixClientContext","_useEventEmitter","_languageHandler","_Modal","_beacon","_location","_displayStatus","_BeaconStatus","_OwnBeaconStatus","_location2","_MapError","_MapFallback","_beacon2","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","useBeaconState","beaconInfoEvent","beacon","useBeacon","isLive","useEventEmitterState","BeaconEvent","LivenessChange","latestLocationState","LocationUpdate","waitingToStart","isBeaconWaitingToStart","description","beaconInfo","useUniqueId","eventId","id","setId","useState","randomString","useEffect","useHandleBeaconRedaction","event","matrixClient","getRelationsForEvent","onBeforeBeaconInfoRedaction","useCallback","_event","redactionEvent","relations","getId","RelationType","Reference","M_BEACON","name","undefined","getRelations","forEach","locationEvent","redactEvent","getRoomId","getContent","addListener","MatrixEventEvent","BeforeRedaction","removeListener","MBeaconBody","React","forwardRef","mxEvent","ref","mapId","useContext","MatrixClientContext","error","setError","isMapDisplayError","message","LocationShareError","MapStyleUrlNotConfigured","MapStyleUrlNotReachable","displayStatus","getBeaconDisplayStatus","markerRoomMember","isSelfLocation","sender","isOwnBeacon","beaconInfoOwner","getUserId","onClick","BeaconDisplayStatus","Active","Modal","createDialog","BeaconViewDialog","roomId","initialFocusedBeacon","map","uri","createElement","Map","centerGeoUri","onError","className","SmartMarker","geoUri","roomMember","useMemberColor","MapError","classNames","mx_MBeaconBody_mapErrorInteractive","isMinimised","isLoading","Loading","withIcon","label","_t","_default","exports"],"sources":["../../../../src/components/views/messages/MBeaconBody.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2022 The Matrix.org Foundation C.I.C.\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 React, { ForwardRefExoticComponent, useCallback, useContext, useEffect, useState } from \"react\";\nimport {\n    Beacon,\n    BeaconEvent,\n    MatrixEvent,\n    MatrixEventEvent,\n    MatrixClient,\n    RelationType,\n    IRedactOpts,\n    ContentHelpers,\n    M_BEACON,\n} from \"matrix-js-sdk/src/matrix\";\nimport { randomString } from \"matrix-js-sdk/src/randomstring\";\nimport classNames from \"classnames\";\n\nimport MatrixClientContext from \"../../../contexts/MatrixClientContext\";\nimport { useEventEmitterState } from \"../../../hooks/useEventEmitter\";\nimport { _t } from \"../../../languageHandler\";\nimport Modal from \"../../../Modal\";\nimport { isBeaconWaitingToStart, useBeacon } from \"../../../utils/beacon\";\nimport { isSelfLocation, LocationShareError } from \"../../../utils/location\";\nimport { BeaconDisplayStatus, getBeaconDisplayStatus } from \"../beacon/displayStatus\";\nimport BeaconStatus from \"../beacon/BeaconStatus\";\nimport OwnBeaconStatus from \"../beacon/OwnBeaconStatus\";\nimport { Map, SmartMarker } from \"../location\";\nimport { MapError } from \"../location/MapError\";\nimport MapFallback from \"../location/MapFallback\";\nimport { GetRelationsForEvent } from \"../rooms/EventTile\";\nimport { BeaconViewDialog } from \"../beacon\";\nimport { IBodyProps } from \"./IBodyProps\";\n\nconst useBeaconState = (\n    beaconInfoEvent: MatrixEvent,\n): {\n    beacon?: Beacon;\n    description?: string;\n    latestLocationState?: ContentHelpers.BeaconLocationState;\n    isLive?: boolean;\n    waitingToStart?: boolean;\n} => {\n    const beacon = useBeacon(beaconInfoEvent);\n\n    const isLive = useEventEmitterState(beacon, BeaconEvent.LivenessChange, () => beacon?.isLive);\n\n    const latestLocationState = useEventEmitterState(\n        beacon,\n        BeaconEvent.LocationUpdate,\n        () => beacon?.latestLocationState,\n    );\n\n    if (!beacon) {\n        return {};\n    }\n\n    // a beacon's starting timestamp can be in the future\n    // (either from small deviations in system clock times, or on purpose from another client)\n    // a beacon is only live between its start timestamp and expiry\n    // detect when a beacon is waiting to become live\n    // and display a loading state\n    const waitingToStart = !!beacon && isBeaconWaitingToStart(beacon);\n    const { description } = beacon.beaconInfo;\n\n    return {\n        beacon,\n        description,\n        isLive,\n        waitingToStart,\n        latestLocationState,\n    };\n};\n\n// multiple instances of same map might be in document\n// eg thread and main timeline, reply\n// maplibregl needs a unique id to attach the map instance to\nconst useUniqueId = (eventId: string): string => {\n    const [id, setId] = useState(`${eventId}_${randomString(8)}`);\n\n    useEffect(() => {\n        setId(`${eventId}_${randomString(8)}`);\n    }, [eventId]);\n\n    return id;\n};\n\n// remove related beacon locations on beacon redaction\nconst useHandleBeaconRedaction = (\n    event: MatrixEvent,\n    matrixClient: MatrixClient,\n    getRelationsForEvent?: GetRelationsForEvent,\n): void => {\n    const onBeforeBeaconInfoRedaction = useCallback(\n        (_event: MatrixEvent, redactionEvent: MatrixEvent) => {\n            const relations = getRelationsForEvent\n                ? getRelationsForEvent(event.getId()!, RelationType.Reference, M_BEACON.name)\n                : undefined;\n\n            relations?.getRelations()?.forEach((locationEvent) => {\n                matrixClient.redactEvent(\n                    locationEvent.getRoomId()!,\n                    locationEvent.getId()!,\n                    undefined,\n                    redactionEvent.getContent<IRedactOpts>(),\n                );\n            });\n        },\n        [event, matrixClient, getRelationsForEvent],\n    );\n\n    useEffect(() => {\n        event.addListener(MatrixEventEvent.BeforeRedaction, onBeforeBeaconInfoRedaction);\n        return () => {\n            event.removeListener(MatrixEventEvent.BeforeRedaction, onBeforeBeaconInfoRedaction);\n        };\n    }, [event, onBeforeBeaconInfoRedaction]);\n};\n\nconst MBeaconBody = React.forwardRef<HTMLDivElement, IBodyProps>(({ mxEvent, getRelationsForEvent }, ref) => {\n    const { beacon, isLive, latestLocationState, waitingToStart } = useBeaconState(mxEvent);\n    const mapId = useUniqueId(mxEvent.getId()!);\n\n    const matrixClient = useContext(MatrixClientContext);\n    const [error, setError] = useState<Error>();\n    const isMapDisplayError =\n        error?.message === LocationShareError.MapStyleUrlNotConfigured ||\n        error?.message === LocationShareError.MapStyleUrlNotReachable;\n    const displayStatus = getBeaconDisplayStatus(\n        !!isLive,\n        latestLocationState,\n        // if we are unable to display maps because it is not configured for the server\n        // don't display an error\n        isMapDisplayError ? undefined : error,\n        waitingToStart,\n    );\n    const markerRoomMember = isSelfLocation(mxEvent.getContent()) ? mxEvent.sender : undefined;\n    const isOwnBeacon = beacon?.beaconInfoOwner === matrixClient.getUserId();\n\n    useHandleBeaconRedaction(mxEvent, matrixClient, getRelationsForEvent);\n\n    const onClick = (): void => {\n        if (displayStatus !== BeaconDisplayStatus.Active) {\n            return;\n        }\n        Modal.createDialog(\n            BeaconViewDialog,\n            {\n                roomId: mxEvent.getRoomId()!,\n                matrixClient,\n                initialFocusedBeacon: beacon,\n            },\n            \"mx_BeaconViewDialog_wrapper\",\n            false, // isPriority\n            true, // isStatic\n        );\n    };\n\n    let map: JSX.Element;\n    if (displayStatus === BeaconDisplayStatus.Active && !isMapDisplayError && latestLocationState?.uri) {\n        map = (\n            <Map\n                id={mapId}\n                centerGeoUri={latestLocationState.uri}\n                onError={setError}\n                onClick={onClick}\n                className=\"mx_MBeaconBody_map\"\n            >\n                {({ map }) => (\n                    <SmartMarker\n                        map={map}\n                        id={`${mapId}-marker`}\n                        geoUri={latestLocationState.uri!}\n                        roomMember={markerRoomMember ?? undefined}\n                        useMemberColor\n                    />\n                )}\n            </Map>\n        );\n    } else if (isMapDisplayError) {\n        map = (\n            <MapError\n                error={error.message as LocationShareError}\n                onClick={onClick}\n                className={classNames(\n                    \"mx_MBeaconBody_mapError\",\n                    // set interactive class when maximised map can be opened\n                    { mx_MBeaconBody_mapErrorInteractive: displayStatus === BeaconDisplayStatus.Active },\n                )}\n                isMinimised\n            />\n        );\n    } else {\n        map = (\n            <MapFallback\n                isLoading={displayStatus === BeaconDisplayStatus.Loading}\n                className=\"mx_MBeaconBody_map mx_MBeaconBody_mapFallback\"\n            />\n        );\n    }\n\n    return (\n        <div className=\"mx_MBeaconBody\" ref={ref}>\n            {map}\n            {isOwnBeacon ? (\n                <OwnBeaconStatus\n                    className=\"mx_MBeaconBody_chin\"\n                    beacon={beacon}\n                    displayStatus={displayStatus}\n                    withIcon\n                />\n            ) : (\n                <BeaconStatus\n                    className=\"mx_MBeaconBody_chin\"\n                    beacon={beacon}\n                    displayStatus={displayStatus}\n                    label={_t(\"timeline|m.beacon_info|view_live_location\")}\n                    withIcon\n                />\n            )}\n        </div>\n    );\n}) as ForwardRefExoticComponent<IBodyProps>;\n\nexport default MBeaconBody;\n"],"mappings":"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","ignoreList":[]}