@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.
@@ -1,10 +1,10 @@
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';
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.buildHostId({
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
- }).pipe(map(res => res.hostId || ''));
21
+ applicationContextProperties: req.applicationContextProperties,
22
+ })
23
+ .pipe(map((res) => res.hostId || ""));
22
24
  }
23
25
  doesCalendarExist(calendarIdentifier) {
24
- return this.hostAPIService.doesCalendarExist({ calendarIdentifier: calendarIdentifier }).pipe(map(resp => resp.exists));
26
+ return this.hostAPIService
27
+ .doesCalendarExist({ calendarIdentifier: calendarIdentifier })
28
+ .pipe(map((resp) => resp.exists));
25
29
  }
26
30
  getCalendar(req) {
27
- return this.hostAPIService.getCalendar({ calendarId: req.calendarId }).pipe(map(res => CalendarFromApi(res?.calendar)));
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.ensurePersonalCalendarExists({
36
+ return this.hostAPIService
37
+ .ensurePersonalCalendarExists({
31
38
  userId: req.userId,
32
39
  applicationContextProperties: req.applicationContextProperties,
33
- }).pipe(map(res => res ? res.calendarId : ''));
40
+ })
41
+ .pipe(map((res) => (res ? res.calendarId : "")));
34
42
  }
35
43
  ensureGroupCalendarsExist(req) {
36
- return this.hostAPIService.ensureGroupCalendarsExist({ externalIds: req.externalIds }).pipe(map(res => res?.calendarIds || []));
44
+ return this.hostAPIService
45
+ .ensureGroupCalendarsExist({ externalIds: req.externalIds })
46
+ .pipe(map((res) => res?.calendarIds || []));
37
47
  }
38
48
  /*
39
- createCalendar creates a calendar which meeting types can be created for and events can be booked on
40
- The fields of a calendar are documented in https://github.com/vendasta/vendastaapis/blob/master/meetings/v1/shared.proto
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.updateCalendar({
56
+ return this.hostAPIService
57
+ .updateCalendar({
47
58
  calendarId: calendarId,
48
59
  calendarUpdate: { slug: newSlug },
49
- fieldMask: { paths: ['slug'] },
50
- }).pipe(mapTo(undefined));
60
+ fieldMask: { paths: ["slug"] },
61
+ })
62
+ .pipe(mapTo(undefined));
51
63
  }
52
64
  updateCalendarHostUserIDs(calendarId, replacementHostUserIds) {
53
- return this.hostAPIService.updateCalendar({
65
+ return this.hostAPIService
66
+ .updateCalendar({
54
67
  calendarId: calendarId,
55
68
  calendarUpdate: { hostUserIds: replacementHostUserIds },
56
- fieldMask: { paths: ['host_user_ids'] },
57
- }).pipe(mapTo(undefined));
69
+ fieldMask: { paths: ["host_user_ids"] },
70
+ })
71
+ .pipe(mapTo(undefined));
58
72
  }
59
73
  getMeetingTypesForCalendars(req) {
60
- return this.hostAPIService.getMeetingTypesForCalendars({ calendarIds: req.calendarIds }).pipe(map(res => {
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() ? Environment.PROD : Environment.DEMO,
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
- listMeetingTypes returns a list of meeting types for a host
80
- @param hostId: An identifier for an individual host
81
- @param metadata: optional metadata to include on the meeting type booking link
82
- @param calendarSlug: used to replace hostId in the url. Use it when you are confident you know the host's slug.
83
- - calendarSlug IS NOT USED TO RETRIEVE MEETING TYPES, ONLY TO MAKE THE BOOKING URLS
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() ? Environment.PROD : Environment.DEMO,
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
- getBookingUrl returns a link that can be used to book a meeting with this host.
103
- @param calendarId: An identifier for an individual host or grouping of hosts (i.e., team).
104
- @param @deprecated hostId: An identifier for an individual host.
105
- @param meetingTypeId: An optional identifier for the meeting type. Default: 30-minutes.
106
- @param metadata: optional metadata to include in the url.
107
- - metadata can be used to pre-fill certain form fields and will be stored during the booking process.
108
- - metadata can be obtained by subscribing to the booking event.
109
- @param calendarSlug: used to replace hostId in the url. Use it when you are confident you know the host's slug.
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
- getGeneralBookingUrl returns a link that can be used to select a meeting type to book with the given calendar.
121
- @param calendarId: An identifier for an individual host or grouping of hosts (i.e., team).
122
- @param metadata: optional metadata to include in the url.
123
- - metadata can be used to pre-fill certain form fields and will be stored during the booking process.
124
- - metadata can be obtained by subscribing to the booking event.
125
- @param calendarSlug: used to replace hostId in the url. Use it when you are confident you know the host's slug.
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
- getBookingUrlsMulti returns a mapping of hosts -> event types -> booking links.
137
- @param calendarId: An identifier for an individual host or grouping of hosts.
138
- @param meetingTypeSlug: meetingTypeSlugs are passed in the form {hostId: [meetingTypeSlug1, meetingTypeSlug2]}
139
- @param metadata: optional metadata to include in the url.
140
- - metadata can be used to pre-fill certain form fields and will be stored during the booking process.
141
- - metadata can be obtained by subscribing to the booking event.
142
- @param calendarSlug: used to replace hostId in the url. Use it when you are confident you know the host's slug.
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() ? Environment.PROD : Environment.DEMO,
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.isHostConfigured(req).pipe(map((resp) => resp.isConfigured));
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.listBookedMeetings({
201
+ return this.hostAPIService
202
+ .listBookedMeetings({
178
203
  ...req,
179
- pagingOptions: new PagedRequestOptions({ cursor: req.cursor, pageSize: req.pageSize }),
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
- }).pipe(map((resp) => {
183
- const meetings = (resp.meetings || []).map(meeting => meetingFromApi(meeting));
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.cancelMeeting({
189
- ...req
190
- }).pipe(mapTo(null));
217
+ return this.hostAPIService
218
+ .cancelMeeting({
219
+ ...req,
220
+ })
221
+ .pipe(mapTo(null));
191
222
  }
192
223
  rescheduleMeeting(req) {
193
- return this.hostAPIService.rescheduleMeeting({
194
- ...req
195
- }).pipe(mapTo(null));
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 || []).filter(Boolean).map(a => {
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({ o: req.preferences, updateFields: req.updateFields });
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.updateHostPreferences({
269
+ return this.hostAPIService
270
+ .updateHostPreferences({
232
271
  hostId: req.hostId,
233
272
  preferences: req.preferences,
234
273
  fieldMask,
235
- }).pipe(mapTo(undefined));
274
+ })
275
+ .pipe(mapTo(undefined));
236
276
  }
237
277
  getPreferences(req) {
238
- return this.hostAPIService.getHostPreferences({
239
- hostId: req.hostId
240
- }).pipe(map(response => PreferencesFromApi(response.preferences)));
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.getHostMeeting({
244
- meetingId: meetingId, location: location,
245
- }).pipe(map((resp) => meetingFromApi(resp.meeting)));
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.updateMeetingMetadata({
293
+ return this.hostAPIService
294
+ .updateMeetingMetadata({
249
295
  meetingId: req.meetingId,
250
- metadata: req.metadata
251
- }).pipe(mapTo(undefined));
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.bookMeeting(req).pipe(map((resp) => resp.meetingId));
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.createDefaultMeetingTypes({ calendarIds: req.calendarIds }).pipe(mapTo(undefined));
314
+ return this.hostAPIService
315
+ .createDefaultMeetingTypes({ calendarIds: req.calendarIds })
316
+ .pipe(mapTo(undefined));
260
317
  }
261
318
  createMeetingType(req) {
262
- const fieldMask = getFieldMask({ o: req.meetingType, updateFields: req.updateFields });
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.createMeetingType({
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({ o: req.meetingType, updateFields: req.updateFields });
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.updateMeetingType({
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
- }).pipe(mapTo(undefined));
362
+ hostId: req.HostId,
363
+ })
364
+ .pipe(mapTo(undefined));
299
365
  }
300
366
  deleteMeetingType(req) {
301
- return this.hostAPIService.deleteMeetingType({ id: req.id }).pipe(mapTo(undefined));
367
+ return this.hostAPIService
368
+ .deleteMeetingType({ id: req.id })
369
+ .pipe(mapTo(undefined));
302
370
  }
303
371
  getHostsForCalendar(req) {
304
- return this.hostAPIService.getHostsForCalendar({ calendarId: req.calendarId }).pipe(map(res => {
305
- return (res.hostUsers || []).map(hostuser => {
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({ o: req.service, updateFields: req.updateFields });
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.createService({
394
+ return this.hostAPIService
395
+ .createService({
322
396
  service: ServiceTypeToApi({ service: req.service }),
323
397
  fieldMask,
324
- hostId: req.HostId
325
- }).pipe(map(res => res.id));
398
+ hostId: req.HostId,
399
+ })
400
+ .pipe(map((res) => res.id));
326
401
  }
327
402
  updateService(req) {
328
- const fieldMask = getFieldMask({ o: req.service, updateFields: req.updateFields });
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.updateService({
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
- }).pipe(mapTo(undefined));
415
+ hostId: req.HostId,
416
+ })
417
+ .pipe(mapTo(undefined));
338
418
  }
339
419
  deleteService(req) {
340
- return this.hostAPIService.deleteService({ id: req.id, hostId: req.hostId }).pipe(mapTo(undefined));
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({ serviceApi: service, environment: onProductionGlobal() ? Environment.PROD : Environment.DEMO }));
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({ o: req.group, updateFields: req.updateFields });
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.createGroup({
445
+ return this.hostAPIService
446
+ .createGroup({
356
447
  group: GroupTypeToAPi({ group: req.group }),
357
448
  fieldMask,
358
- hostId: req.HostId
359
- }).pipe(map(res => res.id));
449
+ hostId: req.HostId,
450
+ })
451
+ .pipe(map((res) => res.id));
360
452
  }
361
453
  updateGroup(req) {
362
- const fieldMask = getFieldMask({ o: req.group, updateFields: req.updateFields });
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.updateGroup({
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
- }).pipe(mapTo(undefined));
466
+ hostId: req.HostId,
467
+ })
468
+ .pipe(mapTo(undefined));
372
469
  }
373
470
  deleteGroup(req) {
374
- return this.hostAPIService.deleteGroup({ id: req.id, hostId: req.hostId }).pipe(mapTo(undefined));
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({ groupApi: group, environment: onProductionGlobal() ? Environment.PROD : Environment.DEMO }));
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: 'root' });
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: 'root' }]
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"]}