matrix-react-sdk
Version:
SDK for matrix.org using React
70 lines (67 loc) • 12.4 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.createMarker = exports.createMap = void 0;
var maplibregl = _interopRequireWildcard(require("maplibre-gl"));
var _logger = require("matrix-js-sdk/src/logger");
var _languageHandler = require("../../languageHandler");
var _findMapStyleUrl = require("./findMapStyleUrl");
var _LocationShareErrors = require("./LocationShareErrors");
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 createMap = (client, interactive, bodyId, onError) => {
try {
const styleUrl = (0, _findMapStyleUrl.findMapStyleUrl)(client);
const map = new maplibregl.Map({
container: bodyId,
style: styleUrl,
zoom: 15,
interactive,
attributionControl: false,
locale: {
"AttributionControl.ToggleAttribution": (0, _languageHandler._t)("location_sharing|toggle_attribution"),
"AttributionControl.MapFeedback": (0, _languageHandler._t)("location_sharing|map_feedback"),
"FullscreenControl.Enter": (0, _languageHandler._t)("action|enter_fullscreen"),
"FullscreenControl.Exit": (0, _languageHandler._t)("action|exit_fullscreeen"),
"GeolocateControl.FindMyLocation": (0, _languageHandler._t)("location_sharing|find_my_location"),
"GeolocateControl.LocationNotAvailable": (0, _languageHandler._t)("location_sharing|location_not_available"),
"LogoControl.Title": (0, _languageHandler._t)("location_sharing|mapbox_logo"),
"NavigationControl.ResetBearing": (0, _languageHandler._t)("location_sharing|reset_bearing"),
"NavigationControl.ZoomIn": (0, _languageHandler._t)("action|zoom_in"),
"NavigationControl.ZoomOut": (0, _languageHandler._t)("action|zoom_out")
}
});
map.addControl(new maplibregl.AttributionControl(), "top-right");
map.on("error", e => {
_logger.logger.error("Failed to load map: check map_style_url in config.json has a valid URL and API key", e.error);
onError?.(new Error(_LocationShareErrors.LocationShareError.MapStyleUrlNotReachable));
});
return map;
} catch (e) {
_logger.logger.error("Failed to render map", e);
const errorMessage = e?.message;
if (errorMessage.includes("Failed to initialize WebGL")) throw new Error(_LocationShareErrors.LocationShareError.WebGLNotEnabled);
throw e;
}
};
exports.createMap = createMap;
const createMarker = (coords, element) => {
const marker = new maplibregl.Marker({
element,
anchor: "bottom",
offset: [0, -1]
}).setLngLat({
lon: coords.longitude,
lat: coords.latitude
});
return marker;
};
exports.createMarker = createMarker;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["maplibregl","_interopRequireWildcard","require","_logger","_languageHandler","_findMapStyleUrl","_LocationShareErrors","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","createMap","client","interactive","bodyId","onError","styleUrl","findMapStyleUrl","map","Map","container","style","zoom","attributionControl","locale","_t","addControl","AttributionControl","on","logger","error","Error","LocationShareError","MapStyleUrlNotReachable","errorMessage","message","includes","WebGLNotEnabled","exports","createMarker","coords","element","marker","Marker","anchor","offset","setLngLat","lon","longitude","lat","latitude"],"sources":["../../../src/utils/location/map.ts"],"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 * as maplibregl from \"maplibre-gl\";\nimport { MatrixClient } from \"matrix-js-sdk/src/matrix\";\nimport { logger } from \"matrix-js-sdk/src/logger\";\n\nimport { _t } from \"../../languageHandler\";\nimport { findMapStyleUrl } from \"./findMapStyleUrl\";\nimport { LocationShareError } from \"./LocationShareErrors\";\n\nexport const createMap = (\n    client: MatrixClient,\n    interactive: boolean,\n    bodyId: string,\n    onError?: (error: Error) => void,\n): maplibregl.Map => {\n    try {\n        const styleUrl = findMapStyleUrl(client);\n\n        const map = new maplibregl.Map({\n            container: bodyId,\n            style: styleUrl,\n            zoom: 15,\n            interactive,\n            attributionControl: false,\n            locale: {\n                \"AttributionControl.ToggleAttribution\": _t(\"location_sharing|toggle_attribution\"),\n                \"AttributionControl.MapFeedback\": _t(\"location_sharing|map_feedback\"),\n                \"FullscreenControl.Enter\": _t(\"action|enter_fullscreen\"),\n                \"FullscreenControl.Exit\": _t(\"action|exit_fullscreeen\"),\n                \"GeolocateControl.FindMyLocation\": _t(\"location_sharing|find_my_location\"),\n                \"GeolocateControl.LocationNotAvailable\": _t(\"location_sharing|location_not_available\"),\n                \"LogoControl.Title\": _t(\"location_sharing|mapbox_logo\"),\n                \"NavigationControl.ResetBearing\": _t(\"location_sharing|reset_bearing\"),\n                \"NavigationControl.ZoomIn\": _t(\"action|zoom_in\"),\n                \"NavigationControl.ZoomOut\": _t(\"action|zoom_out\"),\n            },\n        });\n        map.addControl(new maplibregl.AttributionControl(), \"top-right\");\n\n        map.on(\"error\", (e) => {\n            logger.error(\"Failed to load map: check map_style_url in config.json has a valid URL and API key\", e.error);\n            onError?.(new Error(LocationShareError.MapStyleUrlNotReachable));\n        });\n\n        return map;\n    } catch (e) {\n        logger.error(\"Failed to render map\", e);\n        const errorMessage = (e as Error)?.message;\n        if (errorMessage.includes(\"Failed to initialize WebGL\")) throw new Error(LocationShareError.WebGLNotEnabled);\n        throw e;\n    }\n};\n\nexport const createMarker = (coords: GeolocationCoordinates, element: HTMLElement): maplibregl.Marker => {\n    const marker = new maplibregl.Marker({\n        element,\n        anchor: \"bottom\",\n        offset: [0, -1],\n    }).setLngLat({ lon: coords.longitude, lat: coords.latitude });\n    return marker;\n};\n"],"mappings":"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","ignoreList":[]}