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

NameDescription
wistia-popoverRequired. Tells the embed code that it should behave like a popover.
popover-animate-thumbnailEnables/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-animationSets the launch animation type of the popover.
popover-border-colorSets the border color of the popover.
popover-border-radiusSets the border radius of the popover.
popover-border-widthSets the border width of the popover.
popover-box-shadowEnables/disables the default diffuse box shadow on the popover.
popover-captionSets the text to be displayed directly below the popover.
popover-caption-containerTells 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-contentSets how the popover's container will be displayed.
popover-disable-autoplayEnables/disables autoplaying the popover as soon as it is opened.
popover-overlay-colorSets the background color of the popover's overlay.
popover-overlay-opacitySets the opacity of the popover's overlay.
popover-prevent-scrollEnables/disables scrolling the content behind the popover.
popover-show-on-loadEnables/disables the popover launching as soon as it is loaded.

Events

NameDescription
popover-showFires when the popover becomes visible.
popover-hideFires when the popover is hidden.

Methods

NameDescription
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:

  1. As attributes on the <wistia-player> element using HTML.
  2. As properties of the <wistia-player> element using JavaScript.
  3. 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

We 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

Required for popover embeds. Set this value to true to tell the embed code that it should behave like a popover.

AttributePropertyTypeDefault valueExample values
wistia-popoverwistiaPopoverbooleanfalsetrue, 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

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.

AttributePropertyTypeDefault valueExample values
popover-animate-thumbnailpopoverAnimateThumbnailbooleanfalsetrue, 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

Sets the launch animation type of the popover.

AttributePropertyTypeDefault valueExample values
popover-animationpopoverAnimationstring"slide""none", "fade"

Possible values:

ValueDescription
"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

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.

AttributePropertyTypeDefault valueExample values
popover-border-colorpopoverBorderColorstring"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

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.

AttributePropertyTypeDefault valueExample values
popover-border-radiuspopoverBorderRadiusnumber02, 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

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.

AttributePropertyTypeDefault valueExample values
popover-border-widthpopoverBorderWidthstring05, 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

Popovers have a diffuse box shadow by default. If you don't want any box shadow, set this option to false.

AttributePropertyTypeDefault valueExample values
popover-box-shadowpopoverBoxShadowbooleantruetrue, 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

Use this option to add some short text directly below the video.

AttributePropertyTypeDefault valueExample values
popover-captionpopoverCaptionstringundefined"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

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.

AttributePropertyTypeDefault valueExample values
popover-caption-containerpopoverCaptionContainerstringundefined"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

Sets how the popover's container will be displayed.

AttributePropertyTypeDefault valueExample values
popover-contentpopoverContentstringundefined"thumbnail", "html"

Possible values:

ValueDescription
"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

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.

AttributePropertyTypeDefault valueExample values
popover-disable-autoplaypopoverDisableAutoplaybooleanfalsetrue, 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

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.

AttributePropertyTypeDefault valueExample values
popover-overlay-colorpopoverOverlayColorstring"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

Sets the opacity of the popover's overlay. Expects a decimal value between 0 and 1.

AttributePropertyTypeDefault valueExample values
popover-overlay-opacitypopoverOverlayOpacitynumber0.50, 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

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 the popover-show and popover-hide events.

AttributePropertyTypeDefault valueExample values
popover-prevent-scrollpopoverPreventScrollbooleanfalsetrue, 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

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.

AttributePropertyTypeDefault valueExample values
popover-show-on-loadpopoverShowOnLoadbooleanfalsetrue, 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

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

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()

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()

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>