@vendasta/meetings 0.94.0 → 0.95.2
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/esm2020/lib/_internal/interfaces/index.mjs +1 -1
- package/esm2020/lib/_internal/interfaces/meeting-guest.interface.mjs +1 -1
- package/esm2020/lib/_internal/interfaces/meeting-host.interface.mjs +1 -1
- package/esm2020/lib/_internal/interfaces/shared.interface.mjs +1 -1
- package/esm2020/lib/_internal/meeting-host.api.service.mjs +12 -2
- package/esm2020/lib/_internal/objects/index.mjs +2 -2
- package/esm2020/lib/_internal/objects/meeting-guest.mjs +1 -1
- package/esm2020/lib/_internal/objects/meeting-host.mjs +47 -1
- package/esm2020/lib/_internal/objects/shared.mjs +1 -1
- package/esm2020/lib/host/host.service.mjs +237 -128
- package/fesm2015/vendasta-meetings.mjs +274 -112
- package/fesm2015/vendasta-meetings.mjs.map +1 -1
- package/fesm2020/vendasta-meetings.mjs +285 -120
- package/fesm2020/vendasta-meetings.mjs.map +1 -1
- package/lib/_internal/interfaces/index.d.ts +1 -1
- package/lib/_internal/interfaces/meeting-host.interface.d.ts +8 -0
- package/lib/_internal/meeting-host.api.service.d.ts +4 -2
- package/lib/_internal/objects/index.d.ts +1 -1
- package/lib/_internal/objects/meeting-host.d.ts +14 -0
- package/lib/host/host.service.d.ts +22 -4
- package/package.json +1 -1
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import { Injectable } from
|
|
2
|
-
import { of } from
|
|
3
|
-
import { map, mapTo } from
|
|
4
|
-
import { ListBookedMeetingsRequestFilters, MeetingHostApiService, PagedRequestOptions, TimeRange, TimeZone } from
|
|
5
|
-
import { CalendarFromApi, getFieldMask, GroupFromApi, GroupTypeToAPi, meetingFromApi, MeetingTypeFromApi, MeetingTypeToApi, PagedResponse, PreferencesFromApi, ServiceFromApi, ServiceTypeToApi } from
|
|
6
|
-
import { getBookingUrlImplementation, getGeneralBookingUrlImplementation } from
|
|
7
|
-
import { hostUserFromApi } from
|
|
1
|
+
import { Injectable } from "@angular/core";
|
|
2
|
+
import { of } from "rxjs";
|
|
3
|
+
import { map, mapTo } from "rxjs/operators";
|
|
4
|
+
import { ListBookedMeetingsRequestFilters, MeetingHostApiService, PagedRequestOptions, TimeRange, TimeZone, } from "../_internal";
|
|
5
|
+
import { CalendarFromApi, getFieldMask, GroupFromApi, GroupTypeToAPi, meetingFromApi, MeetingTypeFromApi, MeetingTypeToApi, PagedResponse, PreferencesFromApi, ServiceFromApi, ServiceTypeToApi, } from "../shared";
|
|
6
|
+
import { getBookingUrlImplementation, getGeneralBookingUrlImplementation, } from "./url";
|
|
7
|
+
import { hostUserFromApi } from "../shared/host-user";
|
|
8
8
|
import { Environment, onProductionGlobal } from "../shared/environment";
|
|
9
9
|
import * as i0 from "@angular/core";
|
|
10
10
|
import * as i1 from "../_internal";
|
|
@@ -14,57 +14,75 @@ export class HostService {
|
|
|
14
14
|
}
|
|
15
15
|
// Use buildHostId to get an identifier that can be used in subsequent requests. See vendastaapis for more details
|
|
16
16
|
buildHostId(req) {
|
|
17
|
-
return this.hostAPIService
|
|
17
|
+
return this.hostAPIService
|
|
18
|
+
.buildHostId({
|
|
18
19
|
userId: req.userId,
|
|
19
20
|
// Gross typecast exists because I want to restrict the properties on the map (for now).
|
|
20
|
-
applicationContextProperties: req.applicationContextProperties
|
|
21
|
-
})
|
|
21
|
+
applicationContextProperties: req.applicationContextProperties,
|
|
22
|
+
})
|
|
23
|
+
.pipe(map((res) => res.hostId || ""));
|
|
22
24
|
}
|
|
23
25
|
doesCalendarExist(calendarIdentifier) {
|
|
24
|
-
return this.hostAPIService
|
|
26
|
+
return this.hostAPIService
|
|
27
|
+
.doesCalendarExist({ calendarIdentifier: calendarIdentifier })
|
|
28
|
+
.pipe(map((resp) => resp.exists));
|
|
25
29
|
}
|
|
26
30
|
getCalendar(req) {
|
|
27
|
-
return this.hostAPIService
|
|
31
|
+
return this.hostAPIService
|
|
32
|
+
.getCalendar({ calendarId: req.calendarId })
|
|
33
|
+
.pipe(map((res) => CalendarFromApi(res?.calendar)));
|
|
28
34
|
}
|
|
29
35
|
ensurePersonalCalendarExists(req) {
|
|
30
|
-
return this.hostAPIService
|
|
36
|
+
return this.hostAPIService
|
|
37
|
+
.ensurePersonalCalendarExists({
|
|
31
38
|
userId: req.userId,
|
|
32
39
|
applicationContextProperties: req.applicationContextProperties,
|
|
33
|
-
})
|
|
40
|
+
})
|
|
41
|
+
.pipe(map((res) => (res ? res.calendarId : "")));
|
|
34
42
|
}
|
|
35
43
|
ensureGroupCalendarsExist(req) {
|
|
36
|
-
return this.hostAPIService
|
|
44
|
+
return this.hostAPIService
|
|
45
|
+
.ensureGroupCalendarsExist({ externalIds: req.externalIds })
|
|
46
|
+
.pipe(map((res) => res?.calendarIds || []));
|
|
37
47
|
}
|
|
38
48
|
/*
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
49
|
+
createCalendar creates a calendar which meeting types can be created for and events can be booked on
|
|
50
|
+
The fields of a calendar are documented in https://github.com/vendasta/vendastaapis/blob/master/meetings/v1/shared.proto
|
|
51
|
+
*/
|
|
42
52
|
createCalendar(req) {
|
|
43
53
|
return this.hostAPIService.createCalendar(req);
|
|
44
54
|
}
|
|
45
55
|
updateCalendarSlug(calendarId, newSlug) {
|
|
46
|
-
return this.hostAPIService
|
|
56
|
+
return this.hostAPIService
|
|
57
|
+
.updateCalendar({
|
|
47
58
|
calendarId: calendarId,
|
|
48
59
|
calendarUpdate: { slug: newSlug },
|
|
49
|
-
fieldMask: { paths: [
|
|
50
|
-
})
|
|
60
|
+
fieldMask: { paths: ["slug"] },
|
|
61
|
+
})
|
|
62
|
+
.pipe(mapTo(undefined));
|
|
51
63
|
}
|
|
52
64
|
updateCalendarHostUserIDs(calendarId, replacementHostUserIds) {
|
|
53
|
-
return this.hostAPIService
|
|
65
|
+
return this.hostAPIService
|
|
66
|
+
.updateCalendar({
|
|
54
67
|
calendarId: calendarId,
|
|
55
68
|
calendarUpdate: { hostUserIds: replacementHostUserIds },
|
|
56
|
-
fieldMask: { paths: [
|
|
57
|
-
})
|
|
69
|
+
fieldMask: { paths: ["host_user_ids"] },
|
|
70
|
+
})
|
|
71
|
+
.pipe(mapTo(undefined));
|
|
58
72
|
}
|
|
59
73
|
getMeetingTypesForCalendars(req) {
|
|
60
|
-
return this.hostAPIService
|
|
74
|
+
return this.hostAPIService
|
|
75
|
+
.getMeetingTypesForCalendars({ calendarIds: req.calendarIds })
|
|
76
|
+
.pipe(map((res) => {
|
|
61
77
|
if (!res?.calendarMeetingTypesMap) {
|
|
62
78
|
return {};
|
|
63
79
|
}
|
|
64
80
|
return Object.keys(res.calendarMeetingTypesMap).reduce((calendarToMeetingTypeMap, calendarId) => {
|
|
65
|
-
const meetingTypes = (res.calendarMeetingTypesMap[calendarId]?.meetingTypes || []).map(mt => MeetingTypeFromApi({
|
|
81
|
+
const meetingTypes = (res.calendarMeetingTypesMap[calendarId]?.meetingTypes || []).map((mt) => MeetingTypeFromApi({
|
|
66
82
|
meetingTypeApi: mt,
|
|
67
|
-
environment: onProductionGlobal()
|
|
83
|
+
environment: onProductionGlobal()
|
|
84
|
+
? Environment.PROD
|
|
85
|
+
: Environment.DEMO,
|
|
68
86
|
calendarId,
|
|
69
87
|
metadata: req.metadata,
|
|
70
88
|
}));
|
|
@@ -76,22 +94,24 @@ export class HostService {
|
|
|
76
94
|
}));
|
|
77
95
|
}
|
|
78
96
|
/*
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
97
|
+
listMeetingTypes returns a list of meeting types for a host
|
|
98
|
+
@param hostId: An identifier for an individual host
|
|
99
|
+
@param metadata: optional metadata to include on the meeting type booking link
|
|
100
|
+
@param calendarSlug: used to replace hostId in the url. Use it when you are confident you know the host's slug.
|
|
101
|
+
- calendarSlug IS NOT USED TO RETRIEVE MEETING TYPES, ONLY TO MAKE THE BOOKING URLS
|
|
102
|
+
*/
|
|
85
103
|
listMeetingTypes(req) {
|
|
86
|
-
return this.hostAPIService.listMeetingTypes(req).pipe(map(resp => {
|
|
104
|
+
return this.hostAPIService.listMeetingTypes(req).pipe(map((resp) => {
|
|
87
105
|
if (!resp || !resp.meetingTypes) {
|
|
88
106
|
return [];
|
|
89
107
|
}
|
|
90
|
-
return resp.meetingTypes.map(mt => {
|
|
108
|
+
return resp.meetingTypes.map((mt) => {
|
|
91
109
|
return MeetingTypeFromApi({
|
|
92
110
|
meetingTypeApi: mt,
|
|
93
111
|
calendarId: req.hostId,
|
|
94
|
-
environment: onProductionGlobal()
|
|
112
|
+
environment: onProductionGlobal()
|
|
113
|
+
? Environment.PROD
|
|
114
|
+
: Environment.DEMO,
|
|
95
115
|
metadata: req.metadata,
|
|
96
116
|
calendarSlug: req.calendarSlug,
|
|
97
117
|
});
|
|
@@ -99,15 +119,15 @@ export class HostService {
|
|
|
99
119
|
}));
|
|
100
120
|
}
|
|
101
121
|
/*
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
122
|
+
getBookingUrl returns a link that can be used to book a meeting with this host.
|
|
123
|
+
@param calendarId: An identifier for an individual host or grouping of hosts (i.e., team).
|
|
124
|
+
@param @deprecated hostId: An identifier for an individual host.
|
|
125
|
+
@param meetingTypeId: An optional identifier for the meeting type. Default: 30-minutes.
|
|
126
|
+
@param metadata: optional metadata to include in the url.
|
|
127
|
+
- metadata can be used to pre-fill certain form fields and will be stored during the booking process.
|
|
128
|
+
- metadata can be obtained by subscribing to the booking event.
|
|
129
|
+
@param calendarSlug: used to replace hostId in the url. Use it when you are confident you know the host's slug.
|
|
130
|
+
*/
|
|
111
131
|
getBookingUrl(req) {
|
|
112
132
|
return of(getBookingUrlImplementation({
|
|
113
133
|
...req,
|
|
@@ -117,13 +137,13 @@ export class HostService {
|
|
|
117
137
|
}));
|
|
118
138
|
}
|
|
119
139
|
/*
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
140
|
+
getGeneralBookingUrl returns a link that can be used to select a meeting type to book with the given calendar.
|
|
141
|
+
@param calendarId: An identifier for an individual host or grouping of hosts (i.e., team).
|
|
142
|
+
@param metadata: optional metadata to include in the url.
|
|
143
|
+
- metadata can be used to pre-fill certain form fields and will be stored during the booking process.
|
|
144
|
+
- metadata can be obtained by subscribing to the booking event.
|
|
145
|
+
@param calendarSlug: used to replace hostId in the url. Use it when you are confident you know the host's slug.
|
|
146
|
+
*/
|
|
127
147
|
getGeneralBookingUrl(req) {
|
|
128
148
|
return of(getGeneralBookingUrlImplementation({
|
|
129
149
|
environment: onProductionGlobal() ? Environment.PROD : Environment.DEMO,
|
|
@@ -133,14 +153,14 @@ export class HostService {
|
|
|
133
153
|
}));
|
|
134
154
|
}
|
|
135
155
|
/*
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
156
|
+
getBookingUrlsMulti returns a mapping of hosts -> event types -> booking links.
|
|
157
|
+
@param calendarId: An identifier for an individual host or grouping of hosts.
|
|
158
|
+
@param meetingTypeSlug: meetingTypeSlugs are passed in the form {hostId: [meetingTypeSlug1, meetingTypeSlug2]}
|
|
159
|
+
@param metadata: optional metadata to include in the url.
|
|
160
|
+
- metadata can be used to pre-fill certain form fields and will be stored during the booking process.
|
|
161
|
+
- metadata can be obtained by subscribing to the booking event.
|
|
162
|
+
@param calendarSlug: used to replace hostId in the url. Use it when you are confident you know the host's slug.
|
|
163
|
+
*/
|
|
144
164
|
getBookingUrlsMulti(req, metadata, calendarSlug) {
|
|
145
165
|
return of(Object.keys(req).reduce((hostMap, calendarId) => {
|
|
146
166
|
return {
|
|
@@ -152,16 +172,20 @@ export class HostService {
|
|
|
152
172
|
calendarId,
|
|
153
173
|
meetingTypeSlug,
|
|
154
174
|
metadata,
|
|
155
|
-
environment: onProductionGlobal()
|
|
175
|
+
environment: onProductionGlobal()
|
|
176
|
+
? Environment.PROD
|
|
177
|
+
: Environment.DEMO,
|
|
156
178
|
calendarSlug,
|
|
157
|
-
})
|
|
179
|
+
}),
|
|
158
180
|
};
|
|
159
|
-
}, {})
|
|
181
|
+
}, {}),
|
|
160
182
|
};
|
|
161
183
|
}, {}));
|
|
162
184
|
}
|
|
163
185
|
isHostConfigured(req) {
|
|
164
|
-
return this.hostAPIService
|
|
186
|
+
return this.hostAPIService
|
|
187
|
+
.isHostConfigured(req)
|
|
188
|
+
.pipe(map((resp) => resp.isConfigured));
|
|
165
189
|
}
|
|
166
190
|
setGeneralAvailability(req) {
|
|
167
191
|
const apiReq = {
|
|
@@ -174,32 +198,43 @@ export class HostService {
|
|
|
174
198
|
return this.hostAPIService.setGeneralAvailability(apiReq).pipe(mapTo(null));
|
|
175
199
|
}
|
|
176
200
|
listBookedMeetings(req) {
|
|
177
|
-
return this.hostAPIService
|
|
201
|
+
return this.hostAPIService
|
|
202
|
+
.listBookedMeetings({
|
|
178
203
|
...req,
|
|
179
|
-
pagingOptions: new PagedRequestOptions({
|
|
204
|
+
pagingOptions: new PagedRequestOptions({
|
|
205
|
+
cursor: req.cursor,
|
|
206
|
+
pageSize: req.pageSize,
|
|
207
|
+
}),
|
|
180
208
|
filters: new ListBookedMeetingsRequestFilters(req.filters),
|
|
181
209
|
timeZone: new TimeZone(req.timeZone),
|
|
182
|
-
})
|
|
183
|
-
|
|
210
|
+
})
|
|
211
|
+
.pipe(map((resp) => {
|
|
212
|
+
const meetings = (resp.meetings || []).map((meeting) => meetingFromApi(meeting));
|
|
184
213
|
return new PagedResponse(meetings, resp.pagingMetadata.nextCursor, resp.pagingMetadata.hasMore);
|
|
185
214
|
}));
|
|
186
215
|
}
|
|
187
216
|
cancelMeeting(req) {
|
|
188
|
-
return this.hostAPIService
|
|
189
|
-
|
|
190
|
-
|
|
217
|
+
return this.hostAPIService
|
|
218
|
+
.cancelMeeting({
|
|
219
|
+
...req,
|
|
220
|
+
})
|
|
221
|
+
.pipe(mapTo(null));
|
|
191
222
|
}
|
|
192
223
|
rescheduleMeeting(req) {
|
|
193
|
-
return this.hostAPIService
|
|
194
|
-
|
|
195
|
-
|
|
224
|
+
return this.hostAPIService
|
|
225
|
+
.rescheduleMeeting({
|
|
226
|
+
...req,
|
|
227
|
+
})
|
|
228
|
+
.pipe(mapTo(null));
|
|
196
229
|
}
|
|
197
230
|
listAvailability(req) {
|
|
198
|
-
return this.hostAPIService.listAvailability(req).pipe(map(response => {
|
|
199
|
-
const results = (response.availabilityRules || [])
|
|
231
|
+
return this.hostAPIService.listAvailability(req).pipe(map((response) => {
|
|
232
|
+
const results = (response.availabilityRules || [])
|
|
233
|
+
.filter(Boolean)
|
|
234
|
+
.map((a) => {
|
|
200
235
|
return {
|
|
201
|
-
hostId: a.hostId ||
|
|
202
|
-
meetingTypeId: a.meetingTypeId ||
|
|
236
|
+
hostId: a.hostId || "",
|
|
237
|
+
meetingTypeId: a.meetingTypeId || "",
|
|
203
238
|
day: a.day,
|
|
204
239
|
timeSlot: a.timeSlot,
|
|
205
240
|
timeZone: a.timeZone,
|
|
@@ -224,51 +259,77 @@ export class HostService {
|
|
|
224
259
|
* `Preferences` is an error.
|
|
225
260
|
*/
|
|
226
261
|
updatePreferences(req) {
|
|
227
|
-
const fieldMask = getFieldMask({
|
|
262
|
+
const fieldMask = getFieldMask({
|
|
263
|
+
o: req.preferences,
|
|
264
|
+
updateFields: req.updateFields,
|
|
265
|
+
});
|
|
228
266
|
if (fieldMask.paths.length === 0) {
|
|
229
267
|
return of();
|
|
230
268
|
}
|
|
231
|
-
return this.hostAPIService
|
|
269
|
+
return this.hostAPIService
|
|
270
|
+
.updateHostPreferences({
|
|
232
271
|
hostId: req.hostId,
|
|
233
272
|
preferences: req.preferences,
|
|
234
273
|
fieldMask,
|
|
235
|
-
})
|
|
274
|
+
})
|
|
275
|
+
.pipe(mapTo(undefined));
|
|
236
276
|
}
|
|
237
277
|
getPreferences(req) {
|
|
238
|
-
return this.hostAPIService
|
|
239
|
-
|
|
240
|
-
|
|
278
|
+
return this.hostAPIService
|
|
279
|
+
.getHostPreferences({
|
|
280
|
+
hostId: req.hostId,
|
|
281
|
+
})
|
|
282
|
+
.pipe(map((response) => PreferencesFromApi(response.preferences)));
|
|
241
283
|
}
|
|
242
284
|
getMeeting(meetingId, location) {
|
|
243
|
-
return this.hostAPIService
|
|
244
|
-
|
|
245
|
-
|
|
285
|
+
return this.hostAPIService
|
|
286
|
+
.getHostMeeting({
|
|
287
|
+
meetingId: meetingId,
|
|
288
|
+
location: location,
|
|
289
|
+
})
|
|
290
|
+
.pipe(map((resp) => meetingFromApi(resp.meeting)));
|
|
246
291
|
}
|
|
247
292
|
updateMeetingMetadata(req) {
|
|
248
|
-
return this.hostAPIService
|
|
293
|
+
return this.hostAPIService
|
|
294
|
+
.updateMeetingMetadata({
|
|
249
295
|
meetingId: req.meetingId,
|
|
250
|
-
metadata: req.metadata
|
|
251
|
-
})
|
|
296
|
+
metadata: req.metadata,
|
|
297
|
+
})
|
|
298
|
+
.pipe(mapTo(undefined));
|
|
299
|
+
}
|
|
300
|
+
hostBookMeeting(req) {
|
|
301
|
+
return this.hostAPIService.hostBookMeeting({
|
|
302
|
+
...req,
|
|
303
|
+
attendees: req.attendees,
|
|
304
|
+
});
|
|
252
305
|
}
|
|
253
306
|
bookMeeting(req) {
|
|
254
|
-
return this.hostAPIService
|
|
307
|
+
return this.hostAPIService
|
|
308
|
+
.bookMeeting(req)
|
|
309
|
+
.pipe(map((resp) => resp.meetingId));
|
|
255
310
|
}
|
|
256
311
|
// createDefaultMeetingTypes will create what Meeting Scheduler deems to be the default meeting types.
|
|
257
312
|
// If the calendar already has meeting types, this is guaranteed to be a no-op.
|
|
258
313
|
createDefaultMeetingTypes(req) {
|
|
259
|
-
return this.hostAPIService
|
|
314
|
+
return this.hostAPIService
|
|
315
|
+
.createDefaultMeetingTypes({ calendarIds: req.calendarIds })
|
|
316
|
+
.pipe(mapTo(undefined));
|
|
260
317
|
}
|
|
261
318
|
createMeetingType(req) {
|
|
262
|
-
const fieldMask = getFieldMask({
|
|
319
|
+
const fieldMask = getFieldMask({
|
|
320
|
+
o: req.meetingType,
|
|
321
|
+
updateFields: req.updateFields,
|
|
322
|
+
});
|
|
263
323
|
if (fieldMask.paths.length === 0) {
|
|
264
324
|
return of();
|
|
265
325
|
}
|
|
266
|
-
return this.hostAPIService
|
|
326
|
+
return this.hostAPIService
|
|
327
|
+
.createMeetingType({
|
|
267
328
|
meetingType: MeetingTypeToApi({ meetingType: req.meetingType }),
|
|
268
329
|
fieldMask,
|
|
269
|
-
hostId: req.HostId
|
|
330
|
+
hostId: req.HostId,
|
|
270
331
|
})
|
|
271
|
-
.pipe(map(res => res.id));
|
|
332
|
+
.pipe(map((res) => res.id));
|
|
272
333
|
}
|
|
273
334
|
/* updateMeetingType will update the meeting type fields.
|
|
274
335
|
* It is guaranteed to only update the fields provided.
|
|
@@ -286,23 +347,32 @@ export class HostService {
|
|
|
286
347
|
* `MeetingType` is an error.
|
|
287
348
|
*/
|
|
288
349
|
updateMeetingType(req) {
|
|
289
|
-
const fieldMask = getFieldMask({
|
|
350
|
+
const fieldMask = getFieldMask({
|
|
351
|
+
o: req.meetingType,
|
|
352
|
+
updateFields: req.updateFields,
|
|
353
|
+
});
|
|
290
354
|
if (fieldMask.paths.length === 0) {
|
|
291
355
|
return of();
|
|
292
356
|
}
|
|
293
|
-
return this.hostAPIService
|
|
357
|
+
return this.hostAPIService
|
|
358
|
+
.updateMeetingType({
|
|
294
359
|
id: req.id,
|
|
295
360
|
meetingType: MeetingTypeToApi({ meetingType: req.meetingType }),
|
|
296
361
|
fieldMask,
|
|
297
|
-
hostId: req.HostId
|
|
298
|
-
})
|
|
362
|
+
hostId: req.HostId,
|
|
363
|
+
})
|
|
364
|
+
.pipe(mapTo(undefined));
|
|
299
365
|
}
|
|
300
366
|
deleteMeetingType(req) {
|
|
301
|
-
return this.hostAPIService
|
|
367
|
+
return this.hostAPIService
|
|
368
|
+
.deleteMeetingType({ id: req.id })
|
|
369
|
+
.pipe(mapTo(undefined));
|
|
302
370
|
}
|
|
303
371
|
getHostsForCalendar(req) {
|
|
304
|
-
return this.hostAPIService
|
|
305
|
-
|
|
372
|
+
return this.hostAPIService
|
|
373
|
+
.getHostsForCalendar({ calendarId: req.calendarId })
|
|
374
|
+
.pipe(map((res) => {
|
|
375
|
+
return (res.hostUsers || []).map((hostuser) => {
|
|
306
376
|
return hostUserFromApi(hostuser);
|
|
307
377
|
});
|
|
308
378
|
}));
|
|
@@ -314,71 +384,105 @@ export class HostService {
|
|
|
314
384
|
return this.hostAPIService.sendMeetingRequestEmail(req);
|
|
315
385
|
}
|
|
316
386
|
createService(req) {
|
|
317
|
-
const fieldMask = getFieldMask({
|
|
387
|
+
const fieldMask = getFieldMask({
|
|
388
|
+
o: req.service,
|
|
389
|
+
updateFields: req.updateFields,
|
|
390
|
+
});
|
|
318
391
|
if (fieldMask.paths.length === 0) {
|
|
319
392
|
return of();
|
|
320
393
|
}
|
|
321
|
-
return this.hostAPIService
|
|
394
|
+
return this.hostAPIService
|
|
395
|
+
.createService({
|
|
322
396
|
service: ServiceTypeToApi({ service: req.service }),
|
|
323
397
|
fieldMask,
|
|
324
|
-
hostId: req.HostId
|
|
325
|
-
})
|
|
398
|
+
hostId: req.HostId,
|
|
399
|
+
})
|
|
400
|
+
.pipe(map((res) => res.id));
|
|
326
401
|
}
|
|
327
402
|
updateService(req) {
|
|
328
|
-
const fieldMask = getFieldMask({
|
|
403
|
+
const fieldMask = getFieldMask({
|
|
404
|
+
o: req.service,
|
|
405
|
+
updateFields: req.updateFields,
|
|
406
|
+
});
|
|
329
407
|
if (fieldMask.paths.length === 0) {
|
|
330
408
|
return of();
|
|
331
409
|
}
|
|
332
|
-
return this.hostAPIService
|
|
410
|
+
return this.hostAPIService
|
|
411
|
+
.updateService({
|
|
333
412
|
id: req.id,
|
|
334
413
|
service: ServiceTypeToApi({ service: req.service }),
|
|
335
414
|
fieldMask,
|
|
336
|
-
hostId: req.HostId
|
|
337
|
-
})
|
|
415
|
+
hostId: req.HostId,
|
|
416
|
+
})
|
|
417
|
+
.pipe(mapTo(undefined));
|
|
338
418
|
}
|
|
339
419
|
deleteService(req) {
|
|
340
|
-
return this.hostAPIService
|
|
420
|
+
return this.hostAPIService
|
|
421
|
+
.deleteService({ id: req.id, hostId: req.hostId })
|
|
422
|
+
.pipe(mapTo(undefined));
|
|
341
423
|
}
|
|
342
424
|
listServices(req) {
|
|
343
|
-
return this.hostAPIService.listServices({ hostId: req.hostId }).pipe(map(res => {
|
|
425
|
+
return this.hostAPIService.listServices({ hostId: req.hostId }).pipe(map((res) => {
|
|
344
426
|
if (!res || !res.services) {
|
|
345
427
|
return [];
|
|
346
428
|
}
|
|
347
|
-
return res.services.map(service => ServiceFromApi({
|
|
429
|
+
return res.services.map((service) => ServiceFromApi({
|
|
430
|
+
serviceApi: service,
|
|
431
|
+
environment: onProductionGlobal()
|
|
432
|
+
? Environment.PROD
|
|
433
|
+
: Environment.DEMO,
|
|
434
|
+
}));
|
|
348
435
|
}));
|
|
349
436
|
}
|
|
350
437
|
createGroup(req) {
|
|
351
|
-
const fieldMask = getFieldMask({
|
|
438
|
+
const fieldMask = getFieldMask({
|
|
439
|
+
o: req.group,
|
|
440
|
+
updateFields: req.updateFields,
|
|
441
|
+
});
|
|
352
442
|
if (fieldMask.paths.length === 0) {
|
|
353
443
|
return of();
|
|
354
444
|
}
|
|
355
|
-
return this.hostAPIService
|
|
445
|
+
return this.hostAPIService
|
|
446
|
+
.createGroup({
|
|
356
447
|
group: GroupTypeToAPi({ group: req.group }),
|
|
357
448
|
fieldMask,
|
|
358
|
-
hostId: req.HostId
|
|
359
|
-
})
|
|
449
|
+
hostId: req.HostId,
|
|
450
|
+
})
|
|
451
|
+
.pipe(map((res) => res.id));
|
|
360
452
|
}
|
|
361
453
|
updateGroup(req) {
|
|
362
|
-
const fieldMask = getFieldMask({
|
|
454
|
+
const fieldMask = getFieldMask({
|
|
455
|
+
o: req.group,
|
|
456
|
+
updateFields: req.updateFields,
|
|
457
|
+
});
|
|
363
458
|
if (fieldMask.paths.length === 0) {
|
|
364
459
|
return of();
|
|
365
460
|
}
|
|
366
|
-
return this.hostAPIService
|
|
461
|
+
return this.hostAPIService
|
|
462
|
+
.updateGroup({
|
|
367
463
|
id: req.id,
|
|
368
464
|
group: GroupTypeToAPi({ group: req.group }),
|
|
369
465
|
fieldMask,
|
|
370
|
-
hostId: req.HostId
|
|
371
|
-
})
|
|
466
|
+
hostId: req.HostId,
|
|
467
|
+
})
|
|
468
|
+
.pipe(mapTo(undefined));
|
|
372
469
|
}
|
|
373
470
|
deleteGroup(req) {
|
|
374
|
-
return this.hostAPIService
|
|
471
|
+
return this.hostAPIService
|
|
472
|
+
.deleteGroup({ id: req.id, hostId: req.hostId })
|
|
473
|
+
.pipe(mapTo(undefined));
|
|
375
474
|
}
|
|
376
475
|
listGroups(req) {
|
|
377
|
-
return this.hostAPIService.listGroups({ hostId: req.hostId }).pipe(map(res => {
|
|
476
|
+
return this.hostAPIService.listGroups({ hostId: req.hostId }).pipe(map((res) => {
|
|
378
477
|
if (!res || !res.groups) {
|
|
379
478
|
return [];
|
|
380
479
|
}
|
|
381
|
-
return res.groups.map(group => GroupFromApi({
|
|
480
|
+
return res.groups.map((group) => GroupFromApi({
|
|
481
|
+
groupApi: group,
|
|
482
|
+
environment: onProductionGlobal()
|
|
483
|
+
? Environment.PROD
|
|
484
|
+
: Environment.DEMO,
|
|
485
|
+
}));
|
|
382
486
|
}));
|
|
383
487
|
}
|
|
384
488
|
getGroup(req) {
|
|
@@ -387,11 +491,16 @@ export class HostService {
|
|
|
387
491
|
getService(req) {
|
|
388
492
|
return this.hostAPIService.getService(req);
|
|
389
493
|
}
|
|
494
|
+
checkGroupOrServiceSlugExist(req) {
|
|
495
|
+
return this.hostAPIService
|
|
496
|
+
.checkGroupOrServiceSlugExist(req)
|
|
497
|
+
.pipe(map((res) => res.exists));
|
|
498
|
+
}
|
|
390
499
|
}
|
|
391
500
|
HostService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: HostService, deps: [{ token: i1.MeetingHostApiService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
392
|
-
HostService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: HostService, providedIn:
|
|
501
|
+
HostService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: HostService, providedIn: "root" });
|
|
393
502
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.3", ngImport: i0, type: HostService, decorators: [{
|
|
394
503
|
type: Injectable,
|
|
395
|
-
args: [{ providedIn:
|
|
504
|
+
args: [{ providedIn: "root" }]
|
|
396
505
|
}], ctorParameters: function () { return [{ type: i1.MeetingHostApiService }]; } });
|
|
397
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"host.service.js","sourceRoot":"","sources":["../../../../../meetings_sdk/src/lib/host/host.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Inject, Injectable} from '@angular/core';\nimport {Observable, of} from 'rxjs';\nimport {map, mapTo} from 'rxjs/operators';\nimport {\n    CreateCalendarRequestInterface,\n    CreateCalendarResponse,\n    DayOfWeek, GetGroupResponse,\n    GetHostMeetingResponse, GetServiceResponse,\n    HostBookMeetingRequestInterface,\n    HostBookMeetingResponse, IsCalendarConfiguredRequestInterface, IsCalendarConfiguredResponse,\n    IsHostConfiguredResponse,\n    ListAvailabilityRequestFiltersInterface,\n    ListBookedMeetingsRequestFilters,\n    ListBookedMeetingsRequestFiltersInterface,\n    ListBookedMeetingsResponse,\n    MeetingHostApiService,\n    PagedRequestOptions,\n    PagedRequestOptionsInterface, SendMeetingRequestEmailRequestInterface,\n    TimeRange,\n    TimeRangeInterface,\n    TimeZone,\n    TimeZoneInterface,\n    WeekdayAvailability\n} from '../_internal';\nimport {\n    ApplicationContextPropertiesSet,\n    AvailabilityRule,\n    Calendar,\n    CalendarFromApi,\n    getFieldMask, Group, GroupFromApi, GroupTypeToAPi,\n    HostUrlMap,\n    Meeting,\n    meetingFromApi,\n    MeetingMetadata,\n    MeetingType,\n    MeetingTypeFromApi,\n    MeetingTypeToApi,\n    PagedResponse,\n    Preferences,\n    PreferencesFromApi, Service, ServiceFromApi, ServiceTypeToApi\n} from '../shared';\nimport {getBookingUrlImplementation, getGeneralBookingUrlImplementation} from './url';\nimport {HostUser, hostUserFromApi} from '../shared/host-user'\nimport {Environment, onProductionGlobal} from \"../shared/environment\";\nimport { HttpResponse} from \"@angular/common/http\";\n\n\n@Injectable({providedIn: 'root'})\nexport class HostService {\n    constructor(\n        private hostAPIService: MeetingHostApiService,\n    ) {\n    }\n\n    // Use buildHostId to get an identifier that can be used in subsequent requests. See vendastaapis for more details\n    buildHostId(req: { userId: string, applicationContextProperties: ApplicationContextPropertiesSet }): Observable<string> {\n        return this.hostAPIService.buildHostId({\n                userId: req.userId,\n                // Gross typecast exists because I want to restrict the properties on the map (for now).\n                applicationContextProperties: req.applicationContextProperties as any as { [key: string]: string }\n            }\n        ).pipe(map(res => res.hostId || ''));\n    }\n\n    doesCalendarExist(calendarIdentifier: string): Observable<boolean> {\n        return this.hostAPIService.doesCalendarExist({calendarIdentifier: calendarIdentifier}).pipe(\n            map(resp => resp.exists)\n        );\n    }\n\n    getCalendar(req: { calendarId: string }): Observable<Calendar> {\n        return this.hostAPIService.getCalendar({calendarId: req.calendarId}).pipe(\n            map(res => CalendarFromApi(res?.calendar))\n        );\n    }\n\n    ensurePersonalCalendarExists(req: {\n        userId: string,\n        applicationContextProperties: ApplicationContextPropertiesSet\n    }): Observable<string> {\n        return this.hostAPIService.ensurePersonalCalendarExists({\n            userId: req.userId,\n            applicationContextProperties: req.applicationContextProperties as any as { [key: string]: string },\n        }).pipe(map(res => res ? res.calendarId : ''));\n    }\n\n    ensureGroupCalendarsExist(req: { externalIds: string[] }): Observable<string[]> {\n        return this.hostAPIService.ensureGroupCalendarsExist({externalIds: req.externalIds}).pipe(\n            map(res => res?.calendarIds || [])\n        );\n    }\n\n    /*\n     createCalendar creates a calendar which meeting types can be created for and events can be booked on\n     The fields of a calendar are documented in https://github.com/vendasta/vendastaapis/blob/master/meetings/v1/shared.proto\n    */\n    createCalendar(req: CreateCalendarRequestInterface): Observable<CreateCalendarResponse> {\n        return this.hostAPIService.createCalendar(req);\n    }\n\n    updateCalendarSlug(calendarId: string, newSlug: string): Observable<void> {\n        return this.hostAPIService.updateCalendar({\n            calendarId: calendarId,\n            calendarUpdate: {slug: newSlug},\n            fieldMask: {paths: ['slug']},\n        }).pipe(mapTo(undefined));\n    }\n\n    updateCalendarHostUserIDs(calendarId: string, replacementHostUserIds: string[]): Observable<void> {\n        return this.hostAPIService.updateCalendar({\n            calendarId: calendarId,\n            calendarUpdate: {hostUserIds: replacementHostUserIds},\n            fieldMask: {paths: ['host_user_ids']},\n        }).pipe(mapTo(undefined));\n    }\n\n    getMeetingTypesForCalendars(req: {\n        calendarIds: string[],\n        metadata: { [name: string]: string }\n    }): Observable<{ [calendarId: string]: MeetingType[] }> {\n        return this.hostAPIService.getMeetingTypesForCalendars({calendarIds: req.calendarIds}).pipe(\n            map(res => {\n                if (!res?.calendarMeetingTypesMap) {\n                    return {};\n                }\n                return Object.keys(res.calendarMeetingTypesMap).reduce((calendarToMeetingTypeMap, calendarId) => {\n                    const meetingTypes = (res.calendarMeetingTypesMap[calendarId]?.meetingTypes || []).map(mt => MeetingTypeFromApi({\n                        meetingTypeApi: mt,\n                        environment: onProductionGlobal() ? Environment.PROD : Environment.DEMO,\n                        calendarId,\n                        metadata: req.metadata,\n                    }));\n                    return {\n                        ...calendarToMeetingTypeMap,\n                        [calendarId]: meetingTypes,\n                    };\n                }, {} as { [calendarId: string]: MeetingType[] })\n            })\n        )\n    }\n\n    /*\n     listMeetingTypes returns a list of meeting types for a host\n     @param hostId: An identifier for an individual host\n     @param metadata: optional metadata to include on the meeting type booking link\n     @param calendarSlug: used to replace hostId in the url. Use it when you are confident you know the host's slug.\n        - calendarSlug IS NOT USED TO RETRIEVE MEETING TYPES, ONLY TO MAKE THE BOOKING URLS\n    */\n    listMeetingTypes(req: {\n        hostId: string,\n        metadata?: { [name: string]: string }\n        calendarSlug?: string,\n    }): Observable<MeetingType[]> {\n        return this.hostAPIService.listMeetingTypes(req).pipe(\n            map(resp => {\n                if (!resp || !resp.meetingTypes) {\n                    return [];\n                }\n                return resp.meetingTypes.map(mt => {\n                    return MeetingTypeFromApi({\n                        meetingTypeApi: mt,\n                        calendarId: req.hostId,\n                        environment: onProductionGlobal() ? Environment.PROD : Environment.DEMO,\n                        metadata: req.metadata,\n                        calendarSlug: req.calendarSlug,\n                    });\n                });\n            })\n        )\n    }\n\n    /*\n     getBookingUrl returns a link that can be used to book a meeting with this host.\n     @param calendarId: An identifier for an individual host or grouping of hosts (i.e., team).\n     @param @deprecated hostId: An identifier for an individual host.\n     @param meetingTypeId: An optional identifier for the meeting type. Default: 30-minutes.\n     @param metadata: optional metadata to include in the url.\n     - metadata can be used to pre-fill certain form fields and will be stored during the booking process.\n     - metadata can be obtained by subscribing to the booking event.\n    @param calendarSlug: used to replace hostId in the url. Use it when you are confident you know the host's slug.\n     */\n    getBookingUrl(\n        req: {\n            // @deprecated: use calendarId instead. calendarId not required to avoid breaking existing clients.\n            hostId: string,\n            calendarId?: string,\n            // @deprecated: use meetingTypeSlug instead\n            meetingTypeId?: string,\n            meetingTypeSlug?: string,\n            metadata?: { [name: string]: string },\n            calendarSlug?: string,\n        }): Observable<string> {\n        return of(getBookingUrlImplementation({\n                ...req,\n                calendarId: req.calendarId || req.hostId,\n                environment: onProductionGlobal() ? Environment.PROD : Environment.DEMO,\n                calendarSlug: req.calendarSlug,\n            })\n        );\n    }\n\n    /*\n     getGeneralBookingUrl returns a link that can be used to select a meeting type to book with the given calendar.\n     @param calendarId: An identifier for an individual host or grouping of hosts (i.e., team).\n     @param metadata: optional metadata to include in the url.\n     - metadata can be used to pre-fill certain form fields and will be stored during the booking process.\n     - metadata can be obtained by subscribing to the booking event.\n     @param calendarSlug: used to replace hostId in the url. Use it when you are confident you know the host's slug.\n     */\n    getGeneralBookingUrl(req: {\n        calendarId: string,\n        metadata?: { [name: string]: string },\n        calendarSlug?: string,\n    }): Observable<string> {\n        return of(getGeneralBookingUrlImplementation({\n            environment: onProductionGlobal() ? Environment.PROD : Environment.DEMO,\n            calendarId: req.calendarId,\n            metadata: req.metadata,\n            calendarSlug: req.calendarSlug,\n        }))\n    }\n\n    /*\n     getBookingUrlsMulti returns a mapping of hosts -> event types -> booking links.\n     @param calendarId: An identifier for an individual host or grouping of hosts.\n     @param meetingTypeSlug: meetingTypeSlugs are passed in the form {hostId: [meetingTypeSlug1, meetingTypeSlug2]}\n     @param metadata: optional metadata to include in the url.\n     - metadata can be used to pre-fill certain form fields and will be stored during the booking process.\n     - metadata can be obtained by subscribing to the booking event.\n     @param calendarSlug: used to replace hostId in the url. Use it when you are confident you know the host's slug.\n     */\n    getBookingUrlsMulti(\n        req: { [calendarId: string]: string[] },\n        metadata?: { [name: string]: string },\n        calendarSlug?: string\n    ): Observable<HostUrlMap> {\n        return of(Object.keys(req).reduce((hostMap, calendarId) => {\n            return {\n                ...hostMap,\n                [calendarId]: req[calendarId].reduce((meetingTypeMap, meetingTypeSlug) => {\n                    return {\n                        ...meetingTypeMap,\n                        [meetingTypeSlug]: getBookingUrlImplementation({\n                            calendarId,\n                            meetingTypeSlug,\n                            metadata,\n                            environment: onProductionGlobal() ? Environment.PROD : Environment.DEMO,\n                            calendarSlug,\n                        })\n                    };\n                }, {} as { [meetingTypeId: string]: string })\n            };\n        }, {} as HostUrlMap));\n    }\n\n    isHostConfigured(req: { hostId: string }): Observable<boolean> {\n        return this.hostAPIService.isHostConfigured(req).pipe(\n            map((resp: IsHostConfiguredResponse) => resp.isConfigured)\n        );\n    }\n\n    setGeneralAvailability(req: {\n        hostId: string,\n        meetingTypeId: string,\n        // @deprecated: use weekdaysAvailability instead\n        days?: DayOfWeek[],\n        // @deprecated: use weekdaysAvailability instead\n        timeSlot?: TimeRangeInterface,\n        weekdaysAvailability?: WeekdayAvailability[],\n        timeZone: TimeZoneInterface,\n    }): Observable<null> {\n        const apiReq = {\n            ...req,\n            timeZone: new TimeZone(req.timeZone),\n        }\n        if (req.timeSlot) {\n            apiReq.timeSlot = new TimeRange(req.timeSlot)\n        }\n        return this.hostAPIService.setGeneralAvailability(apiReq).pipe(mapTo(null))\n    }\n\n    listBookedMeetings(req: {\n        filters: ListBookedMeetingsRequestFiltersInterface,\n        cursor: string,\n        pageSize: number,\n        timeZone: TimeZoneInterface,\n    }): Observable<PagedResponse<Meeting>> {\n        return this.hostAPIService.listBookedMeetings({\n            ...req,\n            pagingOptions: new PagedRequestOptions({cursor: req.cursor, pageSize: req.pageSize}),\n            filters: new ListBookedMeetingsRequestFilters(req.filters),\n            timeZone: new TimeZone(req.timeZone),\n        }).pipe(\n            map((resp: ListBookedMeetingsResponse) => {\n                const meetings = (resp.meetings || []).map(meeting => meetingFromApi(meeting));\n                return new PagedResponse(meetings, resp.pagingMetadata.nextCursor, resp.pagingMetadata.hasMore);\n            }),\n        );\n    }\n\n    cancelMeeting(req: {\n        meetingId: string,\n        cancellationReason: string\n    }): Observable<null> {\n        return this.hostAPIService.cancelMeeting({\n            ...req\n        }).pipe(mapTo(null))\n    }\n\n    rescheduleMeeting(req: {\n        meetingId: string,\n        start: Date\n    }): Observable<null> {\n        return this.hostAPIService.rescheduleMeeting({\n            ...req\n        }).pipe(mapTo(null))\n    }\n\n    listAvailability(req: {\n        filters: ListAvailabilityRequestFiltersInterface,\n        pagingOptions: PagedRequestOptionsInterface,\n        timeZone: TimeZoneInterface,\n    }): Observable<PagedResponse<AvailabilityRule>> {\n        return this.hostAPIService.listAvailability(req).pipe(\n            map(response => {\n                const results = (response.availabilityRules || []).filter(Boolean).map(a => {\n                    return {\n                        hostId: a.hostId || '',\n                        meetingTypeId: a.meetingTypeId || '',\n                        day: a.day,\n                        timeSlot: a.timeSlot,\n                        timeZone: a.timeZone,\n                    }\n                });\n                return new PagedResponse(results, response.metadata.nextCursor, response.metadata.hasMore);\n            })\n        )\n    }\n\n    /* updatePreferences will update the host's preferences.\n     * It is guaranteed to only update the fields provided.\n     * For example:\n     *  updatePreferences({meetingIntegration: MeetingSource.MEETING_SOURCE_GOOGLE_MEET})\n     *  will only update the preference meetingIntegration to Google Meet. Keeping the other preferences the same.\n     *\n     * Alternatively, you can provide a list of keys to update as the second argument.\n     * For example:\n     *   updatePreferences({...object with all fields}, ['meetingIntegration'])\n     *   will only update the field 'meetingIntegration' to the value in preferences.\n     *\n     * Calling with an empty object and no keys is a no-op, or an undefined object.\n     * Calling with an object containing fields not in `Preferences` or with updateFields not linked to properties in\n     * `Preferences` is an error.\n     */\n    updatePreferences(req: { hostId: string, preferences: Partial<Preferences>, updateFields?: (keyof Preferences)[] }): Observable<void> {\n        const fieldMask = getFieldMask({o: req.preferences, updateFields: req.updateFields});\n        if (fieldMask.paths.length === 0) {\n            return of();\n        }\n        return this.hostAPIService.updateHostPreferences({\n            hostId: req.hostId,\n            preferences: req.preferences,\n            fieldMask,\n        }).pipe(mapTo(undefined));\n    }\n\n    getPreferences(req: { hostId: string }): Observable<Preferences> {\n        return this.hostAPIService.getHostPreferences({\n            hostId: req.hostId\n        }).pipe(map(response => PreferencesFromApi(response.preferences)))\n    }\n\n    getMeeting(meetingId: string, location: string): Observable<Meeting> {\n        return this.hostAPIService.getHostMeeting({\n            meetingId: meetingId, location: location,\n        }).pipe(\n            map((resp: GetHostMeetingResponse) => meetingFromApi(resp.meeting))\n        )\n    }\n\n    updateMeetingMetadata(req: { meetingId: string, metadata: MeetingMetadata }): Observable<void> {\n        return this.hostAPIService.updateMeetingMetadata({\n            meetingId: req.meetingId,\n            metadata: req.metadata\n        }).pipe(mapTo(undefined));\n    }\n\n    bookMeeting(req: HostBookMeetingRequestInterface): Observable<string> {\n        return this.hostAPIService.bookMeeting(req).pipe(map((resp: HostBookMeetingResponse) => resp.meetingId));\n    }\n\n    // createDefaultMeetingTypes will create what Meeting Scheduler deems to be the default meeting types.\n    // If the calendar already has meeting types, this is guaranteed to be a no-op.\n    createDefaultMeetingTypes(req: { calendarIds: string[], }): Observable<void> {\n        return this.hostAPIService.createDefaultMeetingTypes({calendarIds: req.calendarIds}).pipe(mapTo(undefined));\n    }\n\n    createMeetingType(req: { meetingType: MeetingType, updateFields?: (keyof MeetingType)[], HostId?: string }): Observable<string> {\n        const fieldMask = getFieldMask({o: req.meetingType, updateFields: req.updateFields});\n        if (fieldMask.paths.length === 0) {\n            return of();\n        }\n        return this.hostAPIService.createMeetingType({\n            meetingType: MeetingTypeToApi({meetingType: req.meetingType}),\n            fieldMask,\n            hostId: req.HostId})\n            .pipe(map(res => res.id));\n    }\n\n    /* updateMeetingType will update the meeting type fields.\n     * It is guaranteed to only update the fields provided.\n     * For example:\n     *  updateMeetingType({name: 'Onboarding'})\n     *  will only update the field 'name' to 'Onboarding'. Keeping the other fields the same.\n     *\n     * Alternatively, you can provide a list of keys to update as the second argument.\n     * For example:\n     *   updateMeetingType({...object with all fields}, ['name'])\n     *   will only update the field 'name' to the value passed in.\n     *\n     * Calling with an empty object and no keys is a no-op, or an undefined object.\n     * Calling with an object containing fields not in `MeetingType` or with updateFields not linked to properties in\n     * `MeetingType` is an error.\n     */\n    updateMeetingType(req: { id: string, meetingType: Partial<MeetingType>, updateFields?: (keyof MeetingType)[], HostId?: string }): Observable<void> {\n        const fieldMask = getFieldMask({o: req.meetingType, updateFields: req.updateFields});\n        if (fieldMask.paths.length === 0) {\n            return of();\n        }\n        return this.hostAPIService.updateMeetingType({\n            id: req.id,\n            meetingType: MeetingTypeToApi({meetingType: req.meetingType}),\n            fieldMask,\n            hostId: req.HostId\n        }).pipe(mapTo(undefined));\n    }\n\n    deleteMeetingType(req: { id: string }): Observable<void> {\n        return this.hostAPIService.deleteMeetingType({id: req.id}).pipe(mapTo(undefined));\n    }\n\n    getHostsForCalendar(req: { calendarId: string }): Observable<HostUser[]> {\n        return this.hostAPIService.getHostsForCalendar({calendarId: req.calendarId}).pipe(\n            map(res => {\n                return (res.hostUsers || []).map(hostuser => {\n                    return hostUserFromApi(hostuser)\n                })\n            })\n        )\n    }\n\n    IsCalendarConfigured(req: IsCalendarConfiguredRequestInterface): Observable<IsCalendarConfiguredResponse> {\n        return this.hostAPIService.isCalendarConfigured(req);\n    }\n\n    sendMeetingRequestEmail(req: SendMeetingRequestEmailRequestInterface): Observable<HttpResponse<null>> {\n        return this.hostAPIService.sendMeetingRequestEmail(req);\n    }\n\n    createService(req: { service: Service, updateFields?: (keyof Service)[], HostId?: string }): Observable<string> {\n        const fieldMask = getFieldMask({o: req.service, updateFields: req.updateFields});\n        if (fieldMask.paths.length === 0) {\n            return of();\n        }\n        return this.hostAPIService.createService({\n            service: ServiceTypeToApi({service: req.service}),\n            fieldMask,\n            hostId: req.HostId\n        }).pipe(map(res => res.id))\n    }\n\n    updateService(req: {\n        id: string,\n        service: Partial<Service>,\n        updateFields?: (keyof Service)[],\n        HostId?: string\n    }): Observable<void> {\n        const fieldMask = getFieldMask({o: req.service, updateFields: req.updateFields});\n        if (fieldMask.paths.length === 0) {\n            return of();\n        }\n        return this.hostAPIService.updateService({\n            id: req.id,\n            service: ServiceTypeToApi({service: req.service}),\n            fieldMask,\n            hostId: req.HostId\n        }).pipe(mapTo(undefined));\n    }\n\n    deleteService(req: { id: string,hostId: string }): Observable<void> {\n        return this.hostAPIService.deleteService({id: req.id,hostId: req.hostId}).pipe(mapTo(undefined));\n    }\n\n    listServices( req: { hostId: string }): Observable<Service[]> {\n        return this.hostAPIService.listServices({hostId: req.hostId}).pipe(\n            map(res => {\n                if (!res || !res.services) {\n                    return [];\n                }\n                return res.services.map(service => ServiceFromApi({serviceApi: service,environment: onProductionGlobal() ? Environment.PROD : Environment.DEMO}))\n            })\n        )\n    }\n\n    createGroup(req: { group: Group, updateFields?: (keyof Group)[], HostId?: string }): Observable<string> {\n        const fieldMask = getFieldMask({o: req.group, updateFields: req.updateFields});\n        if (fieldMask.paths.length === 0) {\n            return of();\n        }\n        return this.hostAPIService.createGroup({\n            group: GroupTypeToAPi({group: req.group}),\n            fieldMask,\n            hostId: req.HostId\n        }).pipe(map(res => res.id))\n    }\n\n    updateGroup(req: {\n        id: string,\n        group: Partial<Group>,\n        updateFields?: (keyof Group)[],\n        HostId?: string\n    }): Observable<void> {\n        const fieldMask = getFieldMask({o: req.group, updateFields: req.updateFields});\n        if (fieldMask.paths.length === 0) {\n            return of();\n        }\n        return this.hostAPIService.updateGroup({\n            id: req.id,\n            group: GroupTypeToAPi({group: req.group}),\n            fieldMask,\n            hostId: req.HostId\n        }).pipe(mapTo(undefined));\n    }\n\n    deleteGroup(req: { id: string, hostId: string }): Observable<void> {\n        return this.hostAPIService.deleteGroup({id: req.id,hostId: req.hostId}).pipe(mapTo(undefined));\n    }\n\n    listGroups( req: { hostId: string }): Observable<Group[]> {\n        return this.hostAPIService.listGroups({hostId: req.hostId}).pipe(\n            map(res => {\n                if (!res || !res.groups) {\n                    return [];\n                }\n                return res.groups.map(group => GroupFromApi({groupApi: group,environment: onProductionGlobal() ? Environment.PROD : Environment.DEMO}))\n            })\n        )\n    }\n\n    getGroup(req: { groupId: string,slug: string,hostId: string }): Observable<GetGroupResponse> {\n        return this.hostAPIService.getGroup(req);\n    }\n    getService(req: { serviceId: string,slug: string,hostId: string  }): Observable<GetServiceResponse> {\n        return this.hostAPIService.getService(req);\n    }\n\n\n}\n\n\n\n"]}
|
|
506
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"host.service.js","sourceRoot":"","sources":["../../../../../meetings_sdk/src/lib/host/host.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from \"@angular/core\";\nimport { Observable, of } from \"rxjs\";\nimport { map, mapTo } from \"rxjs/operators\";\nimport {\n  CheckGroupOrServiceSlugExistResponse,\n  CreateCalendarRequestInterface,\n  CreateCalendarResponse,\n  DayOfWeek,\n  GetGroupResponse,\n  GetHostMeetingResponse,\n  GetServiceResponse,\n  HostBookMeetingRequestInterface,\n  HostBookMeetingResponse,\n  IsCalendarConfiguredRequestInterface,\n  IsCalendarConfiguredResponse,\n  IsHostConfiguredResponse,\n  ListAvailabilityRequestFiltersInterface,\n  ListBookedMeetingsRequestFilters,\n  ListBookedMeetingsRequestFiltersInterface,\n  ListBookedMeetingsResponse,\n  MeetingHostApiService,\n  PagedRequestOptions,\n  PagedRequestOptionsInterface,\n  SendMeetingRequestEmailRequestInterface,\n  TimeRange,\n  TimeRangeInterface,\n  TimeZone,\n  TimeZoneInterface,\n  WeekdayAvailability,\n  Contact,\n\n} from \"../_internal\";\n\nimport { BookMeetingResponse } from '../guest';\n\nimport {\n  ApplicationContextPropertiesSet,\n  AvailabilityRule,\n  Calendar,\n  CalendarFromApi,\n  getFieldMask,\n  Group,\n  GroupFromApi,\n  GroupTypeToAPi,\n  HostUrlMap,\n  Meeting,\n  meetingFromApi,\n  MeetingMetadata,\n  MeetingType,\n  MeetingTypeFromApi,\n  MeetingTypeToApi,\n  PagedResponse,\n  Preferences,\n  PreferencesFromApi,\n  Service,\n  ServiceFromApi,\n  ServiceTypeToApi,\n} from \"../shared\";\nimport {\n  getBookingUrlImplementation,\n  getGeneralBookingUrlImplementation,\n} from \"./url\";\nimport { HostUser, hostUserFromApi } from \"../shared/host-user\";\nimport { Environment, onProductionGlobal } from \"../shared/environment\";\nimport { HttpResponse } from \"@angular/common/http\";\n\n@Injectable({ providedIn: \"root\" })\nexport class HostService {\n  constructor(private hostAPIService: MeetingHostApiService) {}\n\n  // Use buildHostId to get an identifier that can be used in subsequent requests. See vendastaapis for more details\n  buildHostId(req: {\n    userId: string;\n    applicationContextProperties: ApplicationContextPropertiesSet;\n  }): Observable<string> {\n    return this.hostAPIService\n      .buildHostId({\n        userId: req.userId,\n        // Gross typecast exists because I want to restrict the properties on the map (for now).\n        applicationContextProperties:\n          req.applicationContextProperties as any as { [key: string]: string },\n      })\n      .pipe(map((res) => res.hostId || \"\"));\n  }\n\n  doesCalendarExist(calendarIdentifier: string): Observable<boolean> {\n    return this.hostAPIService\n      .doesCalendarExist({ calendarIdentifier: calendarIdentifier })\n      .pipe(map((resp) => resp.exists));\n  }\n\n  getCalendar(req: { calendarId: string }): Observable<Calendar> {\n    return this.hostAPIService\n      .getCalendar({ calendarId: req.calendarId })\n      .pipe(map((res) => CalendarFromApi(res?.calendar)));\n  }\n\n  ensurePersonalCalendarExists(req: {\n    userId: string;\n    applicationContextProperties: ApplicationContextPropertiesSet;\n  }): Observable<string> {\n    return this.hostAPIService\n      .ensurePersonalCalendarExists({\n        userId: req.userId,\n        applicationContextProperties:\n          req.applicationContextProperties as any as { [key: string]: string },\n      })\n      .pipe(map((res) => (res ? res.calendarId : \"\")));\n  }\n\n  ensureGroupCalendarsExist(req: {\n    externalIds: string[];\n  }): Observable<string[]> {\n    return this.hostAPIService\n      .ensureGroupCalendarsExist({ externalIds: req.externalIds })\n      .pipe(map((res) => res?.calendarIds || []));\n  }\n\n  /*\n     createCalendar creates a calendar which meeting types can be created for and events can be booked on\n     The fields of a calendar are documented in https://github.com/vendasta/vendastaapis/blob/master/meetings/v1/shared.proto\n    */\n  createCalendar(\n    req: CreateCalendarRequestInterface\n  ): Observable<CreateCalendarResponse> {\n    return this.hostAPIService.createCalendar(req);\n  }\n\n  updateCalendarSlug(calendarId: string, newSlug: string): Observable<void> {\n    return this.hostAPIService\n      .updateCalendar({\n        calendarId: calendarId,\n        calendarUpdate: { slug: newSlug },\n        fieldMask: { paths: [\"slug\"] },\n      })\n      .pipe(mapTo(undefined));\n  }\n\n  updateCalendarHostUserIDs(\n    calendarId: string,\n    replacementHostUserIds: string[]\n  ): Observable<void> {\n    return this.hostAPIService\n      .updateCalendar({\n        calendarId: calendarId,\n        calendarUpdate: { hostUserIds: replacementHostUserIds },\n        fieldMask: { paths: [\"host_user_ids\"] },\n      })\n      .pipe(mapTo(undefined));\n  }\n\n  getMeetingTypesForCalendars(req: {\n    calendarIds: string[];\n    metadata: { [name: string]: string };\n  }): Observable<{ [calendarId: string]: MeetingType[] }> {\n    return this.hostAPIService\n      .getMeetingTypesForCalendars({ calendarIds: req.calendarIds })\n      .pipe(\n        map((res) => {\n          if (!res?.calendarMeetingTypesMap) {\n            return {};\n          }\n          return Object.keys(res.calendarMeetingTypesMap).reduce(\n            (calendarToMeetingTypeMap, calendarId) => {\n              const meetingTypes = (\n                res.calendarMeetingTypesMap[calendarId]?.meetingTypes || []\n              ).map((mt) =>\n                MeetingTypeFromApi({\n                  meetingTypeApi: mt,\n                  environment: onProductionGlobal()\n                    ? Environment.PROD\n                    : Environment.DEMO,\n                  calendarId,\n                  metadata: req.metadata,\n                })\n              );\n              return {\n                ...calendarToMeetingTypeMap,\n                [calendarId]: meetingTypes,\n              };\n            },\n            {} as { [calendarId: string]: MeetingType[] }\n          );\n        })\n      );\n  }\n\n  /*\n     listMeetingTypes returns a list of meeting types for a host\n     @param hostId: An identifier for an individual host\n     @param metadata: optional metadata to include on the meeting type booking link\n     @param calendarSlug: used to replace hostId in the url. Use it when you are confident you know the host's slug.\n        - calendarSlug IS NOT USED TO RETRIEVE MEETING TYPES, ONLY TO MAKE THE BOOKING URLS\n    */\n  listMeetingTypes(req: {\n    hostId: string;\n    metadata?: { [name: string]: string };\n    calendarSlug?: string;\n  }): Observable<MeetingType[]> {\n    return this.hostAPIService.listMeetingTypes(req).pipe(\n      map((resp) => {\n        if (!resp || !resp.meetingTypes) {\n          return [];\n        }\n        return resp.meetingTypes.map((mt) => {\n          return MeetingTypeFromApi({\n            meetingTypeApi: mt,\n            calendarId: req.hostId,\n            environment: onProductionGlobal()\n              ? Environment.PROD\n              : Environment.DEMO,\n            metadata: req.metadata,\n            calendarSlug: req.calendarSlug,\n          });\n        });\n      })\n    );\n  }\n\n  /*\n     getBookingUrl returns a link that can be used to book a meeting with this host.\n     @param calendarId: An identifier for an individual host or grouping of hosts (i.e., team).\n     @param @deprecated hostId: An identifier for an individual host.\n     @param meetingTypeId: An optional identifier for the meeting type. Default: 30-minutes.\n     @param metadata: optional metadata to include in the url.\n     - metadata can be used to pre-fill certain form fields and will be stored during the booking process.\n     - metadata can be obtained by subscribing to the booking event.\n    @param calendarSlug: used to replace hostId in the url. Use it when you are confident you know the host's slug.\n     */\n  getBookingUrl(req: {\n    // @deprecated: use calendarId instead. calendarId not required to avoid breaking existing clients.\n    hostId: string;\n    calendarId?: string;\n    // @deprecated: use meetingTypeSlug instead\n    meetingTypeId?: string;\n    meetingTypeSlug?: string;\n    metadata?: { [name: string]: string };\n    calendarSlug?: string;\n  }): Observable<string> {\n    return of(\n      getBookingUrlImplementation({\n        ...req,\n        calendarId: req.calendarId || req.hostId,\n        environment: onProductionGlobal() ? Environment.PROD : Environment.DEMO,\n        calendarSlug: req.calendarSlug,\n      })\n    );\n  }\n\n  /*\n     getGeneralBookingUrl returns a link that can be used to select a meeting type to book with the given calendar.\n     @param calendarId: An identifier for an individual host or grouping of hosts (i.e., team).\n     @param metadata: optional metadata to include in the url.\n     - metadata can be used to pre-fill certain form fields and will be stored during the booking process.\n     - metadata can be obtained by subscribing to the booking event.\n     @param calendarSlug: used to replace hostId in the url. Use it when you are confident you know the host's slug.\n     */\n  getGeneralBookingUrl(req: {\n    calendarId: string;\n    metadata?: { [name: string]: string };\n    calendarSlug?: string;\n  }): Observable<string> {\n    return of(\n      getGeneralBookingUrlImplementation({\n        environment: onProductionGlobal() ? Environment.PROD : Environment.DEMO,\n        calendarId: req.calendarId,\n        metadata: req.metadata,\n        calendarSlug: req.calendarSlug,\n      })\n    );\n  }\n\n  /*\n     getBookingUrlsMulti returns a mapping of hosts -> event types -> booking links.\n     @param calendarId: An identifier for an individual host or grouping of hosts.\n     @param meetingTypeSlug: meetingTypeSlugs are passed in the form {hostId: [meetingTypeSlug1, meetingTypeSlug2]}\n     @param metadata: optional metadata to include in the url.\n     - metadata can be used to pre-fill certain form fields and will be stored during the booking process.\n     - metadata can be obtained by subscribing to the booking event.\n     @param calendarSlug: used to replace hostId in the url. Use it when you are confident you know the host's slug.\n     */\n  getBookingUrlsMulti(\n    req: { [calendarId: string]: string[] },\n    metadata?: { [name: string]: string },\n    calendarSlug?: string\n  ): Observable<HostUrlMap> {\n    return of(\n      Object.keys(req).reduce((hostMap, calendarId) => {\n        return {\n          ...hostMap,\n          [calendarId]: req[calendarId].reduce(\n            (meetingTypeMap, meetingTypeSlug) => {\n              return {\n                ...meetingTypeMap,\n                [meetingTypeSlug]: getBookingUrlImplementation({\n                  calendarId,\n                  meetingTypeSlug,\n                  metadata,\n                  environment: onProductionGlobal()\n                    ? Environment.PROD\n                    : Environment.DEMO,\n                  calendarSlug,\n                }),\n              };\n            },\n            {} as { [meetingTypeId: string]: string }\n          ),\n        };\n      }, {} as HostUrlMap)\n    );\n  }\n\n  isHostConfigured(req: { hostId: string }): Observable<boolean> {\n    return this.hostAPIService\n      .isHostConfigured(req)\n      .pipe(map((resp: IsHostConfiguredResponse) => resp.isConfigured));\n  }\n\n  setGeneralAvailability(req: {\n    hostId: string;\n    meetingTypeId: string;\n    // @deprecated: use weekdaysAvailability instead\n    days?: DayOfWeek[];\n    // @deprecated: use weekdaysAvailability instead\n    timeSlot?: TimeRangeInterface;\n    weekdaysAvailability?: WeekdayAvailability[];\n    timeZone: TimeZoneInterface;\n  }): Observable<null> {\n    const apiReq = {\n      ...req,\n      timeZone: new TimeZone(req.timeZone),\n    };\n    if (req.timeSlot) {\n      apiReq.timeSlot = new TimeRange(req.timeSlot);\n    }\n    return this.hostAPIService.setGeneralAvailability(apiReq).pipe(mapTo(null));\n  }\n\n  listBookedMeetings(req: {\n    filters: ListBookedMeetingsRequestFiltersInterface;\n    cursor: string;\n    pageSize: number;\n    timeZone: TimeZoneInterface;\n  }): Observable<PagedResponse<Meeting>> {\n    return this.hostAPIService\n      .listBookedMeetings({\n        ...req,\n        pagingOptions: new PagedRequestOptions({\n          cursor: req.cursor,\n          pageSize: req.pageSize,\n        }),\n        filters: new ListBookedMeetingsRequestFilters(req.filters),\n        timeZone: new TimeZone(req.timeZone),\n      })\n      .pipe(\n        map((resp: ListBookedMeetingsResponse) => {\n          const meetings = (resp.meetings || []).map((meeting) =>\n            meetingFromApi(meeting)\n          );\n          return new PagedResponse(\n            meetings,\n            resp.pagingMetadata.nextCursor,\n            resp.pagingMetadata.hasMore\n          );\n        })\n      );\n  }\n\n  cancelMeeting(req: {\n    meetingId: string;\n    cancellationReason: string;\n  }): Observable<null> {\n    return this.hostAPIService\n      .cancelMeeting({\n        ...req,\n      })\n      .pipe(mapTo(null));\n  }\n\n  rescheduleMeeting(req: { meetingId: string; start: Date }): Observable<null> {\n    return this.hostAPIService\n      .rescheduleMeeting({\n        ...req,\n      })\n      .pipe(mapTo(null));\n  }\n\n  listAvailability(req: {\n    filters: ListAvailabilityRequestFiltersInterface;\n    pagingOptions: PagedRequestOptionsInterface;\n    timeZone: TimeZoneInterface;\n  }): Observable<PagedResponse<AvailabilityRule>> {\n    return this.hostAPIService.listAvailability(req).pipe(\n      map((response) => {\n        const results = (response.availabilityRules || [])\n          .filter(Boolean)\n          .map((a) => {\n            return {\n              hostId: a.hostId || \"\",\n              meetingTypeId: a.meetingTypeId || \"\",\n              day: a.day,\n              timeSlot: a.timeSlot,\n              timeZone: a.timeZone,\n            };\n          });\n        return new PagedResponse(\n          results,\n          response.metadata.nextCursor,\n          response.metadata.hasMore\n        );\n      })\n    );\n  }\n\n  /* updatePreferences will update the host's preferences.\n   * It is guaranteed to only update the fields provided.\n   * For example:\n   *  updatePreferences({meetingIntegration: MeetingSource.MEETING_SOURCE_GOOGLE_MEET})\n   *  will only update the preference meetingIntegration to Google Meet. Keeping the other preferences the same.\n   *\n   * Alternatively, you can provide a list of keys to update as the second argument.\n   * For example:\n   *   updatePreferences({...object with all fields}, ['meetingIntegration'])\n   *   will only update the field 'meetingIntegration' to the value in preferences.\n   *\n   * Calling with an empty object and no keys is a no-op, or an undefined object.\n   * Calling with an object containing fields not in `Preferences` or with updateFields not linked to properties in\n   * `Preferences` is an error.\n   */\n  updatePreferences(req: {\n    hostId: string;\n    preferences: Partial<Preferences>;\n    updateFields?: (keyof Preferences)[];\n  }): Observable<void> {\n    const fieldMask = getFieldMask({\n      o: req.preferences,\n      updateFields: req.updateFields,\n    });\n    if (fieldMask.paths.length === 0) {\n      return of();\n    }\n    return this.hostAPIService\n      .updateHostPreferences({\n        hostId: req.hostId,\n        preferences: req.preferences,\n        fieldMask,\n      })\n      .pipe(mapTo(undefined));\n  }\n\n  getPreferences(req: { hostId: string }): Observable<Preferences> {\n    return this.hostAPIService\n      .getHostPreferences({\n        hostId: req.hostId,\n      })\n      .pipe(map((response) => PreferencesFromApi(response.preferences)));\n  }\n\n  getMeeting(meetingId: string, location: string): Observable<Meeting> {\n    return this.hostAPIService\n      .getHostMeeting({\n        meetingId: meetingId,\n        location: location,\n      })\n      .pipe(\n        map((resp: GetHostMeetingResponse) => meetingFromApi(resp.meeting))\n      );\n  }\n\n  updateMeetingMetadata(req: {\n    meetingId: string;\n    metadata: MeetingMetadata;\n  }): Observable<void> {\n    return this.hostAPIService\n      .updateMeetingMetadata({\n        meetingId: req.meetingId,\n        metadata: req.metadata,\n      })\n      .pipe(mapTo(undefined));\n  }\n\n  hostBookMeeting(req: {\n    hostId: string,\n    meetingTypeId: string,\n    start: Date,\n    comment: string,\n    metadata?: MeetingMetadata,\n    attendees: (Omit<Contact, 'fromProto' | 'toApiJson' | 'constructor' | 'timeZone'> & { timeZone: TimeZoneInterface })[],\n    location?: string,\n    userId?: string,\n  }): Observable<BookMeetingResponse> {\n    return this.hostAPIService.hostBookMeeting({\n      ...req,\n      attendees: req.attendees,\n    });\n  }\n\n  bookMeeting(req: HostBookMeetingRequestInterface): Observable<string> {\n    return this.hostAPIService\n      .bookMeeting(req)\n      .pipe(map((resp: HostBookMeetingResponse) => resp.meetingId));\n  }\n\n  // createDefaultMeetingTypes will create what Meeting Scheduler deems to be the default meeting types.\n  // If the calendar already has meeting types, this is guaranteed to be a no-op.\n  createDefaultMeetingTypes(req: { calendarIds: string[] }): Observable<void> {\n    return this.hostAPIService\n      .createDefaultMeetingTypes({ calendarIds: req.calendarIds })\n      .pipe(mapTo(undefined));\n  }\n\n  createMeetingType(req: {\n    meetingType: MeetingType;\n    updateFields?: (keyof MeetingType)[];\n    HostId?: string;\n  }): Observable<string> {\n    const fieldMask = getFieldMask({\n      o: req.meetingType,\n      updateFields: req.updateFields,\n    });\n    if (fieldMask.paths.length === 0) {\n      return of();\n    }\n    return this.hostAPIService\n      .createMeetingType({\n        meetingType: MeetingTypeToApi({ meetingType: req.meetingType }),\n        fieldMask,\n        hostId: req.HostId,\n      })\n      .pipe(map((res) => res.id));\n  }\n\n  /* updateMeetingType will update the meeting type fields.\n   * It is guaranteed to only update the fields provided.\n   * For example:\n   *  updateMeetingType({name: 'Onboarding'})\n   *  will only update the field 'name' to 'Onboarding'. Keeping the other fields the same.\n   *\n   * Alternatively, you can provide a list of keys to update as the second argument.\n   * For example:\n   *   updateMeetingType({...object with all fields}, ['name'])\n   *   will only update the field 'name' to the value passed in.\n   *\n   * Calling with an empty object and no keys is a no-op, or an undefined object.\n   * Calling with an object containing fields not in `MeetingType` or with updateFields not linked to properties in\n   * `MeetingType` is an error.\n   */\n  updateMeetingType(req: {\n    id: string;\n    meetingType: Partial<MeetingType>;\n    updateFields?: (keyof MeetingType)[];\n    HostId?: string;\n  }): Observable<void> {\n    const fieldMask = getFieldMask({\n      o: req.meetingType,\n      updateFields: req.updateFields,\n    });\n    if (fieldMask.paths.length === 0) {\n      return of();\n    }\n    return this.hostAPIService\n      .updateMeetingType({\n        id: req.id,\n        meetingType: MeetingTypeToApi({ meetingType: req.meetingType }),\n        fieldMask,\n        hostId: req.HostId,\n      })\n      .pipe(mapTo(undefined));\n  }\n\n  deleteMeetingType(req: { id: string }): Observable<void> {\n    return this.hostAPIService\n      .deleteMeetingType({ id: req.id })\n      .pipe(mapTo(undefined));\n  }\n\n  getHostsForCalendar(req: { calendarId: string }): Observable<HostUser[]> {\n    return this.hostAPIService\n      .getHostsForCalendar({ calendarId: req.calendarId })\n      .pipe(\n        map((res) => {\n          return (res.hostUsers || []).map((hostuser) => {\n            return hostUserFromApi(hostuser);\n          });\n        })\n      );\n  }\n\n  IsCalendarConfigured(\n    req: IsCalendarConfiguredRequestInterface\n  ): Observable<IsCalendarConfiguredResponse> {\n    return this.hostAPIService.isCalendarConfigured(req);\n  }\n\n  sendMeetingRequestEmail(\n    req: SendMeetingRequestEmailRequestInterface\n  ): Observable<HttpResponse<null>> {\n    return this.hostAPIService.sendMeetingRequestEmail(req);\n  }\n\n  createService(req: {\n    service: Service;\n    updateFields?: (keyof Service)[];\n    HostId?: string;\n  }): Observable<string> {\n    const fieldMask = getFieldMask({\n      o: req.service,\n      updateFields: req.updateFields,\n    });\n    if (fieldMask.paths.length === 0) {\n      return of();\n    }\n    return this.hostAPIService\n      .createService({\n        service: ServiceTypeToApi({ service: req.service }),\n        fieldMask,\n        hostId: req.HostId,\n      })\n      .pipe(map((res) => res.id));\n  }\n\n  updateService(req: {\n    id: string;\n    service: Partial<Service>;\n    updateFields?: (keyof Service)[];\n    HostId?: string;\n  }): Observable<void> {\n    const fieldMask = getFieldMask({\n      o: req.service,\n      updateFields: req.updateFields,\n    });\n    if (fieldMask.paths.length === 0) {\n      return of();\n    }\n    return this.hostAPIService\n      .updateService({\n        id: req.id,\n        service: ServiceTypeToApi({ service: req.service }),\n        fieldMask,\n        hostId: req.HostId,\n      })\n      .pipe(mapTo(undefined));\n  }\n\n  deleteService(req: { id: string; hostId: string }): Observable<void> {\n    return this.hostAPIService\n      .deleteService({ id: req.id, hostId: req.hostId })\n      .pipe(mapTo(undefined));\n  }\n\n  listServices(req: { hostId: string }): Observable<Service[]> {\n    return this.hostAPIService.listServices({ hostId: req.hostId }).pipe(\n      map((res) => {\n        if (!res || !res.services) {\n          return [];\n        }\n        return res.services.map((service) =>\n          ServiceFromApi({\n            serviceApi: service,\n            environment: onProductionGlobal()\n              ? Environment.PROD\n              : Environment.DEMO,\n          })\n        );\n      })\n    );\n  }\n\n  createGroup(req: {\n    group: Group;\n    updateFields?: (keyof Group)[];\n    HostId?: string;\n  }): Observable<string> {\n    const fieldMask = getFieldMask({\n      o: req.group,\n      updateFields: req.updateFields,\n    });\n    if (fieldMask.paths.length === 0) {\n      return of();\n    }\n    return this.hostAPIService\n      .createGroup({\n        group: GroupTypeToAPi({ group: req.group }),\n        fieldMask,\n        hostId: req.HostId,\n      })\n      .pipe(map((res) => res.id));\n  }\n\n  updateGroup(req: {\n    id: string;\n    group: Partial<Group>;\n    updateFields?: (keyof Group)[];\n    HostId?: string;\n  }): Observable<void> {\n    const fieldMask = getFieldMask({\n      o: req.group,\n      updateFields: req.updateFields,\n    });\n    if (fieldMask.paths.length === 0) {\n      return of();\n    }\n    return this.hostAPIService\n      .updateGroup({\n        id: req.id,\n        group: GroupTypeToAPi({ group: req.group }),\n        fieldMask,\n        hostId: req.HostId,\n      })\n      .pipe(mapTo(undefined));\n  }\n\n  deleteGroup(req: { id: string; hostId: string }): Observable<void> {\n    return this.hostAPIService\n      .deleteGroup({ id: req.id, hostId: req.hostId })\n      .pipe(mapTo(undefined));\n  }\n\n  listGroups(req: { hostId: string }): Observable<Group[]> {\n    return this.hostAPIService.listGroups({ hostId: req.hostId }).pipe(\n      map((res) => {\n        if (!res || !res.groups) {\n          return [];\n        }\n        return res.groups.map((group) =>\n          GroupFromApi({\n            groupApi: group,\n            environment: onProductionGlobal()\n              ? Environment.PROD\n              : Environment.DEMO,\n          })\n        );\n      })\n    );\n  }\n\n  getGroup(req: {\n    groupId: string;\n    slug: string;\n    hostId: string;\n  }): Observable<GetGroupResponse> {\n    return this.hostAPIService.getGroup(req);\n  }\n  getService(req: {\n    serviceId: string;\n    slug: string;\n    hostId: string;\n  }): Observable<GetServiceResponse> {\n    return this.hostAPIService.getService(req);\n  }\n\n  checkGroupOrServiceSlugExist(req: {\n    hostId: string;\n    slugIdentifier: string;\n    category: string;\n  }): Observable<boolean> {\n    return this.hostAPIService\n      .checkGroupOrServiceSlugExist(req)\n      .pipe(map((res) => res.exists));\n  }\n}\n"]}
|