super-media-element
TypeScript icon, indicating that this package has built-in type declarations

1.4.1 • Public • Published

Super Media Element

NPM Version NPM Downloads jsDelivr hits (npm) npm bundle size

A custom element that helps save alienated player API's in bringing back their true inner HTMLMediaElement API, or to extend a native media element like <audio> or <video>.

Usage

import { SuperVideoElement } from 'super-media-element';

class MyVideoElement extends SuperVideoElement {

  static observedAttributes = ['color', ...SuperVideoElement.observedAttributes];

  // Skip from forwarding the `src` attribute to the native element.
  static skipAttributes = ['src'];


  async attributeChangedCallback(attrName, oldValue, newValue) {
    
    if (attrName === 'color') {
      this.api.color = newValue;
    }

    super.attributeChangedCallback(attrName, oldValue, newValue);
  }

  async load() {
    // This is called when the `src` changes.
    
    // Load a video player from a script here.
    // Example: https://github.com/luwes/jwplayer-video-element/blob/main/jwplayer-video-element.js#L55-L75

    this.api = new VideoPlayer();
  }

  get nativeEl() {
    return this.querySelector('.loaded-video-element');
  }
}

if (!globalThis.customElements.get('my-video')) {
  globalThis.customElements.define('my-video', MyVideoElement);
}

export { MyVideoElement };

Related

Package Sidebar

Install

npm i super-media-element

Weekly Downloads

343

Version

1.4.1

License

MIT

Unpacked Size

18.7 kB

Total Files

4

Last publish

Collaborators

  • luwes
  • mux-npmjs