@tellescope/react-components 1.239.1 → 1.241.0

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.
Files changed (76) hide show
  1. package/lib/cjs/Forms/inputs.d.ts +1 -1
  2. package/lib/cjs/TwilioVideo/TwilioControls.d.ts +8 -0
  3. package/lib/cjs/TwilioVideo/TwilioControls.d.ts.map +1 -0
  4. package/lib/cjs/TwilioVideo/TwilioControls.js +57 -0
  5. package/lib/cjs/TwilioVideo/TwilioControls.js.map +1 -0
  6. package/lib/cjs/TwilioVideo/TwilioLocalPreview.d.ts +6 -0
  7. package/lib/cjs/TwilioVideo/TwilioLocalPreview.d.ts.map +1 -0
  8. package/lib/cjs/TwilioVideo/TwilioLocalPreview.js +173 -0
  9. package/lib/cjs/TwilioVideo/TwilioLocalPreview.js.map +1 -0
  10. package/lib/cjs/TwilioVideo/TwilioParticipant.d.ts +11 -0
  11. package/lib/cjs/TwilioVideo/TwilioParticipant.d.ts.map +1 -0
  12. package/lib/cjs/TwilioVideo/TwilioParticipant.js +98 -0
  13. package/lib/cjs/TwilioVideo/TwilioParticipant.js.map +1 -0
  14. package/lib/cjs/TwilioVideo/TwilioVideoContext.d.ts +28 -0
  15. package/lib/cjs/TwilioVideo/TwilioVideoContext.d.ts.map +1 -0
  16. package/lib/cjs/TwilioVideo/TwilioVideoContext.js +222 -0
  17. package/lib/cjs/TwilioVideo/TwilioVideoContext.js.map +1 -0
  18. package/lib/cjs/TwilioVideo/TwilioVideoRoom.d.ts +10 -0
  19. package/lib/cjs/TwilioVideo/TwilioVideoRoom.d.ts.map +1 -0
  20. package/lib/cjs/TwilioVideo/TwilioVideoRoom.js +49 -0
  21. package/lib/cjs/TwilioVideo/TwilioVideoRoom.js.map +1 -0
  22. package/lib/cjs/TwilioVideo/hooks.d.ts +44 -0
  23. package/lib/cjs/TwilioVideo/hooks.d.ts.map +1 -0
  24. package/lib/cjs/TwilioVideo/hooks.js +232 -0
  25. package/lib/cjs/TwilioVideo/hooks.js.map +1 -0
  26. package/lib/cjs/TwilioVideo/index.d.ts +7 -0
  27. package/lib/cjs/TwilioVideo/index.d.ts.map +1 -0
  28. package/lib/cjs/TwilioVideo/index.js +19 -0
  29. package/lib/cjs/TwilioVideo/index.js.map +1 -0
  30. package/lib/cjs/index.d.ts +1 -0
  31. package/lib/cjs/index.d.ts.map +1 -1
  32. package/lib/cjs/index.js +1 -0
  33. package/lib/cjs/index.js.map +1 -1
  34. package/lib/esm/Forms/inputs.d.ts +1 -1
  35. package/lib/esm/TwilioVideo/TwilioControls.d.ts +8 -0
  36. package/lib/esm/TwilioVideo/TwilioControls.d.ts.map +1 -0
  37. package/lib/esm/TwilioVideo/TwilioControls.js +53 -0
  38. package/lib/esm/TwilioVideo/TwilioControls.js.map +1 -0
  39. package/lib/esm/TwilioVideo/TwilioLocalPreview.d.ts +6 -0
  40. package/lib/esm/TwilioVideo/TwilioLocalPreview.d.ts.map +1 -0
  41. package/lib/esm/TwilioVideo/TwilioLocalPreview.js +166 -0
  42. package/lib/esm/TwilioVideo/TwilioLocalPreview.js.map +1 -0
  43. package/lib/esm/TwilioVideo/TwilioParticipant.d.ts +11 -0
  44. package/lib/esm/TwilioVideo/TwilioParticipant.d.ts.map +1 -0
  45. package/lib/esm/TwilioVideo/TwilioParticipant.js +94 -0
  46. package/lib/esm/TwilioVideo/TwilioParticipant.js.map +1 -0
  47. package/lib/esm/TwilioVideo/TwilioVideoContext.d.ts +28 -0
  48. package/lib/esm/TwilioVideo/TwilioVideoContext.d.ts.map +1 -0
  49. package/lib/esm/TwilioVideo/TwilioVideoContext.js +214 -0
  50. package/lib/esm/TwilioVideo/TwilioVideoContext.js.map +1 -0
  51. package/lib/esm/TwilioVideo/TwilioVideoRoom.d.ts +10 -0
  52. package/lib/esm/TwilioVideo/TwilioVideoRoom.d.ts.map +1 -0
  53. package/lib/esm/TwilioVideo/TwilioVideoRoom.js +45 -0
  54. package/lib/esm/TwilioVideo/TwilioVideoRoom.js.map +1 -0
  55. package/lib/esm/TwilioVideo/hooks.d.ts +44 -0
  56. package/lib/esm/TwilioVideo/hooks.d.ts.map +1 -0
  57. package/lib/esm/TwilioVideo/hooks.js +226 -0
  58. package/lib/esm/TwilioVideo/hooks.js.map +1 -0
  59. package/lib/esm/TwilioVideo/index.d.ts +7 -0
  60. package/lib/esm/TwilioVideo/index.d.ts.map +1 -0
  61. package/lib/esm/TwilioVideo/index.js +7 -0
  62. package/lib/esm/TwilioVideo/index.js.map +1 -0
  63. package/lib/esm/index.d.ts +1 -0
  64. package/lib/esm/index.d.ts.map +1 -1
  65. package/lib/esm/index.js +1 -0
  66. package/lib/esm/index.js.map +1 -1
  67. package/lib/tsconfig.tsbuildinfo +1 -1
  68. package/package.json +12 -11
  69. package/src/TwilioVideo/TwilioControls.tsx +110 -0
  70. package/src/TwilioVideo/TwilioLocalPreview.tsx +151 -0
  71. package/src/TwilioVideo/TwilioParticipant.tsx +136 -0
  72. package/src/TwilioVideo/TwilioVideoContext.tsx +198 -0
  73. package/src/TwilioVideo/TwilioVideoRoom.tsx +98 -0
  74. package/src/TwilioVideo/hooks.ts +159 -0
  75. package/src/TwilioVideo/index.ts +19 -0
  76. package/src/index.ts +2 -1
@@ -0,0 +1,222 @@
1
+ "use strict";
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
4
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
5
+ s = arguments[i];
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
8
+ }
9
+ return t;
10
+ };
11
+ return __assign.apply(this, arguments);
12
+ };
13
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
14
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
15
+ return new (P || (P = Promise))(function (resolve, reject) {
16
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
17
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
18
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
19
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
20
+ });
21
+ };
22
+ var __generator = (this && this.__generator) || function (thisArg, body) {
23
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
24
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
25
+ function verb(n) { return function (v) { return step([n, v]); }; }
26
+ function step(op) {
27
+ if (f) throw new TypeError("Generator is already executing.");
28
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
29
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
30
+ if (y = 0, t) op = [op[0] & 2, t.value];
31
+ switch (op[0]) {
32
+ case 0: case 1: t = op; break;
33
+ case 4: _.label++; return { value: op[1], done: false };
34
+ case 5: _.label++; y = op[1]; op = [0]; continue;
35
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
36
+ default:
37
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
38
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
39
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
40
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
41
+ if (t[2]) _.ops.pop();
42
+ _.trys.pop(); continue;
43
+ }
44
+ op = body.call(thisArg, _);
45
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
46
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
47
+ }
48
+ };
49
+ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
50
+ if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
51
+ if (ar || !(i in from)) {
52
+ if (!ar) ar = Array.prototype.slice.call(from, 0, i);
53
+ ar[i] = from[i];
54
+ }
55
+ }
56
+ return to.concat(ar || Array.prototype.slice.call(from));
57
+ };
58
+ var __importDefault = (this && this.__importDefault) || function (mod) {
59
+ return (mod && mod.__esModule) ? mod : { "default": mod };
60
+ };
61
+ Object.defineProperty(exports, "__esModule", { value: true });
62
+ exports.TwilioVideoProvider = exports.useTwilioVideo = void 0;
63
+ var jsx_runtime_1 = require("react/jsx-runtime");
64
+ var react_1 = require("react");
65
+ var twilio_video_1 = __importDefault(require("twilio-video"));
66
+ var TwilioVideoContext = (0, react_1.createContext)(null);
67
+ var useTwilioVideo = function () {
68
+ var context = (0, react_1.useContext)(TwilioVideoContext);
69
+ if (!context) {
70
+ throw new Error('useTwilioVideo must be used within TwilioVideoProvider');
71
+ }
72
+ return context;
73
+ };
74
+ exports.useTwilioVideo = useTwilioVideo;
75
+ var TwilioVideoProvider = function (_a) {
76
+ var children = _a.children;
77
+ var _b = (0, react_1.useState)(null), room = _b[0], setRoom = _b[1];
78
+ var _c = (0, react_1.useState)(false), isConnecting = _c[0], setIsConnecting = _c[1];
79
+ var _d = (0, react_1.useState)(null), localVideoTrack = _d[0], setLocalVideoTrack = _d[1];
80
+ var _e = (0, react_1.useState)(null), localAudioTrack = _e[0], setLocalAudioTrack = _e[1];
81
+ var _f = (0, react_1.useState)([]), participants = _f[0], setParticipants = _f[1];
82
+ var _g = (0, react_1.useState)(null), error = _g[0], setError = _g[1];
83
+ var _h = (0, react_1.useState)(false), isHost = _h[0], setIsHost = _h[1];
84
+ var _j = (0, react_1.useState)(true), isVideoEnabled = _j[0], setIsVideoEnabled = _j[1];
85
+ var _k = (0, react_1.useState)(true), isAudioEnabled = _k[0], setIsAudioEnabled = _k[1];
86
+ var localTracksRef = (0, react_1.useRef)([]);
87
+ var connect = (0, react_1.useCallback)(function (token, roomName) { return __awaiter(void 0, void 0, void 0, function () {
88
+ var tracks, videoTrack, audioTrack, newRoom, existingParticipants, err_1;
89
+ return __generator(this, function (_a) {
90
+ switch (_a.label) {
91
+ case 0:
92
+ setIsConnecting(true);
93
+ setError(null);
94
+ _a.label = 1;
95
+ case 1:
96
+ _a.trys.push([1, 4, 5, 6]);
97
+ return [4 /*yield*/, twilio_video_1.default.createLocalTracks({
98
+ audio: true,
99
+ video: { width: 640 },
100
+ })];
101
+ case 2:
102
+ tracks = _a.sent();
103
+ localTracksRef.current = tracks;
104
+ videoTrack = tracks.find(function (track) { return track.kind === 'video'; });
105
+ audioTrack = tracks.find(function (track) { return track.kind === 'audio'; });
106
+ if (videoTrack)
107
+ setLocalVideoTrack(videoTrack);
108
+ if (audioTrack)
109
+ setLocalAudioTrack(audioTrack);
110
+ return [4 /*yield*/, twilio_video_1.default.connect(token, {
111
+ name: roomName,
112
+ tracks: tracks,
113
+ dominantSpeaker: true,
114
+ networkQuality: { local: 1, remote: 1 },
115
+ })];
116
+ case 3:
117
+ newRoom = _a.sent();
118
+ setRoom(newRoom);
119
+ existingParticipants = Array.from(newRoom.participants.values());
120
+ setParticipants(existingParticipants);
121
+ // Listen for new participants
122
+ newRoom.on('participantConnected', function (participant) {
123
+ setParticipants(function (prev) { return __spreadArray(__spreadArray([], prev, true), [participant], false); });
124
+ });
125
+ newRoom.on('participantDisconnected', function (participant) {
126
+ setParticipants(function (prev) { return prev.filter(function (p) { return p.sid !== participant.sid; }); });
127
+ });
128
+ newRoom.on('disconnected', function () {
129
+ // Stop all local tracks when disconnected
130
+ localTracksRef.current.forEach(function (track) {
131
+ track.stop();
132
+ });
133
+ localTracksRef.current = [];
134
+ setRoom(null);
135
+ setLocalVideoTrack(null);
136
+ setLocalAudioTrack(null);
137
+ setParticipants([]);
138
+ });
139
+ return [3 /*break*/, 6];
140
+ case 4:
141
+ err_1 = _a.sent();
142
+ setError(err_1);
143
+ console.error('Failed to connect to Twilio Video:', err_1);
144
+ return [3 /*break*/, 6];
145
+ case 5:
146
+ setIsConnecting(false);
147
+ return [7 /*endfinally*/];
148
+ case 6: return [2 /*return*/];
149
+ }
150
+ });
151
+ }); }, []);
152
+ var disconnect = (0, react_1.useCallback)(function () {
153
+ if (room) {
154
+ room.disconnect();
155
+ }
156
+ // Stop local tracks
157
+ localTracksRef.current.forEach(function (track) {
158
+ track.stop();
159
+ });
160
+ localTracksRef.current = [];
161
+ setRoom(null);
162
+ setLocalVideoTrack(null);
163
+ setLocalAudioTrack(null);
164
+ setParticipants([]);
165
+ }, [room]);
166
+ var toggleVideo = (0, react_1.useCallback)(function () { return __awaiter(void 0, void 0, void 0, function () {
167
+ return __generator(this, function (_a) {
168
+ if (localVideoTrack) {
169
+ if (isVideoEnabled) {
170
+ localVideoTrack.disable();
171
+ }
172
+ else {
173
+ localVideoTrack.enable();
174
+ }
175
+ setIsVideoEnabled(!isVideoEnabled);
176
+ }
177
+ return [2 /*return*/];
178
+ });
179
+ }); }, [localVideoTrack, isVideoEnabled]);
180
+ var toggleAudio = (0, react_1.useCallback)(function () {
181
+ if (localAudioTrack) {
182
+ if (isAudioEnabled) {
183
+ localAudioTrack.disable();
184
+ }
185
+ else {
186
+ localAudioTrack.enable();
187
+ }
188
+ setIsAudioEnabled(!isAudioEnabled);
189
+ }
190
+ }, [localAudioTrack, isAudioEnabled]);
191
+ // Cleanup on unmount
192
+ (0, react_1.useEffect)(function () {
193
+ return function () {
194
+ if (room) {
195
+ room.disconnect();
196
+ }
197
+ localTracksRef.current.forEach(function (track) {
198
+ track.stop();
199
+ });
200
+ };
201
+ }, []);
202
+ var value = {
203
+ room: room,
204
+ isConnecting: isConnecting,
205
+ isConnected: !!room,
206
+ localVideoTrack: localVideoTrack,
207
+ localAudioTrack: localAudioTrack,
208
+ participants: participants,
209
+ error: error,
210
+ isHost: isHost,
211
+ isVideoEnabled: isVideoEnabled,
212
+ isAudioEnabled: isAudioEnabled,
213
+ connect: connect,
214
+ disconnect: disconnect,
215
+ toggleVideo: toggleVideo,
216
+ toggleAudio: toggleAudio,
217
+ setIsHost: setIsHost,
218
+ };
219
+ return ((0, jsx_runtime_1.jsx)(TwilioVideoContext.Provider, __assign({ value: value }, { children: children })));
220
+ };
221
+ exports.TwilioVideoProvider = TwilioVideoProvider;
222
+ //# sourceMappingURL=TwilioVideoContext.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TwilioVideoContext.js","sourceRoot":"","sources":["../../../src/TwilioVideo/TwilioVideoContext.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ import React from 'react';
2
+ export interface TwilioVideoRoomProps {
3
+ onLeave?: () => void;
4
+ onEndForAll?: () => void;
5
+ style?: React.CSSProperties;
6
+ /** Resolve participant identity to a display label. Defaults to empty string. */
7
+ resolveIdentity?: (identity: string) => string;
8
+ }
9
+ export declare const TwilioVideoRoom: React.FC<TwilioVideoRoomProps>;
10
+ //# sourceMappingURL=TwilioVideoRoom.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TwilioVideoRoom.d.ts","sourceRoot":"","sources":["../../../src/TwilioVideo/TwilioVideoRoom.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAMzB,MAAM,WAAW,oBAAoB;IACnC,OAAO,CAAC,EAAE,MAAM,IAAI,CAAA;IACpB,WAAW,CAAC,EAAE,MAAM,IAAI,CAAA;IACxB,KAAK,CAAC,EAAE,KAAK,CAAC,aAAa,CAAA;IAC3B,iFAAiF;IACjF,eAAe,CAAC,EAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,MAAM,CAAA;CAC/C;AAED,eAAO,MAAM,eAAe,EAAE,KAAK,CAAC,EAAE,CAAC,oBAAoB,CAmF1D,CAAA"}
@@ -0,0 +1,49 @@
1
+ "use strict";
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
4
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
5
+ s = arguments[i];
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
8
+ }
9
+ return t;
10
+ };
11
+ return __assign.apply(this, arguments);
12
+ };
13
+ Object.defineProperty(exports, "__esModule", { value: true });
14
+ exports.TwilioVideoRoom = void 0;
15
+ var jsx_runtime_1 = require("react/jsx-runtime");
16
+ var material_1 = require("@mui/material");
17
+ var TwilioVideoContext_1 = require("./TwilioVideoContext");
18
+ var TwilioParticipant_1 = require("./TwilioParticipant");
19
+ var TwilioControls_1 = require("./TwilioControls");
20
+ var TwilioVideoRoom = function (_a) {
21
+ var onLeave = _a.onLeave, onEndForAll = _a.onEndForAll, style = _a.style, resolveIdentity = _a.resolveIdentity;
22
+ var _b = (0, TwilioVideoContext_1.useTwilioVideo)(), room = _b.room, participants = _b.participants;
23
+ if (!room)
24
+ return null;
25
+ var localParticipant = room.localParticipant;
26
+ var hasRemoteParticipants = participants.length > 0;
27
+ return ((0, jsx_runtime_1.jsxs)(material_1.Box, __assign({ sx: __assign({ display: 'flex', flexDirection: 'column', height: '100%', width: '100%', backgroundColor: '#1a1a1a' }, style) }, { children: [(0, jsx_runtime_1.jsxs)(material_1.Box, __assign({ sx: {
28
+ flex: 1,
29
+ position: 'relative',
30
+ overflow: 'hidden',
31
+ } }, { children: [hasRemoteParticipants ? ((0, jsx_runtime_1.jsx)(material_1.Grid, __assign({ container: true, sx: {
32
+ height: '100%',
33
+ width: '100%',
34
+ } }, { children: participants.map(function (participant) { return ((0, jsx_runtime_1.jsx)(material_1.Grid, __assign({ item: true, xs: participants.length === 1 ? 12 : 6, sx: { height: participants.length <= 2 ? '100%' : '50%' } }, { children: (0, jsx_runtime_1.jsx)(TwilioParticipant_1.TwilioParticipant, { participant: participant, resolveIdentity: resolveIdentity }) }), participant.sid)); }) }))) : (
35
+ // When alone, show local video larger
36
+ (0, jsx_runtime_1.jsx)(material_1.Box, __assign({ sx: { height: '100%', width: '100%' } }, { children: (0, jsx_runtime_1.jsx)(TwilioParticipant_1.TwilioParticipant, { participant: localParticipant, isLocal: true, resolveIdentity: resolveIdentity }) }))), hasRemoteParticipants && ((0, jsx_runtime_1.jsx)(material_1.Box, __assign({ sx: {
37
+ position: 'absolute',
38
+ top: 16,
39
+ right: 16,
40
+ width: 200,
41
+ height: 150,
42
+ zIndex: 10,
43
+ borderRadius: 1,
44
+ overflow: 'hidden',
45
+ boxShadow: '0 2px 8px rgba(0,0,0,0.3)',
46
+ } }, { children: (0, jsx_runtime_1.jsx)(TwilioParticipant_1.TwilioParticipant, { participant: localParticipant, isLocal: true, resolveIdentity: resolveIdentity }) })))] })), (0, jsx_runtime_1.jsx)(TwilioControls_1.TwilioControlBar, { onLeave: onLeave, onEndForAll: onEndForAll })] })));
47
+ };
48
+ exports.TwilioVideoRoom = TwilioVideoRoom;
49
+ //# sourceMappingURL=TwilioVideoRoom.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TwilioVideoRoom.js","sourceRoot":"","sources":["../../../src/TwilioVideo/TwilioVideoRoom.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;AACA,0CAAyC;AACzC,2DAAqD;AACrD,yDAAuD;AACvD,mDAAmD;AAU5C,IAAM,eAAe,GAAmC,UAAC,EAK/D;QAJC,OAAO,aAAA,EACP,WAAW,iBAAA,EACX,KAAK,WAAA,EACL,eAAe,qBAAA;IAET,IAAA,KAAyB,IAAA,mCAAc,GAAE,EAAvC,IAAI,UAAA,EAAE,YAAY,kBAAqB,CAAA;IAE/C,IAAI,CAAC,IAAI;QAAE,OAAO,IAAI,CAAA;IAEtB,IAAM,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAA;IAC9C,IAAM,qBAAqB,GAAG,YAAY,CAAC,MAAM,GAAG,CAAC,CAAA;IAErD,OAAO,CACL,wBAAC,cAAG,aACF,EAAE,aACA,OAAO,EAAE,MAAM,EACf,aAAa,EAAE,QAAQ,EACvB,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,MAAM,EACb,eAAe,EAAE,SAAS,IACvB,KAAK,kBAIV,wBAAC,cAAG,aACF,EAAE,EAAE;oBACF,IAAI,EAAE,CAAC;oBACP,QAAQ,EAAE,UAAU;oBACpB,QAAQ,EAAE,QAAQ;iBACnB,iBAGA,qBAAqB,CAAC,CAAC,CAAC,CACvB,uBAAC,eAAI,aACH,SAAS,QACT,EAAE,EAAE;4BACF,MAAM,EAAE,MAAM;4BACd,KAAK,EAAE,MAAM;yBACd,gBAEA,YAAY,CAAC,GAAG,CAAC,UAAC,WAAW,IAAK,OAAA,CACjC,uBAAC,eAAI,aACH,IAAI,QAEJ,EAAE,EAAE,YAAY,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EACtC,EAAE,EAAE,EAAE,MAAM,EAAE,YAAY,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,EAAE,gBAEzD,uBAAC,qCAAiB,IAAC,WAAW,EAAE,WAAW,EAAE,eAAe,EAAE,eAAe,GAAI,KAJ5E,WAAW,CAAC,GAAG,CAKf,CACR,EATkC,CASlC,CAAC,IACG,CACR,CAAC,CAAC,CAAC;oBACF,sCAAsC;oBACtC,uBAAC,cAAG,aAAC,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,gBACxC,uBAAC,qCAAiB,IAAC,WAAW,EAAE,gBAAgB,EAAE,OAAO,QAAC,eAAe,EAAE,eAAe,GAAI,IAC1F,CACP,EAGA,qBAAqB,IAAI,CACxB,uBAAC,cAAG,aACF,EAAE,EAAE;4BACF,QAAQ,EAAE,UAAU;4BACpB,GAAG,EAAE,EAAE;4BACP,KAAK,EAAE,EAAE;4BACT,KAAK,EAAE,GAAG;4BACV,MAAM,EAAE,GAAG;4BACX,MAAM,EAAE,EAAE;4BACV,YAAY,EAAE,CAAC;4BACf,QAAQ,EAAE,QAAQ;4BAClB,SAAS,EAAE,2BAA2B;yBACvC,gBAED,uBAAC,qCAAiB,IAAC,WAAW,EAAE,gBAAgB,EAAE,OAAO,QAAC,eAAe,EAAE,eAAe,GAAI,IAC1F,CACP,KACG,EAGN,uBAAC,iCAAgB,IAAC,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,WAAW,GAAI,KAC5D,CACP,CAAA;AACH,CAAC,CAAA;AAnFY,QAAA,eAAe,mBAmF3B"}
@@ -0,0 +1,44 @@
1
+ /**
2
+ * Hook for hosts to start a Twilio Video call for a calendar event
3
+ */
4
+ export declare const useStartTwilioVideoCall: (calendarEventId?: string) => {
5
+ starting: boolean;
6
+ ending: boolean;
7
+ room: import("twilio-video").Room | null;
8
+ isConnected: boolean;
9
+ startMeeting: (eventId?: string) => Promise<string>;
10
+ endMeeting: (meetingId: string) => Promise<void>;
11
+ };
12
+ /**
13
+ * Hook for participants to join a Twilio Video call
14
+ */
15
+ export declare const useJoinTwilioVideoCall: () => {
16
+ joining: boolean;
17
+ room: import("twilio-video").Room | null;
18
+ isConnected: boolean;
19
+ joinMeeting: (calendarEventId: string) => Promise<void>;
20
+ leaveMeeting: () => void;
21
+ };
22
+ /**
23
+ * Hook for calendar event-based Twilio Video calls
24
+ * Combines start and join functionality with meeting status polling
25
+ */
26
+ export declare const useTwilioMeetingForCalendarEvent: (calendarEventId: string) => {
27
+ event: (import("@tellescope/types-models").CalendarEvent & {
28
+ id: string;
29
+ createdAt: Date;
30
+ }) | null | undefined;
31
+ meeting: (import("@tellescope/types-models").Meeting & {
32
+ id: string;
33
+ createdAt: Date;
34
+ }) | null | undefined;
35
+ room: import("twilio-video").Room | null;
36
+ isConnected: boolean;
37
+ isHost: boolean;
38
+ starting: boolean;
39
+ joining: boolean;
40
+ startAndJoinMeeting: () => Promise<void>;
41
+ joinMeeting: () => Promise<void>;
42
+ meetingStatus: "disabled" | "loading" | "waiting-room" | "joined";
43
+ };
44
+ //# sourceMappingURL=hooks.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hooks.d.ts","sourceRoot":"","sources":["../../../src/TwilioVideo/hooks.ts"],"names":[],"mappings":"AAOA;;GAEG;AACH,eAAO,MAAM,uBAAuB,qBAAsB,MAAM;;;;;6BAOZ,MAAM;4BAgCP,MAAM;CAqBxD,CAAA;AAED;;GAEG;AACH,eAAO,MAAM,sBAAsB;;;;mCAKuB,MAAM;;CA+B/D,CAAA;AAED;;;GAGG;AACH,eAAO,MAAM,gCAAgC,oBAAqB,MAAM;;;;;;;;;;;;;;;;;CAyCvE,CAAA"}
@@ -0,0 +1,232 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ var __generator = (this && this.__generator) || function (thisArg, body) {
12
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
13
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
14
+ function verb(n) { return function (v) { return step([n, v]); }; }
15
+ function step(op) {
16
+ if (f) throw new TypeError("Generator is already executing.");
17
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
18
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
19
+ if (y = 0, t) op = [op[0] & 2, t.value];
20
+ switch (op[0]) {
21
+ case 0: case 1: t = op; break;
22
+ case 4: _.label++; return { value: op[1], done: false };
23
+ case 5: _.label++; y = op[1]; op = [0]; continue;
24
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
25
+ default:
26
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
27
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
28
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
29
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
30
+ if (t[2]) _.ops.pop();
31
+ _.trys.pop(); continue;
32
+ }
33
+ op = body.call(thisArg, _);
34
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
35
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
36
+ }
37
+ };
38
+ Object.defineProperty(exports, "__esModule", { value: true });
39
+ exports.useTwilioMeetingForCalendarEvent = exports.useJoinTwilioVideoCall = exports.useStartTwilioVideoCall = void 0;
40
+ var react_1 = require("react");
41
+ var authentication_1 = require("../authentication");
42
+ var state_1 = require("../state");
43
+ var TwilioVideoContext_1 = require("./TwilioVideoContext");
44
+ /**
45
+ * Hook for hosts to start a Twilio Video call for a calendar event
46
+ */
47
+ var useStartTwilioVideoCall = function (calendarEventId) {
48
+ var session = (0, authentication_1.useSession)();
49
+ var _a = (0, TwilioVideoContext_1.useTwilioVideo)(), connect = _a.connect, disconnect = _a.disconnect, setIsHost = _a.setIsHost, room = _a.room, isConnected = _a.isConnected;
50
+ var _b = (0, state_1.useCalendarEvents)(), updateLocalEvent = _b[1].updateLocalElement;
51
+ var _c = (0, react_1.useState)(false), starting = _c[0], setStarting = _c[1];
52
+ var _d = (0, react_1.useState)(false), ending = _d[0], setEnding = _d[1];
53
+ var startMeeting = (0, react_1.useCallback)(function (eventId) { return __awaiter(void 0, void 0, void 0, function () {
54
+ var targetEventId, response, hostInfo, roomName, err_1;
55
+ return __generator(this, function (_a) {
56
+ switch (_a.label) {
57
+ case 0:
58
+ targetEventId = eventId || calendarEventId;
59
+ if (!targetEventId) {
60
+ throw new Error('No calendar event ID provided');
61
+ }
62
+ setStarting(true);
63
+ _a.label = 1;
64
+ case 1:
65
+ _a.trys.push([1, 4, 5, 6]);
66
+ return [4 /*yield*/, session.api.meetings.start_meeting_for_event({
67
+ calendarEventId: targetEventId,
68
+ })
69
+ // Update local event with meetingId
70
+ ];
71
+ case 2:
72
+ response = _a.sent();
73
+ // Update local event with meetingId
74
+ updateLocalEvent(targetEventId, { meetingId: response.id });
75
+ hostInfo = response.host.info;
76
+ roomName = response.meeting.Meeting.ExternalMeetingId || response.id;
77
+ setIsHost(true);
78
+ return [4 /*yield*/, connect(hostInfo.JoinToken, roomName)];
79
+ case 3:
80
+ _a.sent();
81
+ return [2 /*return*/, response.id];
82
+ case 4:
83
+ err_1 = _a.sent();
84
+ console.error('Failed to start Twilio meeting:', err_1);
85
+ throw err_1;
86
+ case 5:
87
+ setStarting(false);
88
+ return [7 /*endfinally*/];
89
+ case 6: return [2 /*return*/];
90
+ }
91
+ });
92
+ }); }, [session, calendarEventId, connect, setIsHost, updateLocalEvent]);
93
+ var endMeeting = (0, react_1.useCallback)(function (meetingId) { return __awaiter(void 0, void 0, void 0, function () {
94
+ var err_2;
95
+ return __generator(this, function (_a) {
96
+ switch (_a.label) {
97
+ case 0:
98
+ setEnding(true);
99
+ _a.label = 1;
100
+ case 1:
101
+ _a.trys.push([1, 3, 4, 5]);
102
+ return [4 /*yield*/, session.api.meetings.end_meeting({ id: meetingId })];
103
+ case 2:
104
+ _a.sent();
105
+ disconnect();
106
+ return [3 /*break*/, 5];
107
+ case 3:
108
+ err_2 = _a.sent();
109
+ console.error('Failed to end Twilio meeting:', err_2);
110
+ throw err_2;
111
+ case 4:
112
+ setEnding(false);
113
+ return [7 /*endfinally*/];
114
+ case 5: return [2 /*return*/];
115
+ }
116
+ });
117
+ }); }, [session, disconnect]);
118
+ return {
119
+ starting: starting,
120
+ ending: ending,
121
+ room: room,
122
+ isConnected: isConnected,
123
+ startMeeting: startMeeting,
124
+ endMeeting: endMeeting,
125
+ };
126
+ };
127
+ exports.useStartTwilioVideoCall = useStartTwilioVideoCall;
128
+ /**
129
+ * Hook for participants to join a Twilio Video call
130
+ */
131
+ var useJoinTwilioVideoCall = function () {
132
+ var session = (0, authentication_1.useResolvedSession)();
133
+ var _a = (0, TwilioVideoContext_1.useTwilioVideo)(), connect = _a.connect, disconnect = _a.disconnect, room = _a.room, isConnected = _a.isConnected;
134
+ var _b = (0, react_1.useState)(false), joining = _b[0], setJoining = _b[1];
135
+ var joinMeeting = (0, react_1.useCallback)(function (calendarEventId) { return __awaiter(void 0, void 0, void 0, function () {
136
+ var response, attendeeInfo, roomName, err_3;
137
+ return __generator(this, function (_a) {
138
+ switch (_a.label) {
139
+ case 0:
140
+ setJoining(true);
141
+ _a.label = 1;
142
+ case 1:
143
+ _a.trys.push([1, 4, 5, 6]);
144
+ return [4 /*yield*/, session.api.meetings.join_meeting_for_event({
145
+ calendarEventId: calendarEventId,
146
+ })];
147
+ case 2:
148
+ response = _a.sent();
149
+ attendeeInfo = response.attendee.info;
150
+ roomName = response.meeting.Meeting.ExternalMeetingId || response.id;
151
+ return [4 /*yield*/, connect(attendeeInfo.JoinToken, roomName)];
152
+ case 3:
153
+ _a.sent();
154
+ return [3 /*break*/, 6];
155
+ case 4:
156
+ err_3 = _a.sent();
157
+ console.error('Failed to join Twilio meeting:', err_3);
158
+ throw err_3;
159
+ case 5:
160
+ setJoining(false);
161
+ return [7 /*endfinally*/];
162
+ case 6: return [2 /*return*/];
163
+ }
164
+ });
165
+ }); }, [session, connect]);
166
+ var leaveMeeting = (0, react_1.useCallback)(function () {
167
+ disconnect();
168
+ }, [disconnect]);
169
+ return {
170
+ joining: joining,
171
+ room: room,
172
+ isConnected: isConnected,
173
+ joinMeeting: joinMeeting,
174
+ leaveMeeting: leaveMeeting,
175
+ };
176
+ };
177
+ exports.useJoinTwilioVideoCall = useJoinTwilioVideoCall;
178
+ /**
179
+ * Hook for calendar event-based Twilio Video calls
180
+ * Combines start and join functionality with meeting status polling
181
+ */
182
+ var useTwilioMeetingForCalendarEvent = function (calendarEventId) {
183
+ var session = (0, authentication_1.useResolvedSession)();
184
+ var _a = (0, TwilioVideoContext_1.useTwilioVideo)(), room = _a.room, isConnected = _a.isConnected;
185
+ var _b = (0, exports.useStartTwilioVideoCall)(calendarEventId), startMeeting = _b.startMeeting, starting = _b.starting;
186
+ var _c = (0, exports.useJoinTwilioVideoCall)(), joinMeeting = _c.joinMeeting, joining = _c.joining;
187
+ var _d = (0, state_1.useCalendarEvents)(), findEvent = _d[1].findById;
188
+ var _e = (0, state_1.useMeetings)(), findMeeting = _e[1].findById;
189
+ var event = findEvent(calendarEventId);
190
+ var meeting = (event === null || event === void 0 ? void 0 : event.meetingId) ? findMeeting(event.meetingId) : undefined;
191
+ var startAndJoinMeeting = (0, react_1.useCallback)(function () { return __awaiter(void 0, void 0, void 0, function () {
192
+ return __generator(this, function (_a) {
193
+ switch (_a.label) {
194
+ case 0: return [4 /*yield*/, startMeeting(calendarEventId)];
195
+ case 1:
196
+ _a.sent();
197
+ return [2 /*return*/];
198
+ }
199
+ });
200
+ }); }, [startMeeting, calendarEventId]);
201
+ var join = (0, react_1.useCallback)(function () { return __awaiter(void 0, void 0, void 0, function () {
202
+ return __generator(this, function (_a) {
203
+ switch (_a.label) {
204
+ case 0: return [4 /*yield*/, joinMeeting(calendarEventId)];
205
+ case 1:
206
+ _a.sent();
207
+ return [2 /*return*/];
208
+ }
209
+ });
210
+ }); }, [joinMeeting, calendarEventId]);
211
+ var isHost = session.userInfo.id === (event === null || event === void 0 ? void 0 : event.creator);
212
+ return {
213
+ event: event,
214
+ meeting: meeting,
215
+ room: room,
216
+ isConnected: isConnected,
217
+ isHost: isHost,
218
+ starting: starting,
219
+ joining: joining,
220
+ startAndJoinMeeting: startAndJoinMeeting,
221
+ joinMeeting: join,
222
+ meetingStatus: ((event === null || event === void 0 ? void 0 : event.videoIntegration) !== 'Twilio'
223
+ ? 'disabled'
224
+ : !(event === null || event === void 0 ? void 0 : event.meetingId)
225
+ ? 'waiting-room'
226
+ : isConnected
227
+ ? 'joined'
228
+ : 'loading'),
229
+ };
230
+ };
231
+ exports.useTwilioMeetingForCalendarEvent = useTwilioMeetingForCalendarEvent;
232
+ //# sourceMappingURL=hooks.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../../src/TwilioVideo/hooks.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ export { TwilioVideoProvider, useTwilioVideo, type TwilioVideoState, type TwilioVideoActions, type TwilioVideoContextType, type TwilioVideoProviderProps, } from './TwilioVideoContext';
2
+ export { useStartTwilioVideoCall, useJoinTwilioVideoCall, useTwilioMeetingForCalendarEvent, } from './hooks';
3
+ export { TwilioParticipant, type TwilioParticipantProps } from './TwilioParticipant';
4
+ export { TwilioControlBar, type TwilioControlBarProps } from './TwilioControls';
5
+ export { TwilioVideoRoom, type TwilioVideoRoomProps } from './TwilioVideoRoom';
6
+ export { TwilioLocalPreview, type TwilioLocalPreviewProps } from './TwilioLocalPreview';
7
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/TwilioVideo/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,mBAAmB,EACnB,cAAc,EACd,KAAK,gBAAgB,EACrB,KAAK,kBAAkB,EACvB,KAAK,sBAAsB,EAC3B,KAAK,wBAAwB,GAC9B,MAAM,sBAAsB,CAAA;AAE7B,OAAO,EACL,uBAAuB,EACvB,sBAAsB,EACtB,gCAAgC,GACjC,MAAM,SAAS,CAAA;AAEhB,OAAO,EAAE,iBAAiB,EAAE,KAAK,sBAAsB,EAAE,MAAM,qBAAqB,CAAA;AACpF,OAAO,EAAE,gBAAgB,EAAE,KAAK,qBAAqB,EAAE,MAAM,kBAAkB,CAAA;AAC/E,OAAO,EAAE,eAAe,EAAE,KAAK,oBAAoB,EAAE,MAAM,mBAAmB,CAAA;AAC9E,OAAO,EAAE,kBAAkB,EAAE,KAAK,uBAAuB,EAAE,MAAM,sBAAsB,CAAA"}
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TwilioLocalPreview = exports.TwilioVideoRoom = exports.TwilioControlBar = exports.TwilioParticipant = exports.useTwilioMeetingForCalendarEvent = exports.useJoinTwilioVideoCall = exports.useStartTwilioVideoCall = exports.useTwilioVideo = exports.TwilioVideoProvider = void 0;
4
+ var TwilioVideoContext_1 = require("./TwilioVideoContext");
5
+ Object.defineProperty(exports, "TwilioVideoProvider", { enumerable: true, get: function () { return TwilioVideoContext_1.TwilioVideoProvider; } });
6
+ Object.defineProperty(exports, "useTwilioVideo", { enumerable: true, get: function () { return TwilioVideoContext_1.useTwilioVideo; } });
7
+ var hooks_1 = require("./hooks");
8
+ Object.defineProperty(exports, "useStartTwilioVideoCall", { enumerable: true, get: function () { return hooks_1.useStartTwilioVideoCall; } });
9
+ Object.defineProperty(exports, "useJoinTwilioVideoCall", { enumerable: true, get: function () { return hooks_1.useJoinTwilioVideoCall; } });
10
+ Object.defineProperty(exports, "useTwilioMeetingForCalendarEvent", { enumerable: true, get: function () { return hooks_1.useTwilioMeetingForCalendarEvent; } });
11
+ var TwilioParticipant_1 = require("./TwilioParticipant");
12
+ Object.defineProperty(exports, "TwilioParticipant", { enumerable: true, get: function () { return TwilioParticipant_1.TwilioParticipant; } });
13
+ var TwilioControls_1 = require("./TwilioControls");
14
+ Object.defineProperty(exports, "TwilioControlBar", { enumerable: true, get: function () { return TwilioControls_1.TwilioControlBar; } });
15
+ var TwilioVideoRoom_1 = require("./TwilioVideoRoom");
16
+ Object.defineProperty(exports, "TwilioVideoRoom", { enumerable: true, get: function () { return TwilioVideoRoom_1.TwilioVideoRoom; } });
17
+ var TwilioLocalPreview_1 = require("./TwilioLocalPreview");
18
+ Object.defineProperty(exports, "TwilioLocalPreview", { enumerable: true, get: function () { return TwilioLocalPreview_1.TwilioLocalPreview; } });
19
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/TwilioVideo/index.ts"],"names":[],"mappings":";;;AAAA,2DAO6B;AAN3B,yHAAA,mBAAmB,OAAA;AACnB,oHAAA,cAAc,OAAA;AAOhB,iCAIgB;AAHd,gHAAA,uBAAuB,OAAA;AACvB,+GAAA,sBAAsB,OAAA;AACtB,yHAAA,gCAAgC,OAAA;AAGlC,yDAAoF;AAA3E,sHAAA,iBAAiB,OAAA;AAC1B,mDAA+E;AAAtE,kHAAA,gBAAgB,OAAA;AACzB,qDAA8E;AAArE,kHAAA,eAAe,OAAA;AACxB,2DAAuF;AAA9E,wHAAA,kBAAkB,OAAA"}
@@ -17,4 +17,5 @@ export * from "./Forms/index";
17
17
  export * from "./Community/index";
18
18
  export * from "./CMS/index";
19
19
  export * from "./Calendar/index";
20
+ export * from "./TwilioVideo/index";
20
21
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC;AAC5B,cAAc,UAAU,CAAC;AACzB,cAAc,SAAS,CAAC;AACxB,cAAc,WAAW,CAAC;AAC1B,cAAc,UAAU,CAAC;AACzB,cAAc,YAAY,CAAC;AAC3B,cAAc,UAAU,CAAC;AACzB,cAAc,iBAAiB,CAAC;AAChC,cAAc,kBAAkB,CAAA;AAChC,cAAc,SAAS,CAAA;AACvB,cAAc,OAAO,CAAA;AACrB,cAAc,SAAS,CAAC;AACxB,cAAc,SAAS,CAAA;AACvB,cAAc,YAAY,CAAA;AAC1B,cAAc,SAAS,CAAA;AACvB,cAAc,eAAe,CAAA;AAC7B,cAAc,mBAAmB,CAAA;AACjC,cAAc,aAAa,CAAA;AAC3B,cAAc,kBAAkB,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,aAAa,CAAC;AAC5B,cAAc,UAAU,CAAC;AACzB,cAAc,SAAS,CAAC;AACxB,cAAc,WAAW,CAAC;AAC1B,cAAc,UAAU,CAAC;AACzB,cAAc,YAAY,CAAC;AAC3B,cAAc,UAAU,CAAC;AACzB,cAAc,iBAAiB,CAAC;AAChC,cAAc,kBAAkB,CAAA;AAChC,cAAc,SAAS,CAAA;AACvB,cAAc,OAAO,CAAA;AACrB,cAAc,SAAS,CAAC;AACxB,cAAc,SAAS,CAAA;AACvB,cAAc,YAAY,CAAA;AAC1B,cAAc,SAAS,CAAA;AACvB,cAAc,eAAe,CAAA;AAC7B,cAAc,mBAAmB,CAAA;AACjC,cAAc,aAAa,CAAA;AAC3B,cAAc,kBAAkB,CAAA;AAChC,cAAc,qBAAqB,CAAA"}