Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/roblabs/maps-withastro
Bring Leaflet & MapLibre maps directly into Astro
https://github.com/roblabs/maps-withastro
astro mapbox mapkit-js maplibre
Last synced: 2 months ago
JSON representation
Bring Leaflet & MapLibre maps directly into Astro
- Host: GitHub
- URL: https://github.com/roblabs/maps-withastro
- Owner: roblabs
- Created: 2023-06-29T13:39:20.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-04-13T20:20:22.000Z (9 months ago)
- Last Synced: 2024-04-14T10:52:09.524Z (9 months ago)
- Topics: astro, mapbox, mapkit-js, maplibre
- Language: Astro
- Homepage:
- Size: 758 KB
- Stars: 7
- Watchers: 2
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-maplibre - maps-withastro - Bring Leaflet & MapLibre maps directly into Astro. (Bindings / JavaScript)
README
[![vscode.dev](https://img.shields.io/badge/Open_in_vscode.dev-Repo-blue)][vscode.dev]
![GitHub Actions Workflow Status](https://img.shields.io/github/actions/workflow/status/roblabs/maps-withastro/deploy.yml)# Creating an Astro Component template for Web Maps
https://Astro.build is a great start for creating web sites. This project allows you to bring Leaflet & MapLibre maps directly into Astro.
# Demo
[![maps-withastro.RobLabs.com](https://img.shields.io/badge/🎲_🎲-Live_Demo-green)][maps-withastro.RobLabs.com]
## Test
The Astro Docs has a section on creating a `test` directory for testing and demonstrating the component. See https://docs.astro.build/en/reference/publish-to-npm/#creating-a-package
We followed these notes to add `test/` in the root of this project. The Demo project supports Astro & MDX examples of displaying a map.
├── test
│  ├── public
│  │  ├── favicon.svg
│  │  └── jwt
│  ├── src
│  │  └── pages
│  │  ├── index.astro
│  │  └── mapkit.mdx## Astro Component
To create the template, we started with the official Astro template `component` and started this project called `maps-withastro`. See https://github.com/withastro/astro/tree/main/examples/component.
```bash
pnpm create astro@latest maps-withastro -- --template component
``````bash
# done for you, left here for replication notes
# pnpm create astro@latest demo -- --template minimal
```Astro + Leaflet, MapLibre or Mapbox
![alt text](demo-leaflet-maplibre-mapbox.png)
---
Astro + MapKit
![alt text](demo-mapkit.png)
## Architecture
The architecture is to pass in Astro properties via an HTMLElement dataset property. The pattern for the Leaflet map example is from an Astro project called `hello-astro`.
```JavaScript
// Copyright (c) 2022 Hello Tham Pty Ltd. https://github.com/hellotham/hello-astro
// SPDX-License-Identifier: MIT
```## Develop
To do local development, change the dependency to the local workspace.
```json
"maps-withastro": "workspace:*"
```See https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement/dataset
### Leaflet with AstroSee [demo/src/pages/index.astro](demo/src/pages/index.astro).
```jsx
import { Leaflet } from 'maps-withastro';
---```
### MapLibre with Astro
```jsx
import { MapLibre } from 'maps-withastro';
---```
### Mapbox with Astro
```jsx
```
### MapKit with Astro
* Use either `zoom` or `cameradistance`. If both are given, then `zoom` is preferred.
* Pass in JSON Web Token as either a URL or string
* jwt="http://localhost:3141/jwt"
* jwt="eyJhxGciO...."```jsx
import { MapKit } from 'maps-withastro';
---```
# How to Replicate
Here are the steps taken to create this repo containing the Maps with Astro components. See https://docs.astro.build/en/reference/publish-to-npm
You can make use of these notes if you want to extend the Map components with Astro beyond Leaflet or MapLibre.
### Leaflet dependencies
```bash
# done for you, left here for replication notes
# pnpm install leaflet --workspace-root
# pnpm install @types/leaflet --save-dev --workspace-root
```### MapLibre dependencies
```bash
# done for you, left here for replication notes
# pnpm install maplibre-gl --workspace-root
```### Mapbox dependencies
```bash
# done for you, left here for replication notes
# pnpm install mapbox-gl --workspace-root
```### MapKit dependencies
For detailed information on the required fields for the JWT header and payload, see [Creating and Using Tokens with MapKit JS](https://developer.apple.com/documentation/mapkitjs/creating_and_using_tokens_with_mapkit_js). The [MapKit JS Dashboard](https://maps.developer.apple.com/token-maker) also has a tool called *Create a Token*.
```bash
# done for you, left here for replication notes
# pnpm install @types/apple-mapkit-js-browser --save-dev --workspace-root
```## 🧞 Commands
All commands are run from the root of the project, from a terminal:
| Command | Action |
| :------------------------- | :----------------------------------------------- |
| `npm link` | Registers this package locally. for use with `./test` |
| `pnpm link maps-withastro` | Run in the `test/` Astro project to install your components |
| `npm publish` | [Publishes](https://docs.npmjs.com/creating-and-publishing-unscoped-public-packages#publishing-unscoped-public-packages) this package to NPM. Requires you to be [logged in](https://docs.npmjs.com/cli/v8/commands/npm-adduser) |[vscode.dev]: https://vscode.dev/github/roblabs/maps-withastro "A lightweight version of VS Code running fully in the browser."
[maps-withastro.RobLabs.com]: https://maps-withastro.RobLabs.com "🎲 🎲 Live_Demo"