npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

rn-media-player

v0.3.2

Published

Video Player

Downloads

232

Readme

rn-media-player

Introduction

This library is specifically designed for the React Native developer community, aiming to provide a robust and highly performant video player solution. By utilizing native components, our goal is to maximize the performance and efficiency of video playback in React Native applications. Maintaining the fluidity and responsiveness that users expect from native video experiences.

table of contents

Installation

npm install rn-media-player
yarn add rn-media-player

Usage

import { Video } from "rn-media-player";

// ...
const source = {
  url: "http://commondatastorage.googleapis.com/gtv-videos-bucket/sample/BigBuckBunny.mp4"
  title: "Big Buck Bunny"
}

<Video source={source} />

API Reference

This section provides detailed information about the props, methods, and events supported by the VideoPlayer component.

Configurations

| Property | Description | Type | Default | | ------------ | -----------------------------------------------------| ------------ | -------------- | | source | Object attribute where to pass url and title of the video. | Object| {url: "" title: ""} | | thumbnailFramesSeconds | Quantity preview frames generated per seconds. | Number| 1 | | enterInFullScreenWhenDeviceRotated | Enter full screen when rotate device. | Boolean| false | | autoPlay | Enable/Disable auto play on playback init. | Boolean| true | | loop | Enable/Disable loop on playback finish. | Boolean| false | | paused | Pauses playback. | Boolean| false | | rate | Able to change playback rate. | Number| 1 | | startTime | Initial time of playback. | Number| 0 | | resizeMode | Resizes of playback. | EResizeMode| contain | | tapToSeekValue | Value to seek player with backward or forward. | Number| 15 | | suffixLabelTapToSeek | enable/disable loop on playback finish. | Boolean| false | | lockControls | lock controls playback - WIP. | Boolean| false | | speeds | Object with data to display speeds into settings and initial speed selected. | Object| speeds | | qualities | Object with data to display qualities into settings and initial quality selected. | Object| null | | settings | Object with data to display settings. | Object| settings | | controlsProps | Configure controls properties. | Object| controls |

Settings

| Property | Description | Type | | ------------ | -----------------------------------------------------| ------------ | | name | value to settings display. | String| | enabled | enable or disable to display into interface. | Boolean|

{
  data: [
    {
      name: 'Qualities',
      enabled: true,
    },
    {
      name: 'Playback Speeds',
      enabled: true,
    },
    {
      name: 'More Options',
      enabled: true,
    },
  ],
}
Speeds

| Property | Description | Type | | ------------ | -----------------------------------------------------| ------------ | | name | value to display in settings. | String| | value | value to pass to playback speed. | String| | enabled | enable or disable to display into interface. | Boolean|

{
    initialSelected: 'Normal',
    data: [
        {
            name: '0.5x',
            value: '0.5',
            enabled: true,
        },
        {
            name: 'Normal',
            value: '1',
            enabled: true,
        },
        {
            name: '1.5x',
            value: '1.5',
            enabled: true,
        },
    ],
}
Controls

| Property | Description | Type | Details | | ------------ | -----------------------------------------------------| ------------ | -------- | | loading | Customizes the loading indicator. | Object| { color?: string; } | playback | Controls the appearance of playback elements. | Object| { color?: string; } | seekSlider | Styles the seek slider. | Object| Detailed below | settings | Styles the settings control. | Object| { color?: string; } | fullScreen | Customizes the full-screen button appearance. | Object| { color?: string; } | download | Configures the download button and related UI. | Object| Detailed below | toast | Styles toast notifications within the player. | Object| Detailed below | header | Styles the video player header. | Object| Detailed below

Detailed Configuration Options

Note: This library accepts color specifications in hexadecimal format only. Please ensure that all color properties are provided as hex codes.

seekSlider

  • maximumTrackColor: Color of the slider track (string)
  • minimumTrackColor: Color of the slider track before the thumb (string)
  • seekableTintColor: Color of the track showing seekable range (string)
  • thumbImageColor: Color of the slider thumb (string)
  • thumbnailBorderColor: Border color of the thumbnail on the slider (string)
  • thumbnailTimeCodeColor: Color of the time code on the thumbnail (string)

timeCodes

  • currentTimeColor: Color of the current playback time (string)
  • durationColor: Color of the total duration (string)
  • slashColor: Color of the slash between current time and duration (string)

download

  • color: Color of the download icon (string)
  • progressBarColor: Color of the progress bar frame (string)
  • progressBarFillColor: Fill color of the progress bar (string)
  • messageDelete: Message displayed on deleting (string)
  • messageDownload: Message displayed during downloading (string)
  • labelDelete: Label for delete button (string)
  • labelCancel: Label for cancel button (string)
  • labelDownload: Label for download button (string)

toast

  • label: Text label for the toast (string)
  • backgroundColor: Background color of the toast (string)
  • labelColor: Color of the label text (string)

header

  • leftButtonColor: Color of the left button in the header (string)
  • titleColor: Color of the title in the header (string)
Events

| Property | Description | Type | Details | | ------------ | -----------------------------------------------------| ------------ | -------- | | onSettings | Callback tap settings. | Func| Void | onGoBack | Callback tap goBack. | Func| Void | onPlaybackSpeed | Callback tap playback speed on settings. | Func| Void | onQuality | Callback tap quality on settings. | Func| Void | onFullScreen | Callback tap full screen. | Func| Void | onBufferCompleted | Callback with NativeSyntheticEvent when buffer is completed. | Func| Detailed below | onVideoDownloaded | Callback with NativeSyntheticEvent when video is downloaded. | Func| Detailed below | onBuffer | Callback with NativeSyntheticEvent when video is buffering. | Func| Detailed below | onLoaded | Callback with NativeSyntheticEvent when video is loaded. | Func| Detailed below | onVideoProgress | Callback with NativeSyntheticEvent when video is in-progress. | Func| Detailed below | onPlayPause | Callback with NativeSyntheticEvent when video is playing or paused. | Func| Detailed below | onCompleted | Callback with NativeSyntheticEvent when video is completed. | Func| Detailed below | onError | Callback with NativeSyntheticEvent when video has ocurred error. | Func| Detailed below

Detailed Events

Notes to access events must be use callback params ex:

  <Video
    // ...rest code
    onCompleted={(event)  => event.nativeEvent.xxxx}
  />

onBufferCompleted : Called when the video has completed buffering.

: - Parameters:

  • completed (boolean): True if buffering is complete and playback can continue.

onVideoDownloaded : Called when the video download status changes.

: - Parameters:

  • downloaded (boolean): Indicates whether the video has been fully downloaded.
  • status (string): Status message of the download.
  • error (any): Error object if the download failed.

onBuffer : Indicates changes in the buffering state of the video.

: - Parameters:

  • buffering (boolean): True if the video is currently buffering.

onLoaded : Called when the video is loaded and ready to play.

: - Parameters:

  • duration (Float): The total duration of the video.

onVideoProgress : Called periodically during playback to indicate buffering progress and play progress.

: - Parameters:

  • buffering (Float): Current buffering state as a float value.
  • progress (Float): Current progress of the video playback as a float value.

onPlayPause : Called when the play or pause action is triggered.

: - Parameters:

  • isPlaying (boolean): True if the video is currently playing.

onCompleted : Called when the video playback has completed.

: - Parameters:

  • completed (boolean): True if the video has finished playing.

onError : Called when there is an error during video playback.

: - Parameters:

  • code (number): Error code identifying the type of error.
  • userInfo (string): General information about the error.
  • description (string): Detailed description of what caused the error.
  • failureReason (string): The reason for the video playback failure.
  • fixSuggestion (string): Suggested fix for the error.

License

MIT