-
Notifications
You must be signed in to change notification settings - Fork 432
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Import geoman with leaflet as an es module #1339
Comments
Please try Lazy Loading. |
That still gives the same error. I updated the repo so it now tries to lazy load geoman, if you want to see for yourself. |
I cannot get js on https://unpkg.com/@geoman-io/leaflet-geoman-free@latest/dist/leaflet-geoman.min.js I can't see the map on https://geoman.io/leaflet-geoman also. What happened? |
Any news on this? My use case is that I want to use the Leaflet map in a vanilla web component which in turn can be embedded in a different site. So I'd rather avoid globally importing Leaflet. |
I have the same issue |
if in one file (lets call it import * as L from 'leaflet/dist/leaflet-src.esm.js';
globalThis.L = {};
for (const [key, value] of Object.entries(L)) {
globalThis.L[key] = value;
}
import "leaflet/dist/leaflet.css"; then in another file (lets call it import "@geoman-io/leaflet-geoman-free";
import "@geoman-io/leaflet-geoman-free/dist/leaflet-geoman.css"; then in a 3rd (lets call it import './leaflet-base.js';
import './leaflet-more.js'
export default globalThis.L; then you can just do geoman (and a lot of leaflet extensions) are written in an object oriented way that makes it hard to turn into es modules without a big rewrite (this isn't their fault it was the "recommended way" to do leaflet) |
I have trouble importing geoman after importing leaflet as an es module.
This works fine:
This doesn't:
and gives the following error:
leaflet-geoman.min.js:1 Uncaught ReferenceError: L is not defined
.Here is repo with a minimal example: https://github.com/AronSchoffer/import-geoman-with-leaflet-as-esm
I want to import leaflet as esm because typescript gives me errors otherwise.
Maybe more importantly, importing leaflet as an es module allows for partial imports e.g.
import {map} from leaflet
.Does geoman support importing leaflet as an es module? If so, how do I do this properly?
Any workarounds would also be appreciated.
Thanks!
The text was updated successfully, but these errors were encountered: