DefinitelyTyped/types/react-native-video/index.d.ts
2017-09-02 09:42:57 -07:00

82 lines
2.4 KiB
TypeScript

// Type definitions for react-native-video 2.0
// Project: https://github.com/react-native-community/react-native-video
// Definitions by: HuHuanming <https://github.com/huhuanming>
// abrahambotros <https://github.com/abrahambotros>
// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped
// TypeScript Version: 2.3
import * as React from 'react';
import {
ViewProperties
} from 'react-native';
export interface VideoProperties extends ViewProperties {
/* Native only */
src?: any;
seek?: number;
fullscreen?: boolean;
onVideoLoadStart?(): void;
onVideoLoad?(): void;
onVideoBuffer?(): void;
onVideoError?(): void;
onVideoProgress?(): void;
onVideoSeek?(): void;
onVideoEnd?(): void;
onTimedMetadata?(): void;
onVideoFullscreenPlayerWillPresent?(): void;
onVideoFullscreenPlayerDidPresent?(): void;
onVideoFullscreenPlayerWillDismiss?(): void;
onVideoFullscreenPlayerDidDismiss?(): void;
/* Wrapper component */
// Opaque type returned by require('./video.mp4')
source: { uri?: string } | number;
resizeMode?: string;
poster?: string;
repeat?: boolean;
paused?: boolean;
muted?: boolean;
volume?: number;
rate?: number;
playInBackground?: boolean;
playWhenInactive?: boolean;
ignoreSilentSwitch?: 'ignore' | 'obey';
disableFocus?: boolean;
controls?: boolean;
currentTime?: number;
progressUpdateInterval?: number;
onLoadStart?(): void;
onLoad?(): void;
onBuffer?(): void;
onError?(): void;
onProgress?(data: {
currentTime: number,
playableDuration: number,
}): void;
onSeek?(): void;
onEnd?(): void;
onFullscreenPlayerWillPresent?(): void;
onFullscreenPlayerDidPresent?(): void;
onFullscreenPlayerWillDismiss?(): void;
onFullscreenPlayerDidDismiss?(): void;
onReadyForDisplay?(): void;
onPlaybackStalled?(): void;
onPlaybackResume?(): void;
onPlaybackRateChange?(): void;
onAudioFocusChanged?(): void;
onAudioBecomingNoisy?(): void;
/* Required by react-native */
scaleX?: number;
scaleY?: number;
translateX?: number;
translateY?: number;
rotation?: number;
}
export default class Video extends React.Component<VideoProperties> {
seek(time: number): void;
presentFullscreenPlayer(): void;
dismissFullscreenPlayer(): void;
}