Skip to content

Map Basemap docs

Vue.js library for managing and switching between different base map types

🚀 Introduction

Map Basemap is a Vue.js library that provides components for managing and switching between different base map types. The library supports various base map types including satellite, street, terrain, and custom maps.

📦 Installation

bash
npm install @hungpvq/vue-map-basemap

🎯 Features

  • Multiple basemaps - Support for various base map types
  • Basemap controls - Easy switching between base maps
  • Custom basemaps - Add your own custom base maps
  • Basemap cards - Visual base map selection cards
  • Basemap tags - Categorize base maps with tags
  • Compare mode - Side-by-side base map comparison
  • Responsive design - Mobile-friendly interface
  • TypeScript support - Full TypeScript support
  • Vue 3 Composition API - Modern Vue 3 Composition API

🚀 Usage

Basic Basemap Control

vue
<template>
  <Map @map-loaded="onMapLoaded">
    <BaseMapControl position="bottom-left" />
  </Map>
</template>

<script setup lang="ts">
import { Map } from '@hungpvq/vue-map-core';
import { BaseMapControl } from '@hungpvq/vue-map-basemap';
import '@hungpvq/vue-map-core/style.css';
import '@hungpvq/vue-map-basemap/style.css';

function onMapLoaded(map: any) {
  console.log('Map loaded:', map);
}
</script>

Basemap with Tags

vue
<template>
  <Map @map-loaded="onMapLoaded">
    <BaseMapTagControl position="bottom-left" />
    <BaseMapControl position="bottom-left" />
  </Map>
</template>

<script setup lang="ts">
import { Map } from '@hungpvq/vue-map-core';
import { BaseMapControl, BaseMapTagControl } from '@hungpvq/vue-map-basemap';

function onMapLoaded(map: any) {
  console.log('Map loaded:', map);
}
</script>

Basemap with Custom Sources

vue
<template>
  <Map @map-loaded="onMapLoaded">
    <BaseMapControl position="bottom-left" :customBasemaps="customBasemaps" />
  </Map>
</template>

<script setup lang="ts">
import { ref } from 'vue';
import { Map } from '@hungpvq/vue-map-core';
import { BaseMapControl } from '@hungpvq/vue-map-basemap';

const customBasemaps = ref([
  {
    link: '',
    thumbnail: '/static/img/icon-stack.png',
    type: 'no-basemap',
    title: 'None',
    id: 'null',
  },
  {
    id: 1,
    title: 'Streets',
    type: 'vector',
    thumbnail: '',
    links: ['https://tiles.eofactory.ai/styles/basic/style.json'],
  },
  {
    id: 2,
    title: 'ArcGIS Satellite',
    type: 'raster',
    thumbnail: '',
    links: ['https://services.arcgisonline.com/ArcGIS/rest/services/World_Imagery/MapServer/tile/{z}/{y}/{x}'],
    maxzoom: 19,
    minzoom: 0,
  },
]);

function onMapLoaded(map: any) {
  console.log('Map loaded:', map);
}
</script>

Using Basemap Hooks

vue
<script setup lang="ts">
import { useBaseMap } from '@hungpvq/vue-map-basemap';
import { useMap } from '@hungpvq/vue-map-core';

const props = defineProps({
  mapId: { type: String, required: true },
});
const { mapId } = useMap(props);
const { currentBaseMap, setCurrent, baseMaps } = useBaseMap(mapId.value);

// Get current basemap
function getCurrent() {
  const current = currentBaseMap.value;
  console.log('Current basemap:', current);
}

// Set new basemap
function changeBasemap(basemap: BaseMapItem) {
  setCurrent(basemap);
}

// Get all available basemaps
function getBasemaps() {
  const basemaps = baseMaps.value;
  console.log('Available basemaps:', basemaps);
}
</script>

With Map Core

vue
<template>
  <Map :mapId="mapId" @map-loaded="onMapLoaded">
    <!-- Core controls -->
    <ZoomControl position="top-right" />
    <HomeControl position="top-right" />

    <!-- Basemap controls -->
    <BaseMapControl position="bottom-left" />
    <BaseMapTagControl position="bottom-left" />
  </Map>
</template>

<script setup lang="ts">
import { Map, ZoomControl, HomeControl } from '@hungpvq/vue-map-core';
import { BaseMapControl, BaseMapTagControl } from '@hungpvq/vue-map-basemap';
</script>

With Dataset Management

vue
<template>
  <Map :mapId="mapId" @map-loaded="onMapLoaded">
    <LayerControl position="top-left" show>
      <template #endList="{ mapId }">
        <BaseMapCard :mapId="mapId" />
      </template>
    </LayerControl>
    <BaseMapControl position="bottom-left" />
  </Map>
</template>

<script setup lang="ts">
import { Map } from '@hungpvq/vue-map-core';
import { BaseMapControl, BaseMapCard } from '@hungpvq/vue-map-basemap';
import { LayerControl } from '@hungpvq/vue-map-dataset';
</script>

🤝 Contributing

All contributions are welcome! Please:

  1. Fork the repository
  2. Create a feature branch
  3. Commit your changes
  4. Push to the branch
  5. Create a Pull Request

📄 License

MIT License