A set of Vue 3 components to display an interactive SVG map.
npm install --save vue-svg-map
Install the map you need from svg-maps or use your own map. See maps section for more details.
This is the base component to display an SVG map.
In a SFC (Single File Component):
- Import
SvgMap
component fromvue-svg-map
- Import the map you want
- Optionally, import
vue-svg-map/style.css
if you want to apply the default styles
<script setup>
import { SvgMap } from "vue-svg-map";
import Taiwan from "@svg-maps/taiwan";
</script>
<template>
<SvgMap :map="Taiwan" />
</template>
<style src="vue-svg-map/style.css"></style>
Prop | Type | Default | Description |
---|---|---|---|
map | Map |
required | Describe SVG map to display. See maps section for more details. |
locationAttributes | SVGAttributes | ((location: Location, index: number) => SVGAttributes) |
{} |
Attributes of each <path> . The function parameters are the location object and the location index. |
All the listeners (click, keypress...) are applied to each location.
There are 2 named slots:
before
which is before the locationsafter
which is after the locations
This is an implementation of SvgMap
that behaves like a group of checkboxes.
It is based on this WAI-ARIA example to support keyboard navigation and be accessible.
- Import
SvgMapCheckbox
component fromvue-svg-map
- Import the map you want
- Optionally, import
vue-svg-map/style.css
if you want to apply the default styles
<script setup>
import { ref } from 'vue';
import { SvgMapCheckbox } from "vue-svg-map";
import Taiwan from "@svg-maps/taiwan";
const selectedLocationIds = ref([])
</script>
<template>
<SvgMapCheckbox v-model="selectedLocationIds" :map="Taiwan" />
</template>
<style src="vue-svg-map/style.css"></style>
Prop | Type | Default | Description |
---|---|---|---|
map | Map |
required | Describe SVG map to display. See maps section for more details. |
modelValue | string[] |
[] |
List of ids of selected locations. Used for v-model . |
locationAttributes | SVGAttributes | ((location: Location, index: number) => SVGAttributes) |
{} |
Attributes of each <path> . The function parameters are the location object and the location index. |
Like for SvgMap
all the listeners (click, keypress...) are applied to each location.
Event | Output | Description |
---|---|---|
update:modelValue | String[] | Emits the new list of ids when a location is selected/unselected. |
Like in SvgMap
there are 2 named slots:
before
which is before the locationsafter
which is after the locations
Note: inserting focusable elements may break the checkboxes' behaviour.
This is an implementation of SvgMap
that behaves like a group of radio buttons.
It is based on this WAI-ARIA example to support keyboard navigation and be accessible.
- Import
SvgMapRadio
component fromvue-svg-map
- Import the map you want
- Optionally, import
vue-svg-map/style.css
if you want to apply the default styles
<script>
import { ref } from 'vue';
import { SvgMapRadio } from "vue-svg-map";
import Taiwan from "@svg-maps/taiwan";
const selectedLocationId = ref(null)
</script>
<template>
<SvgMapRadio v-model="selectedLocationId" :map="Taiwan" />
</template>
<style src="vue-svg-map/style.css"></style>
Prop | Type | Default | Description |
---|---|---|---|
map | Map |
required | Describe SVG map to display. See maps section for more details. |
modelValue | string |
null |
Id of selected location. Used for v-model . |
locationAttributes | SVGAttributes | ((location: Location, index: number) => SVGAttributes) |
{} |
Attributes of each <path> . The function parameters are the location object and the location index. |
Like for SvgMap
all the listeners (click, keypress...) are applied to each location.
Event | Output | Description |
---|---|---|
update:modelValue | string |
Emits the new id when a location is selected. |
Like in SvgMap
there are 2 named slots:
before
which is before the locationsafter
which is after the locations
Note: inserting focusable elements may break the radio buttons' behaviour.
All the existing maps are in an independant svg-maps project because they may be useful for other components/projects.
You can modify existing maps or create your own.
- Import the map to modify
- Create a new object from this map
- Pass this new object as
map
prop of the component
<template>
<svg-map :map="customTaiwan" />
</template>
<script>
import { SvgMap } from "vue-svg-map";
import Taiwan from "@svg-maps/taiwan";
export default {
name: "MyMap",
components: {
SvgMap
},
data() {
return {
customTaiwan: {
...Taiwan,
label: "Custom map label",
locations: Taiwan.locations.map(location => {
// Modify each location to customize id, name or path
})
}
};
}
};
</script>
It is recommended to not modify the SVG properties (viewBox
, path
), because it may break the map's display.
If you create a new map (other country, city...), feel free to contribute to svg-maps project!
MIT