Skip to main content

Home pages

You can display a dedicated UI, or "home page," for your Snap within MetaMask. This is useful for introducing your Snap to end users. Users can access your home page through the Snaps menu in MetaMask. Snap home pages can contain custom UI and interactive UI components.

Steps

1. Request permission to display a home page

Request the endowment:page-home permission. Add the following to your Snap's manifest file:

snap.manifest.json
"initialPermissions": {
"endowment:page-home": {}
}

2. Create a home page

Expose an onHomePage entry point, which returns the custom or interactive UI to be shown. MetaMask calls this method when a user selects your Snap name in the Snaps menu.

The following example displays custom UI that welcomes the user to the Snap's home page:

index.ts
import type { OnHomePageHandler } from "@metamask/snaps-sdk"
import { panel, text, heading } from "@metamask/snaps-sdk"

export const onHomePage: OnHomePageHandler = async () => {
return {
content: panel([
heading("Hello world!"),
text("Welcome to my Snap home page!"),
]),
}
}

Home page example

Example

See the @metamask/home-page-example-snap package for a full example of implementing a Snap home page.