Position controls
Slots for layout
Section titled Slots for layoutSlots are used to tell <media-controller>
where you want your controls positioned. Even if you aren’t explicitly naming a slot, you’re still using one (the “default slot”). Most commonly, you’ll put media control elements like <media-play-button>
or <media-fullscreen-button>
inside slots. But any arbitrary markup can be placed inside a slot.
This gives you a lot of flexibility when customizing your player. For example, here is a player that has an h3 title in the top slot and a play button in the centered slot.
<media-controller>
<video slot="media"></video>
<div slot="top-chrome">
<h3>Episode 2</h3>
</div>
<div slot="centered-chrome">
<media-play-button></media-play-button>
</div>
</media-controller>
You also may want to show different slots on mobile vs. desktop. For example, here’s a player that uses slot="centered-chrome"
on mobile and uses a <media-control-bar>
in the default slot (aka ”bottom-chrome
”) on desktop:
<style>
.desktop {
display: none;
}
@media (min-width: 768px) {
.mobile {
display: none;
}
.desktop {
display: block;
}
}
</style>
<media-controller>
<video slot="media"></video>
<div slot="top-chrome">
<h3>Episode 2</h3>
</div>
<div slot="centered-chrome" class="mobile">
<media-play-button></media-play-button>
</div>
<media-control-bar class="desktop">
<!-- This will go in the default slot, effectively the "bottom-chrome" -->
<media-play-button></media-play-button>
</media-control-bar>
</media-controller>
Below is a more in-depth discussion of available slots and how they work.
(NOTE: slots are actually part of the Web Components / Custom Elements specification, but you shouldn’t need to understand these technical details to work with them in <media-chrome>
)
Working with slots (video)
Section titled Working with slots (video)For an interactive example of how each of the slots render for video
, check out this demo (view source).
Default Slot (effectively the ”bottom-chrome
“)
Section titled Default Slot (effectively the ”bottom-chrome“)data:image/s3,"s3://crabby-images/806be/806be3ee9362e9d3a4a5d0bfd9cc4b64829b9012" alt="Bottom Chrome Visual Description"
-
Render Location: Each child that doesn’t specify a slot will render at the bottom of the
<media-controller>
. If you have more than one element like this they will be stacked vertically. -
Common/Example use cases: showing one or more rows of controls at the bottom of the
<media-controller>
. For many use cases, you can simply add a<media-control-bar>
for each row of controls you’d like, which will provide you with additional automatic sizing and layout behavior.
top-chrome
Section titled top-chromedata:image/s3,"s3://crabby-images/fd7c2/fd7c2f9848992054b7fd051b00a5e9d19d474526" alt="Top Chrome Visual Description"
-
Render Location: Each child that specifies
slot="top-chrome"
will render at the top of the<media-controller>
. If you have more than one element like this they will be stacked vertically. -
Common/Example use cases: showing one or more rows of controls at the top of the
<media-controller>
. For many use cases, you can simply add a<media-control-bar>
for each row of controls you’d like.- Demuxed 2021 theme (mobile screen sizes only) (view source)
middle-chrome
Section titled middle-chromedata:image/s3,"s3://crabby-images/ca9ed/ca9ed0b99d984da13f09ed80d579e1d386a2aaee" alt="Middle Chrome Visual Description"
-
Render Location: Children that specify
slot="middle-chrome"
will show up in the available space between any ”top-chrome
” children and any default slot/”bottom-chrome
” children. -
Common/Example use cases:
middle-chrome
would generally be used for more specific cases, such as custom subtitle/caption rendering, or additional related content you’d like to show while the media is paused or has finished playback. While you can have multiple children that are “slotted to”middle-chrome
, most likely, you’ll want to use one and style it to size/layout any custom content you’d like.- (Examples coming!)
centered-chrome
Section titled centered-chromedata:image/s3,"s3://crabby-images/14f08/14f08bba66b3004143f012a4c03853f62bb67f13" alt="Centered Chrome Visual Description"
-
Render Location: The child that specifies
slot="centered-chrome"
will show up in the center of the<media-controller>
and will be “above” anything in the default slot,top-chrome
, ormiddle-chrome
. -
Common/Example use cases: “big button” controls that are centered and horizontally layed out “on top of” the media. While you can have multiple children that are “slotted to”
centered-chrome
, most likely, you’ll want to use only one, making styling and layout easier and more predictable.
Other use cases
Section titled Other use casesdata:image/s3,"s3://crabby-images/8bb50/8bb50111177f6cbf2e3eeff7f88f853b1fe25477" alt="Mix and Match Usage Visual Description"
<media-control-bar/>
at the top and bottom)data:image/s3,"s3://crabby-images/684de/684de92dfe273752de440d5dfbb6f16c10443afe" alt="Responsive Design Visual Description"
Working with slots (audio)
Section titled Working with slots (audio)Since audio
chromes vary much more than video
, it’s recommended that you only use the default slot and only add a single element (e.g. a single <media-control-bar>
) and style it however you’d like.
As we work through other common use cases, both internally and with the community, we may start adding additional “built-in” styling and layout for <media-control-bar>
slots used with audio
.
- Example use cases: