stream-chat-angular 2.19.0 → 2.20.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/assets/version.d.ts +1 -1
- package/bundles/stream-chat-angular.umd.js +165 -156
- package/bundles/stream-chat-angular.umd.js.map +1 -1
- package/esm2015/assets/version.js +2 -2
- package/esm2015/lib/channel-header/channel-header.component.js +8 -5
- package/esm2015/lib/channel.service.js +71 -59
- package/esm2015/lib/chat-client.service.js +26 -2
- package/esm2015/lib/notification/notification.component.js +1 -1
- package/esm2015/lib/notification-list/notification-list.component.js +7 -4
- package/esm2015/lib/notification.service.js +34 -18
- package/esm2015/lib/types.js +1 -1
- package/fesm2015/stream-chat-angular.js +139 -82
- package/fesm2015/stream-chat-angular.js.map +1 -1
- package/lib/channel-header/channel-header.component.d.ts +8 -1
- package/lib/channel.service.d.ts +13 -13
- package/lib/chat-client.service.d.ts +7 -1
- package/lib/notification/notification.component.d.ts +1 -1
- package/lib/notification-list/notification-list.component.d.ts +6 -2
- package/lib/notification.service.d.ts +14 -13
- package/lib/types.d.ts +11 -0
- package/package.json +1 -1
- package/src/assets/version.ts +1 -1
|
@@ -15,9 +15,11 @@ export class ChatClientService {
|
|
|
15
15
|
this.notificationSubject = new ReplaySubject(1);
|
|
16
16
|
this.connectionStateSubject = new ReplaySubject(1);
|
|
17
17
|
this.appSettingsSubject = new BehaviorSubject(undefined);
|
|
18
|
+
this.pendingInvitesSubject = new BehaviorSubject([]);
|
|
18
19
|
this.notification$ = this.notificationSubject.asObservable();
|
|
19
20
|
this.connectionState$ = this.connectionStateSubject.asObservable();
|
|
20
21
|
this.appSettings$ = this.appSettingsSubject.asObservable();
|
|
22
|
+
this.pendingInvites$ = this.pendingInvitesSubject.asObservable();
|
|
21
23
|
}
|
|
22
24
|
/**
|
|
23
25
|
* Creates a [`StreamChat`](https://github.com/GetStream/stream-chat-js/blob/668b3e5521339f4e14fc657834531b4c8bf8176b/src/client.ts#L124) instance using the provided `apiKey`, and connects a user with the given meta data and token. More info about [connecting users](https://getstream.io/chat/docs/javascript/init_and_users/?language=javascript) can be found in the platform documentation.
|
|
@@ -26,16 +28,20 @@ export class ChatClientService {
|
|
|
26
28
|
* @param userTokenOrProvider
|
|
27
29
|
*/
|
|
28
30
|
init(apiKey, userOrId, userTokenOrProvider) {
|
|
31
|
+
var _a;
|
|
29
32
|
return __awaiter(this, void 0, void 0, function* () {
|
|
30
33
|
this.chatClient = StreamChat.getInstance(apiKey);
|
|
34
|
+
this.chatClient.devToken;
|
|
31
35
|
yield this.ngZone.runOutsideAngular(() => __awaiter(this, void 0, void 0, function* () {
|
|
32
36
|
const user = typeof userOrId === 'string' ? { id: userOrId } : userOrId;
|
|
33
37
|
yield this.chatClient.connectUser(user, userTokenOrProvider);
|
|
34
38
|
this.chatClient.setUserAgent(`stream-chat-angular-${version}-${this.chatClient.getUserAgent()}`);
|
|
35
|
-
this.chatClient.getAppSettings;
|
|
36
39
|
}));
|
|
40
|
+
const channels = yield this.chatClient.queryChannels({ invite: 'pending' }, {}, { user_id: (_a = this.chatClient.user) === null || _a === void 0 ? void 0 : _a.id });
|
|
41
|
+
this.pendingInvitesSubject.next(channels);
|
|
37
42
|
this.appSettingsSubject.next(undefined);
|
|
38
43
|
this.chatClient.on((e) => {
|
|
44
|
+
this.updatePendingInvites(e);
|
|
39
45
|
this.notificationSubject.next({
|
|
40
46
|
eventType: e.type,
|
|
41
47
|
event: e,
|
|
@@ -64,6 +70,7 @@ export class ChatClientService {
|
|
|
64
70
|
*/
|
|
65
71
|
disconnectUser() {
|
|
66
72
|
return __awaiter(this, void 0, void 0, function* () {
|
|
73
|
+
this.pendingInvitesSubject.next([]);
|
|
67
74
|
yield this.chatClient.disconnectUser();
|
|
68
75
|
});
|
|
69
76
|
}
|
|
@@ -108,6 +115,23 @@ export class ChatClientService {
|
|
|
108
115
|
return result.users;
|
|
109
116
|
});
|
|
110
117
|
}
|
|
118
|
+
updatePendingInvites(e) {
|
|
119
|
+
var _a, _b, _c;
|
|
120
|
+
if (((_b = (_a = e.member) === null || _a === void 0 ? void 0 : _a.user) === null || _b === void 0 ? void 0 : _b.id) === ((_c = this.chatClient.user) === null || _c === void 0 ? void 0 : _c.id) && e.channel) {
|
|
121
|
+
const pendingInvites = this.pendingInvitesSubject.getValue();
|
|
122
|
+
if (e.type === 'notification.invited') {
|
|
123
|
+
this.pendingInvitesSubject.next([...pendingInvites, e.channel]);
|
|
124
|
+
}
|
|
125
|
+
else if (e.type === 'notification.invite_accepted' ||
|
|
126
|
+
e.type === 'notification.invite_rejected') {
|
|
127
|
+
const index = pendingInvites.findIndex((i) => { var _a; return (i === null || i === void 0 ? void 0 : i.cid) === ((_a = e.channel) === null || _a === void 0 ? void 0 : _a.cid); });
|
|
128
|
+
if (index !== -1) {
|
|
129
|
+
pendingInvites.splice(index, 1);
|
|
130
|
+
this.pendingInvitesSubject.next([...pendingInvites]);
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
}
|
|
111
135
|
}
|
|
112
136
|
ChatClientService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: ChatClientService, deps: [{ token: i0.NgZone }, { token: i1.NotificationService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
113
137
|
ChatClientService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: ChatClientService, providedIn: 'root' });
|
|
@@ -117,4 +141,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
|
|
|
117
141
|
providedIn: 'root',
|
|
118
142
|
}]
|
|
119
143
|
}], ctorParameters: function () { return [{ type: i0.NgZone }, { type: i1.NotificationService }]; } });
|
|
120
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chat-client.service.js","sourceRoot":"","sources":["../../../../projects/stream-chat-angular/src/lib/chat-client.service.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAU,MAAM,eAAe,CAAC;AACnD,OAAO,EAAE,eAAe,EAAc,aAAa,EAAE,MAAM,MAAM,CAAC;AAElE,OAAO,EAAsB,UAAU,EAAmB,MAAM,aAAa,CAAC;AAC9E,OAAO,EAAE,OAAO,EAAE,MAAM,mBAAmB,CAAC;;;AAQ5C;;GAEG;AAIH,MAAM,OAAO,iBAAiB;IA0B5B,YACU,MAAc,EACd,mBAAwC;QADxC,WAAM,GAAN,MAAM,CAAQ;QACd,wBAAmB,GAAnB,mBAAmB,CAAqB;QAR1C,wBAAmB,GAAG,IAAI,aAAa,CAAe,CAAC,CAAC,CAAC;QACzD,2BAAsB,GAAG,IAAI,aAAa,CAAuB,CAAC,CAAC,CAAC;QACpE,uBAAkB,GAAG,IAAI,eAAe,CAC9C,SAAS,CACV,CAAC;QAMA,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,mBAAmB,CAAC,YAAY,EAAE,CAAC;QAC7D,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,sBAAsB,CAAC,YAAY,EAAE,CAAC;QACnE,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;IAC7D,CAAC;IAED;;;;;OAKG;IACG,IAAI,CACR,MAAc,EACd,QAAiD,EACjD,mBAAoC;;YAEpC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;YACjD,MAAM,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,GAAS,EAAE;gBAC7C,MAAM,IAAI,GAAG,OAAO,QAAQ,KAAK,QAAQ,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC;gBACxE,MAAM,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,IAAI,EAAE,mBAAmB,CAAC,CAAC;gBAC7D,IAAI,CAAC,UAAU,CAAC,YAAY,CAC1B,uBAAuB,OAAO,IAAI,IAAI,CAAC,UAAU,CAAC,YAAY,EAAE,EAAE,CACnE,CAAC;gBACF,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC;YACjC,CAAC,CAAA,CAAC,CAAC;YACH,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YACxC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE;gBACvB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC;oBAC5B,SAAS,EAAE,CAAC,CAAC,IAAI;oBACjB,KAAK,EAAE,CAAC;iBACT,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;YACH,IAAI,kBAAwC,CAAC;YAC7C,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,oBAAoB,EAAE,CAAC,CAAC,EAAE,EAAE;gBAC7C,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE;oBACnB,MAAM,QAAQ,GAAG,CAAC,CAAC,MAAM,CAAC;oBAC1B,IAAI,QAAQ,EAAE;wBACZ,IAAI,kBAAkB,EAAE;4BACtB,kBAAkB,EAAE,CAAC;yBACtB;qBACF;yBAAM;wBACL,kBAAkB;4BAChB,IAAI,CAAC,mBAAmB,CAAC,wBAAwB,CAC/C,oDAAoD,CACrD,CAAC;qBACL;oBACD,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;gBACpE,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QACL,CAAC;KAAA;IAED;;OAEG;IACG,cAAc;;YAClB,MAAM,IAAI,CAAC,UAAU,CAAC,cAAc,EAAE,CAAC;QACzC,CAAC;KAAA;IAED;;OAEG;IACG,cAAc;;YAClB,IAAI,IAAI,CAAC,kBAAkB,CAAC,QAAQ,EAAE,EAAE;gBACtC,OAAO;aACR;YACD,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,cAAc,EAAE,CAAC;YACxD,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,IAAI,EAAE,CAAC,CAAC;QACnD,CAAC;KAAA;IAED;;;OAGG;IACG,WAAW,CAAC,SAAiB;;YACjC,MAAM,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;QAC/C,CAAC;KAAA;IAED;;;;OAIG;IACG,iBAAiB,CAAC,UAAkB;;YACxC,IAAI,CAAC,UAAU,EAAE;gBACf,OAAO,EAAE,CAAC;aACX;YACD,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC;gBAC9C,GAAG,EAAE;oBACH,EAAE,EAAE,EAAE,EAAE,aAAa,EAAE,UAAU,EAAE,EAAE;oBACrC,EAAE,IAAI,EAAE,EAAE,aAAa,EAAE,UAAU,EAAE,EAAE;iBACxC;gBACD,EAAE,EAAE,EAAE,GAAG,EAAE,IAAI,CAAC,UAAU,CAAC,MAAO,EAAE;aACrC,CAAC,CAAC;YACH,OAAO,MAAM,CAAC,KAAK,CAAC;QACtB,CAAC;KAAA;;8GA5HU,iBAAiB;kHAAjB,iBAAiB,cAFhB,MAAM;2FAEP,iBAAiB;kBAH7B,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\nimport { BehaviorSubject, Observable, ReplaySubject } from 'rxjs';\nimport { OwnUserResponse, UserResponse } from 'stream-chat';\nimport { AppSettings, Event, StreamChat, TokenOrProvider } from 'stream-chat';\nimport { version } from '../assets/version';\nimport { NotificationService } from './notification.service';\n\nexport type Notification = {\n  eventType: string;\n  event: Event;\n};\n\n/**\n * The `ChatClient` service connects the user to the Stream chat.\n */\n@Injectable({\n  providedIn: 'root',\n})\nexport class ChatClientService {\n  /**\n   * The [StreamChat client](https://github.com/GetStream/stream-chat-js/blob/master/src/client.ts) instance. In general you shouldn't need to access the client, but it's there if you want to use it.\n   */\n  chatClient!: StreamChat;\n  /**\n   * Emits [`Notification`](https://github.com/GetStream/stream-chat-angular/blob/master/projects/stream-chat-angular/src/lib/chat-client.service.ts) events. The platform documentation covers [the list of client and notification events](https://getstream.io/chat/docs/javascript/event_object/?language=javascript).\n   * :::important\n   * For performance reasons this Observable operates outside of the Angular change detection zone. If you subscribe to it, you need to manually reenter Angular's change detection zone, our [Change detection guide](../concepts/change-detection.mdx) explains this in detail.\n   * :::\n   */\n  notification$: Observable<Notification>;\n  /**\n   * Emits the current [application settings](https://getstream.io/chat/docs/javascript/app_setting_overview/?language=javascript). Since getting the application settings is an expensive API call and we don't always need the result, this is not initialized by default, you need to call `getApplicationSettings` to load them.\n   */\n  appSettings$: Observable<AppSettings | undefined>;\n  /**\n   * Emits the current connection state of the user (`online` or `offline`)\n   */\n  connectionState$: Observable<'offline' | 'online'>;\n  private notificationSubject = new ReplaySubject<Notification>(1);\n  private connectionStateSubject = new ReplaySubject<'offline' | 'online'>(1);\n  private appSettingsSubject = new BehaviorSubject<AppSettings | undefined>(\n    undefined\n  );\n\n  constructor(\n    private ngZone: NgZone,\n    private notificationService: NotificationService\n  ) {\n    this.notification$ = this.notificationSubject.asObservable();\n    this.connectionState$ = this.connectionStateSubject.asObservable();\n    this.appSettings$ = this.appSettingsSubject.asObservable();\n  }\n\n  /**\n   * Creates a [`StreamChat`](https://github.com/GetStream/stream-chat-js/blob/668b3e5521339f4e14fc657834531b4c8bf8176b/src/client.ts#L124) instance using the provided `apiKey`, and connects a user with the given meta data and token. More info about [connecting users](https://getstream.io/chat/docs/javascript/init_and_users/?language=javascript) can be found in the platform documentation.\n   * @param apiKey\n   * @param userOrId\n   * @param userTokenOrProvider\n   */\n  async init(\n    apiKey: string,\n    userOrId: string | OwnUserResponse | UserResponse,\n    userTokenOrProvider: TokenOrProvider\n  ) {\n    this.chatClient = StreamChat.getInstance(apiKey);\n    await this.ngZone.runOutsideAngular(async () => {\n      const user = typeof userOrId === 'string' ? { id: userOrId } : userOrId;\n      await this.chatClient.connectUser(user, userTokenOrProvider);\n      this.chatClient.setUserAgent(\n        `stream-chat-angular-${version}-${this.chatClient.getUserAgent()}`\n      );\n      this.chatClient.getAppSettings;\n    });\n    this.appSettingsSubject.next(undefined);\n    this.chatClient.on((e) => {\n      this.notificationSubject.next({\n        eventType: e.type,\n        event: e,\n      });\n    });\n    let removeNotification: undefined | Function;\n    this.chatClient.on('connection.changed', (e) => {\n      this.ngZone.run(() => {\n        const isOnline = e.online;\n        if (isOnline) {\n          if (removeNotification) {\n            removeNotification();\n          }\n        } else {\n          removeNotification =\n            this.notificationService.addPermanentNotification(\n              'streamChat.Connection failure, reconnecting now...'\n            );\n        }\n        this.connectionStateSubject.next(isOnline ? 'online' : 'offline');\n      });\n    });\n  }\n\n  /**\n   * Disconnects the current user, and closes the WebSocket connection. Useful when disconnecting a chat user, use in combination with [`reset`](./ChannelService.mdx/#reset).\n   */\n  async disconnectUser() {\n    await this.chatClient.disconnectUser();\n  }\n\n  /**\n   * Loads the current [application settings](https://getstream.io/chat/docs/javascript/app_setting_overview/?language=javascript), if the application settings have already been loaded, it does nothing.\n   */\n  async getAppSettings() {\n    if (this.appSettingsSubject.getValue()) {\n      return;\n    }\n    const settings = await this.chatClient.getAppSettings();\n    this.appSettingsSubject.next(settings.app || {});\n  }\n\n  /**\n   * Flag the message with the given ID. If you want to know [more about flags](https://getstream.io/chat/docs/javascript/moderation/?language=javascript) check out the platform documentation.\n   * @param messageId\n   */\n  async flagMessage(messageId: string) {\n    await this.chatClient.flagMessage(messageId);\n  }\n\n  /**\n   * Searches for users in the application that have ID or name matching the provided search term\n   * @param searchTerm\n   * @returns The users matching the search\n   */\n  async autocompleteUsers(searchTerm: string) {\n    if (!searchTerm) {\n      return [];\n    }\n    const result = await this.chatClient.queryUsers({\n      $or: [\n        { id: { $autocomplete: searchTerm } },\n        { name: { $autocomplete: searchTerm } },\n      ],\n      id: { $ne: this.chatClient.userID! },\n    });\n    return result.users;\n  }\n}\n"]}
|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chat-client.service.js","sourceRoot":"","sources":["../../../../projects/stream-chat-angular/src/lib/chat-client.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\nimport { BehaviorSubject, Observable, ReplaySubject } from 'rxjs';\nimport {\n  Channel,\n  ChannelResponse,\n  OwnUserResponse,\n  UserResponse,\n} from 'stream-chat';\nimport { AppSettings, Event, StreamChat, TokenOrProvider } from 'stream-chat';\nimport { version } from '../assets/version';\nimport { NotificationService } from './notification.service';\n\nexport type Notification = {\n  eventType: string;\n  event: Event;\n};\n\n/**\n * The `ChatClient` service connects the user to the Stream chat.\n */\n@Injectable({\n  providedIn: 'root',\n})\nexport class ChatClientService {\n  /**\n   * The [StreamChat client](https://github.com/GetStream/stream-chat-js/blob/master/src/client.ts) instance. In general you shouldn't need to access the client, but it's there if you want to use it.\n   */\n  chatClient!: StreamChat;\n  /**\n   * Emits [`Notification`](https://github.com/GetStream/stream-chat-angular/blob/master/projects/stream-chat-angular/src/lib/chat-client.service.ts) events. The platform documentation covers [the list of client and notification events](https://getstream.io/chat/docs/javascript/event_object/?language=javascript).\n   * :::important\n   * For performance reasons this Observable operates outside of the Angular change detection zone. If you subscribe to it, you need to manually reenter Angular's change detection zone, our [Change detection guide](../concepts/change-detection.mdx) explains this in detail.\n   * :::\n   */\n  notification$: Observable<Notification>;\n  /**\n   * Emits the current [application settings](https://getstream.io/chat/docs/javascript/app_setting_overview/?language=javascript). Since getting the application settings is an expensive API call and we don't always need the result, this is not initialized by default, you need to call `getApplicationSettings` to load them.\n   */\n  appSettings$: Observable<AppSettings | undefined>;\n  /**\n   * Emits the current connection state of the user (`online` or `offline`)\n   */\n  connectionState$: Observable<'offline' | 'online'>;\n  /**\n   * Emits the list of pending invites of the user. It emits every pending invitation during initialization and then extends the list when a new invite is received. More information can be found in the [channel invitations](../code-examples/channel-invites.mdx) guide.\n   */\n  pendingInvites$: Observable<(ChannelResponse | Channel)[]>;\n  private notificationSubject = new ReplaySubject<Notification>(1);\n  private connectionStateSubject = new ReplaySubject<'offline' | 'online'>(1);\n  private appSettingsSubject = new BehaviorSubject<AppSettings | undefined>(\n    undefined\n  );\n  private pendingInvitesSubject = new BehaviorSubject<\n    (ChannelResponse | Channel)[]\n  >([]);\n\n  constructor(\n    private ngZone: NgZone,\n    private notificationService: NotificationService\n  ) {\n    this.notification$ = this.notificationSubject.asObservable();\n    this.connectionState$ = this.connectionStateSubject.asObservable();\n    this.appSettings$ = this.appSettingsSubject.asObservable();\n    this.pendingInvites$ = this.pendingInvitesSubject.asObservable();\n  }\n\n  /**\n   * Creates a [`StreamChat`](https://github.com/GetStream/stream-chat-js/blob/668b3e5521339f4e14fc657834531b4c8bf8176b/src/client.ts#L124) instance using the provided `apiKey`, and connects a user with the given meta data and token. More info about [connecting users](https://getstream.io/chat/docs/javascript/init_and_users/?language=javascript) can be found in the platform documentation.\n   * @param apiKey\n   * @param userOrId\n   * @param userTokenOrProvider\n   */\n  async init(\n    apiKey: string,\n    userOrId: string | OwnUserResponse | UserResponse,\n    userTokenOrProvider: TokenOrProvider\n  ) {\n    this.chatClient = StreamChat.getInstance(apiKey);\n    this.chatClient.devToken;\n    await this.ngZone.runOutsideAngular(async () => {\n      const user = typeof userOrId === 'string' ? { id: userOrId } : userOrId;\n      await this.chatClient.connectUser(user, userTokenOrProvider);\n      this.chatClient.setUserAgent(\n        `stream-chat-angular-${version}-${this.chatClient.getUserAgent()}`\n      );\n    });\n    const channels = await this.chatClient.queryChannels(\n      { invite: 'pending' },\n      {},\n      { user_id: this.chatClient.user?.id }\n    );\n    this.pendingInvitesSubject.next(channels);\n    this.appSettingsSubject.next(undefined);\n    this.chatClient.on((e) => {\n      this.updatePendingInvites(e);\n      this.notificationSubject.next({\n        eventType: e.type,\n        event: e,\n      });\n    });\n    let removeNotification: undefined | Function;\n    this.chatClient.on('connection.changed', (e) => {\n      this.ngZone.run(() => {\n        const isOnline = e.online;\n        if (isOnline) {\n          if (removeNotification) {\n            removeNotification();\n          }\n        } else {\n          removeNotification =\n            this.notificationService.addPermanentNotification(\n              'streamChat.Connection failure, reconnecting now...'\n            );\n        }\n        this.connectionStateSubject.next(isOnline ? 'online' : 'offline');\n      });\n    });\n  }\n\n  /**\n   * Disconnects the current user, and closes the WebSocket connection. Useful when disconnecting a chat user, use in combination with [`reset`](./ChannelService.mdx/#reset).\n   */\n  async disconnectUser() {\n    this.pendingInvitesSubject.next([]);\n    await this.chatClient.disconnectUser();\n  }\n\n  /**\n   * Loads the current [application settings](https://getstream.io/chat/docs/javascript/app_setting_overview/?language=javascript), if the application settings have already been loaded, it does nothing.\n   */\n  async getAppSettings() {\n    if (this.appSettingsSubject.getValue()) {\n      return;\n    }\n    const settings = await this.chatClient.getAppSettings();\n    this.appSettingsSubject.next(settings.app || {});\n  }\n\n  /**\n   * Flag the message with the given ID. If you want to know [more about flags](https://getstream.io/chat/docs/javascript/moderation/?language=javascript) check out the platform documentation.\n   * @param messageId\n   */\n  async flagMessage(messageId: string) {\n    await this.chatClient.flagMessage(messageId);\n  }\n\n  /**\n   * Searches for users in the application that have ID or name matching the provided search term\n   * @param searchTerm\n   * @returns The users matching the search\n   */\n  async autocompleteUsers(searchTerm: string) {\n    if (!searchTerm) {\n      return [];\n    }\n    const result = await this.chatClient.queryUsers({\n      $or: [\n        { id: { $autocomplete: searchTerm } },\n        { name: { $autocomplete: searchTerm } },\n      ],\n      id: { $ne: this.chatClient.userID! },\n    });\n    return result.users;\n  }\n\n  private updatePendingInvites(e: Event) {\n    if (e.member?.user?.id === this.chatClient.user?.id && e.channel) {\n      const pendingInvites = this.pendingInvitesSubject.getValue();\n      if (e.type === 'notification.invited') {\n        this.pendingInvitesSubject.next([...pendingInvites, e.channel]);\n      } else if (\n        e.type === 'notification.invite_accepted' ||\n        e.type === 'notification.invite_rejected'\n      ) {\n        const index = pendingInvites.findIndex(\n          (i) => i?.cid === e.channel?.cid\n        );\n        if (index !== -1) {\n          pendingInvites.splice(index, 1);\n          this.pendingInvitesSubject.next([...pendingInvites]);\n        }\n      }\n    }\n  }\n}\n"]}
|
|
@@ -18,4 +18,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
|
|
|
18
18
|
}], ctorParameters: function () { return []; }, propDecorators: { type: [{
|
|
19
19
|
type: Input
|
|
20
20
|
}] } });
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90aWZpY2F0aW9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2xpYi9ub3RpZmljYXRpb24vbm90aWZpY2F0aW9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2xpYi9ub3RpZmljYXRpb24vbm90aWZpY2F0aW9uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUdqRDs7R0FFRztBQU1ILE1BQU0sT0FBTyxxQkFBcUI7SUFNaEMsZ0JBQWUsQ0FBQzs7a0hBTkwscUJBQXFCO3NHQUFyQixxQkFBcUIscUZDWGxDLDBKQU1BOzJGREthLHFCQUFxQjtrQkFMakMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUscUJBQXFCO29CQUMvQixXQUFXLEVBQUUsK0JBQStCO29CQUM1QyxNQUFNLEVBQUUsRUFBRTtpQkFDWDswRUFLVSxJQUFJO3NCQUFaLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOb3RpZmljYXRpb25UeXBlIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG4vKipcbiAqIFRoZSBgTm90aWZpY2F0aW9uYCBjb21wb25lbnQgZGlzcGxheXMgYSBub3RpZmljYXRpb24gd2l0aGluIHRoZSBbYE5vdGlmaWNhdGlvbkxpc3RgXSguL05vdGlmaWNhdGlvbkxpc3RDb21wb25lbnQubWR4KVxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzdHJlYW0tbm90aWZpY2F0aW9uJyxcbiAgdGVtcGxhdGVVcmw6ICcuL25vdGlmaWNhdGlvbi5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlczogW10sXG59KVxuZXhwb3J0IGNsYXNzIE5vdGlmaWNhdGlvbkNvbXBvbmVudCB7XG4gIC8qKlxuICAgKiBUaGUgdHlwZSBvZiB0aGUgbm90aWZpY2F0aW9uXG4gICAqL1xuICBASW5wdXQoKSB0eXBlOiBOb3RpZmljYXRpb25UeXBlIHwgdW5kZWZpbmVkO1xuXG4gIGNvbnN0cnVjdG9yKCkge31cbn1cbiIsIjxkaXZcbiAgY2xhc3M9XCJzdHItY2hhdF9fY3VzdG9tLW5vdGlmaWNhdGlvbiBub3RpZmljYXRpb24te3sgdHlwZSB9fVwiXG4gIGRhdGEtdGVzdGlkPVwiY3VzdG9tLW5vdGlmaWNhdGlvblwiXG4+XG4gIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbjwvZGl2PlxuIl19
|
|
@@ -12,12 +12,15 @@ export class NotificationListComponent {
|
|
|
12
12
|
this.notificationService = notificationService;
|
|
13
13
|
this.notifications$ = this.notificationService.notifications$;
|
|
14
14
|
}
|
|
15
|
-
|
|
16
|
-
return item;
|
|
15
|
+
trackById(_, item) {
|
|
16
|
+
return item.id;
|
|
17
|
+
}
|
|
18
|
+
getTemplateContext(notification) {
|
|
19
|
+
return Object.assign(Object.assign({}, notification.templateContext), { dismissFn: notification.dismissFn });
|
|
17
20
|
}
|
|
18
21
|
}
|
|
19
22
|
NotificationListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NotificationListComponent, deps: [{ token: i1.NotificationService }], target: i0.ɵɵFactoryTarget.Component });
|
|
20
|
-
NotificationListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.5", type: NotificationListComponent, selector: "stream-notification-list", ngImport: i0, template: "<div class=\"str-chat__list-notifications\">\n <stream-notification\n *ngFor=\"let notification of notifications$ | async; trackBy:
|
|
23
|
+
NotificationListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.5", type: NotificationListComponent, selector: "stream-notification-list", ngImport: i0, template: "<div class=\"str-chat__list-notifications\">\n <stream-notification\n *ngFor=\"let notification of notifications$ | async; trackBy: trackById\"\n [type]=\"notification.type\"\n >\n <div\n *ngIf=\"notification.text !== undefined\"\n data-testclass=\"notification-content\"\n >\n {{ notification.text | translate: notification.translateParams }}\n </div>\n <ng-container *ngIf=\"notification.template !== undefined\">\n <ng-container\n *ngTemplateOutlet=\"\n notification.template;\n context: getTemplateContext(notification)\n \"\n ></ng-container>\n </ng-container>\n </stream-notification>\n</div>\n", components: [{ type: i2.NotificationComponent, selector: "stream-notification", inputs: ["type"] }], directives: [{ type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "async": i3.AsyncPipe, "translate": i4.TranslatePipe } });
|
|
21
24
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NotificationListComponent, decorators: [{
|
|
22
25
|
type: Component,
|
|
23
26
|
args: [{
|
|
@@ -26,4 +29,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
|
|
|
26
29
|
styles: [],
|
|
27
30
|
}]
|
|
28
31
|
}], ctorParameters: function () { return [{ type: i1.NotificationService }]; } });
|
|
29
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90aWZpY2F0aW9uLWxpc3QuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc3RyZWFtLWNoYXQtYW5ndWxhci9zcmMvbGliL25vdGlmaWNhdGlvbi1saXN0L25vdGlmaWNhdGlvbi1saXN0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3N0cmVhbS1jaGF0LWFuZ3VsYXIvc3JjL2xpYi9ub3RpZmljYXRpb24tbGlzdC9ub3RpZmljYXRpb24tbGlzdC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7Ozs7QUFLMUM7O0dBRUc7QUFNSCxNQUFNLE9BQU8seUJBQXlCO0lBR3BDLFlBQW9CLG1CQUF3QztRQUF4Qyx3QkFBbUIsR0FBbkIsbUJBQW1CLENBQXFCO1FBQzFELElBQUksQ0FBQyxjQUFjLEdBQUcsSUFBSSxDQUFDLG1CQUFtQixDQUFDLGNBQWMsQ0FBQztJQUNoRSxDQUFDO0lBRUQsU0FBUyxDQUFDLENBQVMsRUFBRSxJQUF5QjtRQUM1QyxPQUFPLElBQUksQ0FBQyxFQUFFLENBQUM7SUFDakIsQ0FBQztJQUVELGtCQUFrQixDQUFDLFlBQWlDO1FBQ2xELHVDQUNLLFlBQVksQ0FBQyxlQUFlLEtBQy9CLFNBQVMsRUFBRSxZQUFZLENBQUMsU0FBUyxJQUNqQztJQUNKLENBQUM7O3NIQWhCVSx5QkFBeUI7MEdBQXpCLHlCQUF5QixnRUNidEMsMnFCQXFCQTsyRkRSYSx5QkFBeUI7a0JBTHJDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLDBCQUEwQjtvQkFDcEMsV0FBVyxFQUFFLG9DQUFvQztvQkFDakQsTUFBTSxFQUFFLEVBQUU7aUJBQ1giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IE5vdGlmaWNhdGlvblNlcnZpY2UgfSBmcm9tICcuLi9ub3RpZmljYXRpb24uc2VydmljZSc7XG5pbXBvcnQgeyBOb3RpZmljYXRpb25QYXlsb2FkIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG4vKipcbiAqIFRoZSBgTm90aWZpY2F0aW9uTGlzdGAgY29tcG9uZW50IGRpc3BsYXlzIHRoZSBsaXN0IG9mIGFjdGl2ZSBub3RpZmljYXRpb25zLlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzdHJlYW0tbm90aWZpY2F0aW9uLWxpc3QnLFxuICB0ZW1wbGF0ZVVybDogJy4vbm90aWZpY2F0aW9uLWxpc3QuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZXM6IFtdLFxufSlcbmV4cG9ydCBjbGFzcyBOb3RpZmljYXRpb25MaXN0Q29tcG9uZW50IHtcbiAgbm90aWZpY2F0aW9ucyQ6IE9ic2VydmFibGU8Tm90aWZpY2F0aW9uUGF5bG9hZFtdPjtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIG5vdGlmaWNhdGlvblNlcnZpY2U6IE5vdGlmaWNhdGlvblNlcnZpY2UpIHtcbiAgICB0aGlzLm5vdGlmaWNhdGlvbnMkID0gdGhpcy5ub3RpZmljYXRpb25TZXJ2aWNlLm5vdGlmaWNhdGlvbnMkO1xuICB9XG5cbiAgdHJhY2tCeUlkKF86IG51bWJlciwgaXRlbTogTm90aWZpY2F0aW9uUGF5bG9hZCkge1xuICAgIHJldHVybiBpdGVtLmlkO1xuICB9XG5cbiAgZ2V0VGVtcGxhdGVDb250ZXh0KG5vdGlmaWNhdGlvbjogTm90aWZpY2F0aW9uUGF5bG9hZCkge1xuICAgIHJldHVybiB7XG4gICAgICAuLi5ub3RpZmljYXRpb24udGVtcGxhdGVDb250ZXh0LFxuICAgICAgZGlzbWlzc0ZuOiBub3RpZmljYXRpb24uZGlzbWlzc0ZuLFxuICAgIH07XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJzdHItY2hhdF9fbGlzdC1ub3RpZmljYXRpb25zXCI+XG4gIDxzdHJlYW0tbm90aWZpY2F0aW9uXG4gICAgKm5nRm9yPVwibGV0IG5vdGlmaWNhdGlvbiBvZiBub3RpZmljYXRpb25zJCB8IGFzeW5jOyB0cmFja0J5OiB0cmFja0J5SWRcIlxuICAgIFt0eXBlXT1cIm5vdGlmaWNhdGlvbi50eXBlXCJcbiAgPlxuICAgIDxkaXZcbiAgICAgICpuZ0lmPVwibm90aWZpY2F0aW9uLnRleHQgIT09IHVuZGVmaW5lZFwiXG4gICAgICBkYXRhLXRlc3RjbGFzcz1cIm5vdGlmaWNhdGlvbi1jb250ZW50XCJcbiAgICA+XG4gICAgICB7eyBub3RpZmljYXRpb24udGV4dCB8IHRyYW5zbGF0ZTogbm90aWZpY2F0aW9uLnRyYW5zbGF0ZVBhcmFtcyB9fVxuICAgIDwvZGl2PlxuICAgIDxuZy1jb250YWluZXIgKm5nSWY9XCJub3RpZmljYXRpb24udGVtcGxhdGUgIT09IHVuZGVmaW5lZFwiPlxuICAgICAgPG5nLWNvbnRhaW5lclxuICAgICAgICAqbmdUZW1wbGF0ZU91dGxldD1cIlxuICAgICAgICAgIG5vdGlmaWNhdGlvbi50ZW1wbGF0ZTtcbiAgICAgICAgICBjb250ZXh0OiBnZXRUZW1wbGF0ZUNvbnRleHQobm90aWZpY2F0aW9uKVxuICAgICAgICBcIlxuICAgICAgPjwvbmctY29udGFpbmVyPlxuICAgIDwvbmctY29udGFpbmVyPlxuICA8L3N0cmVhbS1ub3RpZmljYXRpb24+XG48L2Rpdj5cbiJdfQ==
|
|
@@ -11,40 +11,56 @@ export class NotificationService {
|
|
|
11
11
|
}
|
|
12
12
|
/**
|
|
13
13
|
* Displays a notification for the given amount of time.
|
|
14
|
-
* @param
|
|
14
|
+
* @param content The text of the notification or the HTML template for the notification
|
|
15
15
|
* @param type The type of the notification
|
|
16
16
|
* @param timeout The number of milliseconds while the notification should be visible
|
|
17
|
-
* @param translateParams Translation parameters for the `text
|
|
17
|
+
* @param translateParams Translation parameters for the `content` (for text notifications)
|
|
18
|
+
* @param templateContext The input of the notification template (for HTML notifications)
|
|
18
19
|
* @returns A method to clear the notification (before the timeout).
|
|
19
20
|
*/
|
|
20
|
-
addTemporaryNotification(
|
|
21
|
-
this.
|
|
22
|
-
const id = setTimeout(() => this.removeNotification(
|
|
23
|
-
|
|
21
|
+
addTemporaryNotification(content, type = 'error', timeout = 5000, translateParams, templateContext) {
|
|
22
|
+
const notification = this.createNotification(content, type, translateParams, templateContext);
|
|
23
|
+
const id = setTimeout(() => this.removeNotification(notification.id), timeout);
|
|
24
|
+
notification.dismissFn = () => {
|
|
24
25
|
clearTimeout(id);
|
|
25
|
-
this.removeNotification(
|
|
26
|
+
this.removeNotification(notification.id);
|
|
26
27
|
};
|
|
28
|
+
this.notificationsSubject.next([
|
|
29
|
+
...this.notificationsSubject.getValue(),
|
|
30
|
+
notification,
|
|
31
|
+
]);
|
|
32
|
+
return notification.dismissFn;
|
|
27
33
|
}
|
|
28
34
|
/**
|
|
29
35
|
* Displays a notification, that will be visible until it's removed.
|
|
30
|
-
* @param
|
|
36
|
+
* @param content The text of the notification or the HTML template for the notification
|
|
31
37
|
* @param type The type of the notification
|
|
32
|
-
* @param translateParams Translation parameters for the `text
|
|
38
|
+
* @param translateParams Translation parameters for the `content` (for text notifications)
|
|
39
|
+
* @param templateContext The input of the notification template (for HTML notifications)
|
|
33
40
|
* @returns A method to clear the notification.
|
|
34
41
|
*/
|
|
35
|
-
addPermanentNotification(
|
|
36
|
-
this.
|
|
37
|
-
return () => this.removeNotification(text);
|
|
38
|
-
}
|
|
39
|
-
addNotification(text, type, translateParams) {
|
|
42
|
+
addPermanentNotification(content, type = 'error', translateParams, templateContext) {
|
|
43
|
+
const notification = this.createNotification(content, type, translateParams, templateContext);
|
|
40
44
|
this.notificationsSubject.next([
|
|
41
45
|
...this.notificationsSubject.getValue(),
|
|
42
|
-
|
|
46
|
+
notification,
|
|
43
47
|
]);
|
|
48
|
+
return notification.dismissFn;
|
|
49
|
+
}
|
|
50
|
+
createNotification(content, type, translateParams, templateContext) {
|
|
51
|
+
const id = new Date().getTime().toString() + Math.random().toString();
|
|
52
|
+
return {
|
|
53
|
+
id,
|
|
54
|
+
[typeof content === 'string' ? 'text' : 'template']: content,
|
|
55
|
+
type,
|
|
56
|
+
translateParams,
|
|
57
|
+
templateContext,
|
|
58
|
+
dismissFn: () => this.removeNotification(id),
|
|
59
|
+
};
|
|
44
60
|
}
|
|
45
|
-
removeNotification(
|
|
61
|
+
removeNotification(id) {
|
|
46
62
|
const notifications = this.notificationsSubject.getValue();
|
|
47
|
-
const index = notifications.findIndex((n) => n.
|
|
63
|
+
const index = notifications.findIndex((n) => n.id === id);
|
|
48
64
|
if (index === -1) {
|
|
49
65
|
return;
|
|
50
66
|
}
|
|
@@ -60,4 +76,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
|
|
|
60
76
|
providedIn: 'root',
|
|
61
77
|
}]
|
|
62
78
|
}], ctorParameters: function () { return []; } });
|
|
63
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notification.service.js","sourceRoot":"","sources":["../../../../projects/stream-chat-angular/src/lib/notification.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAe,MAAM,eAAe,CAAC;AACxD,OAAO,EAAE,eAAe,EAAc,MAAM,MAAM,CAAC;;AAGnD;;GAEG;AAIH,MAAM,OAAO,mBAAmB;IAO9B;QAFQ,yBAAoB,GAAG,IAAI,eAAe,CAAwB,EAAE,CAAC,CAAC;QAG5E,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,oBAAoB,CAAC,YAAY,EAAE,CAAC;IACjE,CAAC;IAED;;;;;;;;OAQG;IACH,wBAAwB,CACtB,OAAgC,EAChC,OAAyB,OAAO,EAChC,UAAkB,IAAI,EACtB,eAAwB,EACxB,eAAmB;QAEnB,MAAM,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAC1C,OAAO,EACP,IAAI,EACJ,eAAe,EACf,eAAe,CAChB,CAAC;QACF,MAAM,EAAE,GAAG,UAAU,CACnB,GAAG,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,YAAY,CAAC,EAAE,CAAC,EAC9C,OAAO,CACR,CAAC;QACF,YAAY,CAAC,SAAS,GAAG,GAAG,EAAE;YAC5B,YAAY,CAAC,EAAE,CAAC,CAAC;YACjB,IAAI,CAAC,kBAAkB,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC;QAC3C,CAAC,CAAC;QACF,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC;YAC7B,GAAG,IAAI,CAAC,oBAAoB,CAAC,QAAQ,EAAE;YACvC,YAAY;SACb,CAAC,CAAC;QAEH,OAAO,YAAY,CAAC,SAAS,CAAC;IAChC,CAAC;IAED;;;;;;;OAOG;IACH,wBAAwB,CAMtB,OAAgC,EAChC,OAAyB,OAAO,EAChC,eAAwB,EACxB,eAAmB;QAEnB,MAAM,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAC1C,OAAO,EACP,IAAI,EACJ,eAAe,EACf,eAAe,CAChB,CAAC;QACF,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC;YAC7B,GAAG,IAAI,CAAC,oBAAoB,CAAC,QAAQ,EAAE;YACvC,YAAY;SACb,CAAC,CAAC;QAEH,OAAO,YAAY,CAAC,SAAS,CAAC;IAChC,CAAC;IAEO,kBAAkB,CACxB,OAAgC,EAChC,IAAsB,EACtB,eAAwB,EACxB,eAAmB;QAEnB,MAAM,EAAE,GAAG,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE,CAAC;QACtE,OAAO;YACL,EAAE;YACF,CAAC,OAAO,OAAO,KAAK,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,EAAE,OAAO;YAC5D,IAAI;YACJ,eAAe;YACf,eAAe;YACf,SAAS,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,EAAE,CAAC;SAC7C,CAAC;IACJ,CAAC;IAEO,kBAAkB,CAAC,EAAU;QACnC,MAAM,aAAa,GAAG,IAAI,CAAC,oBAAoB,CAAC,QAAQ,EAAE,CAAC;QAC3D,MAAM,KAAK,GAAG,aAAa,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;QAC1D,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE;YAChB,OAAO;SACR;QACD,aAAa,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;QAC/B,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC,GAAG,aAAa,CAAC,CAAC,CAAC;IACrD,CAAC;;gHA3GU,mBAAmB;oHAAnB,mBAAmB,cAFlB,MAAM;2FAEP,mBAAmB;kBAH/B,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","sourcesContent":["import { Injectable, TemplateRef } from '@angular/core';\nimport { BehaviorSubject, Observable } from 'rxjs';\nimport { NotificationPayload, NotificationType } from './types';\n\n/**\n * The `NotificationService` can be used to add or remove notifications. By default the [`NotificationList`](../components/NotificationListComponent.mdx) component displays the currently active notifications.\n */\n@Injectable({\n  providedIn: 'root',\n})\nexport class NotificationService {\n  /**\n   * Emits the currently active [notifications](https://github.com/GetStream/stream-chat-angular/blob/master/projects/stream-chat-angular/src/lib/notification.service.ts).\n   */\n  notifications$: Observable<NotificationPayload[]>;\n  private notificationsSubject = new BehaviorSubject<NotificationPayload[]>([]);\n\n  constructor() {\n    this.notifications$ = this.notificationsSubject.asObservable();\n  }\n\n  /**\n   * Displays a notification for the given amount of time.\n   * @param content The text of the notification or the HTML template for the notification\n   * @param type The type of the notification\n   * @param timeout The number of milliseconds while the notification should be visible\n   * @param translateParams Translation parameters for the `content` (for text notifications)\n   * @param templateContext The input of the notification template (for HTML notifications)\n   * @returns A method to clear the notification (before the timeout).\n   */\n  addTemporaryNotification<T>(\n    content: string | TemplateRef<T>,\n    type: NotificationType = 'error',\n    timeout: number = 5000,\n    translateParams?: Object,\n    templateContext?: T\n  ) {\n    const notification = this.createNotification<T>(\n      content,\n      type,\n      translateParams,\n      templateContext\n    );\n    const id = setTimeout(\n      () => this.removeNotification(notification.id),\n      timeout\n    );\n    notification.dismissFn = () => {\n      clearTimeout(id);\n      this.removeNotification(notification.id);\n    };\n    this.notificationsSubject.next([\n      ...this.notificationsSubject.getValue(),\n      notification,\n    ]);\n\n    return notification.dismissFn;\n  }\n\n  /**\n   * Displays a notification, that will be visible until it's removed.\n   * @param content The text of the notification or the HTML template for the notification\n   * @param type The type of the notification\n   * @param translateParams Translation parameters for the `content` (for text notifications)\n   * @param templateContext The input of the notification template (for HTML notifications)\n   * @returns A method to clear the notification.\n   */\n  addPermanentNotification<\n    T = {\n      [key: string]: any;\n      dismissFn: () => {};\n    }\n  >(\n    content: string | TemplateRef<T>,\n    type: NotificationType = 'error',\n    translateParams?: Object,\n    templateContext?: T\n  ) {\n    const notification = this.createNotification<T>(\n      content,\n      type,\n      translateParams,\n      templateContext\n    );\n    this.notificationsSubject.next([\n      ...this.notificationsSubject.getValue(),\n      notification,\n    ]);\n\n    return notification.dismissFn;\n  }\n\n  private createNotification<T>(\n    content: string | TemplateRef<T>,\n    type: NotificationType,\n    translateParams?: Object,\n    templateContext?: T\n  ) {\n    const id = new Date().getTime().toString() + Math.random().toString();\n    return {\n      id,\n      [typeof content === 'string' ? 'text' : 'template']: content,\n      type,\n      translateParams,\n      templateContext,\n      dismissFn: () => this.removeNotification(id),\n    };\n  }\n\n  private removeNotification(id: string) {\n    const notifications = this.notificationsSubject.getValue();\n    const index = notifications.findIndex((n) => n.id === id);\n    if (index === -1) {\n      return;\n    }\n    notifications.splice(index, 1);\n    this.notificationsSubject.next([...notifications]);\n  }\n}\n"]}
|
package/esm2015/lib/types.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9zdHJlYW0tY2hhdC1hbmd1bGFyL3NyYy9saWIvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRlbXBsYXRlUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgdHlwZSB7XG4gIEF0dGFjaG1lbnQsXG4gIENoYW5uZWxNZW1iZXJSZXNwb25zZSxcbiAgQ29tbWFuZFJlc3BvbnNlLFxuICBFdmVudCxcbiAgRm9ybWF0TWVzc2FnZVJlc3BvbnNlLFxuICBMaXRlcmFsU3RyaW5nRm9yVW5pb24sXG4gIE11dGUsXG4gIFVzZXJSZXNwb25zZSxcbn0gZnJvbSAnc3RyZWFtLWNoYXQnO1xuXG5leHBvcnQgdHlwZSBVbmtub3duVHlwZSA9IFJlY29yZDxzdHJpbmcsIHVua25vd24+O1xuXG5leHBvcnQgdHlwZSBDdXN0b21UcmlnZ2VyID0ge1xuICBba2V5OiBzdHJpbmddOiB7XG4gICAgY29tcG9uZW50UHJvcHM6IFVua25vd25UeXBlO1xuICAgIGRhdGE6IFVua25vd25UeXBlO1xuICB9O1xufTtcblxuZXhwb3J0IHR5cGUgRGVmYXVsdEF0dGFjaG1lbnRUeXBlID0gVW5rbm93blR5cGUgJiB7XG4gIGFzc2V0X3VybD86IHN0cmluZztcbiAgaWQ/OiBzdHJpbmc7XG4gIGltYWdlcz86IEFycmF5PEF0dGFjaG1lbnQ8RGVmYXVsdEF0dGFjaG1lbnRUeXBlPj47XG4gIG1pbWVfdHlwZT86IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIERlZmF1bHRDaGFubmVsVHlwZSA9IFVua25vd25UeXBlICYge1xuICBpbWFnZT86IHN0cmluZztcbiAgbWVtYmVyX2NvdW50PzogbnVtYmVyO1xuICBzdWJ0aXRsZT86IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIERlZmF1bHRDb21tYW5kVHlwZSA9IExpdGVyYWxTdHJpbmdGb3JVbmlvbjtcblxuZXhwb3J0IHR5cGUgRGVmYXVsdEV2ZW50VHlwZSA9IFVua25vd25UeXBlO1xuXG5leHBvcnQgdHlwZSBEZWZhdWx0TWVzc2FnZVR5cGUgPSBVbmtub3duVHlwZSAmIHtcbiAgY3VzdG9tVHlwZT86ICdjaGFubmVsLmludHJvJyB8ICdtZXNzYWdlLmRhdGUnO1xuICBkYXRlPzogc3RyaW5nIHwgRGF0ZTtcbiAgZXJyb3JTdGF0dXNDb2RlPzogbnVtYmVyO1xuICBldmVudD86IEV2ZW50PFxuICAgIERlZmF1bHRBdHRhY2htZW50VHlwZSxcbiAgICBEZWZhdWx0Q2hhbm5lbFR5cGUsXG4gICAgRGVmYXVsdENvbW1hbmRUeXBlLFxuICAgIERlZmF1bHRFdmVudFR5cGUsXG4gICAgRGVmYXVsdE1lc3NhZ2VUeXBlLFxuICAgIERlZmF1bHRSZWFjdGlvblR5cGUsXG4gICAgRGVmYXVsdFVzZXJUeXBlXG4gID47XG4gIHVucmVhZD86IGJvb2xlYW47XG4gIHJlYWRCeTogVXNlclJlc3BvbnNlPERlZmF1bHRVc2VyVHlwZT5bXTtcbn07XG5cbmV4cG9ydCB0eXBlIERlZmF1bHRSZWFjdGlvblR5cGUgPSBVbmtub3duVHlwZTtcblxuZXhwb3J0IHR5cGUgRGVmYXVsdFVzZXJUeXBlSW50ZXJuYWwgPSB7XG4gIGltYWdlPzogc3RyaW5nO1xuICBzdGF0dXM/OiBzdHJpbmc7XG59O1xuXG5leHBvcnQgdHlwZSBEZWZhdWx0VXNlclR5cGU8XG4gIFVzZXJUeXBlIGV4dGVuZHMgRGVmYXVsdFVzZXJUeXBlSW50ZXJuYWwgPSBEZWZhdWx0VXNlclR5cGVJbnRlcm5hbFxuPiA9IFVua25vd25UeXBlICZcbiAgRGVmYXVsdFVzZXJUeXBlSW50ZXJuYWwgJiB7XG4gICAgbXV0ZXM/OiBBcnJheTxNdXRlPFVzZXJUeXBlPj47XG4gIH07XG5cbmV4cG9ydCB0eXBlIFN0cmVhbU1lc3NhZ2U8XG4gIEF0IGV4dGVuZHMgRGVmYXVsdEF0dGFjaG1lbnRUeXBlID0gRGVmYXVsdEF0dGFjaG1lbnRUeXBlLFxuICBDaCBleHRlbmRzIERlZmF1bHRDaGFubmVsVHlwZSA9IERlZmF1bHRDaGFubmVsVHlwZSxcbiAgQ28gZXh0ZW5kcyBEZWZhdWx0Q29tbWFuZFR5cGUgPSBEZWZhdWx0Q29tbWFuZFR5cGUsXG4gIE1lIGV4dGVuZHMgRGVmYXVsdE1lc3NhZ2VUeXBlID0gRGVmYXVsdE1lc3NhZ2VUeXBlLFxuICBSZSBleHRlbmRzIERlZmF1bHRSZWFjdGlvblR5cGUgPSBEZWZhdWx0UmVhY3Rpb25UeXBlLFxuICBVcyBleHRlbmRzIERlZmF1bHRVc2VyVHlwZTxVcz4gPSBEZWZhdWx0VXNlclR5cGVcbj4gPSBGb3JtYXRNZXNzYWdlUmVzcG9uc2U8QXQsIENoLCBDbywgTWUsIFJlLCBVcz47XG5cbmV4cG9ydCB0eXBlIEF0dGFjaG1lbnRVcGxvYWQgPSB7XG4gIGZpbGU6IEZpbGU7XG4gIHN0YXRlOiAnZXJyb3InIHwgJ3N1Y2Nlc3MnIHwgJ3VwbG9hZGluZyc7XG4gIHVybD86IHN0cmluZztcbiAgdHlwZTogJ2ltYWdlJyB8ICdmaWxlJztcbiAgcHJldmlld1VyaT86IHN0cmluZyB8IEFycmF5QnVmZmVyO1xufTtcblxuZXhwb3J0IHR5cGUgTWVudGlvbkF1dGNvbXBsZXRlTGlzdEl0ZW1Db250ZXh0ID0ge1xuICBpdGVtOiBNZW50aW9uQXV0Y29tcGxldGVMaXN0SXRlbTtcbn07XG5cbmV4cG9ydCB0eXBlIENvbW1hbmRBdXRvY29tcGxldGVMaXN0SXRlbUNvbnRleHQgPSB7XG4gIGl0ZW06IENvbWFuZEF1dG9jb21wbGV0ZUxpc3RJdGVtO1xufTtcblxuZXhwb3J0IHR5cGUgTWVudGlvbkF1dGNvbXBsZXRlTGlzdEl0ZW0gPSAoXG4gIHwgQ2hhbm5lbE1lbWJlclJlc3BvbnNlXG4gIHwgVXNlclJlc3BvbnNlXG4pICYge1xuICBhdXRvY29tcGxldGVMYWJlbDogc3RyaW5nO1xufTtcblxuZXhwb3J0IHR5cGUgQ29tYW5kQXV0b2NvbXBsZXRlTGlzdEl0ZW0gPSBDb21tYW5kUmVzcG9uc2UgJiB7XG4gIGF1dG9jb21wbGV0ZUxhYmVsOiBzdHJpbmc7XG59O1xuXG5leHBvcnQgdHlwZSBOb3RpZmljYXRpb25UeXBlID0gJ3N1Y2Nlc3MnIHwgJ2Vycm9yJyB8ICdpbmZvJztcblxuZXhwb3J0IHR5cGUgTm90aWZpY2F0aW9uUGF5bG9hZDxUID0ge30+ID0ge1xuICBpZDogc3RyaW5nO1xuICB0eXBlOiBOb3RpZmljYXRpb25UeXBlO1xuICB0ZXh0Pzogc3RyaW5nO1xuICB0cmFuc2xhdGVQYXJhbXM/OiBPYmplY3Q7XG4gIHRlbXBsYXRlPzogVGVtcGxhdGVSZWY8VD47XG4gIHRlbXBsYXRlQ29udGV4dD86IFQ7XG4gIGRpc21pc3NGbjogRnVuY3Rpb247XG59O1xuIl19
|