matrix-react-sdk
Version:
SDK for matrix.org using React
87 lines (84 loc) • 11.2 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 _location = require("../../../utils/location");
var _map = require("../../../utils/location/map");
var _Marker = _interopRequireDefault(require("./Marker"));
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 useMapMarker = (map, geoUri) => {
const [marker, setMarker] = (0, _react.useState)();
const onElementRef = (0, _react.useCallback)(element => {
if (marker || !element) {
return;
}
const coords = (0, _location.parseGeoUri)(geoUri);
if (coords) {
const newMarker = (0, _map.createMarker)(coords, element);
newMarker.addTo(map);
setMarker(newMarker);
}
}, [marker, geoUri, map]);
(0, _react.useEffect)(() => {
if (marker) {
const coords = (0, _location.parseGeoUri)(geoUri);
if (coords) {
marker.setLngLat({
lon: coords.longitude,
lat: coords.latitude
});
}
}
}, [marker, geoUri]);
(0, _react.useEffect)(() => () => {
if (marker) {
marker.remove();
}
}, [marker]);
return {
marker,
onElementRef
};
};
/**
* Generic location marker
*/
const SmartMarker = ({
id,
map,
geoUri,
roomMember,
useMemberColor,
tooltip
}) => {
const {
onElementRef
} = useMapMarker(map, geoUri);
return (
/*#__PURE__*/
// maplibregl hijacks the Marker dom element
// and removes it from the dom when the maplibregl.Marker instance
// is removed
// wrap in a span so that react doesn't get confused
// when trying to unmount this component
_react.default.createElement("span", null, /*#__PURE__*/_react.default.createElement(_Marker.default, {
ref: onElementRef,
id: id,
roomMember: roomMember,
useMemberColor: useMemberColor,
tooltip: tooltip
}))
);
};
var _default = exports.default = SmartMarker;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_location","_map","_Marker","_interopRequireDefault","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","useMapMarker","map","geoUri","marker","setMarker","useState","onElementRef","useCallback","element","coords","parseGeoUri","newMarker","createMarker","addTo","useEffect","setLngLat","lon","longitude","lat","latitude","remove","SmartMarker","id","roomMember","useMemberColor","tooltip","createElement","ref","_default","exports"],"sources":["../../../../src/components/views/location/SmartMarker.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, { ReactNode, useCallback, useEffect, useState } from \"react\";\nimport * as maplibregl from \"maplibre-gl\";\nimport { RoomMember } from \"matrix-js-sdk/src/matrix\";\n\nimport { parseGeoUri } from \"../../../utils/location\";\nimport { createMarker } from \"../../../utils/location/map\";\nimport Marker from \"./Marker\";\n\nconst useMapMarker = (\n    map: maplibregl.Map,\n    geoUri: string,\n): { marker?: maplibregl.Marker; onElementRef: (el: HTMLDivElement) => void } => {\n    const [marker, setMarker] = useState<maplibregl.Marker>();\n\n    const onElementRef = useCallback(\n        (element: HTMLDivElement) => {\n            if (marker || !element) {\n                return;\n            }\n            const coords = parseGeoUri(geoUri);\n            if (coords) {\n                const newMarker = createMarker(coords, element);\n                newMarker.addTo(map);\n                setMarker(newMarker);\n            }\n        },\n        [marker, geoUri, map],\n    );\n\n    useEffect(() => {\n        if (marker) {\n            const coords = parseGeoUri(geoUri);\n            if (coords) {\n                marker.setLngLat({ lon: coords.longitude, lat: coords.latitude });\n            }\n        }\n    }, [marker, geoUri]);\n\n    useEffect(\n        () => () => {\n            if (marker) {\n                marker.remove();\n            }\n        },\n        [marker],\n    );\n\n    return {\n        marker,\n        onElementRef,\n    };\n};\n\nexport interface SmartMarkerProps {\n    map: maplibregl.Map;\n    geoUri: string;\n    id?: string;\n    // renders MemberAvatar when provided\n    roomMember?: RoomMember;\n    // use member text color as background\n    useMemberColor?: boolean;\n    tooltip?: ReactNode;\n}\n\n/**\n * Generic location marker\n */\nconst SmartMarker: React.FC<SmartMarkerProps> = ({ id, map, geoUri, roomMember, useMemberColor, tooltip }) => {\n    const { onElementRef } = useMapMarker(map, geoUri);\n\n    return (\n        // maplibregl hijacks the Marker dom element\n        // and removes it from the dom when the maplibregl.Marker instance\n        // is removed\n        // wrap in a span so that react doesn't get confused\n        // when trying to unmount this component\n        <span>\n            <Marker\n                ref={onElementRef}\n                id={id}\n                roomMember={roomMember}\n                useMemberColor={useMemberColor}\n                tooltip={tooltip}\n            />\n        </span>\n    );\n};\n\nexport default SmartMarker;\n"],"mappings":"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","ignoreList":[]}