@vkontakte/calls-sdk 2.6.2-beta.11 → 2.6.2-beta.12
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CallsSDK.d.ts +8 -4
- package/abstract/BaseSignaling.d.ts +3 -2
- package/calls-sdk.cjs.js +8 -8
- package/calls-sdk.esm.js +8 -8
- package/classes/Conversation.d.ts +6 -2
- package/default/Signaling.d.ts +3 -2
- package/enums/SignalingNotification.d.ts +5 -1
- package/package.json +1 -1
- package/static/External.d.ts +60 -3
- package/static/Params.d.ts +35 -1
- package/types/ExternalId.d.ts +2 -0
- package/types/MediaSettings.d.ts +1 -1
- package/types/MovieShare.d.ts +42 -0
- package/types/Participant.d.ts +2 -0
- package/types/SignalingMessage.d.ts +10 -0
|
@@ -15,6 +15,7 @@ import { JSONObject } from '../static/Json';
|
|
|
15
15
|
import { ExternalParticipant, ExternalParticipantId, ExternalParticipantListChunk, ExternalUserId } from '../types/ExternalId';
|
|
16
16
|
import MediaModifiers from '../types/MediaModifiers';
|
|
17
17
|
import { IVideoDimentions } from '../types/MediaSettings';
|
|
18
|
+
import { IAddMovieParams } from '../types/MovieShare';
|
|
18
19
|
import MuteStates from '../types/MuteStates';
|
|
19
20
|
import { CompositeUserId, IGetParticipantsParameters, OkUserId, ParticipantId } from '../types/Participant';
|
|
20
21
|
import { ParticipantLayout } from '../types/ParticipantLayout';
|
|
@@ -209,6 +210,9 @@ export default class Conversation extends EventEmitter {
|
|
|
209
210
|
private _onParticipantSourcesUpdate;
|
|
210
211
|
private _onParticipantPromoted;
|
|
211
212
|
private _onChatRoomUpdated;
|
|
213
|
+
private _onSharedMovieUpdate;
|
|
214
|
+
private _onSharedMovieInfoStarted;
|
|
215
|
+
private _onSharedMovieInfoStopped;
|
|
212
216
|
private _waitForStreamIfNeeded;
|
|
213
217
|
private _matchStreamDescription;
|
|
214
218
|
private _getWaitingTime;
|
|
@@ -232,11 +236,11 @@ export default class Conversation extends EventEmitter {
|
|
|
232
236
|
customData(data: JSONObject, participantId?: ParticipantId | null): Promise<void>;
|
|
233
237
|
createJoinLink(): Promise<string>;
|
|
234
238
|
removeJoinLink(): Promise<never>;
|
|
235
|
-
addMovie(movieId:
|
|
239
|
+
addMovie({ movieId, gain, metadata }: IAddMovieParams): Promise<{
|
|
236
240
|
movieId: string;
|
|
237
241
|
streamType: string;
|
|
238
242
|
}>;
|
|
239
|
-
updateMovie(movieId: string, gain?: number, offset?:
|
|
243
|
+
updateMovie(movieId: string, gain?: number, offset?: number, pause?: boolean): Promise<void>;
|
|
240
244
|
removeMovie(movieId: string): Promise<void>;
|
|
241
245
|
startStream(isRecord?: boolean, name?: string | null, movieId?: string | null, privacy?: 'PUBLIC' | 'FRIENDS' | 'DIRECT_LINK', groupId?: string | null): Promise<SignalingMessage>;
|
|
242
246
|
stopStream(): Promise<SignalingMessage>;
|
package/default/Signaling.d.ts
CHANGED
|
@@ -11,6 +11,7 @@ import UserRole from '../enums/UserRole';
|
|
|
11
11
|
import { JSONObject } from '../static/Json';
|
|
12
12
|
import MediaModifiers from '../types/MediaModifiers';
|
|
13
13
|
import MediaSettings from '../types/MediaSettings';
|
|
14
|
+
import { IAddMovieParams, ISharedMovieState } from '../types/MovieShare';
|
|
14
15
|
import MuteStates from '../types/MuteStates';
|
|
15
16
|
import { CompositeUserId, ParticipantId } from '../types/Participant';
|
|
16
17
|
import ParticipantLayout, { RequestKeyFrame, StopStream } from '../types/ParticipantLayout';
|
|
@@ -96,8 +97,8 @@ export default class Signaling extends BaseSignaling {
|
|
|
96
97
|
updateDisplayLayout(layouts: {
|
|
97
98
|
[streamDesc: string]: ParticipantLayout | StopStream | RequestKeyFrame;
|
|
98
99
|
}): Promise<SignalingMessage>;
|
|
99
|
-
addMovie(data:
|
|
100
|
-
updateMovie(data:
|
|
100
|
+
addMovie(data: IAddMovieParams): Promise<SignalingMessage>;
|
|
101
|
+
updateMovie(data: ISharedMovieState): Promise<SignalingMessage>;
|
|
101
102
|
removeMovie(data: any): Promise<SignalingMessage>;
|
|
102
103
|
startStream(data: any): Promise<SignalingMessage>;
|
|
103
104
|
stopStream(): Promise<SignalingMessage>;
|
|
@@ -35,6 +35,10 @@ declare enum SignalingNotification {
|
|
|
35
35
|
PROMOTE_PARTICIPANT = "promote-participant",
|
|
36
36
|
CHAT_ROOM_UPDATED = "chat-room-updated",
|
|
37
37
|
PROMOTION_APPROVED = "promotion-approved",
|
|
38
|
-
JOIN_LINK_CHANGED = "join-link-changed"
|
|
38
|
+
JOIN_LINK_CHANGED = "join-link-changed",
|
|
39
|
+
MOVIE_UPDATE_NOTIFICATION = "movie-update-notification",
|
|
40
|
+
MOVIE_SHARE_INFO = "movie-share-info",
|
|
41
|
+
MOVIE_SHARE_STARTED = "movie-share-started",
|
|
42
|
+
MOVIE_SHARE_STOPPED = "movie-share-stopped"
|
|
39
43
|
}
|
|
40
44
|
export default SignalingNotification;
|
package/package.json
CHANGED
package/static/External.d.ts
CHANGED
|
@@ -10,6 +10,7 @@ import UserRole from '../enums/UserRole';
|
|
|
10
10
|
import { ExternalId, ExternalParticipant, ExternalParticipantId, ExternalParticipantListChunk, ExternalParticipantListMarkers } from '../types/ExternalId';
|
|
11
11
|
import MediaModifiers from '../types/MediaModifiers';
|
|
12
12
|
import MediaSettings from '../types/MediaSettings';
|
|
13
|
+
import { IOnRemoteMovieData, ISharedMovieInfo, ISharedMovieState, ISharedMovieStoppedInfo } from '../types/MovieShare';
|
|
13
14
|
import MuteStates from '../types/MuteStates';
|
|
14
15
|
import { ParticipantStateMapped } from '../types/Participant';
|
|
15
16
|
import { DebugMessageType } from './Debug';
|
|
@@ -72,10 +73,31 @@ declare namespace External {
|
|
|
72
73
|
* Если сервер закончил стримить собеседника, вместо стрима будет передан null
|
|
73
74
|
*
|
|
74
75
|
* @param userId
|
|
75
|
-
* @param
|
|
76
|
-
|
|
76
|
+
* @param data
|
|
77
|
+
*/
|
|
78
|
+
function onRemoteLive(userId: ExternalParticipantId, data: IOnRemoteMovieData): void;
|
|
79
|
+
/**
|
|
80
|
+
* Получен собственный стрим лайв.
|
|
81
|
+
* Если сервер закончил стримить собеседника, вместо стрима будет передан null
|
|
82
|
+
*
|
|
83
|
+
* @param userId
|
|
84
|
+
* @param data
|
|
85
|
+
*/
|
|
86
|
+
function onLocalLive(userId: ExternalParticipantId, data: IOnRemoteMovieData): void;
|
|
87
|
+
/**
|
|
88
|
+
* Получено обновление стрима или лайва от собеседника.
|
|
89
|
+
*
|
|
90
|
+
* @param userId
|
|
91
|
+
* @param data
|
|
92
|
+
*/
|
|
93
|
+
function onRemoteLiveUpdate(userId: ExternalParticipantId, data: ISharedMovieState): void;
|
|
94
|
+
/**
|
|
95
|
+
* Получено обновление собственного стрима или лайва.
|
|
96
|
+
*
|
|
97
|
+
* @param userId
|
|
98
|
+
* @param data
|
|
77
99
|
*/
|
|
78
|
-
function
|
|
100
|
+
function onLocalLiveUpdate(userId: ExternalParticipantId, data: ISharedMovieState): void;
|
|
79
101
|
/**
|
|
80
102
|
* Получен стрим с экрана собеседника.
|
|
81
103
|
* Если сервер закончил стримить экран собеседника, вместо стрима будет передан null
|
|
@@ -106,6 +128,41 @@ declare namespace External {
|
|
|
106
128
|
* @param markers
|
|
107
129
|
*/
|
|
108
130
|
function onRemoteMediaSettings(userId: ExternalParticipantId, mediaSettings: MediaSettings, markers?: ExternalParticipantListMarkers): void;
|
|
131
|
+
/**
|
|
132
|
+
* Изменились данные собственного стрима
|
|
133
|
+
*
|
|
134
|
+
* @param userId
|
|
135
|
+
* @param mediaSettings
|
|
136
|
+
*/
|
|
137
|
+
function onLocalMediaSettings(userId: ExternalParticipantId, mediaSettings: MediaSettings): void;
|
|
138
|
+
/**
|
|
139
|
+
* Полученны данные по стримам (лайв/мувик) от собеседника
|
|
140
|
+
*
|
|
141
|
+
* @param userId
|
|
142
|
+
* @param sharedMovieInfo
|
|
143
|
+
*/
|
|
144
|
+
function onRemoteSharedMovieInfo(userId: ExternalParticipantId, sharedMovieInfo: ISharedMovieInfo): void;
|
|
145
|
+
/**
|
|
146
|
+
* Полученны данные по остановленным стримам (лайв/мувик) от собеседника
|
|
147
|
+
*
|
|
148
|
+
* @param userId
|
|
149
|
+
* @param sharedMovieStoppedInfo
|
|
150
|
+
*/
|
|
151
|
+
function onRemoteSharedMovieStoppedInfo(userId: ExternalParticipantId, sharedMovieStoppedInfo: ISharedMovieStoppedInfo): void;
|
|
152
|
+
/**
|
|
153
|
+
* Полученны данные по собственным стримам (лайв/мувик)
|
|
154
|
+
*
|
|
155
|
+
* @param userId
|
|
156
|
+
* @param sharedMovieInfo
|
|
157
|
+
*/
|
|
158
|
+
function onLocalSharedMovieInfo(userId: ExternalParticipantId, sharedMovieInfo: ISharedMovieInfo): void;
|
|
159
|
+
/**
|
|
160
|
+
* Полученны данные по собственным остановленным стримам (лайв/мувик)
|
|
161
|
+
*
|
|
162
|
+
* @param userId
|
|
163
|
+
* @param sharedMovieStoppedInfo
|
|
164
|
+
*/
|
|
165
|
+
function onLocalSharedMovieStoppedInfo(userId: ExternalParticipantId, sharedMovieStoppedInfo: ISharedMovieStoppedInfo): void;
|
|
109
166
|
/**
|
|
110
167
|
* Добавили участника
|
|
111
168
|
*
|
package/static/Params.d.ts
CHANGED
|
@@ -11,6 +11,7 @@ import { ExternalId, ExternalParticipant, ExternalParticipantId, ExternalPartici
|
|
|
11
11
|
import IceServer from '../types/IceServer';
|
|
12
12
|
import MediaModifiers from '../types/MediaModifiers';
|
|
13
13
|
import MediaSettings from '../types/MediaSettings';
|
|
14
|
+
import { IOnRemoteMovieData, ISharedMovieInfo, ISharedMovieState, ISharedMovieStoppedInfo } from '../types/MovieShare';
|
|
14
15
|
import MuteStates from '../types/MuteStates';
|
|
15
16
|
import { ParticipantStateMapped } from '../types/Participant';
|
|
16
17
|
import AuthData from './AuthData';
|
|
@@ -310,7 +311,20 @@ export declare type ParamsObject = {
|
|
|
310
311
|
* Получен стрим трансляция или мувик от собеседника.
|
|
311
312
|
* Если сервер закончил стримить экран собеседника, вместо стрима будет передан null
|
|
312
313
|
*/
|
|
313
|
-
onRemoteLive?: (userId: ExternalParticipantId,
|
|
314
|
+
onRemoteLive?: (userId: ExternalParticipantId, data: IOnRemoteMovieData) => void;
|
|
315
|
+
/**
|
|
316
|
+
* Получен собственный стрим трансляция или мувик.
|
|
317
|
+
* Если сервер закончил стримить экран собеседника, вместо стрима будет передан null
|
|
318
|
+
*/
|
|
319
|
+
onLocalLive?: (userId: ExternalParticipantId, data: IOnRemoteMovieData) => void;
|
|
320
|
+
/**
|
|
321
|
+
* Получено обновление стрима или лайва от собеседника.
|
|
322
|
+
*/
|
|
323
|
+
onRemoteLiveUpdate?: (userId: ExternalParticipantId, data: ISharedMovieState) => void;
|
|
324
|
+
/**
|
|
325
|
+
* Получено обновление собственного стрима или лайва.
|
|
326
|
+
*/
|
|
327
|
+
onLocalLiveUpdate?: (userId: ExternalParticipantId, data: ISharedMovieState) => void;
|
|
314
328
|
/**
|
|
315
329
|
* Начат звонок
|
|
316
330
|
*/
|
|
@@ -323,6 +337,26 @@ export declare type ParamsObject = {
|
|
|
323
337
|
* Изменились данные стрима собеседника
|
|
324
338
|
*/
|
|
325
339
|
onRemoteMediaSettings?: (userId: ExternalParticipantId, mediaSettings: MediaSettings, markers?: ExternalParticipantListMarkers) => void;
|
|
340
|
+
/**
|
|
341
|
+
* Изменились данные стрима собеседника
|
|
342
|
+
*/
|
|
343
|
+
onLocalMediaSettings?: (userId: ExternalParticipantId, mediaSettings: MediaSettings) => void;
|
|
344
|
+
/**
|
|
345
|
+
* Полученны данные по стримам (лайв/мувик) от собеседника
|
|
346
|
+
*/
|
|
347
|
+
onRemoteSharedMovieInfo?: (userId: ExternalParticipantId, sharedMovieInfo: ISharedMovieInfo) => void;
|
|
348
|
+
/**
|
|
349
|
+
* Полученны данные по остановленным стримам (лайв/мувик) от собеседника
|
|
350
|
+
*/
|
|
351
|
+
onRemoteSharedMovieStoppedInfo?: (userId: ExternalParticipantId, sharedMovieStoppedInfo: ISharedMovieStoppedInfo) => void;
|
|
352
|
+
/**
|
|
353
|
+
* Полученны данные по собственным стримам (лайв/мувик)
|
|
354
|
+
*/
|
|
355
|
+
onLocalSharedMovieInfo?: (userId: ExternalParticipantId, sharedMovieInfo: ISharedMovieInfo) => void;
|
|
356
|
+
/**
|
|
357
|
+
* Полученны данные по собственным остановленным стримам (лайв/мувик)
|
|
358
|
+
*/
|
|
359
|
+
onLocalSharedMovieStoppedInfo?: (userId: ExternalParticipantId, sharedMovieStoppedInfo: ISharedMovieStoppedInfo) => void;
|
|
326
360
|
/**
|
|
327
361
|
* Добавили участника
|
|
328
362
|
*/
|
package/types/ExternalId.d.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import MediaOption from '../enums/MediaOption';
|
|
2
2
|
import { ParticipantStatus } from '../static/External';
|
|
3
3
|
import MediaSettings from './MediaSettings';
|
|
4
|
+
import { ISharedMovieInfo } from './MovieShare';
|
|
4
5
|
import MuteStates from './MuteStates';
|
|
5
6
|
import { ParticipantListMarker, ParticipantListType, ParticipantStateMapped } from './Participant';
|
|
6
7
|
import SignalingMessage from './SignalingMessage';
|
|
@@ -94,6 +95,7 @@ export interface ExternalParticipant {
|
|
|
94
95
|
*/
|
|
95
96
|
unmuteOptions: MediaOption[];
|
|
96
97
|
markers?: ExternalParticipantListMarkers;
|
|
98
|
+
movieShareInfos?: ISharedMovieInfo[];
|
|
97
99
|
}
|
|
98
100
|
export interface ExternalParticipantListChunk {
|
|
99
101
|
participants: ExternalParticipant[];
|
package/types/MediaSettings.d.ts
CHANGED
|
@@ -19,7 +19,7 @@ export declare type MediaSettings = {
|
|
|
19
19
|
export declare type VideoStreamInfo = {
|
|
20
20
|
id: string;
|
|
21
21
|
source: string;
|
|
22
|
-
|
|
22
|
+
externalMovieId?: string;
|
|
23
23
|
};
|
|
24
24
|
export default MediaSettings;
|
|
25
25
|
export declare function compareMediaSettings(ms1: MediaSettings, ms2: MediaSettings): boolean;
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { OkUserId, CompositeUserId } from './Participant';
|
|
2
|
+
import { MediaType } from './ParticipantStreamDescription';
|
|
3
|
+
export interface IMoviePreview {
|
|
4
|
+
url: string;
|
|
5
|
+
width: number;
|
|
6
|
+
height: number;
|
|
7
|
+
}
|
|
8
|
+
export interface IAddMovieParams {
|
|
9
|
+
movieId: string;
|
|
10
|
+
gain?: number;
|
|
11
|
+
metadata?: {
|
|
12
|
+
title?: string;
|
|
13
|
+
thumbnails?: IMoviePreview[];
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
export declare type ISharedMovieStateResponse = [number, number, boolean, number, number];
|
|
17
|
+
export interface ISharedMovieState {
|
|
18
|
+
participantId: CompositeUserId;
|
|
19
|
+
gain?: number;
|
|
20
|
+
pause?: boolean;
|
|
21
|
+
offset?: number;
|
|
22
|
+
duration?: number;
|
|
23
|
+
}
|
|
24
|
+
export interface ISharedMovieInfo {
|
|
25
|
+
movieId: OkUserId;
|
|
26
|
+
initiatorId: CompositeUserId;
|
|
27
|
+
title: string;
|
|
28
|
+
source: MediaType;
|
|
29
|
+
externalMovieId: string;
|
|
30
|
+
duration: number;
|
|
31
|
+
thumbnails: IMoviePreview[];
|
|
32
|
+
}
|
|
33
|
+
export interface ISharedMovieStoppedInfo {
|
|
34
|
+
movieId: OkUserId;
|
|
35
|
+
initiatorId: CompositeUserId;
|
|
36
|
+
source: MediaType;
|
|
37
|
+
}
|
|
38
|
+
export interface IOnRemoteMovieData {
|
|
39
|
+
streamName: string;
|
|
40
|
+
stream: MediaStream | null;
|
|
41
|
+
mediaType: MediaType;
|
|
42
|
+
}
|
package/types/Participant.d.ts
CHANGED
|
@@ -4,6 +4,7 @@ import UserRole from '../enums/UserRole';
|
|
|
4
4
|
import { ParticipantStatus } from '../static/External';
|
|
5
5
|
import MediaSettings from '../types/MediaSettings';
|
|
6
6
|
import { ExternalId, ExternalParticipantId, ExternalParticipantListMarkers } from './ExternalId';
|
|
7
|
+
import { ISharedMovieInfo } from './MovieShare';
|
|
7
8
|
import MuteStates from './MuteStates';
|
|
8
9
|
import ParticipantLayout from './ParticipantLayout';
|
|
9
10
|
/**
|
|
@@ -55,6 +56,7 @@ export interface Participant {
|
|
|
55
56
|
unmuteOptions: MediaOption[];
|
|
56
57
|
observedIds: CompositeUserId[];
|
|
57
58
|
markers?: ExternalParticipantListMarkers;
|
|
59
|
+
movieShareInfos?: ISharedMovieInfo[];
|
|
58
60
|
}
|
|
59
61
|
export interface IGetParticipantsParameters {
|
|
60
62
|
externalIds: ExternalId[];
|
|
@@ -9,6 +9,7 @@ import UserRole from '../enums/UserRole';
|
|
|
9
9
|
import UserType from '../enums/UserType';
|
|
10
10
|
import MediaModifiers from './MediaModifiers';
|
|
11
11
|
import MediaSettings from './MediaSettings';
|
|
12
|
+
import { ISharedMovieInfo, ISharedMovieState, ISharedMovieStoppedInfo } from './MovieShare';
|
|
12
13
|
import MuteStates from './MuteStates';
|
|
13
14
|
import { CompositeUserId, OkUserId, ParticipantId, ParticipantListMarker as ParticipantParticipantListMarker, ParticipantListMarkers, ParticipantListType as ParticipantParticipantListType } from './Participant';
|
|
14
15
|
import VideoSettings from './VideoSettings';
|
|
@@ -54,6 +55,7 @@ declare namespace SignalingMessage {
|
|
|
54
55
|
unmuteOptions?: MediaOption[];
|
|
55
56
|
markers?: ParticipantListMarkers;
|
|
56
57
|
observedIds?: CompositeUserId[];
|
|
58
|
+
movieShareInfos?: ISharedMovieInfo[];
|
|
57
59
|
}
|
|
58
60
|
export interface ParticipantListChunk extends Notification {
|
|
59
61
|
participants: (Participant & Required<Pick<Participant, 'markers'>>)[];
|
|
@@ -279,6 +281,14 @@ declare namespace SignalingMessage {
|
|
|
279
281
|
export interface JoinLinkChanged extends Notification {
|
|
280
282
|
joinLink: string;
|
|
281
283
|
}
|
|
284
|
+
export interface SharedMovieState extends Notification {
|
|
285
|
+
data: ISharedMovieState[];
|
|
286
|
+
}
|
|
287
|
+
export interface SharedMovieInfo extends Notification {
|
|
288
|
+
movieShareInfo: ISharedMovieInfo;
|
|
289
|
+
}
|
|
290
|
+
export interface SharedMovieStoppedInfo extends Notification, ISharedMovieStoppedInfo {
|
|
291
|
+
}
|
|
282
292
|
export {};
|
|
283
293
|
}
|
|
284
294
|
export default SignalingMessage;
|