Security News
Input Validation Vulnerabilities Dominate MITRE's 2024 CWE Top 25 List
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
A simple React component that provide good looking UI video player
npm install netplayer # or yarn add netplayer
import NetPlayer from 'netplayer';
<NetPlayer
sources={[
{
file: 'https://www.googleapis.com/drive/v3/files/1Q6LsjpWgPoYIs6GaD8G6lNZRM2-VJXAY?alt=media&key=AIzaSyCFwU3MAtwS2TgPPEObV-hDXexH83ae1Fs',
label: '1080p',
},
{
file: 'https://www.googleapis.com/drive/v3/files/1sKXS6VU8uUGeW8WPKDp2dXxwAJ96Tk9c?alt=media&key=AIzaSyCFwU3MAtwS2TgPPEObV-hDXexH83ae1Fs',
label: '720p',
},
]}
subtitles={[
{
lang: 'en',
language: 'English',
file: 'https://subtitles.netpop.app/subtitles/20211116/1637057950304_国王排名 2_英语.srt',
},
{
lang: 'vi',
language: 'Tiếng Việt',
file: 'https://subtitles.netpop.app/subtitles/20211116/1637057969656_国王排名 2_越南语.srt',
},
]}
/>;
Or play around with this component
NetPlayer accepts video element props and these specific props
Prop | Type | Description | Default | Required |
---|---|---|---|---|
sources | Source[] | An array of sources contain file , label and type | null | true |
subtitles | Subtitle[] | An array of subtitles contain file , lang and language | null | false |
hlsRef | React.MutableRefObject<Hls | null> | hls.js instance ref | React.createRef() | false |
dashRef | React.MutableRefObject<DashJS.MediaPlayerClass | null> | dashjs instance ref | React.createRef() | false |
hlsConfig | Hls['config'] | hls.js config | {} | false |
changeSourceUrl | (currentSourceUrl: string, source: Source): string | A function that modify given source url (hls only) | () => null | false |
onHlsInit | (hls: Hls): void | A function that called after hls.js initialization | () => null | false |
onDashInit | (dash: DashJS.MediaPlayerClass): void | A function that called after dashjs initialization | () => null | false |
onInit | (videoEl: HTMLVideoElement): void | A function that called after video initialization | () => null | false |
ref | React.MutableRefObject<HTMLVideoElement | null> | video element ref | null | false |
i18n | I18n | Translations | Default Translations | false |
hotkeys | Hotkey[] | Hotkeys (shortcuts) | Default Hotkeys | false |
components | Component[] | See Customization | Default components | false |
thumbnail | string | Thumbnails on progress bar hover | null | false |
You can customize the player by passing defined components with components
props. See defined components
By passing components, the passed components will override default existing components. Allow you to customize the player how you want it to be.
import NetPlayer, { TimeIndicator } from 'netplayer';
<NetPlayer
{...props}
components={{
Controls: () => {
return (
<div className="flex items-center justify-between">
<p>A custom Controls component</p>
<TimeIndicator />
</div>
);
},
}}
/>;
Note: use built-in hooks and components for better customization
NetPlayer use this default structure
To override it, simply pass your own structure as NetPlayer's children
import NetPlayer, { Controls, Player, Overlay } from 'netplayer';
<NetPlayer {...props}>
<div>
<div>
<Player />
</div>
<div>
<Controls />
</div>
<div>
<Overlay />
</div>
<div>
<p>Look I'm over here!</p>
</div>
</div>
</NetPlayer>;
You can access to the video
element by passing ref
to NetPlayer and use all its methods.
NetPlayer supports all video
element supported formats and HLS
format
See the contribution guidelines before creating a pull request.
FAQs
Unknown package
We found that netplayer demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
Security News
In this segment of the Risky Business podcast, Feross Aboukhadijeh and Patrick Gray discuss the challenges of tracking malware discovered in open source softare.
Research
Security News
A threat actor's playbook for exploiting the npm ecosystem was exposed on the dark web, detailing how to build a blockchain-powered botnet.