Aurora Popover Embed API
Customize your popover embeds with options, methods, and tips specific to popovers.
Wistia's popover embed displays in a lightbox that pops out over the page when opened. This article contains details on options and API functions specific to these lightbox-style embeds.
Popover embeds
The basic structure of a popover embed includes the player.js
script, a <wistia-player>
web component, and the wistia-popover
embed option.
<script src="https://fast.wistia.com/embed/abc123.js" async type="module"></script>
<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player media-id="abc123" wistia-popover></wistia-player>
import { WistiaPlayer } from "@wistia/wistia-player-react";
export default function App() {
return (
<WistiaPlayer mediaId="abc123" wistiaPopover={true} />
);
}
That is, they are very similar in structure to standard embeds, but with the option wistia-popover
.
Quick reference
Note: Most non-popover attributes, properties, events, and methods can also be used with popover embeds!
Attributes and properties
Name | Description |
---|---|
wistia-popover | Required. Tells the embed code that it should behave like a popover. |
popover-animate-thumbnail | Enables/disables a special behavior of the play button. If set to true , the button will expand to cover the thumbnail on hover, while also displaying the duration of the video. |
popover-animation | Sets the launch animation type of the popover. |
popover-border-color | Sets the border color of the popover. |
popover-border-radius | Sets the border radius of the popover. |
popover-border-width | Sets the border width of the popover. |
popover-box-shadow | Enables/disables the default diffuse box shadow on the popover. |
popover-caption | Sets the text to be displayed directly below the popover. |
popover-caption-container | Tells the embed code it should look for the specified ID of a DOM element. If found, that element will be moved and shown below the popover. |
popover-content | Sets how the popover's container will be displayed. |
popover-disable-autoplay | Enables/disables autoplaying the popover as soon as it is opened. |
popover-overlay-color | Sets the background color of the popover's overlay. |
popover-overlay-opacity | Sets the opacity of the popover's overlay. |
popover-prevent-scroll | Enables/disables scrolling the content behind the popover. |
popover-show-on-load | Enables/disables the popover launching as soon as it is loaded. |
Events
Name | Description |
---|---|
popover-show | Fires when the popover becomes visible. |
popover-hide | Fires when the popover is hidden. |
Methods
Name | Description |
---|---|
showPopover() | If the popover is hidden, this will show it. |
hidePopover() | If the popover is open, this will hide it. |
Options
Using popover embed options
Just like adding options to a standard embed, popover embed options can be set on the embed in three ways:
- As attributes on the
<wistia-player>
element using HTML. - As properties of the
<wistia-player>
element using JavaScript. - Via a
window.wistiaOptions
configuration object, before the popover is embedded.
1. As attributes
The embed option is added as an attribute directly on <wistia-player>
.
<script src="https://fast.wistia.com/embed/abc123.js" async type="module"></script>
<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player media-id="abc123" wistia-popover popover-border-width="2"></wistia-player>
import { WistiaPlayer } from "@wistia/wistia-player-react";
export default function App() {
return (
<WistiaPlayer
mediaId="abc123"
wistiaPopover={true}
popoverBorderWidth={2}
/>
);
}
2. As properties
Once we have a reference to the <wistia-player>
HTML element, we can interact with its properties via JavaScript.
const player = document.getElementById('my-player');
player.popoverBorderWidth = "2";
<script src="https://fast.wistia.com/embed/abc123.js" async type="module"></script>
<script src="https://fast.wistia.com/player.js@latest" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover></wistia-player>
3. Via a window.wistiaOptions
configuration object
window.wistiaOptions
configuration objectWe can set multiple or complex options via a window.wistiaOptions
configuration object. The object's keys must match the media-id
of the media on which we want the options to be applied. There is also a global '_all'
key, to easily apply options to all medias embedded on a page.
Note: The
window.wistiaOptions
object must appear before the<wistia-player>
element for its embed options to take effect.
<script src="https://fast.wistia.com/embed/abc123.js" async type="module"></script>
<script src="https://fast.wistia.com/embed/def456.js" async type="module"></script>
<script src="https://fast.wistia.com/player.js" async></script>
<script>
window.wistiaOptions = {
'_all': {
popoverBorderWidth: 2,
},
'abc123': {
popoverOverlayColor: '2949E5',
},
'def456': {
popoverOverlayOpacity: 1,
}
}
</script>
<wistia-player media-id="abc123"></wistia-player>
<wistia-player media-id="def456"></wistia-player>
wistia-popover
wistia-popover
Required for popover embeds. Set this value to true
to tell the embed code that it should behave like a popover.
Attribute | Property | Type | Default value | Example values |
---|---|---|---|---|
wistia-popover | wistiaPopover | boolean | false | true , false |
Example code:
<wistia-player media-id="abc123" wistia-popover></wistia-player>
// Set up a new player
const wistiaPlayer = document.createElement("wistia-player");
wistiaPlayer.mediaId = "abc123";
// Set wistiaPopover option
wistiaPlayer.wistiaPopover = true;
wistiaPlayer.wistiaPopover; // Returns `true`
// Add player to document
document.body.appendChild(wistiaPlayer);
import { WistiaPlayer } from '@wistia/wistia-player-react'
<WistiaPlayer mediaId="abc123" wistiaPopover={true} />
popover-animate-thumbnail
popover-animate-thumbnail
Enables/disables a special behavior of the play button. If set to true
, the button will expand to cover the thumbnail on hover, while also displaying the duration of the video. If set to false
(which is the default), there will be no special behavior on hover.
Attribute | Property | Type | Default value | Example values |
---|---|---|---|---|
popover-animate-thumbnail | popoverAnimateThumbnail | boolean | false | true , false |
Example code:
<wistia-player media-id="abc123" wistia-popover popover-animate-thumbnail></wistia-player>
// Set up a new player
const player = document.createElement("wistia-player");
player.mediaId = "abc123";
// Set popoverAnimateThumbnail option
player.popoverAnimateThumbnail = true;
player.popoverAnimateThumbnail; // Returns `true`
// Add player to document
document.body.appendChild(player);
popover-animation
popover-animation
Sets the launch animation type of the popover.
Attribute | Property | Type | Default value | Example values |
---|---|---|---|---|
popover-animation | popoverAnimation | string | "slide" | "none" , "fade" |
Possible values:
Value | Description |
---|---|
"slide" | Default behavior. Fades in the overlay and slides/fades the video up into place. |
"none" | Shows the popover with no animation and no delay. |
"fade" | Fades in the popover along with the overlay. |
Example code:
<wistia-player media-id="abc123" wistia-popover popover-animation="none"></wistia-player>
// Set up a new player
const player = document.createElement("wistia-player");
player.mediaId = "abc123";
// Set popoverAnimation option
player.popoverAnimation = "none";
player.popoverAnimation; // Returns `"none"`
// Add player to document
document.body.appendChild(player);
popover-border-color
popover-border-color
Sets the border color of the popover. Expects a six-character hexadecimal RGB string like #2949E5
. The string can include or exclude the preceding #
character.
Attribute | Property | Type | Default value | Example values |
---|---|---|---|---|
popover-border-color | popoverBorderColor | string | "ffffff" | "#000000" , "2949E5" |
Example code:
<wistia-player media-id="abc123" wistia-popover popover-border-color="2949E5"></wistia-player>
// Set up a new player
const player = document.createElement("wistia-player");
player.mediaId = "abc123";
// Set popoverBorderColor option
player.popoverBorderColor = "2949E5";
player.popoverBorderColor; // Returns `"2949E5"`
// Add player to document
document.body.appendChild(player);
popover-border-radius
popover-border-radius
Popovers have a 0
border radius by default. If your website uses round borders, use this option to set a matching border radius. It expects a value in pixels.
Attribute | Property | Type | Default value | Example values |
---|---|---|---|---|
popover-border-radius | popoverBorderRadius | number | 0 | 2 , 4 |
Example code:
<wistia-player media-id="abc123" wistia-popover popover-border-radius="2"></wistia-player>
// Set up a new player
const player = document.createElement("wistia-player");
player.mediaId = "abc123";
// Set popoverBorderRadius option
player.popoverBorderRadius = 2;
player.popoverBorderRadius; // Returns `2`
// Add player to document
document.body.appendChild(player);
popover-border-width
popover-border-width
Popovers have no borders by default. Use this option to add a border around the video. It expects the width to be an integer defined in pixels.
Attribute | Property | Type | Default value | Example values |
---|---|---|---|---|
popover-border-width | popoverBorderWidth | string | 0 | 5 , 15 |
Example code:
<wistia-player media-id="abc123" wistia-popover popover-border-width="5"></wistia-player>
// Set up a new player
const player = document.createElement("wistia-player");
player.mediaId = "abc123";
// Set popoverBorderWidth option
player.popoverBorderWidth = 5;
player.popoverBorderWidth; // Returns `5`
// Add player to document
document.body.appendChild(player);
popover-box-shadow
popover-box-shadow
Popovers have a diffuse box shadow by default. If you don't want any box shadow, set this option to false
.
Attribute | Property | Type | Default value | Example values |
---|---|---|---|---|
popover-box-shadow | popoverBoxShadow | boolean | true | true , false |
Example code:
<wistia-player media-id="abc123" wistia-popover popover-box-shadow="false"></wistia-player>
// Set up a new player
const player = document.createElement("wistia-player");
player.mediaId = "abc123";
// Set popoverBoxShadow option
player.popoverBoxShadow = false;
player.popoverBoxShadow; // Returns `false`
// Add player to document
document.body.appendChild(player);
popover-caption
popover-caption
Use this option to add some short text directly below the video.
Attribute | Property | Type | Default value | Example values |
---|---|---|---|---|
popover-caption | popoverCaption | string | undefined | "This is my caption!" |
Example code:
<wistia-player media-id="abc123" wistia-popover popover-caption="This is my caption!"></wistia-player>
// Set up a new player
const player = document.createElement("wistia-player");
player.mediaId = "abc123";
// Set popoverCaption option
player.popoverCaption = "This is my caption!";
player.popoverCaption; // Returns `"This is my caption!"`
// Add player to document
document.body.appendChild(player);
popover-caption-container
popover-caption-container
If you need longer text or more complex behavior and styling, use this option instead of popover-caption
. With popover-caption-container
, you specify the ID of a DOM element that should be shown below the caption. This DOM element will be moved (not cloned) and displayed when the popover is launched, so any bindings or styles that target it will stay in tact.
Attribute | Property | Type | Default value | Example values |
---|---|---|---|---|
popover-caption-container | popoverCaptionContainer | string | undefined | "my-caption" |
Example code:
<wistia-player media-id="abc123" wistia-popover popover-caption-container="my-caption"></wistia-player>
<div id="my-caption" style="display:none;">
I can have complex markup here, <a href="#" onclick="alert('Hi!'); return false;">setup bindings</a>, or even define other embed codes to accompany this one.
</div>
// Set up a new player
const player = document.createElement("wistia-player");
player.mediaId = "abc123";
// Set popoverCaptionContainer option
player.popoverCaptionContainer = "my-caption";
player.popoverCaptionContainer; // Returns `"my-caption"`
// Add player to document
document.body.appendChild(player);
popover-content
popover-content
Sets how the popover's container will be displayed.
Attribute | Property | Type | Default value | Example values |
---|---|---|---|---|
popover-content | popoverContent | string | undefined | "thumbnail" , "html" |
Possible values:
Value | Description |
---|---|
"thumbnail" | Default behavior. The video thumbnail will be rendered in the container, cropped to fit. |
"html" | The HTML in the container is not modified, with the exception of being wrapped in a div. Clicking inside this container will launch the popover. |
When popover-content
is not set or explicitly set to "thumbnail"
, the video thumbnail will be rendered in the container, cropped to fit with no black bars.
Example code:
<wistia-player media-id="abc123" wistia-popover popover-content="thumbnail"></wistia-player>
// Set up a new player
const player = document.createElement("wistia-player");
player.mediaId = "abc123";
// Set popoverContent option
player.popoverContent = "thumbnail";
player.popoverContent; // Returns `"thumbnail"`
// Add player to document
document.body.appendChild(player);
When popover-content
is set to "html"
, the HTML inside the container is not modified, with the exception of being wrapped in a div. Clicking inside this container will launch the popover video. You do not need to use an <a>
tag inside the popover, but we use it in our example to conveniently borrow native link styles.
Example code:
<wistia-player media-id="abc123" wistia-popover popover-content="html">
<a href="#">Launch the popover!</a>
</wistia-player>
Using a link-based popover will still load in a thumbnail from Wistia, adding to the page load. To prevent this from happening, implement the poster
embed option with a custom image or a meaningless string.
We recommend using this image URL which is a tiny, base64-encoded, fully transparent .png
image:

Example code:
<wistia-player media-id="abc123" wistia-popover popover-content="html" poster="">
<a href="#">Launch the popover!</a>
</wistia-player>
popover-disable-autoplay
popover-disable-autoplay
Enables/disables autoplaying the popover as soon as it is opened. If autoplay is disabled, launching the popover will not automatically play the media—it will require an additional click. You will see the thumbnail of the video when you click the initial thumbnail display for the popover.
Attribute | Property | Type | Default value | Example values |
---|---|---|---|---|
popover-disable-autoplay | popoverDisableAutoplay | boolean | false | true , false |
Example code:
<wistia-player media-id="abc123" wistia-popover popover-disable-autoplay></wistia-player>
// Set up a new player
const player = document.createElement("wistia-player");
player.mediaId = "abc123";
// Set popoverDisableAutoplay option
player.popoverDisableAutoplay = true;
player.popoverDisableAutoplay; // Returns `true`
// Add player to document
document.body.appendChild(player);
popover-overlay-color
popover-overlay-color
Sets the background color of the popover's overlay. Expects a six-character hexadecimal RGB string like #2949E5
. The string can include or exclude the preceding #
character.
Attribute | Property | Type | Default value | Example values |
---|---|---|---|---|
popover-overlay-color | popoverOverlayColor | string | "000000" | "#ffffff" , "2949E5" |
Example code:
<wistia-player media-id="abc123" wistia-popover popover-overlay-color="2949E5"></wistia-player>
// Set up a new player
const player = document.createElement("wistia-player");
player.mediaId = "abc123";
// Set popoverOverlayColor option
player.popoverOverlayColor = "2949E5";
player.popoverOverlayColor; // Returns `"2949E5"`
// Add player to document
document.body.appendChild(player);
popover-overlay-opacity
popover-overlay-opacity
Sets the opacity of the popover's overlay. Expects a decimal value between 0 and 1.
Attribute | Property | Type | Default value | Example values |
---|---|---|---|---|
popover-overlay-opacity | popoverOverlayOpacity | number | 0.5 | 0 , 1 |
Example code:
<wistia-player media-id="abc123" wistia-popover popover-overlay-opacity="0.75"></wistia-player>
// Set up a new player
const player = document.createElement("wistia-player");
player.mediaId = "abc123";
// Set popoverOverlayOpacity option
player.popoverOverlayOpacity = 0.75;
player.popoverOverlayOpacity; // Returns `0.75`
// Add player to document
document.body.appendChild(player);
popover-prevent-scroll
popover-prevent-scroll
By default, popovers render an overlay covering the entire document. But they do not stop the user from scrolling the content behind the video. Set this to true
if you would like to prevent the user from scrolling content.
Note: It accomplishes this by setting
height:100%;overflow:hidden
CSS properties on the<body>
element. If you have a custom scrolling implementation, this will not prevent scrolling in it. To implement a custom solution, you may want to bind to thepopover-show
andpopover-hide
events.
Attribute | Property | Type | Default value | Example values |
---|---|---|---|---|
popover-prevent-scroll | popoverPreventScroll | boolean | false | true , false |
Example code:
<wistia-player media-id="abc123" wistia-popover popover-prevent-scroll></wistia-player>
// Set up a new player
const player = document.createElement("wistia-player");
player.mediaId = "abc123";
// Set popoverPreventScroll option
player.popoverPreventScroll = true;
player.popoverPreventScroll; // Returns `true`
// Add player to document
document.body.appendChild(player);
popover-show-on-load
popover-show-on-load
Enables/disables the popover launching as soon as it is loaded, as if it was clicked. This may be useful for landing pages where you want the video to be front and center but don't otherwise have the space.
Attribute | Property | Type | Default value | Example values |
---|---|---|---|---|
popover-show-on-load | popoverShowOnLoad | boolean | false | true , false |
Example code:
<wistia-player media-id="abc123" wistia-popover popover-show-on-load></wistia-player>
// Set up a new player
const player = document.createElement("wistia-player");
player.mediaId = "abc123";
// Set popoverShowOnLoad option
player.popoverShowOnLoad = true;
player.popoverShowOnLoad; // Returns `true`
// Add player to document
document.body.appendChild(player);
Events
popover-show
popover-show
Fires when the popover becomes visible.
const player = document.getElementById('my-player');
player.addEventListener("popover-show", () => {
console.log("The popover for", player.mediaId, "is visible!");
});
<script src="https://fast.wistia.com/embed/abc123.js" async type="module"></script>
<script src="https://fast.wistia.com/player.js@latest" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover></wistia-player>
popover-hide
popover-hide
Fires when the popover is hidden.
const player = document.getElementById('my-player');
player.addEventListener("popover-hide", () => {
console.log("The popover for", player.mediaId, "is hidden!");
});
<script src="https://fast.wistia.com/embed/abc123.js" async type="module"></script>
<script src="https://fast.wistia.com/player.js@latest" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover></wistia-player>
Methods
showPopover()
showPopover()
If the popover is hidden, this will show it.
const player = document.getElementById('my-player');
player.showPopover();
<script src="https://fast.wistia.com/embed/abc123.js" async type="module"></script>
<script src="https://fast.wistia.com/player.js@latest" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover></wistia-player>
hidePopover()
hidePopover()
If the popover is open, this will hide it.
const player = document.getElementById('my-player');
player.hidePopover();
<script src="https://fast.wistia.com/embed/abc123.js" async type="module"></script>
<script src="https://fast.wistia.com/player.js@latest" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover></wistia-player>
Tips and examples
Simple custom popover button
The simplest way to create a custom button or element for your popover starts with the popover-content
embed option, like this one:
Example:
<script src="https://fast.wistia.com/embed/ns6e2w2xw1.js" async type="module"></script>
<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player media-id="ns6e2w2xw1" wistia-popover popover-content="html">
<a href="#">Launch the popover!</a>
</wistia-player>
The anchor element, <a href="#">
, inside of the <wistia-player>
container opens the popover. So you can replace the link text Launch the popover!
with a button
, img
, or other desired element!
Example:
<script src="https://fast.wistia.com/embed/ns6e2w2xw1.js" async type="module"></script>
<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player media-id="ns6e2w2xw1" wistia-popover popover-content="html">
<a href="#"><button type="button">Click Me!</button></a>
</wistia-player>
Custom popover button using embed links
If you need the popover to open from a custom button but are unable to place the button inside of the <wistia-player>
, for example when embedding within a specific theme or template, you can use Wistia's embed links to get around this limitation. Similar to the example above, we'll first embed a text link popover on the page, and simply remove the link inside of the <wistia-player>
element:
<script src="https://fast.wistia.com/embed/ns6e2w2xw1.js" async type="module"></script>
<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player media-id="ns6e2w2xw1" wistia-popover popover-content="html"></wistia-player>
This will embed the video, but keep it hidden until the button is clicked. Next, we'll construct an embed link that points to the hashed_id of our video:
#wistia_ns6e2w2xw1
The final step is to make sure that a button links to #wistia_ns6e2w2xw1
. If the video is successfully embedded on the page and the media id of the embed link matches the embed code, this should open the popover when clicked.
Example:
<script src="https://fast.wistia.com/embed/ns6e2w2xw1.js" async type="module"></script>
<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player media-id="ns6e2w2xw1" wistia-popover popover-content="html"></wistia-player>
<a href="#wistia_ns6e2w2xw1">
<button type="Click me!">Click me!</button>
</a>
Updated 19 days ago