diff options
| author | ondratra <ondratra@gmail.com> | 2019-08-07 00:08:10 +0200 | 
|---|---|---|
| committer | ondratra <ondratra@gmail.com> | 2019-08-07 00:08:10 +0200 | 
| commit | 800c8e0a17dd5c86f2fc38a7d13523c4ab747d2d (patch) | |
| tree | 7f7090192ee30e70084d6fbad2dec4db73c4b2a4 /src | |
| parent | dfc09b8e04f6e4829c29a68106eb4af5be76a2ff (diff) | |
| download | plyr-800c8e0a17dd5c86f2fc38a7d13523c4ab747d2d.tar.lz plyr-800c8e0a17dd5c86f2fc38a7d13523c4ab747d2d.tar.xz plyr-800c8e0a17dd5c86f2fc38a7d13523c4ab747d2d.zip | |
typescript typings
Diffstat (limited to 'src')
| -rw-r--r-- | src/js/plyr.d.ts | 560 | 
1 files changed, 560 insertions, 0 deletions
| diff --git a/src/js/plyr.d.ts b/src/js/plyr.d.ts new file mode 100644 index 00000000..4f64898f --- /dev/null +++ b/src/js/plyr.d.ts @@ -0,0 +1,560 @@ +// Type definitions for plyr 3.5 +// Project: https://plyr.io +// Definitions by: ondratra <https://github.com/ondratra> +// TypeScript Version: 3.0 + +export = Plyr; +export as namespace Plyr; + + +declare class Plyr { +    /** +     * Setup a new instance +     */ +    static setup(targets: NodeList | HTMLElement | HTMLElement[] | string, options?: Plyr.Options): Plyr[]; + +    /** +     * Check for support +     * @param mediaType +     * @param provider +     * @param playsInline Whether the player has the playsinline attribute (only applicable to iOS 10+) +     */ +    static supported(mediaType?: Plyr.MediaType, provider?: Plyr.Provider, playsInline?: boolean): Plyr.Support; + +    constructor(targets: NodeList | HTMLElement | HTMLElement[] | string, options?: Plyr.Options); + +    /** +     * Indicates if the current player is HTML5. +     */ +    readonly isHTML5: boolean; + +    /** +     * Indicates if the current player is an embedded player. +     */ +    readonly isEmbed: boolean; + +    /** +     * Indicates if the current player is playing. +     */ +    readonly playing: boolean; + +    /** +     * Indicates if the current player is paused. +     */ +    readonly paused: boolean; + +    /** +     * Indicates if the current player is stopped. +     */ +    readonly stopped: boolean; + +    /** +     * Indicates if the current player has finished playback. +     */ +    readonly ended: boolean; + +    /** +     * Returns a float between 0 and 1 indicating how much of the media is buffered +     */ +    readonly buffered: number; + +    /** +     * Gets or sets the currentTime for the player. The setter accepts a float in seconds. +     */ +    currentTime: number; + +    /** +     * Indicates if the current player is seeking. +     */ +    readonly seeking: boolean; + +    /** +     * Returns the duration for the current media. +     */ +    readonly duration: number; + +    /** +     * Gets or sets the volume for the player. The setter accepts a float between 0 and 1. +     */ +    volume: number; + +    /** +     * Gets or sets the muted state of the player. The setter accepts a boolean. +     */ +    muted: boolean; + +    /** +     * Indicates if the current media has an audio track. +     */ +    readonly hasAudio: boolean; + +    /** +     * Gets or sets the speed for the player. The setter accepts a value in the options specified in your config. Generally the minimum should be 0.5. +     */ +    speed: number; + +    /** +     * Gets or sets the quality for the player. The setter accepts a value from the options specified in your config. +     * Remarks: YouTube only. HTML5 will follow. +     */ +    quality: string; + +    /** +     * Gets or sets the current loop state of the player. +     */ +    loop: boolean; + +    /** +     * Gets or sets the current source for the player. +     */ +    source: Plyr.SourceInfo; + +    /** +     * Gets or sets the current poster image URL for the player. +     */ +    poster: string; + +    /** +     * Gets or sets the autoplay state of the player. +     */ +    autoplay: boolean; + +    /** +     * Gets or sets the caption track by index. 1 means the track is missing or captions is not active +     */ +    currentTrack: number; + +    /** +     * Gets or sets the preferred captions language for the player. The setter accepts an ISO twoletter language code. Support for the languages is dependent on the captions you include. +     * If your captions don't have any language data, or if you have multiple tracks with the same language, you may want to use currentTrack instead. +     */ +    language: string; + +    /** +     * Gets or sets the picture-in-picture state of the player. This currently only supported on Safari 10+ on MacOS Sierra+ and iOS 10+. +     */ +    pip: boolean; + +    readonly fullscreen: Plyr.FullscreenControl; + +    /** +     * Start playback. +     * For HTML5 players, play() will return a Promise in some browsers - WebKit and Mozilla according to MDN at time of writing. +     */ +    play(): Promise<void> | void; + +    /** +     * Pause playback. +     */ +    pause(): void; + +    /** +     * Toggle playback, if no parameters are passed, it will toggle based on current status. +     */ +    togglePlay(toggle?: boolean): boolean; + +    /** +     * Stop playback and reset to start. +     */ +    stop(): void; + +    /** +     * Restart playback. +     */ +    restart(): void; + +    /** +     * Rewind playback by the specified seek time. If no parameter is passed, the default seek time will be used. +     */ +    rewind(seekTime?: number): void; + +    /** +     * Fast forward by the specified seek time. If no parameter is passed, the default seek time will be used. +     */ +    forward(seekTime?: number): void; + +    /** +     * Increase volume by the specified step. If no parameter is passed, the default step will be used. +     */ +    increaseVolume(step?: number): void; + +    /** +     * Increase volume by the specified step. If no parameter is passed, the default step will be used. +     */ +    decreaseVolume(step?: number): void; + +    /** +     * Toggle captions display. If no parameter is passed, it will toggle based on current status. +     */ +    toggleCaptions(toggle?: boolean): void; + +    /** +     * Trigger the airplay dialog on supported devices. +     */ +    airplay(): void; + +    /** +     * Toggle the controls (video only). Takes optional truthy value to force it on/off. +     */ +    toggleControls(toggle: boolean): void; + +    /** +     * Add an event listener for the specified event. +     */ +    on(event: Plyr.StandardEvent | Plyr.Html5Event | Plyr.YoutubeEvent, callback: (this: this, event: Plyr.PlyrEvent) => void): void; + +    /** +     * Add an event listener for the specified event once. +     */ +    once(event: Plyr.StandardEvent | Plyr.Html5Event | Plyr.YoutubeEvent, callback: (this: this, event: Plyr.PlyrEvent) => void): void; + +    /** +     * Remove an event listener for the specified event. +     */ +    off(event: Plyr.StandardEvent | Plyr.Html5Event | Plyr.YoutubeEvent, callback: (this: this, event: Plyr.PlyrEvent) => void): void; + +    /** +     * Check support for a mime type. +     */ +    supports(type: string): boolean; + +    /** +     * Destroy lib instance +     */ +    destroy(): void; +} + +declare namespace Plyr { +    type MediaType = "audio" | "video"; +    type Provider = "html5" | "youtube" | "vimeo"; +    type StandardEvent = "progress" | "playing" | "play" | "pause" | "timeupdate" | "volumechange" | "seeking" | "seeked" | "ratechange" | "ended" | "enterfullscreen" | "exitfullscreen" +        | "captionsenabled" | "captionsdisabled" | "languagechange" | "controlshidden" | "controlsshown" | "ready"; +    type Html5Event = "loadstart" | "loadeddata" | "loadedmetadata" | "canplay" | "canplaythrough" | "stalled" | "waiting" | "emptied" | "cuechange" | "error"; +    type YoutubeEvent = "statechange" | "qualitychange" | "qualityrequested"; + +    interface FullscreenControl { +        /** +         * Indicates if the current player is in fullscreen mode. +         */ +        readonly active: boolean; + +        /** +         * Indicates if the current player has fullscreen enabled. +         */ +        readonly enabled: boolean; + +        /** +         * Enter fullscreen. If fullscreen is not supported, a fallback ""full window/viewport"" is used instead. +         */ +        enter(): void; + +        /** +         * Exit fullscreen. +         */ +        exit(): void; + +        /** +         * Toggle fullscreen. +         */ +        toggle(): void; +    } + +    interface Options { +        /** +         * Completely disable Plyr. This would allow you to do a User Agent check or similar to programmatically enable or disable Plyr for a certain UA. Example below. +         */ +        enabled?: boolean; + +        /** +         * Display debugging information in the console +         */ +        debug?: boolean; + +        /** +         * If a function is passed, it is assumed your method will return either an element or HTML string for the controls. Three arguments will be passed to your function; +         * id (the unique id for the player), seektime (the seektime step in seconds), and title (the media title). See controls.md for more info on how the html needs to be structured. +         * Defaults to ['play-large', 'play', 'progress', 'current-time', 'mute', 'volume', 'captions', 'settings', 'pip', 'airplay', 'fullscreen'] +         */ +        controls?: string[] | ((id: string, seektime: number, title: string) => unknown) | Element; + +        /** +         * If you're using the default controls are used then you can specify which settings to show in the menu +         * Defaults to ['captions', 'quality', 'speed', 'loop'] +         */ +        settings?: string[]; + +        /** +         * Used for internationalization (i18n) of the text within the UI. +         */ +        i18n?: any; + +        /** +         * Load the SVG sprite specified as the iconUrl option (if a URL). If false, it is assumed you are handling sprite loading yourself. +         */ +        loadSprite?: boolean; + +        /** +         * Specify a URL or path to the SVG sprite. See the SVG section for more info. +         */ +        iconUrl?: string; + +        /** +         * Specify the id prefix for the icons used in the default controls (e.g. plyr-play would be plyr). +         * This is to prevent clashes if you're using your own SVG sprite but with the default controls. +         * Most people can ignore this option. +         */ +        iconPrefix?: string; + +        /** +         * Specify a URL or path to a blank video file used to properly cancel network requests. +         */ +        blankUrl?: string; + +        /** +         * Autoplay the media on load. This is generally advised against on UX grounds. It is also disabled by default in some browsers. +         * If the autoplay attribute is present on a <video> or <audio> element, this will be automatically set to true. +         */ +        autoplay?: boolean; + +        /** +         * Only allow one player playing at once. +         */ +        autopause?: boolean; + +        /** +         * The time, in seconds, to seek when a user hits fast forward or rewind. +         */ +        seekTime?: number; + +        /** +         * A number, between 0 and 1, representing the initial volume of the player. +         */ +        volume?: number; + +        /** +         * Whether to start playback muted. If the muted attribute is present on a <video> or <audio> element, this will be automatically set to true. +         */ +        muted?: boolean; + +        /** +         * Click (or tap) of the video container will toggle play/pause. +         */ +        clickToPlay?: boolean; + +        /** +         * Disable right click menu on video to help as very primitive obfuscation to prevent downloads of content. +         */ +        disableContextMenu?: boolean; + +        /** +         * Hide video controls automatically after 2s of no mouse or focus movement, on control element blur (tab out), on playback start or entering fullscreen. +         * As soon as the mouse is moved, a control element is focused or playback is paused, the controls reappear instantly. +         */ +        hideControls?: boolean; + +        /** +         * Reset the playback to the start once playback is complete. +         */ +        resetOnEnd?: boolean; + +        /** +         * Enable keyboard shortcuts for focused players only or globally +         */ +        keyboard?: KeyboardOptions; + +        /** +         * controls: Display control labels as tooltips on :hover & :focus (by default, the labels are screen reader only). +         * seek: Display a seek tooltip to indicate on click where the media would seek to. +         */ +        tooltips?: TooltipOptions; + +        /** +         * Specify a custom duration for media. +         */ +        duration?: number; + +        /** +         * Displays the duration of the media on the metadataloaded event (on startup) in the current time display. +         * This will only work if the preload attribute is not set to none (or is not set at all) and you choose not to display the duration (see controls option). +         */ +        displayDuration?: boolean; + +        /** +         * Display the current time as a countdown rather than an incremental counter. +         */ +        invertTime?: boolean; + +        /** +         * Allow users to click to toggle the above. +         */ +        toggleInvert?: boolean; + +        /** +         * Allows binding of event listeners to the controls before the default handlers. See the defaults.js for available listeners. +         * If your handler prevents default on the event (event.preventDefault()), the default handler will not fire. +         */ +        listeners?: {[key: string]: (error: PlyrEvent) => void}; + +        /** +         * active: Toggles if captions should be active by default. language: Sets the default language to load (if available). 'auto' uses the browser language. +         * update: Listen to changes to tracks and update menu. This is needed for some streaming libraries, but can result in unselectable language options). +         */ +        captions?: CaptionOptions; + +        /** +         * enabled: Toggles whether fullscreen should be enabled. fallback: Allow fallback to a full-window solution. +         * iosNative: whether to use native iOS fullscreen when entering fullscreen (no custom controls) +         */ +        fullscreen?: FullScreenOptions; + +        /** +         * The aspect ratio you want to use for embedded players. +         */ +        ratio?: string; + +        /** +         * enabled: Allow use of local storage to store user settings. key: The key name to use. +         */ +        storage?: StorageOptions; + +        /** +         * selected: The default speed for playback. options: Options to display in the menu. Most browsers will refuse to play slower than 0.5. +         */ +        speed?: SpeedOptions; + +        /** +         * Currently only supported by YouTube. default is the default quality level, determined by YouTube. options are the options to display. +         */ +        quality?: QualityOptions; + +        /** +         * active: Whether to loop the current video. If the loop attribute is present on a <video> or <audio> element, +         * this will be automatically set to true This is an object to support future functionality. +         */ +        loop?: LoopOptions; + +        /** +         * enabled: Whether to enable vi.ai ads. publisherId: Your unique vi.ai publisher ID. +         */ +        ads?: AdOptions; +    } + +    interface QualityOptions { +        default: string; +        options: string[]; +    } + +    interface LoopOptions { +        active: boolean; +    } + +    interface AdOptions { +        enabled: boolean; +        publisherId: string; +    } + +    interface SpeedOptions { +        selected: number; +        options: number[]; +    } + +    interface KeyboardOptions { +        focused?: boolean; +        global?: boolean; +    } + +    interface TooltipOptions { +        controls?: boolean; +        seek?: boolean; +    } + +    interface FullScreenOptions { +        enabled?: boolean; +        fallback?: boolean; +        allowAudio?: boolean; +    } + +    interface CaptionOptions { +        active?: boolean; +        language?: string; +        update?: boolean; +    } + +    interface StorageOptions { +        enabled?: boolean; +        key?: string; +    } + +    interface SourceInfo { +        /** +         * Note: YouTube and Vimeo are currently not supported as audio sources. +         */ +        type: MediaType; + +        /** +         * Title of the new media. Used for the aria-label attribute on the play button, and outer container. YouTube and Vimeo are populated automatically. +         */ +        title?: string; + +        /** +         * This is an array of sources. For HTML5 media, the properties of this object are mapped directly to HTML attributes so more can be added to the object if required. +         */ +        sources: Source[]; + +        /** +         * The URL for the poster image (HTML5 video only). +         */ +        poster?: string; + +        /** +         * An array of track objects. Each element in the array is mapped directly to a track element and any keys mapped directly to HTML attributes so as in the example above, +         * it will render as <track kind="captions" label="English" srclang="en" src="https://cdn.selz.com/plyr/1.0/example_captions_en.vtt" default> and similar for the French version. +         * Booleans are converted to HTML5 value-less attributes. +         */ +        tracks?: Track[]; +    } + +    interface Source { +        /** +         * The URL of the media file (or YouTube/Vimeo URL). +         */ +        src: string; +        /** +         * The MIME type of the media file (if HTML5). +         */ +        type?: string; +        provider?: Provider; +        size?: number; +    } + +    type TrackKind = "subtitles" | "captions" | "descriptions" | "chapters" | "metadata"; +    interface Track { +        /** +         * Indicates how the text track is meant to be used +         */ +        kind: TrackKind; +        /** +         * Indicates a user-readable title for the track +         */ +        label: string; +        /** +         * The language of the track text data. It must be a valid BCP 47 language tag. If the kind attribute is set to subtitles, then srclang must be defined. +         */ +        srcLang?: string; +        /** +         * The URL of the track (.vtt file). +         */ +        src: string; + +        default?: boolean; +    } + +    interface PlyrEvent extends CustomEvent { +        readonly detail: { readonly plyr: Plyr; }; +    } + +    interface Support { +        api: boolean; +        ui: boolean; +    } +} | 
