import "@arcgis/map-components/components/arcgis-basemap-gallery";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 | 
|---|---|---|
activeBasemap | active-basemap | BasemapProperties | string | 
autoDestroyDisabled | auto-destroy-disabled | boolean | 
disabledreflected  | disabled | boolean | 
headingLevel | heading-level | 1 | 2 | 3 | 4 | 5 | 6 | 
icon | icon | string | 
label | label | string | 
messageOverrides |  | Record<string, unknown> | 
positiondeprecated  | position | "bottom-leading" | "bottom-left" | "bottom-right" | "bottom-trailing" | "manual" | "top-leading" | "top-left" | "top-right" | "top-trailing" | 
referenceElement | reference-element | HTMLArcgisLinkChartElement | HTMLArcgisMapElement | HTMLArcgisSceneElement | string | 
source |  | LocalBasemapsSource | PortalBasemapsSource | 
statereadonlyreflected  | state | "disabled" | "loading" | "ready" | "unsupported" | 
view |  | MapView | SceneView | 
activeBasemap
activeBasemap: BasemapProperties | stringThe map's current basemap.
- Attribute
 - active-basemap
 
autoDestroyDisabled
autoDestroyDisabled: booleanIf 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
disabled: booleanWhen true, sets the component to a disabled state so the user cannot interact with it.
- Attribute
 - disabled
 - Default value
 - false
 
headingLevel
headingLevel: 1 | 2 | 3 | 4 | 5 | 6Indicates 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
icon: stringIcon 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"
 
messageOverrides
messageOverrides: Record<string, unknown>Replace localized message strings with your own strings.
Note: Individual message keys may change between releases.
position
position: "bottom-leading" | "bottom-left" | "bottom-right" | "bottom-trailing" | "manual" | "top-leading" | "top-left" | "top-right" | "top-trailing"slot instead.- Attribute
 - position
 
referenceElement
referenceElement: HTMLArcgisLinkChartElement | HTMLArcgisMapElement | HTMLArcgisSceneElement | stringBy 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
source: LocalBasemapsSource | PortalBasemapsSourceThe 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 element
  const basemapGallery = document.querySelector("arcgis-basemap-gallery");
  // set the source from a local collection of basemaps
  basemapGallery.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 element
  const basemapGallery = document.querySelector("arcgis-basemap-gallery");
  // set the source from a portal group containing basemaps with different projections
  basemapGallery.source = new PortalBasemapsSource({
    // portal: new Portal(...) // default is ArcGIS Online
    query: { id: "bdb9d65e0b5c480c8dcc6916e7f4e099" }
  });
</script>state
state: "disabled" | "loading" | "ready" | "unsupported"The current state of the component.
- Attribute
 - state
 - Default value
 - "disabled"
 
view
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 Basemap Gallery component will be associated with a map or scene component rather than using theviewproperty.
Methods
| Method | Signature | 
|---|---|
componentOnReady | componentOnReady(): Promise<void> | 
destroy | destroy(): Promise<void> | 
componentOnReady
componentOnReady(): Promise<void>Create a promise that resolves once component is fully loaded.
Example
const arcgisBasemapGallery = document.querySelector("arcgis-basemap-gallery");
document.body.append(arcgisBasemapGallery);
await arcgisBasemapGallery.componentOnReady();
console.log("arcgis-basemap-gallery is ready to go!");- Returns
 - Promise<void>
 
Events
| Event | Type | 
|---|---|
arcgisPropertyChange | CustomEvent<{ name: "state" | "activeBasemap"; }> | 
arcgisReady | CustomEvent<void> | 
arcgisPropertyChange
arcgisPropertyChange: CustomEvent<{ name: "state" | "activeBasemap"; }>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.