Skip to content

Playground

Play with some of the components

vue
<template>
  <div>
    <mgl-map
      v-if="showMap"
      height="400px"
      :map-style="style"
      :center="center"
      :zoom="zoom"
      :attribution-control="false"
      @map:load="onLoad"
      @map:zoomstart="isZooming = true"
      @map:zoomend="isZooming = false"
    >
      <mgl-fullscreen-control/>
      <mgl-attribution-control/>
      <mgl-navigation-control/>
      <mgl-scale-control/>
      <mgl-geolocate-control/>
    </mgl-map>
  </div>
  <div style="margin-bottom: 20px">Version: {{ mapVersion }}</div>
  Loaded Count: {{ loaded }}<br>
  Is Zooming: {{ isZooming }}<br>
  <div>
    <input type="checkbox" v-model="showMap" id="showmap">
    <label for="showmap">Show Map</label>
  </div>
</template>

<script setup lang="ts">
import { ref, watch } from 'vue';
import {
  MglEvent,
  useMap,
  MglMap,
  MglFullscreenControl,
  MglAttributionControl,
  MglNavigationControl,
  MglScaleControl,
  MglGeolocateControl,
} from '@indoorequal/vue-maplibre-gl';
import { LngLatLike, MapLayerMouseEvent } from 'maplibre-gl';

const style = 'https://api.maptiler.com/maps/streets-v2/style.json?key=get_your_own_api_key_3YeFnghdqUJJpIvlgLti';

const map = useMap();
const mapVersion= ref<string>();
const loaded = ref(0);
const isZooming = ref(false);
const showMap = ref(true);
const center = [ -122.483696, 37.833818 ] as LngLatLike;
const zoom = 15;

watch(() => map.isLoaded, () => (console.log('IS LOADED', map)), { immediate: true });

watch(() => map.isMounted, (v: boolean) => (console.log('IS MOUNTED', v)), { immediate: true });

function onLoad(e: MglEvent) {
  loaded.value++;
  mapVersion.value = e.map.version;
  console.log(e.type, e, e.map.version);
}
</script>

<style lang="scss">
@import "maplibre-gl/dist/maplibre-gl.css";
</style>

Released under the MIT License.