@mapsindoors/map-template
v1.63.0
Published
Get a MapsIndoors map up and running in less than 10 mins.
Downloads
1,295
Keywords
Readme
Map Template
Web Component: Installation and usage
Using NPM
Install the package:
npm install @mapsindoors/map-template@stable
In your script:
import MapsIndoorsMap from '@mapsindoors/map-template/dist/mapsindoors-webcomponent.es.js';
window.customElements.define('mapsindoors-map', MapsIndoorsMap);
In your styles make sure to give it a size. For example:
mapsindoors-map {
display: block;
width: 100vw;
height: 100dvh;
}
Use the Web Component in your HTML:
<mapsindoors-map></mapsindoors-map>
Add attributes to the Web Component as needed (see supported properties below).
Note! The external-IDs
and app-user-roles
expect an array, which in a Web Component is handled differently (see example below).
In your script, define the array of external IDs that you want to be shown on the Map Template.
Then get a hold of the mapsIndoors map element using the document.querySelector()
method.
When you have the mapsIndoors map element, assign its prop externalIDs
the array of external IDs that you defined at the beginning.
const externalIDsArray = ["externalID-1", "externalID-2"]
const mapsIndoorsMapElement = document.querySelector('mapsindoors-map')
mapsIndoorsMapElement.externalIDs = externalIDsArray;
Use query parameters to configure the Web Component by setting the supports-url-parameter
attribute to true
.
Using just the browser
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>MapsIndoors Map Template</title>
<script type="module">
import MapsindoorsMap from 'https://www.unpkg.com/@mapsindoors/map-template@stable/dist/mapsindoors-webcomponent.es.js';
window.customElements.define('mapsindoors-map', MapsindoorsMap)
</script>
<style>
body {
margin: 0;
}
mapsindoors-map {
display: block;
width: 100vw;
height: 100dvh;
}
</style>
</head>
<body>
<mapsindoors-map></mapsindoors-map>
</body>
</html>
Add attributes to the Web Component as needed (see supported properties below).
Use query parameters to configure the Web Component by setting the supports-url-parameter
attribute to true
.
React component: Installation and usage
Using NPM
Install the package:
npm install @mapsindoors/map-template@stable
Use the MapsIndoorsMap
component in a React component:
import MapsIndoorsMap from '@mapsindoors/map-template/dist/mapsindoors-react.es.js';
// Somewhere in your JSX:
<div style={{
display: 'block',
width: '100vw',
height: '100dvh'
}}>
<MapsIndoorsMap></MapsIndoorsMap>
</div>
Add properties to the MapsIndoorsMap component as needed (see list below).
Use query parameters to configure the MapsIndoorsMap component by setting the supportsUrlParameters
prop to true
.
Supported attributes on the MapsIndoors Map components
Note that when using the React component, the properties should conform to JSX prop naming, eg. api-key
becomes apiKey
.
|Attribute|React prop name|Type|Description|
|:--|:--|:--|:--|
|api-key
|apiKey
|string
|The MapsIndoors Solution you want to load. Takes both API key as string and "App alias". |
|gm-api-key
|gmApiKey
|string
|Your Google Maps API key. Can also be set in the MapsIndoors App Config as "gmKey" under "appSettings".|
|mapbox-access-token
|mapboxAccessToken
|string
|Your Mapbox Access Token. Can also be set in the MapsIndoors App Config "mapboxAccessToken" under "appSettings". Setting it will load a Mapbox map. If you set both a Mapbox Access Token and Google Maps API key, the Mapbox Access Token takes precedence. |
|venue
|venue
|string
|The Venue to load from your MapsIndoors Solution. |
|location-id
|locationId
|string
|Set a MapsIndoors Location ID to show it on the map and its details in the sheet. |
|primary-color
|primaryColor
|string
|The primary color to use throughout the app. |
|logo
|logo
|string
|The logo to show during initial load. |
|app-user-roles
|appUserRoles
|array
|A list of App User Roles to apply when loading data. Used like so: appUserRoles={["App User Role"]}
|
|directions-from
|directionsFrom
|string
|Set a MapsIndoors Location ID to be used as origin to instantly show directions. |
|directions-to
|directionsTo
|string
|Set a MapsIndoors Location ID to be used as destination to instantly show directions. |
|external-IDs
|etxternalIDs
|array
|Array of external IDs which filters the map and shows a list of locations. Because of the way browsers work, you can not use External IDs with the ,
, &
, #
and +
, character in them, as they are interpreted by the browser in a particular way. |
|tile-style
|tileStyle
|string
|Name of Tile Style to display on the map. |
|start-zoom-level
|startZoomLevel
|number
|The initial zoom level of the map. |
|supports-url-parameters
|supportsUrlParameters
|bool
|Indicates if the Map Template supports URL parameters. |
|gm-map-id
|gmMapId
|string
|The Google Maps Map ID associated with a specific map style or feature. |
|pitch
|pitch
|number
|The pitch (Mapbox) or tilt (Google) value of the map. The value of the pitch can be between 0-85 degrees on a Mapbox map. |
|bearing
|bearing
|number
|The bearing (Mapbox) or heading (Google) value of the map. It accepts any value, and will modify it to fit into the range [0, 360]. |
|use-map-provider-module
|useMapProviderModule
| Set to true if the Map Template should take MapsIndoors solution modules into consideration when determining what map type to use. |
|language
|language
|string
|The language to show textual content in. Supported values are "en" for English, "da" for Danish, "de" for German, "fr" for French, "it" for Italian, "es" for Spanish and "nl" for Dutch. If the prop is not set, the language of the browser will be used (if it is one of the supported languages - otherwise it will default to English). |
|kiosk-origin-location-id
|kioskOriginLocationId
|string
|If running the Map Template as a Kiosk, provide the Location ID that represents the location of the Kiosk. |
|timeout
|timeout
|number
|If you want the Map Template to reset the map position and the UI elements to the initial state after some time of inactivity, use this to specify the number of seconds of inactivity before resetting. This property is not dependent on the kioskOriginLocationId
. |
|use-keyboard
|useKeyboard
|bool
|If running the Map Template as a Kiosk, set this prop to true
and it will display a virtual keyboard. This property is dependent on the kioskOriginLocationId
. |
|mi-transition-level
|miTransitionLevel
|number
|The zoom level on which to transition from Mapbox to MapsIndoors data. Default value is 17. This feature is only available for Mapbox. |
|category
|category
|string
|If you want to indicate an active category on the map. The value should be the Key (Administrative ID). |
|search-all-venues
|searchAllVenues
|bool
|If you want to perform search across all venues in the solution. |
|hide-non-matches
|hideNonMatches
|bool
|Determine whether the locations on the map should be filtered (only show the matched locations and hide the rest) or highlighted (show all locations and highlight the matched ones with a red dot by default). If set to true, the locations will be filtered. |
|show-road-names
|showRoadNames
|bool
|A boolean parameter that dictates whether Mapbox road names should be shown. By default, Mapbox road names are hidden when MapsIndoors data is shown. It is dictated by mi-transition-level
which default value is 17. |
|show-external-ids
|showExternalIDs
|bool
|Determine whether the location details on the map should have an external ID visible. The default value is set to false. |
|search-external-locations
|searchExternalLocations
|bool
|If you want to perform search for external locations in the Wayfinding mode. If set to true, Mapbox/Google places will be displayed depending on the Map Provider you are using. If set to false, the results returned will only be MapsIndoors results. The default is true. |
Using Query Parameters
The Map Template supports using query parameters for all the properties provided by the MapsIndoorsMap component if the supportsUrlParameters
property is set to true.
The supported query parameters are the following:
apiKey
- Used like thisapiKey=yourApiKey
. If no apiKey is provided, the app will default tomapspeople3d
.venue
- Used like thisvenue=yourVenueName
- the Venue property is case sensitive. If no venue is provided, the app will select the first venue from the solution in alphabetical order.locationId
- Used like thislocationId=yourLocationId
primaryColor
- Used like thisprimaryColor=000000
. Note! You need to provide a hex color value, without the#
, due to the hashtag being a reserved symbol that has a predefined purpose in a query string. If no primary color is provided, the app will default to the MapsPeople brand color.logo
- Used like thislogo=https://images.g2crowd.com/uploads/product/image/social_landscape/social_landscape_7a75ff13f42605422950b411ab7e03b5/mapspeople.png
. Use an image address to provide a different logo on the loading screen. If no logo is provided, the app will default to the MapsPeople icon.appUserRoles
- Used like thisappUserRoles=visitor,staff,security
- the App User Roles are case sensitive. Note! You need to provide a list of comma separated values, without any spaces between the comma and the value. This will further be converted into an array of appUserRoles.directionsFrom
- Used like thisdirectionsFrom=yourOriginLocationId
when having a location ID, or like thisdirectionsFrom=USER_POSITION
when having the user location. Using thedirectionsFrom
property in the URL followed by the selection of a destination location in the search view results in the wayfinding having both the origin and the destination prefilled.directionsTo
- Used like thisdirectionsTo=yourDestinationLocationId
when having a location ID, or like thisdirectionsTo=USER_POSITION
when having the user location.externalIDs
- Used like thisexternalIDs=0.0.1,0.0.2,0.0.3
. Note! You need to provide a list of comma separated values, without any spaces between the comma and the value. This will further be converted into an array of external IDs. Because of the way browsers work, you cannot use External IDs with the,
,&
,#
and+
, character in them, as they are interpreted by the browser in a particular way.tileStyle
- Used like thistileStyle=yourTileStyleName
. If no tile style is provided, the app will show the default tile style.mapboxAccessToken
- Used like thismapboxAccessToken=yourMapboxAccessToken
. If both themapboxAccessToken
and thegmApiKey
are present, the app will load a Mapbox map.gmApiKey
- Used like thisgmApiKey=yourGmApiKey
. If both themapboxAccessToken
and thegmApiKey
are present, the app will load a Mapbox map.startZoomLevel
- Used like thisstartZoomLevel=22
.gmMapId
- Used like thisgmMapId=yourGmMapId
.pitch
- Used like thispitch=30
. Not compatible with MapsIndoors 2D models and MapsIndoors labels on Google Maps. The value of the pitch can be between 0-85 degrees on a Mapbox map.bearing
- Used like thisbearing=180
. Not compatible with MapsIndoors 2D models and MapsIndoors labels on Google Maps. It accepts any value, and will modify it to fit into the range [0, 360].useMapProviderModule
- Set to "true" if the Map Template should take MapsIndoors solution modules into consideration when determining what map type to use.language
- The language to show textual content in. Supported values are "en" for English, "da" for Danish, "de" for German, "fr" for French, "it" for Italian and "es" for Spanish. If the prop is not set, the language of the browser will be used (if it is one of the supported languages - otherwise it will default to English).kioskOriginLocationId
- If running the Map Template as a Kiosk, provide the Location ID that represents the location of the Kiosk.timeout
- If you want the Map Template to reset the map position and the UI elements to the initial state after some time of inactivity, use this to specify the number of seconds of inactivity before resetting. This property is not dependent on thekioskOriginLocationId
.useKeyboard
- If running the Map Template as a Kiosk, set this prop totrue
and it will display a virtual keyboard. This property is dependent on thekioskOriginLocationId
.miTransitionLevel
- The zoom level on which to transition from Mapbox to MapsIndoors data. Default value is 17. This feature is only available for Mapbox.category
- If you want to indicate an active category on the map. The value should be the Key (Administrative ID).searchAllVenues
- If you want to perform search across all venues in the solution.hideNonMatches
- Determine whether the locations on the map should be filtered (only show the matched locations and hide the rest) or highlighted (show all locations and highlight the matched ones with a red dot by default). If set to true, the locations will be filtered.showRoadNames
- A boolean parameter that dictates whether Mapbox road names should be shown. By default, Mapbox road names are hidden when MapsIndoors data is shown. It is dictated bymi-transition-level
which default value is 17.showExternalIDs
- Determine whether the location details on the map should have an external ID visible. The default value is set to false.searchExternalLocations
- If you want to perform search for external locations in the Wayfinding mode. If set to true, Mapbox/Google places will be displayed depending on the Map Provider you are using. If set to false, the results returned will only be MapsIndoors results. The default is true.
Note! All the query parameters need to be separated with the &
symbol, without any spaces in between.
Note! When using parameters such as directionsTo
, directionsFrom
, locationId
, externalIDs
, and tileStyle
make sure you are using the correct apiKey
parameter to which they belong.
Note! When using the gmMapId
property, you need to use it together with the gmApiKey
that it is associated with.
Example of URL:
https://domain.com/?apiKey=yourApiKey&venue=yourVenueName&locationId=yourLocationId&primaryColor=000000&logo=https://images.g2crowd.com/uploads/product/image/social_landscape/social_landscape_7a75ff13f42605422950b411ab7e03b5/mapspeople.png&appUserRoles=visitor,staff,security
Important! Not all the query parameters can be used together, as they serve their own purpose which in some cases overlaps with other query parameters. Example of cases that DON’T work together:
locationId
+ startZoomLevel
→ the startZoomLevel
has priority over the locationId
locationId
+ externalIDs
→ the locationId
has priority over the externalIDs
directionsTo
+ directionsFrom
+ locationId
→ the directionsTo
+ directionsFrom
have priority over the locationId
directionsTo
+ directionsFrom
+ externalIDs
→ the directionsTo
+ directionsFrom
have priority over the externalIDs
External customization of the Map Template
When using the Map Template as a React Component or as a Web Component, you can control the map and the data on it by accessing the MapsIndoors instance. To do this, listen for the mapsIndoorsInstanceAvailable
event on the window
object.
You can read about all the methods that can be used on the MapsIndoors Instance [here]. (https://app.mapsindoors.com/mapsindoors/js/sdk/latest/docs/mapsindoors.MapsIndoors.html)
1. React Component
To use the MapsIndoors instance within a React Component, you can create a useEffect
hook that listens for the mapsIndoorsInstanceAvailable
event on the window
object.
import MapsIndoorsMap from '@mapsindoors/map-template/dist/mapsindoors-react.es.js';
import { useEffect } from 'react';
function App() {
useEffect(() => {
window.addEventListener('mapsIndoorsInstanceAvailable', () => {
window.mapsIndoorsInstance.setDisplayRule('yourLocationId', { 'polygonFillColor': '#ff69b4' })
})
}, [])
return (
<div>
<MapsIndoorsMap apiKey="yourApiKey" mapboxAccessToken="yourMapboxAccessToken" />
</div>
)
}
export default App;
2. Web Component
To use the MapsIndoors instance within a Web Component, include a script tag that listens for the mapsIndoorsInstanceAvailable
event on the window
object.
<body>
<mapsindoors-map api-key="yourApiKey" mapbox-access-token="yourMapboxAccessToken"></mapsindoors-map>
<script>
window.addEventListener('mapsIndoorsInstanceAvailable', () => {
window.mapsIndoorsInstance.setDisplayRule('yourLocationId', { 'polygonFillColor': '#ff69b4' })
})
</script>
</body>