This repository has been archived by the owner on Jun 9, 2022. It is now read-only.
forked from doublesymmetry/react-native-track-player
-
Notifications
You must be signed in to change notification settings - Fork 1
/
index.d.ts
204 lines (169 loc) · 6.4 KB
/
index.d.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
import { Component } from 'react';
export = RNTrackPlayer;
declare namespace RNTrackPlayer {
export type EventType =
| "playback-state"
| "playback-error"
| "playback-queue-ended"
| "playback-track-changed"
| "remote-play"
| "remote-play-id"
| "remote-play-search"
| "remote-pause"
| "remote-stop"
| "remote-skip"
| "remote-next"
| "remote-previous"
| "remote-jump-forward"
| "remote-jump-backward"
| "remote-seek"
| "remote-set-rating"
| "remote-duck"
| "remote-like"
| "remote-dislike"
| "remote-bookmark";
export type TrackType =
| "default"
| "dash"
| "hls"
| "smoothstreaming";
type ResourceObject = any;
type State = string | number;
type RatingType = string | number;
type Capability = string | number;
type PitchAlgorithm = string | number;
type EventHandler = (type: EventType, ...args: any[]) => void;
export function registerEventHandler(handler: EventHandler): void;
type ServiceHandler = () => Promise<void>;
export function registerPlaybackService(serviceFactory: () => ServiceHandler): void;
type EmitterSubscription = { remove: () => void; };
export function addEventListener(type: EventType, listener: (data: any) => void): EmitterSubscription;
export interface TrackMetadata {
duration?: number;
title: string;
artist: string;
album?: string;
description?: string;
genre?: string;
date?: string;
rating?: number | boolean;
artwork?: string | ResourceObject;
}
export interface Track extends TrackMetadata {
id: string;
url: string | ResourceObject;
type?: TrackType;
userAgent?: string;
contentType?: string;
pitchAlgorithm?: PitchAlgorithm;
[key: string]: any;
}
export interface PlayerOptions {
minBuffer?: number;
maxBuffer?: number;
playBuffer?: number;
maxCacheSize?: number;
iosCategory?: 'playback' | 'playAndRecord' | 'multiRoute' | 'ambient' | 'soloAmbient' | 'record';
iosCategoryMode?: 'default' | 'gameChat' | 'measurement' | 'moviePlayback' | 'spokenAudio' | 'videoChat' | 'videoRecording' | 'voiceChat' | 'voicePrompt';
iosCategoryOptions?: Array<'mixWithOthers' | 'duckOthers' | 'interruptSpokenAudioAndMixWithOthers' | 'allowBluetooth' | 'allowBluetoothA2DP' | 'allowAirPlay' | 'defaultToSpeaker'>;
waitForBuffer?: boolean;
}
interface FeedbackOptions {
/** Marks wether the option should be marked as active or "done" */
isActive: boolean
/** The title to give the action (relevant for iOS) */
title: string
}
export interface MetadataOptions {
ratingType?: RatingType;
jumpInterval?: number;
likeOptions?: FeedbackOptions;
dislikeOptions?: FeedbackOptions;
bookmarkOptions?: FeedbackOptions;
stopWithApp?: boolean;
capabilities?: Capability[];
notificationCapabilities?: Capability[];
compactCapabilities?: Capability[];
icon?: ResourceObject;
playIcon?: ResourceObject;
pauseIcon?: ResourceObject;
stopIcon?: ResourceObject;
previousIcon?: ResourceObject;
nextIcon?: ResourceObject;
rewindIcon?: ResourceObject;
forwardIcon?: ResourceObject;
color?: number;
}
// General
export function setupPlayer(options?: PlayerOptions): Promise<void>;
export function destroy(): void;
// Player Queue Commands
export function add(tracks: Track | Track[], insertBeforeId?: string): Promise<void>;
export function remove(trackIds: string | string[]): Promise<void>;
export function skip(trackId: string): Promise<void>;
export function skipToNext(): Promise<void>;
export function skipToPrevious(): Promise<void>;
export function removeUpcomingTracks(): Promise<void>;
// Control Center / Notification Metadata Commands
export function updateOptions(options: MetadataOptions): void;
export function updateMetadataForTrack(id: string, metadata: TrackMetadata) : Promise<void>;
// Player Playback Commands
export function reset(): Promise<void>;
export function play(): Promise<void>;
export function pause(): Promise<void>;
export function stop(): Promise<void>;
export function seekTo(seconds: number): Promise<void>;
export function setVolume(level: number): Promise<void>;
export function setRate(rate: number): Promise<void>;
// Player Getters
export function getQueue(): Promise<Track[]>;
export function getTrack(id: string): Promise<Track>;
export function getCurrentTrack(): Promise<string>;
export function getVolume(): Promise<number>;
export function getDuration(): Promise<number>;
export function getPosition(): Promise<number>;
export function getBufferedPosition(): Promise<number>;
export function getState(): Promise<State>;
export function getRate(): Promise<number>;
// Components
export interface ProgressComponentState {
position: number;
bufferedPosition: number;
duration: number;
}
export class ProgressComponent<P = {}, S = {}> extends Component<P, ProgressComponentState & S> {
public getProgress: () => number;
public getBufferedProgress: () => number;
}
// Constants
export const STATE_NONE: State;
export const STATE_PLAYING: State;
export const STATE_PAUSED: State;
export const STATE_STOPPED: State;
export const STATE_BUFFERING: State;
export const STATE_READY: State;
export const RATING_HEART: RatingType;
export const RATING_THUMBS_UP_DOWN: RatingType;
export const RATING_3_STARS: RatingType;
export const RATING_4_STARS: RatingType;
export const RATING_5_STARS: RatingType;
export const RATING_PERCENTAGE: RatingType;
export const CAPABILITY_PLAY: Capability;
export const CAPABILITY_PLAY_FROM_ID: Capability;
export const CAPABILITY_PLAY_FROM_SEARCH: Capability;
export const CAPABILITY_PAUSE: Capability;
export const CAPABILITY_STOP: Capability;
export const CAPABILITY_SEEK_TO: Capability;
export const CAPABILITY_SKIP: Capability;
export const CAPABILITY_SKIP_TO_NEXT: Capability;
export const CAPABILITY_SKIP_TO_PREVIOUS: Capability;
export const CAPABILITY_SET_RATING: Capability;
export const CAPABILITY_JUMP_FORWARD: Capability;
export const CAPABILITY_JUMP_BACKWARD: Capability;
export const CAPABILITY_LIKE: Capability;
export const CAPABILITY_DISLIKE: Capability;
export const CAPABILITY_BOOKMARK: Capability;
export const PITCH_ALGORITHM_LINEAR: PitchAlgorithm;
export const PITCH_ALGORITHM_MUSIC: PitchAlgorithm;
export const PITCH_ALGORITHM_VOICE: PitchAlgorithm;
}