matrix-react-sdk
Version:
SDK for matrix.org using React
131 lines (127 loc) • 19.6 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = exports.LocationBodyFallbackContent = exports.LocationBodyContent = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireDefault(require("react"));
var _matrix = require("matrix-js-sdk/src/matrix");
var _randomstring = require("matrix-js-sdk/src/randomstring");
var _compoundWeb = require("@vector-im/compound-web");
var _languageHandler = require("../../../languageHandler");
var _Modal = _interopRequireDefault(require("../../../Modal"));
var _location = require("../../../utils/location");
var _MatrixClientContext = _interopRequireDefault(require("../../../contexts/MatrixClientContext"));
var _location2 = require("../location");
var _connection = require("../../../utils/connection");
/*
Copyright 2024 New Vector Ltd.
Copyright 2021 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.
*/
class MLocationBody extends _react.default.Component {
constructor(props, context) {
super(props, context);
// multiple instances of same map might be in document
// eg thread and main timeline, reply
(0, _defineProperty2.default)(this, "unmounted", false);
(0, _defineProperty2.default)(this, "mapId", void 0);
(0, _defineProperty2.default)(this, "reconnectedListener", void 0);
(0, _defineProperty2.default)(this, "onClick", () => {
_Modal.default.createDialog(_location2.LocationViewDialog, {
matrixClient: this.context,
mxEvent: this.props.mxEvent
}, "mx_LocationViewDialog_wrapper", false,
// isPriority
true // isStatic
);
});
(0, _defineProperty2.default)(this, "clearError", () => {
this.context.off(_matrix.ClientEvent.Sync, this.reconnectedListener);
this.setState({
error: undefined
});
});
(0, _defineProperty2.default)(this, "onError", error => {
if (this.unmounted) return;
this.setState({
error
});
// Unregister first in case we already had it registered
this.context.off(_matrix.ClientEvent.Sync, this.reconnectedListener);
this.context.on(_matrix.ClientEvent.Sync, this.reconnectedListener);
});
const idSuffix = `${props.mxEvent.getId()}_${(0, _randomstring.randomString)(8)}`;
this.mapId = `mx_MLocationBody_${idSuffix}`;
this.reconnectedListener = (0, _connection.createReconnectedListener)(this.clearError);
this.state = {};
}
componentWillUnmount() {
this.unmounted = true;
this.context.off(_matrix.ClientEvent.Sync, this.reconnectedListener);
}
render() {
return this.state.error ? /*#__PURE__*/_react.default.createElement(LocationBodyFallbackContent, {
error: this.state.error,
event: this.props.mxEvent
}) : /*#__PURE__*/_react.default.createElement(LocationBodyContent, {
mxEvent: this.props.mxEvent,
mapId: this.mapId,
onError: this.onError,
tooltip: (0, _languageHandler._t)("location_sharing|expand_map"),
onClick: this.onClick
});
}
}
exports.default = MLocationBody;
(0, _defineProperty2.default)(MLocationBody, "contextType", _MatrixClientContext.default);
const LocationBodyFallbackContent = ({
error,
event
}) => {
const errorType = error?.message;
const message = `${(0, _languageHandler._t)("location_sharing|failed_load_map")}: ${(0, _location.getLocationShareErrorMessage)(errorType)}`;
const locationFallback = (0, _location.isSelfLocation)(event.getContent()) ? (0, _languageHandler._t)("timeline|m.location|self_location") + event.getContent()?.body : (0, _languageHandler._t)("timeline|m.location|location") + event.getContent()?.body;
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_EventTile_body mx_MLocationBody"
}, /*#__PURE__*/_react.default.createElement("span", {
className: errorType !== _location.LocationShareError.MapStyleUrlNotConfigured ? "mx_EventTile_tileError" : ""
}, message), /*#__PURE__*/_react.default.createElement("br", null), locationFallback);
};
exports.LocationBodyFallbackContent = LocationBodyFallbackContent;
const LocationBodyContent = ({
mxEvent,
mapId,
tooltip,
onError,
onClick
}) => {
// only pass member to marker when should render avatar marker
const markerRoomMember = (0, _location.isSelfLocation)(mxEvent.getContent()) ? mxEvent.sender : undefined;
const geoUri = (0, _location.locationEventGeoUri)(mxEvent);
const mapElement = /*#__PURE__*/_react.default.createElement(_location2.Map, {
id: mapId,
centerGeoUri: geoUri,
onClick: onClick,
onError: onError,
className: "mx_MLocationBody_map"
}, ({
map
}) => /*#__PURE__*/_react.default.createElement(_location2.SmartMarker, {
map: map,
id: `${mapId}-marker`,
geoUri: geoUri,
roomMember: markerRoomMember ?? undefined
}));
return /*#__PURE__*/_react.default.createElement("div", {
className: "mx_MLocationBody"
}, /*#__PURE__*/_react.default.createElement(_compoundWeb.Tooltip, {
label: tooltip
}, /*#__PURE__*/_react.default.createElement("div", {
className: "mx_MLocationBody_map"
}, mapElement)));
};
exports.LocationBodyContent = LocationBodyContent;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_matrix","_randomstring","_compoundWeb","_languageHandler","_Modal","_location","_MatrixClientContext","_location2","_connection","MLocationBody","React","Component","constructor","props","context","_defineProperty2","default","Modal","createDialog","LocationViewDialog","matrixClient","mxEvent","off","ClientEvent","Sync","reconnectedListener","setState","error","undefined","unmounted","on","idSuffix","getId","randomString","mapId","createReconnectedListener","clearError","state","componentWillUnmount","render","createElement","LocationBodyFallbackContent","event","LocationBodyContent","onError","tooltip","_t","onClick","exports","MatrixClientContext","errorType","message","getLocationShareErrorMessage","locationFallback","isSelfLocation","getContent","body","className","LocationShareError","MapStyleUrlNotConfigured","markerRoomMember","sender","geoUri","locationEventGeoUri","mapElement","Map","id","centerGeoUri","map","SmartMarker","roomMember","Tooltip","label"],"sources":["../../../../src/components/views/messages/MLocationBody.tsx"],"sourcesContent":["/*\nCopyright 2024 New Vector Ltd.\nCopyright 2021 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 from \"react\";\nimport { MatrixEvent, ClientEvent, ClientEventHandlerMap } from \"matrix-js-sdk/src/matrix\";\nimport { randomString } from \"matrix-js-sdk/src/randomstring\";\nimport { Tooltip } from \"@vector-im/compound-web\";\n\nimport { _t } from \"../../../languageHandler\";\nimport Modal from \"../../../Modal\";\nimport {\n    locationEventGeoUri,\n    getLocationShareErrorMessage,\n    LocationShareError,\n    isSelfLocation,\n} from \"../../../utils/location\";\nimport MatrixClientContext from \"../../../contexts/MatrixClientContext\";\nimport { SmartMarker, Map, LocationViewDialog } from \"../location\";\nimport { IBodyProps } from \"./IBodyProps\";\nimport { createReconnectedListener } from \"../../../utils/connection\";\n\ninterface IState {\n    error?: Error;\n}\n\nexport default class MLocationBody extends React.Component<IBodyProps, IState> {\n    public static contextType = MatrixClientContext;\n    public declare context: React.ContextType<typeof MatrixClientContext>;\n\n    private unmounted = false;\n    private mapId: string;\n    private reconnectedListener: ClientEventHandlerMap[ClientEvent.Sync];\n\n    public constructor(props: IBodyProps, context: React.ContextType<typeof MatrixClientContext>) {\n        super(props, context);\n\n        // multiple instances of same map might be in document\n        // eg thread and main timeline, reply\n        const idSuffix = `${props.mxEvent.getId()}_${randomString(8)}`;\n        this.mapId = `mx_MLocationBody_${idSuffix}`;\n\n        this.reconnectedListener = createReconnectedListener(this.clearError);\n\n        this.state = {};\n    }\n\n    private onClick = (): void => {\n        Modal.createDialog(\n            LocationViewDialog,\n            {\n                matrixClient: this.context,\n                mxEvent: this.props.mxEvent,\n            },\n            \"mx_LocationViewDialog_wrapper\",\n            false, // isPriority\n            true, // isStatic\n        );\n    };\n\n    private clearError = (): void => {\n        this.context.off(ClientEvent.Sync, this.reconnectedListener);\n        this.setState({ error: undefined });\n    };\n\n    private onError = (error: Error): void => {\n        if (this.unmounted) return;\n        this.setState({ error });\n        // Unregister first in case we already had it registered\n        this.context.off(ClientEvent.Sync, this.reconnectedListener);\n        this.context.on(ClientEvent.Sync, this.reconnectedListener);\n    };\n\n    public componentWillUnmount(): void {\n        this.unmounted = true;\n        this.context.off(ClientEvent.Sync, this.reconnectedListener);\n    }\n\n    public render(): React.ReactElement<HTMLDivElement> {\n        return this.state.error ? (\n            <LocationBodyFallbackContent error={this.state.error} event={this.props.mxEvent} />\n        ) : (\n            <LocationBodyContent\n                mxEvent={this.props.mxEvent}\n                mapId={this.mapId}\n                onError={this.onError}\n                tooltip={_t(\"location_sharing|expand_map\")}\n                onClick={this.onClick}\n            />\n        );\n    }\n}\n\nexport const LocationBodyFallbackContent: React.FC<{ event: MatrixEvent; error: Error }> = ({ error, event }) => {\n    const errorType = error?.message as LocationShareError;\n    const message = `${_t(\"location_sharing|failed_load_map\")}: ${getLocationShareErrorMessage(errorType)}`;\n\n    const locationFallback = isSelfLocation(event.getContent())\n        ? _t(\"timeline|m.location|self_location\") + event.getContent()?.body\n        : _t(\"timeline|m.location|location\") + event.getContent()?.body;\n\n    return (\n        <div className=\"mx_EventTile_body mx_MLocationBody\">\n            <span className={errorType !== LocationShareError.MapStyleUrlNotConfigured ? \"mx_EventTile_tileError\" : \"\"}>\n                {message}\n            </span>\n            <br />\n            {locationFallback}\n        </div>\n    );\n};\n\ninterface LocationBodyContentProps {\n    mxEvent: MatrixEvent;\n    mapId: string;\n    tooltip: string;\n    onError: (error: Error) => void;\n    onClick?: () => void;\n}\nexport const LocationBodyContent: React.FC<LocationBodyContentProps> = ({\n    mxEvent,\n    mapId,\n    tooltip,\n    onError,\n    onClick,\n}) => {\n    // only pass member to marker when should render avatar marker\n    const markerRoomMember = isSelfLocation(mxEvent.getContent()) ? mxEvent.sender : undefined;\n    const geoUri = locationEventGeoUri(mxEvent);\n\n    const mapElement = (\n        <Map id={mapId} centerGeoUri={geoUri} onClick={onClick} onError={onError} className=\"mx_MLocationBody_map\">\n            {({ map }) => (\n                <SmartMarker\n                    map={map}\n                    id={`${mapId}-marker`}\n                    geoUri={geoUri}\n                    roomMember={markerRoomMember ?? undefined}\n                />\n            )}\n        </Map>\n    );\n\n    return (\n        <div className=\"mx_MLocationBody\">\n            <Tooltip label={tooltip}>\n                <div className=\"mx_MLocationBody_map\">{mapElement}</div>\n            </Tooltip>\n        </div>\n    );\n};\n"],"mappings":"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","ignoreList":[]}