import "@arcgis/map-components/components/arcgis-basemap-gallery";- Inheritance
- ArcgisBasemapGallery→
PublicLitElement
- Since
- ArcGIS Maps SDK for JavaScript 4.28
The Basemap Gallery component displays a collection images representing basemaps from ArcGIS.com or a user-defined set of map or image services. When a new basemap is selected from the Basemap Gallery, the map's basemap layers are removed and replaced with the basemap layers of the associated basemap selected in the gallery.
Demo
Properties
| Property | Attribute | Type |
|---|---|---|
| active-basemap | ||
| auto-destroy-disabled | ||
| reflected | disabled | |
| heading-level | ||
| icon | ||
| label | ||
| | ||
| reference-element | ||
| | ||
| readonly | | |
| |
activeBasemap
- Type
- BasemapProperties | string | undefined
The map's current basemap.
- Attribute
- active-basemap
autoDestroyDisabled
- Type
- boolean
If true, the component will not be destroyed automatically when it is disconnected from the document. This is useful when you want to move the component to a different place on the page, or temporarily hide it. If this is set, make sure to call the destroy() method when you are done to prevent memory leaks.
- Attribute
- auto-destroy-disabled
- Default value
- false
disabled
- Type
- boolean
When true, the component is visually withdrawn and cannot receive user interaction.
- Attribute
- disabled
- Default value
- false
headingLevel
- Type
- HeadingLevel
Indicates the heading level to use for the message "No basemaps available" when no basemaps are available in the Basemap Gallery.
- Attribute
- heading-level
- Default value
- 2
icon
- Type
- string
Icon which represents the component. Typically used when the component is controlled by another component (e.g. by the Expand component).
- See also
- Attribute
- icon
- Default value
- "basemap"
referenceElement
- Type
- ArcgisReferenceElement | string | undefined
By assigning the id attribute of the Map or Scene component to this property, you can position a child component anywhere in the DOM while still maintaining a connection to the Map or Scene.
- Attribute
- reference-element
source
The source for basemaps that the component will display.
- Examples
Set the source from a local basemap collection.
<arcgis-map basemap="gray"><arcgis-basemap-gallery slot="top-right"></arcgis-basemap-gallery></arcgis-map><script type="module">const [Basemap, LocalBasemapsSource] = await $arcgis.import(["@arcgis/core/Basemap.js","@arcgis/core/widgets/BasemapGallery/support/LocalBasemapsSource.js",]);// get the basemap gallery elementconst basemapGallery = document.querySelector("arcgis-basemap-gallery");// set the source from a local collection of basemapsbasemapGallery.source = new LocalBasemapsSource({basemaps: [Basemap.fromId("topo-vector"), Basemap.fromId("hybrid")],});</script>Set the source from a Portal group
<arcgis-map item-id="8d91bd39e873417ea21673e0fee87604"><arcgis-basemap-gallery slot="top-right"></arcgis-basemap-gallery></arcgis-map><script type="module">const PortalBasemapsSource = await $arcgis.import("@arcgis/core/widgets/BasemapGallery/support/PortalBasemapsSource.js");// get the basemap gallery elementconst basemapGallery = document.querySelector("arcgis-basemap-gallery");// set the source from a portal group containing basemaps with different projectionsbasemapGallery.source = new PortalBasemapsSource({// portal: new Portal(...) // default is ArcGIS Onlinequery: { id: "bdb9d65e0b5c480c8dcc6916e7f4e099" }});</script>
view
- Type
- MapViewOrSceneView | null | undefined
The view associated with the component.
Note: The recommended approach is to fully migrate applications to use map and scene components and avoid using MapView and SceneView directly. However, if you are migrating a large application from widgets to components, you might prefer a more gradual transition. To support this use case, the SDK includes this
viewproperty which connects a component to a MapView or SceneView. Ultimately, once migration is complete, the arcgis-basemap-gallery component will be associated with a map or scene component rather than using theviewproperty.
Methods
| Method | Signature |
|---|---|
| inherited | componentOnReady(): Promise<this> |
| destroy(): Promise<void> |
componentOnReady
- Signature
-
componentOnReady (): Promise<this>
Creates a promise that resolves once the component is fully loaded.
- Returns
- Promise<this>
- Example
- const arcgisBasemapGallery = document.querySelector("arcgis-basemap-gallery");document.body.append(arcgisBasemapGallery);await arcgisBasemapGallery.componentOnReady();console.log("arcgis-basemap-gallery is ready to go!");
Events
| Name | Type |
|---|---|
| CustomEvent<{ name: "activeBasemap" | "state"; }> | |
arcgisPropertyChange
arcgisPropertyChange: CustomEvent<{ name: "activeBasemap" | "state"; }> Emitted when the value of a property is changed. Use this to listen to changes to properties.
arcgisReady
arcgisReady: CustomEvent<void> Emitted when the component associated with a map or scene view is ready to be interacted with.