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!

Customizable attributes and properties

HTML attributeJavaScript propertyDescription
wistia-popoverwistiaPopoverRequired for popover embeds. Tells the embed code that it should behave like a popover.
popover-animate-thumbnailpopoverAnimateThumbnailEnables/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-animationpopoverAnimationSets the launch animation type of the popover.
popover-border-colorpopoverBorderColorSets the border color of the popover.
popover-border-radiuspopoverBorderRadiusSets the border radius of the popover.
popover-border-widthpopoverBorderWidthSets the border width of the popover.
popover-box-shadowpopoverBoxShadowEnables/disables the default diffuse box shadow on the popover.
popover-captionpopoverCaptionSets the text to be displayed directly below the popover.
popover-caption-containerpopoverCaptionContainerTells 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-contentpopoverContentSets how the popover's container will be displayed.
popover-disable-autoplaypopoverDisableAutoplayEnables/disables autoplaying the popover as soon as it is opened.
popover-overlay-colorpopoverOverlayColorSets the background color of the popover's overlay.
popover-overlay-opacitypopoverOverlayOpacitySets the opacity of the popover's overlay.
popover-prevent-scrollpopoverPreventScrollEnables/disables scrolling the content behind the popover.
popover-show-on-loadpopoverShowOnLoadEnables/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 HTML 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 JavaScript properties

Once we have a reference to the <wistia-player> HTML element, we can interact with its properties via JavaScript.

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

<script>
  const player = document.getElementById('my-player');
  player.popoverBorderWidth = "2";
</script>

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.

HTML attributeJavaScript propertyTypeDefault valueExample values
wistia-popoverwistiaPopoverbooleanfalsetrue, false

Example code:

<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover></wistia-player>
import { WistiaPlayer } from "@wistia/wistia-player-react";
<WistiaPlayer id="my-player" mediaId="abc123" wistiaPopover={true} />
<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123"></wistia-player>

<script>
  const player = document.getElementById("my-player"); // Finds the existing player
  player.wistiaPopover = true;
  player.wistiaPopover; // Returns `true`
</script>

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.

HTML attributeJavaScript propertyTypeDefault valueExample values
popover-animate-thumbnailpopoverAnimateThumbnailbooleanfalsetrue, false

Example code:

<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover popover-animate-thumbnail></wistia-player>
import { WistiaPlayer } from "@wistia/wistia-player-react";
<WistiaPlayer id="my-player" mediaId="abc123" wistiaPopover={true} popoverAnimateThumbnail={true} />
<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover></wistia-player>

<script>
  const player = document.getElementById("my-player"); // Finds the existing player
  player.popoverAnimateThumbnail = true;
  player.popoverAnimateThumbnail; // Returns `true`
</script>

popover-animation

Sets the launch animation type of the popover.

HTML attributeJavaScript propertyTypeDefault 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:

<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover popover-animation="none"></wistia-player>
import { WistiaPlayer } from "@wistia/wistia-player-react";
<WistiaPlayer id="my-player" mediaId="abc123" wistiaPopover={true} popoverAnimation="none" />
<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover></wistia-player>

<script>
  const player = document.getElementById("my-player"); // Finds the existing player
  player.popoverAnimation = "none";
  player.popoverAnimation; // Returns `"none"`
</script>

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.

HTML attributeJavaScript propertyTypeDefault valueExample values
popover-border-colorpopoverBorderColorstring"ffffff""#000000", "2949E5"

Example code:

<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover popover-border-color="2949E5"></wistia-player>
import { WistiaPlayer } from "@wistia/wistia-player-react";
<WistiaPlayer id="my-player" mediaId="abc123" wistiaPopover={true} popoverBorderColor="2949E5" />
<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover></wistia-player>

<script>
  const player = document.getElementById("my-player"); // Finds the existing player
  player.popoverBorderColor = "2949E5";
  player.popoverBorderColor; // Returns `"2949E5"`
</script>

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.

HTML attributeJavaScript propertyTypeDefault valueExample values
popover-border-radiuspopoverBorderRadiusnumber02, 4

Example code:

<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover popover-border-radius="2"></wistia-player>
import { WistiaPlayer } from "@wistia/wistia-player-react";
<WistiaPlayer id="my-player" mediaId="abc123" wistiaPopover={true} popoverBorderRadius={2} />
<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover></wistia-player>

<script>
  const player = document.getElementById("my-player"); // Finds the existing player
  player.popoverBorderRadius = 2;
  player.popoverBorderRadius; // Returns `2`
</script>

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.

HTML attributeJavaScript propertyTypeDefault valueExample values
popover-border-widthpopoverBorderWidthstring05, 15

Example code:

<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover popover-border-width="5"></wistia-player>
import { WistiaPlayer } from "@wistia/wistia-player-react";
<WistiaPlayer id="my-player" mediaId="abc123" wistiaPopover={true} popoverBorderWidth={5} />
<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover></wistia-player>

<script>
  const player = document.getElementById("my-player"); // Finds the existing player
  player.popoverBorderWidth = 5;
  player.popoverBorderWidth; // Returns `5`
</script>

popover-box-shadow

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

HTML attributeJavaScript propertyTypeDefault valueExample values
popover-box-shadowpopoverBoxShadowbooleantruetrue, false

Example code:

<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover popover-box-shadow="false"></wistia-player>
import { WistiaPlayer } from "@wistia/wistia-player-react";
<WistiaPlayer id="my-player" mediaId="abc123" wistiaPopover={true} popoverBoxShadow={false} />
<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover></wistia-player>

<script>
  const player = document.getElementById("my-player"); // Finds the existing player
  player.popoverBoxShadow = false;
  player.popoverBoxShadow; // Returns `false`
</script>

popover-caption

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

HTML attributeJavaScript propertyTypeDefault valueExample values
popover-captionpopoverCaptionstringundefined"This is my caption!"

Example code:

<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover popover-caption="This is my caption!"></wistia-player>
import { WistiaPlayer } from "@wistia/wistia-player-react";
<WistiaPlayer id="my-player" mediaId="abc123" wistiaPopover={true} popoverCaption="This is my caption!" />
<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover></wistia-player>

<script>
  const player = document.getElementById("my-player"); // Finds the existing player
  player.popoverCaption = "This is my caption!";
  player.popoverCaption; // Returns `"This is my caption!"`
</script>

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.

HTML attributeJavaScript propertyTypeDefault valueExample values
popover-caption-containerpopoverCaptionContainerstringundefined"my-caption"

Example code:

<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-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>
import { WistiaPlayer } from "@wistia/wistia-player-react";

export default function App() {
  return (
    <WistiaPlayer mediaId="abc123" wistiaPopover popoverCaptionContainer="my-caption" />
    <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>
  );
}
<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover></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>

<script>
  const player = document.getElementById("my-player"); // Finds the existing player
  player.popoverCaptionContainer = "my-caption";
  player.popoverCaptionContainer; // Returns `"my-caption"`
</script>

popover-content

Sets how the popover's container will be displayed.

HTML attributeJavaScript propertyTypeDefault 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:

<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover popover-content="thumbnail"></wistia-player>
import { WistiaPlayer } from "@wistia/wistia-player-react";
<WistiaPlayer id="my-player" mediaId="abc123" wistiaPopover={true} popoverContent="thumbnail" />

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:

<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player media-id="abc123" wistia-popover popover-content="html">
  <a href="#">Launch the popover!</a>
</wistia-player>
import { WistiaPlayer } from "@wistia/wistia-player-react";
<WistiaPlayer id="my-player" mediaId="abc123" wistiaPopover={true} popoverContent="html">
  <a href="#">Launch the popover!</a>
</WistiaPlayer

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:

<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player
  media-id="abc123"
  wistia-popover
  popover-content="html"
  poster=""
>
  <a href="#">Launch the popover!</a>
</wistia-player>
import { WistiaPlayer } from "@wistia/wistia-player-react";
<WistiaPlayer
  id="my-player"
  mediaId="abc123"
  wistiaPopover={true}
  popoverContent="html"
  poster=""
>
  <a href="#">Launch the popover!</a>
</WistiaPlayer>

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.

HTML attributeJavaScript propertyTypeDefault valueExample values
popover-disable-autoplaypopoverDisableAutoplaybooleanfalsetrue, false

Example code:

<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover popover-disable-autoplay></wistia-player>
import { WistiaPlayer } from "@wistia/wistia-player-react";
<WistiaPlayer id="my-player" mediaId="abc123" wistiaPopover={true} popoverDisableAutoplay={true} />
<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover></wistia-player>

<script>
  const player = document.getElementById("my-player"); // Finds the existing player
  player.popoverDisableAutoplay = true;
  player.popoverDisableAutoplay; // Returns `true`
</script>

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.

HTML attributeJavaScript propertyTypeDefault valueExample values
popover-overlay-colorpopoverOverlayColorstring"000000""#ffffff", "2949E5"

Example code:

<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover popover-overlay-color="2949E5"></wistia-player>
import { WistiaPlayer } from "@wistia/wistia-player-react";
<WistiaPlayer id="my-player" mediaId="abc123" wistiaPopover={true} popoverOverlayColor="2949E5" />
<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover></wistia-player>

<script>
  const player = document.getElementById("my-player"); // Finds the existing player
  player.popoverOverlayColor = "2949E5";
  player.popoverOverlayColor; // Returns `"2949E5"`
</script>

popover-overlay-opacity

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

HTML attributeJavaScript propertyTypeDefault valueExample values
popover-overlay-opacitypopoverOverlayOpacitynumber0.50, 1

Example code:

<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover popover-overlay-opacity="0.75"></wistia-player>
import { WistiaPlayer } from "@wistia/wistia-player-react";
<WistiaPlayer id="my-player" mediaId="abc123" wistiaPopover={true} popoverOverlayOpacity={0.75} />
<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover></wistia-player>

<script>
  const player = document.getElementById("my-player"); // Finds the existing player
  player.popoverOverlayOpacity = 0.75;
  player.popoverOverlayOpacity; // Returns `0.75`
</script>

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.

HTML attributeJavaScript propertyTypeDefault valueExample values
popover-prevent-scrollpopoverPreventScrollbooleanfalsetrue, false

Example code:

<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover popover-prevent-scroll></wistia-player>
import { WistiaPlayer } from "@wistia/wistia-player-react";
<WistiaPlayer id="my-player" mediaId="abc123" wistiaPopover={true} popoverPreventScroll={true} />
<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover></wistia-player>

<script>
  const player = document.getElementById("my-player"); // Finds the existing player
  player.popoverPreventScroll = true;
  player.popoverPreventScroll; // Returns `true`
</script>

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.

HTML attributeJavaScript propertyTypeDefault valueExample values
popover-show-on-loadpopoverShowOnLoadbooleanfalsetrue, false

Example code:

<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover popover-show-on-load></wistia-player>
import { WistiaPlayer } from "@wistia/wistia-player-react";
<WistiaPlayer id="my-player" mediaId="abc123" wistiaPopover={true} popoverShowOnLoad={true} />
<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover></wistia-player>

<script>
  const player = document.getElementById("my-player"); // Finds the existing player
  player.popoverShowOnLoad = true;
  player.popoverShowOnLoad; // Returns `true`
</script>

Events

popover-show

Fires when the popover becomes visible.

Example code:

<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover></wistia-player>

<script>
  const player = document.getElementById("my-player");
  player.addEventListener("popover-show", () => {
    console.log("The popover for", player.mediaId, "is visible!");
    
    // Example output: "The popover for abc123 is visible!"
  });
</script>
import { useRef } from "react";
import { WistiaPlayer } from "@wistia/wistia-player-react";

export default function App() {
  const player = useRef(null);
  
  function handlePopoverShow() {
    if (player.current === null) { return; }
    console.log("The popover for", player.current.mediaId, "is visible!");
    
    // Example output: "The popover for abc123 is visible!"
  };
  
  return (
    <WistiaPlayer ref={player} mediaId="abc123" wistiaPopover={true} onPopoverShow={handlePopoverShow} />
  );
}

popover-hide

Fires when the popover is hidden.

Example code:

<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover></wistia-player>

<script>
  const player = document.getElementById("my-player");
  player.addEventListener("popover-hide", () => {
    console.log("The popover for", player.mediaId, "is hidden!");
    
    // Example output: "The popover for abc123 is hidden!"
  });
</script>
import { useRef } from "react";
import { WistiaPlayer } from "@wistia/wistia-player-react";

export default function App() {
  const player = useRef(null);
  
  function handlePopoverHide() {
    if (player.current === null) { return; }
    console.log("The popover for", player.current.mediaId, "is hidden!");
    
    // Example output: "The popover for abc123 is hidden!"
  };
  
  return (
    <WistiaPlayer ref={player} mediaId="abc123" wistiaPopover={true} onPopoverHide={handlePopoverHide} />
  );
}

Methods

showPopover()

If the popover is hidden, this will show it.

Example code:

<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover></wistia-player>

<button type="button" id="custom-show-button">Show Popover</button>

<script>
  const player = document.getElementById("my-player");
  const customShowButton = document.getElementById('custom-show-button');

  // When our custom button is clicked, show the popover.
  customShowButton.addEventListener("click", () => {
    player.showPopover();
  });
</script>
import { useRef } from "react";
import { WistiaPlayer } from "@wistia/wistia-player-react";

export default function App() {
  const player = useRef(null);
  
  // When our custom button is clicked, show the popover.
  function handleClick() {
    if (player.current === null) { return; }
    player.current.showPopover();
  };
  
  return (
    <WistiaPlayer ref={player} mediaId="abc123" wistiaPopover={true} />
    <button type="button" onClick={handleClick}>Show Popover</button>
  );
}

hidePopover()

If the popover is open, this will hide it.

Example code:

<script src="https://fast.wistia.com/player.js" async></script>
<wistia-player id="my-player" media-id="abc123" wistia-popover></wistia-player>

<button type="button" id="custom-hide-button">Hide Popover</button>

<script>
  const player = document.getElementById("my-player");
  const customHideButton = document.getElementById('custom-hide-button');

  // When our custom button is clicked, hide the popover.
  customHideButton.addEventListener("click", () => {
    player.hidePopover();
  });
</script>
import { useRef } from "react";
import { WistiaPlayer } from "@wistia/wistia-player-react";

export default function App() {
  const player = useRef(null);
  
  // When our custom button is clicked, hide the popover.
  function handleClick() {
    if (player.current === null) { return; }
    player.current.hidePopover();
  };
  
  return (
    <WistiaPlayer ref={player} mediaId="abc123" wistiaPopover={true} />
    <button type="button" onClick={handleClick}>Hide Popover</button>
  );
}

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 media-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>