Skip to content
FrameworkStyle

media-menu

A composable menu component for settings, option selection, and actions

Anatomy

<button type="button" commandfor="settings-menu">Settings</button>

<media-menu id="settings-menu">
  <media-menu-view>
    <media-menu-item commandfor="speed-menu" type="playback-rate">
      Speed <media-menu-item-value></media-menu-item-value>
    </media-menu-item>
    <media-menu-item commandfor="captions-menu" type="captions">
      Captions <media-menu-item-value></media-menu-item-value>
    </media-menu-item>
    <media-menu-item>Copy link</media-menu-item>
  </media-menu-view>

  <media-menu id="speed-menu">
    <media-menu-back></media-menu-back>
    <media-menu-radio-group value="1">
      <media-menu-group-label>Speed</media-menu-group-label>
      <media-menu-radio-item value="1">Normal</media-menu-radio-item>
      <media-menu-radio-item value="1.5">1.5x</media-menu-radio-item>
    </media-menu-radio-group>
  </media-menu>

  <media-menu id="captions-menu">
    <media-menu-back></media-menu-back>
    <media-menu-radio-group value="off">
      <media-menu-group-label>Captions</media-menu-group-label>
      <media-menu-radio-item value="off">Off</media-menu-radio-item>
      <media-menu-radio-item value="en">English</media-menu-radio-item>
    </media-menu-radio-group>
  </media-menu>
</media-menu>

Behavior

Menus open from a trigger and close when you select an item, click outside, move focus away, or press Escape. Root menus are positioned against their trigger with side and align.

Nest Menu.Root inside Menu.Content to create an in-place submenu. In HTML, link a submenu with commandfor. Wrap the root list in Menu.View or <media-menu-view> when the root list and child menus share one animated viewport.

Set type="playback-rate" or type="captions" on a submenu trigger when it represents a media setting. Menu.ItemValue and <media-menu-item-value> read that setting context and display the current value, such as 1.5x, English, or Off.

Styling

Use data attributes to style open state, highlighted items, selected radio items, and submenu views:

media-menu[data-open] {
  opacity: 1;
}

media-menu-item[data-highlighted] {
  background: rgba(255, 255, 255, 0.16);
}

media-menu-radio-item[aria-checked="true"] {
  font-weight: 600;
}

Accessibility

Menu content renders with role="menu". Items use menuitem, menuitemradio, or menuitemcheckbox roles. Radio and checkbox items reflect selection with aria-checked.

Keyboard controls:

  • Enter / Space: Select the highlighted item.
  • Arrow Up / Arrow Down: Move between items.
  • Arrow Right: Open a submenu.
  • Arrow Left: Return to the parent menu.
  • Escape: Close the root menu or return from a submenu.

Use Menu.GroupLabel or <media-menu-group-label> inside grouped choices so the group receives an accessible label.

Examples

Basic usage

<video-player class="video-player">
    <media-container>
        <video
            src="https://stream.mux.com/BV3YZtogl89mg9VcNBhhnHm02Y34zI1nlMuMQfAbl3dM/highest.mp4"
            autoplay
            muted
            playsinline
            loop
        >
            <track kind="captions" src="/docs/demos/captions-button/captions.vtt" srclang="en" label="English" />
            <track kind="subtitles" src="/docs/demos/captions-button/captions.vtt" srclang="es" label="Spanish" />
        </video>
        <div class="menu-bar">
            <button type="button" commandfor="settings-menu" class="settings-trigger">Settings</button>
            <media-menu id="settings-menu" side="top" align="end" class="menu">
                <media-menu-view class="menu-panel">
                    <media-menu-item commandfor="speed-menu" type="playback-rate" class="menu-item">
                        <span>Speed</span>
                        <span class="menu-value">
                            <media-menu-item-value></media-menu-item-value>
                            <span aria-hidden="true"></span>
                        </span>
                    </media-menu-item>
                    <media-menu-item commandfor="captions-menu" type="captions" class="menu-item">
                        <span>Captions</span>
                        <span class="menu-value">
                            <media-menu-item-value></media-menu-item-value>
                            <span aria-hidden="true"></span>
                        </span>
                    </media-menu-item>
                    <media-menu-item class="menu-item">Copy link</media-menu-item>
                </media-menu-view>

                <media-menu id="speed-menu" class="menu-panel">
                    <media-menu-back class="menu-back">Speed</media-menu-back>
                    <media-playback-rate-radio-group class="menu-group">
                        <template>
                            <media-menu-radio-item class="menu-item">
                                <span data-part="label"></span>
                                <media-menu-item-indicator force-mount></media-menu-item-indicator>
                            </media-menu-radio-item>
                        </template>
                    </media-playback-rate-radio-group>
                </media-menu>

                <media-menu id="captions-menu" class="menu-panel">
                    <media-menu-back class="menu-back">Captions</media-menu-back>
                    <media-captions-radio-group class="menu-group">
                        <template>
                            <media-menu-radio-item class="menu-item">
                                <span data-part="label"></span>
                                <media-menu-item-indicator force-mount></media-menu-item-indicator>
                            </media-menu-radio-item>
                        </template>
                    </media-captions-radio-group>
                </media-menu>
            </media-menu>
        </div>
    </media-container>
</video-player>

API Reference

media-menu

Props

Prop Type Default Details

State

State is reflected as data attributes for CSS styling.

Property Type Details

Data attributes

Attribute Type Details

CSS custom properties

Variable Details

media-menu-back

Button that navigates back to the parent menu view. Place at the top of a submenu Content.

Props

Prop Type Default Details

media-menu-checkbox-item

A checkbox-style menu item. Renders a <div> with role="menuitemcheckbox".

Props

Prop Type Default Details

media-menu-group

Groups related menu items. Renders a <div> with role="group".

media-menu-group-label

Non-interactive label for a group of items. Renders a <div>.

media-menu-item

A single action in the menu. Renders a <div> with role="menuitem".

Props

Prop Type Default Details

media-menu-item-indicator

Visual indicator for a checked state. Only renders when checked is true (or forceMount is set).

Props

Prop Type Default Details

media-menu-item-value

Displays the current value for a settings menu item from Menu.Item or Menu.Trigger context.

Data attributes

Attribute Type Details

media-menu-radio-group

A group of mutually exclusive radio items. Renders a <div> with role="group".

Props

Prop Type Default Details

media-menu-radio-item

A radio-style menu item. Renders a <div> with role="menuitemradio".

Props

Prop Type Default Details

media-menu-separator

Visual divider between groups of items. Renders a <div> with role="separator".

media-menu-view

Root menu view inside the menu viewport.