@banta/sdk 5.2.5 → 5.4.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/{esm2022 → esm2020}/banta-sdk.mjs +4 -4
- package/{esm2022 → esm2020}/lib/attachment-scraper.mjs +1 -1
- package/esm2020/lib/banta/banta.component.mjs +204 -0
- package/{esm2022 → esm2020}/lib/banta-logo.component.mjs +11 -11
- package/{esm2022 → esm2020}/lib/banta-sdk.module.mjs +135 -135
- package/esm2020/lib/chat/banta-chat/banta-chat.component.mjs +209 -0
- package/esm2020/lib/chat/chat-message/chat-message.component.mjs +62 -0
- package/esm2020/lib/chat/chat-view/chat-view.component.mjs +170 -0
- package/{esm2022 → esm2020}/lib/chat/chat.module.mjs +51 -51
- package/{esm2022 → esm2020}/lib/chat/index.mjs +5 -5
- package/esm2020/lib/chat/live-chat-message.component.mjs +80 -0
- package/esm2020/lib/chat-backend-base.mjs +31 -0
- package/esm2020/lib/chat-backend.mjs +194 -0
- package/{esm2022 → esm2020}/lib/chat-source-base.mjs +1 -1
- package/esm2020/lib/chat-source.mjs +233 -0
- package/esm2020/lib/comments/attachment-button/attachment-button.component.mjs +76 -0
- package/esm2020/lib/comments/attachment-scraper.directive.mjs +107 -0
- package/esm2020/lib/comments/banta-comments/banta-comments.component.mjs +749 -0
- package/esm2020/lib/comments/comment/comment.component.mjs +175 -0
- package/esm2020/lib/comments/comment-field/comment-field.component.mjs +401 -0
- package/esm2020/lib/comments/comment-sort/comment-sort.component.mjs +37 -0
- package/esm2020/lib/comments/comment-view/comment-view.component.mjs +470 -0
- package/{esm2022 → esm2020}/lib/comments/comments.module.mjs +111 -111
- package/{esm2022 → esm2020}/lib/comments/index.mjs +10 -10
- package/esm2020/lib/comments/live-comment.component.mjs +80 -0
- package/{esm2022 → esm2020}/lib/comments/reply-send-options.directive.mjs +13 -13
- package/esm2020/lib/common/attachment/attachment.component.mjs +128 -0
- package/{esm2022 → esm2020}/lib/common/attachments/attachments.component.mjs +75 -75
- package/{esm2022 → esm2020}/lib/common/common.module.mjs +68 -68
- package/{esm2022 → esm2020}/lib/common/index.mjs +10 -10
- package/{esm2022 → esm2020}/lib/common/lazy-connection.mjs +14 -14
- package/esm2020/lib/common/lightbox/lightbox.component.mjs +31 -0
- package/esm2020/lib/common/markdown-to-html.pipe.mjs +88 -0
- package/esm2020/lib/common/mention-linker.pipe.mjs +35 -0
- package/esm2020/lib/common/timer-pool.service.mjs +83 -0
- package/esm2020/lib/common/timestamp.component.mjs +123 -0
- package/{esm2022 → esm2020}/lib/common/trust-resource-url.pipe.mjs +22 -22
- package/esm2020/lib/emoji/emoji-selector-button.component.mjs +116 -0
- package/esm2020/lib/emoji/emoji-selector-panel/emoji-selector-panel.component.mjs +98 -0
- package/{esm2022 → esm2020}/lib/emoji/emoji.module.mjs +55 -55
- package/{esm2022 → esm2020}/lib/emoji/emojis.mjs +6507 -6507
- package/{esm2022 → esm2020}/lib/emoji/index.mjs +4 -4
- package/esm2020/lib/giphy-attachments.mjs +16 -0
- package/{esm2022 → esm2020}/lib/index.mjs +19 -19
- package/{esm2022 → esm2020}/lib/live-message.component.mjs +61 -61
- package/{esm2022 → esm2020}/lib/message-menu-item.mjs +1 -1
- package/{esm2022 → esm2020}/lib/sdk-options.mjs +1 -1
- package/esm2020/lib/static-chat-source.mjs +71 -0
- package/esm2020/lib/tweet-attachments.mjs +13 -0
- package/esm2020/lib/url-attachments.mjs +42 -0
- package/esm2020/lib/youtube-attachments.mjs +29 -0
- package/{esm2022 → esm2020}/public-api.mjs +4 -4
- package/fesm2015/banta-sdk.mjs +11258 -0
- package/fesm2015/banta-sdk.mjs.map +1 -0
- package/{fesm2022 → fesm2020}/banta-sdk.mjs +10823 -10782
- package/fesm2020/banta-sdk.mjs.map +1 -0
- package/index.d.ts +5 -5
- package/lib/attachment-scraper.d.ts +15 -15
- package/lib/banta/banta.component.d.ts +58 -58
- package/lib/banta-logo.component.d.ts +5 -5
- package/lib/banta-sdk.module.d.ts +31 -31
- package/lib/chat/banta-chat/banta-chat.component.d.ts +79 -70
- package/lib/chat/chat-message/chat-message.component.d.ts +21 -21
- package/lib/chat/chat-view/chat-view.component.d.ts +52 -52
- package/lib/chat/chat.module.d.ts +15 -15
- package/lib/chat/index.d.ts +5 -5
- package/lib/chat/live-chat-message.component.d.ts +23 -23
- package/lib/chat-backend-base.d.ts +72 -71
- package/lib/chat-backend.d.ts +67 -67
- package/lib/chat-source-base.d.ts +44 -44
- package/lib/chat-source.d.ts +65 -65
- package/lib/comments/attachment-button/attachment-button.component.d.ts +17 -17
- package/lib/comments/attachment-scraper.directive.d.ts +21 -21
- package/lib/comments/banta-comments/banta-comments.component.d.ts +203 -196
- package/lib/comments/comment/comment.component.d.ts +72 -72
- package/lib/comments/comment-field/comment-field.component.d.ts +89 -89
- package/lib/comments/comment-sort/comment-sort.component.d.ts +16 -16
- package/lib/comments/comment-view/comment-view.component.d.ts +121 -121
- package/lib/comments/comments.module.d.ts +30 -30
- package/lib/comments/index.d.ts +10 -10
- package/lib/comments/live-comment.component.d.ts +23 -23
- package/lib/comments/reply-send-options.directive.d.ts +5 -5
- package/lib/common/attachment/attachment.component.d.ts +34 -34
- package/lib/common/attachments/attachments.component.d.ts +26 -26
- package/lib/common/common.module.d.ts +19 -19
- package/lib/common/index.d.ts +10 -10
- package/lib/common/lazy-connection.d.ts +6 -6
- package/lib/common/lightbox/lightbox.component.d.ts +14 -14
- package/lib/common/markdown-to-html.pipe.d.ts +15 -15
- package/lib/common/mention-linker.pipe.d.ts +13 -13
- package/lib/common/timer-pool.service.d.ts +15 -15
- package/lib/common/timestamp.component.d.ts +19 -19
- package/lib/common/trust-resource-url.pipe.d.ts +10 -10
- package/lib/emoji/emoji-selector-button.component.d.ts +30 -30
- package/lib/emoji/emoji-selector-panel/emoji-selector-panel.component.d.ts +26 -26
- package/lib/emoji/emoji.module.d.ts +16 -16
- package/lib/emoji/emojis.d.ts +6507 -6507
- package/lib/emoji/index.d.ts +4 -4
- package/lib/giphy-attachments.d.ts +5 -5
- package/lib/index.d.ts +19 -19
- package/lib/live-message.component.d.ts +22 -22
- package/lib/message-menu-item.d.ts +6 -6
- package/lib/sdk-options.d.ts +5 -5
- package/lib/static-chat-source.d.ts +42 -42
- package/lib/tweet-attachments.d.ts +5 -5
- package/lib/url-attachments.d.ts +14 -14
- package/lib/youtube-attachments.d.ts +5 -5
- package/package.json +11 -5
- package/public-api.d.ts +1 -1
- package/esm2022/lib/banta/banta.component.mjs +0 -204
- package/esm2022/lib/chat/banta-chat/banta-chat.component.mjs +0 -187
- package/esm2022/lib/chat/chat-message/chat-message.component.mjs +0 -62
- package/esm2022/lib/chat/chat-view/chat-view.component.mjs +0 -170
- package/esm2022/lib/chat/live-chat-message.component.mjs +0 -80
- package/esm2022/lib/chat-backend-base.mjs +0 -31
- package/esm2022/lib/chat-backend.mjs +0 -194
- package/esm2022/lib/chat-source.mjs +0 -233
- package/esm2022/lib/comments/attachment-button/attachment-button.component.mjs +0 -76
- package/esm2022/lib/comments/attachment-scraper.directive.mjs +0 -107
- package/esm2022/lib/comments/banta-comments/banta-comments.component.mjs +0 -730
- package/esm2022/lib/comments/comment/comment.component.mjs +0 -175
- package/esm2022/lib/comments/comment-field/comment-field.component.mjs +0 -401
- package/esm2022/lib/comments/comment-sort/comment-sort.component.mjs +0 -37
- package/esm2022/lib/comments/comment-view/comment-view.component.mjs +0 -470
- package/esm2022/lib/comments/live-comment.component.mjs +0 -80
- package/esm2022/lib/common/attachment/attachment.component.mjs +0 -128
- package/esm2022/lib/common/lightbox/lightbox.component.mjs +0 -31
- package/esm2022/lib/common/markdown-to-html.pipe.mjs +0 -88
- package/esm2022/lib/common/mention-linker.pipe.mjs +0 -35
- package/esm2022/lib/common/timer-pool.service.mjs +0 -83
- package/esm2022/lib/common/timestamp.component.mjs +0 -123
- package/esm2022/lib/emoji/emoji-selector-button.component.mjs +0 -115
- package/esm2022/lib/emoji/emoji-selector-panel/emoji-selector-panel.component.mjs +0 -98
- package/esm2022/lib/giphy-attachments.mjs +0 -16
- package/esm2022/lib/static-chat-source.mjs +0 -71
- package/esm2022/lib/tweet-attachments.mjs +0 -13
- package/esm2022/lib/url-attachments.mjs +0 -42
- package/esm2022/lib/youtube-attachments.mjs +0 -29
- package/fesm2022/banta-sdk.mjs.map +0 -1
|
@@ -1,135 +1,135 @@
|
|
|
1
|
-
import { NgModule } from '@angular/core';
|
|
2
|
-
import { CommentsModule } from './comments';
|
|
3
|
-
import { ChatModule } from './chat';
|
|
4
|
-
import { EmojiModule } from './emoji';
|
|
5
|
-
import { BantaComponent } from './banta/banta.component';
|
|
6
|
-
import { BantaLogoComponent } from './banta-logo.component';
|
|
7
|
-
import { CommonModule } from '@angular/common';
|
|
8
|
-
import { FormsModule } from '@angular/forms';
|
|
9
|
-
import { BantaCommonModule } from './common/common.module';
|
|
10
|
-
import { LiveMessageComponent } from './live-message.component';
|
|
11
|
-
import { MatButtonModule } from "@angular/material/button";
|
|
12
|
-
import { MatIconModule } from "@angular/material/icon";
|
|
13
|
-
import { MatTooltipModule } from "@angular/material/tooltip";
|
|
14
|
-
import { MatMenuModule } from "@angular/material/menu";
|
|
15
|
-
import { MatDialogModule } from "@angular/material/dialog";
|
|
16
|
-
import { MatSnackBarModule } from "@angular/material/snack-bar";
|
|
17
|
-
import { MatFormFieldModule } from "@angular/material/form-field";
|
|
18
|
-
import { MatInputModule } from "@angular/material/input";
|
|
19
|
-
import { MatProgressSpinnerModule } from "@angular/material/progress-spinner";
|
|
20
|
-
import { ChatBackend } from './chat-backend';
|
|
21
|
-
import { BANTA_SDK_OPTIONS } from './sdk-options';
|
|
22
|
-
import { ChatBackendBase } from './chat-backend-base';
|
|
23
|
-
import { OverlayModule } from '@angular/cdk/overlay';
|
|
24
|
-
import { PortalModule } from '@angular/cdk/portal';
|
|
25
|
-
import { UrlAttachmentResolver, UrlAttachmentScraper } from './url-attachments';
|
|
26
|
-
import { YouTubeAttachmentResolver } from './youtube-attachments';
|
|
27
|
-
import { GiphyAttachmentResolver } from './giphy-attachments';
|
|
28
|
-
import { TweetAttachmentResolver } from './tweet-attachments';
|
|
29
|
-
import * as i0 from "@angular/core";
|
|
30
|
-
import * as i1 from "./chat-backend-base";
|
|
31
|
-
import * as i2 from "./common/common.module";
|
|
32
|
-
export class BantaSdkModule {
|
|
33
|
-
constructor(chatBackend) {
|
|
34
|
-
chatBackend.registerAttachmentScraper(new UrlAttachmentScraper());
|
|
35
|
-
chatBackend.registerAttachmentResolver(new GiphyAttachmentResolver());
|
|
36
|
-
chatBackend.registerAttachmentResolver(new YouTubeAttachmentResolver());
|
|
37
|
-
chatBackend.registerAttachmentResolver(new TweetAttachmentResolver());
|
|
38
|
-
chatBackend.registerAttachmentResolver(new UrlAttachmentResolver(chatBackend));
|
|
39
|
-
}
|
|
40
|
-
static configure(options) {
|
|
41
|
-
return {
|
|
42
|
-
ngModule: BantaSdkModule,
|
|
43
|
-
providers: [
|
|
44
|
-
{
|
|
45
|
-
provide: BANTA_SDK_OPTIONS,
|
|
46
|
-
useValue: options || {}
|
|
47
|
-
},
|
|
48
|
-
{ provide: ChatBackendBase, useClass: ChatBackend }
|
|
49
|
-
]
|
|
50
|
-
};
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
}
|
|
97
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
98
|
-
type: NgModule,
|
|
99
|
-
args: [{
|
|
100
|
-
imports: [
|
|
101
|
-
CommonModule,
|
|
102
|
-
FormsModule,
|
|
103
|
-
BantaCommonModule.forRoot(),
|
|
104
|
-
CommentsModule,
|
|
105
|
-
ChatModule,
|
|
106
|
-
EmojiModule,
|
|
107
|
-
MatIconModule,
|
|
108
|
-
MatButtonModule,
|
|
109
|
-
MatTooltipModule,
|
|
110
|
-
MatMenuModule,
|
|
111
|
-
MatDialogModule,
|
|
112
|
-
MatFormFieldModule,
|
|
113
|
-
MatInputModule,
|
|
114
|
-
MatProgressSpinnerModule,
|
|
115
|
-
MatSnackBarModule,
|
|
116
|
-
OverlayModule,
|
|
117
|
-
PortalModule
|
|
118
|
-
],
|
|
119
|
-
declarations: [
|
|
120
|
-
BantaComponent,
|
|
121
|
-
BantaLogoComponent,
|
|
122
|
-
LiveMessageComponent
|
|
123
|
-
],
|
|
124
|
-
exports: [
|
|
125
|
-
BantaComponent,
|
|
126
|
-
BantaLogoComponent,
|
|
127
|
-
LiveMessageComponent,
|
|
128
|
-
BantaCommonModule,
|
|
129
|
-
ChatModule,
|
|
130
|
-
CommentsModule,
|
|
131
|
-
EmojiModule
|
|
132
|
-
]
|
|
133
|
-
}]
|
|
134
|
-
}], ctorParameters: ()
|
|
135
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommentsModule } from './comments';
|
|
3
|
+
import { ChatModule } from './chat';
|
|
4
|
+
import { EmojiModule } from './emoji';
|
|
5
|
+
import { BantaComponent } from './banta/banta.component';
|
|
6
|
+
import { BantaLogoComponent } from './banta-logo.component';
|
|
7
|
+
import { CommonModule } from '@angular/common';
|
|
8
|
+
import { FormsModule } from '@angular/forms';
|
|
9
|
+
import { BantaCommonModule } from './common/common.module';
|
|
10
|
+
import { LiveMessageComponent } from './live-message.component';
|
|
11
|
+
import { MatButtonModule } from "@angular/material/button";
|
|
12
|
+
import { MatIconModule } from "@angular/material/icon";
|
|
13
|
+
import { MatTooltipModule } from "@angular/material/tooltip";
|
|
14
|
+
import { MatMenuModule } from "@angular/material/menu";
|
|
15
|
+
import { MatDialogModule } from "@angular/material/dialog";
|
|
16
|
+
import { MatSnackBarModule } from "@angular/material/snack-bar";
|
|
17
|
+
import { MatFormFieldModule } from "@angular/material/form-field";
|
|
18
|
+
import { MatInputModule } from "@angular/material/input";
|
|
19
|
+
import { MatProgressSpinnerModule } from "@angular/material/progress-spinner";
|
|
20
|
+
import { ChatBackend } from './chat-backend';
|
|
21
|
+
import { BANTA_SDK_OPTIONS } from './sdk-options';
|
|
22
|
+
import { ChatBackendBase } from './chat-backend-base';
|
|
23
|
+
import { OverlayModule } from '@angular/cdk/overlay';
|
|
24
|
+
import { PortalModule } from '@angular/cdk/portal';
|
|
25
|
+
import { UrlAttachmentResolver, UrlAttachmentScraper } from './url-attachments';
|
|
26
|
+
import { YouTubeAttachmentResolver } from './youtube-attachments';
|
|
27
|
+
import { GiphyAttachmentResolver } from './giphy-attachments';
|
|
28
|
+
import { TweetAttachmentResolver } from './tweet-attachments';
|
|
29
|
+
import * as i0 from "@angular/core";
|
|
30
|
+
import * as i1 from "./chat-backend-base";
|
|
31
|
+
import * as i2 from "./common/common.module";
|
|
32
|
+
export class BantaSdkModule {
|
|
33
|
+
constructor(chatBackend) {
|
|
34
|
+
chatBackend.registerAttachmentScraper(new UrlAttachmentScraper());
|
|
35
|
+
chatBackend.registerAttachmentResolver(new GiphyAttachmentResolver());
|
|
36
|
+
chatBackend.registerAttachmentResolver(new YouTubeAttachmentResolver());
|
|
37
|
+
chatBackend.registerAttachmentResolver(new TweetAttachmentResolver());
|
|
38
|
+
chatBackend.registerAttachmentResolver(new UrlAttachmentResolver(chatBackend));
|
|
39
|
+
}
|
|
40
|
+
static configure(options) {
|
|
41
|
+
return {
|
|
42
|
+
ngModule: BantaSdkModule,
|
|
43
|
+
providers: [
|
|
44
|
+
{
|
|
45
|
+
provide: BANTA_SDK_OPTIONS,
|
|
46
|
+
useValue: options || {}
|
|
47
|
+
},
|
|
48
|
+
{ provide: ChatBackendBase, useClass: ChatBackend }
|
|
49
|
+
]
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
BantaSdkModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: BantaSdkModule, deps: [{ token: i1.ChatBackendBase }], target: i0.ɵɵFactoryTarget.NgModule });
|
|
54
|
+
BantaSdkModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: BantaSdkModule, declarations: [BantaComponent,
|
|
55
|
+
BantaLogoComponent,
|
|
56
|
+
LiveMessageComponent], imports: [CommonModule,
|
|
57
|
+
FormsModule, i2.BantaCommonModule, CommentsModule,
|
|
58
|
+
ChatModule,
|
|
59
|
+
EmojiModule,
|
|
60
|
+
MatIconModule,
|
|
61
|
+
MatButtonModule,
|
|
62
|
+
MatTooltipModule,
|
|
63
|
+
MatMenuModule,
|
|
64
|
+
MatDialogModule,
|
|
65
|
+
MatFormFieldModule,
|
|
66
|
+
MatInputModule,
|
|
67
|
+
MatProgressSpinnerModule,
|
|
68
|
+
MatSnackBarModule,
|
|
69
|
+
OverlayModule,
|
|
70
|
+
PortalModule], exports: [BantaComponent,
|
|
71
|
+
BantaLogoComponent,
|
|
72
|
+
LiveMessageComponent,
|
|
73
|
+
BantaCommonModule,
|
|
74
|
+
ChatModule,
|
|
75
|
+
CommentsModule,
|
|
76
|
+
EmojiModule] });
|
|
77
|
+
BantaSdkModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: BantaSdkModule, imports: [CommonModule,
|
|
78
|
+
FormsModule,
|
|
79
|
+
BantaCommonModule.forRoot(),
|
|
80
|
+
CommentsModule,
|
|
81
|
+
ChatModule,
|
|
82
|
+
EmojiModule,
|
|
83
|
+
MatIconModule,
|
|
84
|
+
MatButtonModule,
|
|
85
|
+
MatTooltipModule,
|
|
86
|
+
MatMenuModule,
|
|
87
|
+
MatDialogModule,
|
|
88
|
+
MatFormFieldModule,
|
|
89
|
+
MatInputModule,
|
|
90
|
+
MatProgressSpinnerModule,
|
|
91
|
+
MatSnackBarModule,
|
|
92
|
+
OverlayModule,
|
|
93
|
+
PortalModule, BantaCommonModule,
|
|
94
|
+
ChatModule,
|
|
95
|
+
CommentsModule,
|
|
96
|
+
EmojiModule] });
|
|
97
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: BantaSdkModule, decorators: [{
|
|
98
|
+
type: NgModule,
|
|
99
|
+
args: [{
|
|
100
|
+
imports: [
|
|
101
|
+
CommonModule,
|
|
102
|
+
FormsModule,
|
|
103
|
+
BantaCommonModule.forRoot(),
|
|
104
|
+
CommentsModule,
|
|
105
|
+
ChatModule,
|
|
106
|
+
EmojiModule,
|
|
107
|
+
MatIconModule,
|
|
108
|
+
MatButtonModule,
|
|
109
|
+
MatTooltipModule,
|
|
110
|
+
MatMenuModule,
|
|
111
|
+
MatDialogModule,
|
|
112
|
+
MatFormFieldModule,
|
|
113
|
+
MatInputModule,
|
|
114
|
+
MatProgressSpinnerModule,
|
|
115
|
+
MatSnackBarModule,
|
|
116
|
+
OverlayModule,
|
|
117
|
+
PortalModule
|
|
118
|
+
],
|
|
119
|
+
declarations: [
|
|
120
|
+
BantaComponent,
|
|
121
|
+
BantaLogoComponent,
|
|
122
|
+
LiveMessageComponent
|
|
123
|
+
],
|
|
124
|
+
exports: [
|
|
125
|
+
BantaComponent,
|
|
126
|
+
BantaLogoComponent,
|
|
127
|
+
LiveMessageComponent,
|
|
128
|
+
BantaCommonModule,
|
|
129
|
+
ChatModule,
|
|
130
|
+
CommentsModule,
|
|
131
|
+
EmojiModule
|
|
132
|
+
]
|
|
133
|
+
}]
|
|
134
|
+
}], ctorParameters: function () { return [{ type: i1.ChatBackendBase }]; } });
|
|
135
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"banta-sdk.module.js","sourceRoot":"","sources":["../../../../projects/sdk/src/lib/banta-sdk.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { ModuleWithProviders, NgModule } from '@angular/core';\r\nimport { CommentsModule } from './comments';\r\nimport { ChatModule } from './chat';\r\nimport { EmojiModule } from './emoji';\r\nimport { BantaComponent } from './banta/banta.component';\r\nimport { BantaLogoComponent } from './banta-logo.component';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { BantaCommonModule } from './common/common.module';\r\nimport { LiveMessageComponent } from './live-message.component';\r\nimport { MatButtonModule } from \"@angular/material/button\";\r\nimport { MatIconModule } from \"@angular/material/icon\";\r\nimport { MatTooltipModule } from \"@angular/material/tooltip\";\r\nimport { MatMenuModule } from \"@angular/material/menu\";\r\nimport { MatDialogModule } from \"@angular/material/dialog\";\r\nimport { MatSnackBarModule } from \"@angular/material/snack-bar\";\r\nimport { MatFormFieldModule } from \"@angular/material/form-field\";\r\nimport { MatInputModule } from \"@angular/material/input\";\r\nimport { MatProgressSpinnerModule } from \"@angular/material/progress-spinner\";\r\nimport { ChatBackend } from './chat-backend';\r\nimport { SdkOptions } from './sdk-options';\r\nimport { BANTA_SDK_OPTIONS } from './sdk-options';\r\nimport { ChatBackendBase } from './chat-backend-base';\r\nimport { OverlayModule } from '@angular/cdk/overlay';\r\nimport { PortalModule } from '@angular/cdk/portal';\r\nimport { UrlAttachmentResolver, UrlAttachmentScraper } from './url-attachments';\r\nimport { YouTubeAttachmentResolver } from './youtube-attachments';\r\nimport { GiphyAttachmentResolver } from './giphy-attachments';\r\nimport { TweetAttachmentResolver } from './tweet-attachments';\r\n\r\n@NgModule({\r\n    imports: [\r\n        CommonModule,\r\n        FormsModule,\r\n        BantaCommonModule.forRoot(),\r\n        CommentsModule,\r\n        ChatModule,\r\n        EmojiModule,\r\n        \r\n        MatIconModule,\r\n        MatButtonModule,\r\n        MatTooltipModule,\r\n        MatMenuModule,\r\n        MatDialogModule,\r\n        MatFormFieldModule,\r\n        MatInputModule,\r\n        MatProgressSpinnerModule,\r\n        MatSnackBarModule,\r\n        OverlayModule,\r\n        PortalModule\r\n    ],\r\n    declarations: [\r\n        BantaComponent,\r\n        BantaLogoComponent,\r\n        LiveMessageComponent\r\n    ],\r\n    exports: [\r\n        BantaComponent,\r\n        BantaLogoComponent,\r\n        LiveMessageComponent,\r\n        BantaCommonModule,\r\n        ChatModule,\r\n        CommentsModule,\r\n        EmojiModule\r\n    ]\r\n})\r\nexport class BantaSdkModule {\r\n    constructor(\r\n        chatBackend: ChatBackendBase\r\n    ) {\r\n        chatBackend.registerAttachmentScraper(new UrlAttachmentScraper());\r\n        chatBackend.registerAttachmentResolver(new GiphyAttachmentResolver());\r\n        chatBackend.registerAttachmentResolver(new YouTubeAttachmentResolver());\r\n        chatBackend.registerAttachmentResolver(new TweetAttachmentResolver());\r\n        chatBackend.registerAttachmentResolver(new UrlAttachmentResolver(chatBackend));\r\n    }\r\n    \r\n    static configure(options?: SdkOptions): ModuleWithProviders<BantaSdkModule> {\r\n        return {\r\n            ngModule: BantaSdkModule,\r\n            providers: [\r\n                { \r\n                    provide: BANTA_SDK_OPTIONS, \r\n                    useValue: options || {}\r\n                },\r\n                { provide: ChatBackendBase, useClass: ChatBackend }\r\n            ]\r\n        }\r\n    }\r\n}"]}
|
|
@@ -0,0 +1,209 @@
|
|
|
1
|
+
import { Component, Input, Output, ViewChild } from "@angular/core";
|
|
2
|
+
import { Subject, Subscription } from 'rxjs';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../../chat-backend-base";
|
|
5
|
+
import * as i2 from "@angular/common";
|
|
6
|
+
import * as i3 from "@angular/forms";
|
|
7
|
+
import * as i4 from "@angular/material/button";
|
|
8
|
+
import * as i5 from "../../emoji/emoji-selector-button.component";
|
|
9
|
+
import * as i6 from "../chat-view/chat-view.component";
|
|
10
|
+
/**
|
|
11
|
+
* Chat component
|
|
12
|
+
*/
|
|
13
|
+
export class BantaChatComponent {
|
|
14
|
+
constructor(backend) {
|
|
15
|
+
this.backend = backend;
|
|
16
|
+
this._subs = new Subscription();
|
|
17
|
+
this.user = null;
|
|
18
|
+
this._metadata = {};
|
|
19
|
+
this.signInLabel = 'Sign In';
|
|
20
|
+
this.sendLabel = 'Send';
|
|
21
|
+
this.permissionDeniedLabel = 'Send';
|
|
22
|
+
this.messageFieldPlaceholder = 'Chat';
|
|
23
|
+
this.emptyLabel = 'Be the first to chat';
|
|
24
|
+
this._selected = new Subject();
|
|
25
|
+
this._selected$ = this._selected.asObservable();
|
|
26
|
+
this._reported = new Subject();
|
|
27
|
+
this._reported$ = this._reported.asObservable();
|
|
28
|
+
this._upvoted = new Subject();
|
|
29
|
+
this._upvoted$ = this._upvoted.asObservable();
|
|
30
|
+
this._userSelected = new Subject();
|
|
31
|
+
this._userSelected$ = this._userSelected.asObservable();
|
|
32
|
+
this._permissionDeniedError = new Subject();
|
|
33
|
+
this._permissionDeniedError$ = this._permissionDeniedError.asObservable();
|
|
34
|
+
this._signInSelected = new Subject();
|
|
35
|
+
this._signInSelected$ = this._signInSelected.asObservable();
|
|
36
|
+
this._received = new Subject();
|
|
37
|
+
this._received$ = this._received.asObservable();
|
|
38
|
+
this.showEmojiPanel = false;
|
|
39
|
+
this.newMessage = {};
|
|
40
|
+
}
|
|
41
|
+
ngOnInit() {
|
|
42
|
+
this._subs.add(this.backend.userChanged.subscribe(user => this.user = user));
|
|
43
|
+
}
|
|
44
|
+
ngOnDestroy() {
|
|
45
|
+
this._subs.unsubscribe();
|
|
46
|
+
}
|
|
47
|
+
get source() {
|
|
48
|
+
return this._source;
|
|
49
|
+
}
|
|
50
|
+
set source(value) {
|
|
51
|
+
this._source = value;
|
|
52
|
+
}
|
|
53
|
+
get topicID() {
|
|
54
|
+
return this._source.identifier;
|
|
55
|
+
}
|
|
56
|
+
set topicID(value) {
|
|
57
|
+
this.setSourceFromTopicID(value);
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Arbitrary metadata to send to the chat server. This can be used to provide context about the client to the server
|
|
61
|
+
* for things like validating authorization and other uses.
|
|
62
|
+
*/
|
|
63
|
+
get metadata() { return this._metadata; }
|
|
64
|
+
set metadata(value) {
|
|
65
|
+
if (JSON.stringify(this._metadata) !== JSON.stringify(value)) {
|
|
66
|
+
this._metadata = value;
|
|
67
|
+
this.reloadSource();
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
reloadSource() {
|
|
71
|
+
clearTimeout(this._reloadSourceTimeout);
|
|
72
|
+
this._reloadSourceTimeout = setTimeout(() => {
|
|
73
|
+
this.setSourceFromTopicID(this.topicID);
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
async setSourceFromTopicID(topicID) {
|
|
77
|
+
if (this._source && this._source.close)
|
|
78
|
+
this._source.close();
|
|
79
|
+
this._source = null;
|
|
80
|
+
this._source = await this.backend.getSourceForTopic(topicID, {
|
|
81
|
+
metadata: this.metadata
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
get selected() { return this._selected$; }
|
|
85
|
+
get reported() { return this._reported$; }
|
|
86
|
+
get upvoted() { return this._upvoted$; }
|
|
87
|
+
get userSelected() { return this._userSelected$; }
|
|
88
|
+
get permissionDeniedError() { return this._permissionDeniedError$; }
|
|
89
|
+
get signInSelected() { return this._signInSelected$; }
|
|
90
|
+
get received() { return this._received$; }
|
|
91
|
+
onReceived(message) {
|
|
92
|
+
this._received.next(message);
|
|
93
|
+
}
|
|
94
|
+
showSignIn() {
|
|
95
|
+
this._signInSelected.next();
|
|
96
|
+
}
|
|
97
|
+
sendPermissionError(message) {
|
|
98
|
+
this._permissionDeniedError.next(message);
|
|
99
|
+
}
|
|
100
|
+
insertEmoji(emoji) {
|
|
101
|
+
let message = this.newMessage.message || '';
|
|
102
|
+
this.newMessage.message = message + emoji;
|
|
103
|
+
}
|
|
104
|
+
onKeyDown(event) {
|
|
105
|
+
// TODO
|
|
106
|
+
}
|
|
107
|
+
jumpToMessage(message) {
|
|
108
|
+
if (this.chatView)
|
|
109
|
+
this.chatView.jumpTo(message);
|
|
110
|
+
}
|
|
111
|
+
select(message) {
|
|
112
|
+
this._selected.next(message);
|
|
113
|
+
}
|
|
114
|
+
selectUser(message) {
|
|
115
|
+
this._userSelected.next(message);
|
|
116
|
+
}
|
|
117
|
+
report(message) {
|
|
118
|
+
this._reported.next(message);
|
|
119
|
+
}
|
|
120
|
+
async upvote(message) {
|
|
121
|
+
await this.source.likeMessage(message.id);
|
|
122
|
+
this._upvoted.next(message);
|
|
123
|
+
}
|
|
124
|
+
get canChat() {
|
|
125
|
+
if (!this.user)
|
|
126
|
+
return false;
|
|
127
|
+
// TODO
|
|
128
|
+
// if (!this.user.permissions)
|
|
129
|
+
// return true;
|
|
130
|
+
// if (!this.user.permissions.canChat)
|
|
131
|
+
// return true;
|
|
132
|
+
// return this.user.permissions?.canChat(this.source);
|
|
133
|
+
return true;
|
|
134
|
+
}
|
|
135
|
+
async sendMessage() {
|
|
136
|
+
if (!this.source)
|
|
137
|
+
return;
|
|
138
|
+
let text = (this.newMessage.message || '').trim();
|
|
139
|
+
this.newMessage.message = '';
|
|
140
|
+
if (text === '')
|
|
141
|
+
return;
|
|
142
|
+
let message = {
|
|
143
|
+
user: null,
|
|
144
|
+
sentAt: Date.now(),
|
|
145
|
+
likes: 0,
|
|
146
|
+
url: this.url ?? (typeof window !== 'undefined' ? location.href : undefined),
|
|
147
|
+
message: text
|
|
148
|
+
};
|
|
149
|
+
try {
|
|
150
|
+
const intercept = await this.shouldInterceptMessageSend?.(message, this.source);
|
|
151
|
+
if (!intercept) {
|
|
152
|
+
await this.source.send(message);
|
|
153
|
+
}
|
|
154
|
+
this.chatView.scrollToLatest();
|
|
155
|
+
this.inputElementRef.nativeElement.focus();
|
|
156
|
+
}
|
|
157
|
+
catch (e) {
|
|
158
|
+
console.error(`Failed to send message: `, message);
|
|
159
|
+
console.error(e);
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
BantaChatComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: BantaChatComponent, deps: [{ token: i1.ChatBackendBase }], target: i0.ɵɵFactoryTarget.Component });
|
|
164
|
+
BantaChatComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: BantaChatComponent, selector: "banta-chat", inputs: { shouldInterceptMessageSend: "shouldInterceptMessageSend", url: "url", source: "source", topicID: "topicID", metadata: "metadata", signInLabel: "signInLabel", sendLabel: "sendLabel", permissionDeniedLabel: "permissionDeniedLabel", messageFieldPlaceholder: "messageFieldPlaceholder", emptyLabel: "emptyLabel" }, outputs: { selected: "selected", reported: "reported", upvoted: "upvoted", userSelected: "userSelected", permissionDeniedError: "permissionDeniedError", signInSelected: "signInSelected", received: "received" }, viewQueries: [{ propertyName: "chatView", first: true, predicate: ["chatView"], descendants: true }, { propertyName: "inputElementRef", first: true, predicate: ["input"], descendants: true }], ngImport: i0, template: "<banta-chat-view \r\n #chatView\r\n [source]=\"source\"\r\n [emptyLabel]=\"emptyLabel\"\r\n (upvoted)=\"upvote($event)\"\r\n (reported)=\"report($event)\"\r\n (selected)=\"select($event)\"\r\n (received)=\"onReceived($event)\"\r\n (userSelected)=\"selectUser($event)\"\r\n ></banta-chat-view>\r\n\r\n<form class=\"new-message\" (submit)=\"sendMessage()\">\r\n \r\n <div class=\"entry-container\">\r\n <input\r\n #input\r\n type=\"text\"\r\n name=\"message\" \r\n autocomplete=\"off\"\r\n enterkeyhint=\"send\"\r\n [placeholder]=\"messageFieldPlaceholder\"\r\n (keydown)=\"onKeyDown($event)\"\r\n [(ngModel)]=\"newMessage.message\" />\r\n \r\n <emoji-selector-button\r\n (selected)=\"insertEmoji($event)\"\r\n overlayY=\"bottom\"\r\n overlayX=\"end\"\r\n originY=\"top\"\r\n ></emoji-selector-button>\r\n </div>\r\n\r\n <div class=\"actions\">\r\n\r\n <ng-container *ngIf=\"!user\">\r\n <button type=\"button\" (click)=\"showSignIn()\" mat-raised-button color=\"primary\">{{signInLabel}}</button>\r\n </ng-container>\r\n <ng-container *ngIf=\"user\">\r\n <button *ngIf=\"canChat\" [disabled]=\"!newMessage.message\" mat-raised-button color=\"primary\">{{sendLabel}}</button>\r\n <button *ngIf=\"!canChat\" type=\"button\" (click)=\"sendPermissionError()\" mat-raised-button color=\"primary\">{{permissionDeniedLabel}}</button>\r\n </ng-container>\r\n </div>\r\n</form>", styles: [":host{display:flex;flex-direction:column;border-radius:5px;padding:10px;flex-grow:1;font-size:10pt;min-height:1px}.entry-container{display:flex;flex-direction:row;flex-grow:1;position:relative}.entry-container emoji-selector-button{position:absolute;right:0;top:.15em}.entry-container input{height:2.6em;font-size:12pt;padding-left:1em}.entry-container input:-webkit-autofill,.entry-container input:-webkit-autofill:hover,.entry-container input:-webkit-autofill:focus{outline:1px solid #9da302;-webkit-text-fill-color:#9da302;-webkit-box-shadow:0 0 0px 1000px #211e07 inset;-webkit-transition:background-color 5000s ease-in-out 0s;transition:background-color 5000s ease-in-out 0s;caret-color:#9da302}.entry-container emoji-selector-panel{pointer-events:none;opacity:0;position:absolute;bottom:3.5em;right:0}.entry-container emoji-selector-panel.visible{opacity:1;pointer-events:initial}form{display:flex;padding:.5em 0;align-items:center}form textarea{font-size:14pt;background:black;color:#fff;border:1px solid #333;min-height:6em;width:100%}form input[type=text]{background:white;color:#000;border:1px solid #ccc;width:100%;height:3.5em}form .actions{margin-left:1em}form button{display:block;margin:0 0 0 auto}:host-context(.mat-dark-theme) form input[type=text]{background:black;color:#fff;border:1px solid #333}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i4.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i5.EmojiSelectorButtonComponent, selector: "emoji-selector-button", inputs: ["disabled", "overlayX", "overlayY", "originX", "originY"], outputs: ["selected"] }, { kind: "component", type: i6.ChatViewComponent, selector: "banta-chat-view", inputs: ["source", "maxMessages", "emptyLabel"], outputs: ["selected", "userSelected", "reported", "upvoted", "received"] }] });
|
|
165
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: BantaChatComponent, decorators: [{
|
|
166
|
+
type: Component,
|
|
167
|
+
args: [{ selector: 'banta-chat', template: "<banta-chat-view \r\n #chatView\r\n [source]=\"source\"\r\n [emptyLabel]=\"emptyLabel\"\r\n (upvoted)=\"upvote($event)\"\r\n (reported)=\"report($event)\"\r\n (selected)=\"select($event)\"\r\n (received)=\"onReceived($event)\"\r\n (userSelected)=\"selectUser($event)\"\r\n ></banta-chat-view>\r\n\r\n<form class=\"new-message\" (submit)=\"sendMessage()\">\r\n \r\n <div class=\"entry-container\">\r\n <input\r\n #input\r\n type=\"text\"\r\n name=\"message\" \r\n autocomplete=\"off\"\r\n enterkeyhint=\"send\"\r\n [placeholder]=\"messageFieldPlaceholder\"\r\n (keydown)=\"onKeyDown($event)\"\r\n [(ngModel)]=\"newMessage.message\" />\r\n \r\n <emoji-selector-button\r\n (selected)=\"insertEmoji($event)\"\r\n overlayY=\"bottom\"\r\n overlayX=\"end\"\r\n originY=\"top\"\r\n ></emoji-selector-button>\r\n </div>\r\n\r\n <div class=\"actions\">\r\n\r\n <ng-container *ngIf=\"!user\">\r\n <button type=\"button\" (click)=\"showSignIn()\" mat-raised-button color=\"primary\">{{signInLabel}}</button>\r\n </ng-container>\r\n <ng-container *ngIf=\"user\">\r\n <button *ngIf=\"canChat\" [disabled]=\"!newMessage.message\" mat-raised-button color=\"primary\">{{sendLabel}}</button>\r\n <button *ngIf=\"!canChat\" type=\"button\" (click)=\"sendPermissionError()\" mat-raised-button color=\"primary\">{{permissionDeniedLabel}}</button>\r\n </ng-container>\r\n </div>\r\n</form>", styles: [":host{display:flex;flex-direction:column;border-radius:5px;padding:10px;flex-grow:1;font-size:10pt;min-height:1px}.entry-container{display:flex;flex-direction:row;flex-grow:1;position:relative}.entry-container emoji-selector-button{position:absolute;right:0;top:.15em}.entry-container input{height:2.6em;font-size:12pt;padding-left:1em}.entry-container input:-webkit-autofill,.entry-container input:-webkit-autofill:hover,.entry-container input:-webkit-autofill:focus{outline:1px solid #9da302;-webkit-text-fill-color:#9da302;-webkit-box-shadow:0 0 0px 1000px #211e07 inset;-webkit-transition:background-color 5000s ease-in-out 0s;transition:background-color 5000s ease-in-out 0s;caret-color:#9da302}.entry-container emoji-selector-panel{pointer-events:none;opacity:0;position:absolute;bottom:3.5em;right:0}.entry-container emoji-selector-panel.visible{opacity:1;pointer-events:initial}form{display:flex;padding:.5em 0;align-items:center}form textarea{font-size:14pt;background:black;color:#fff;border:1px solid #333;min-height:6em;width:100%}form input[type=text]{background:white;color:#000;border:1px solid #ccc;width:100%;height:3.5em}form .actions{margin-left:1em}form button{display:block;margin:0 0 0 auto}:host-context(.mat-dark-theme) form input[type=text]{background:black;color:#fff;border:1px solid #333}\n"] }]
|
|
168
|
+
}], ctorParameters: function () { return [{ type: i1.ChatBackendBase }]; }, propDecorators: { shouldInterceptMessageSend: [{
|
|
169
|
+
type: Input
|
|
170
|
+
}], url: [{
|
|
171
|
+
type: Input
|
|
172
|
+
}], source: [{
|
|
173
|
+
type: Input
|
|
174
|
+
}], topicID: [{
|
|
175
|
+
type: Input
|
|
176
|
+
}], metadata: [{
|
|
177
|
+
type: Input
|
|
178
|
+
}], signInLabel: [{
|
|
179
|
+
type: Input
|
|
180
|
+
}], sendLabel: [{
|
|
181
|
+
type: Input
|
|
182
|
+
}], permissionDeniedLabel: [{
|
|
183
|
+
type: Input
|
|
184
|
+
}], messageFieldPlaceholder: [{
|
|
185
|
+
type: Input
|
|
186
|
+
}], emptyLabel: [{
|
|
187
|
+
type: Input
|
|
188
|
+
}], selected: [{
|
|
189
|
+
type: Output
|
|
190
|
+
}], reported: [{
|
|
191
|
+
type: Output
|
|
192
|
+
}], upvoted: [{
|
|
193
|
+
type: Output
|
|
194
|
+
}], userSelected: [{
|
|
195
|
+
type: Output
|
|
196
|
+
}], permissionDeniedError: [{
|
|
197
|
+
type: Output
|
|
198
|
+
}], signInSelected: [{
|
|
199
|
+
type: Output
|
|
200
|
+
}], received: [{
|
|
201
|
+
type: Output
|
|
202
|
+
}], chatView: [{
|
|
203
|
+
type: ViewChild,
|
|
204
|
+
args: ['chatView']
|
|
205
|
+
}], inputElementRef: [{
|
|
206
|
+
type: ViewChild,
|
|
207
|
+
args: ['input']
|
|
208
|
+
}] } });
|
|
209
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"banta-chat.component.js","sourceRoot":"","sources":["../../../../../../projects/sdk/src/lib/chat/banta-chat/banta-chat.component.ts","../../../../../../projects/sdk/src/lib/chat/banta-chat/banta-chat.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, ViewChild, ElementRef } from \"@angular/core\";\r\nimport { Subject, Observable, Subscription } from 'rxjs';\r\n\r\nimport { User, ChatMessage, NewMessageForm } from '@banta/common';\r\nimport { ChatViewComponent } from '../chat-view/chat-view.component';\r\nimport { ChatBackendBase } from \"../../chat-backend-base\";\r\nimport { ChatSourceBase } from \"../../chat-source-base\";\r\n\r\n/**\r\n * Chat component\r\n */\r\n@Component({\r\n    selector: 'banta-chat',\r\n    templateUrl: './banta-chat.component.html',\r\n    styleUrls: ['./banta-chat.component.scss']\r\n})\r\nexport class BantaChatComponent {\r\n    constructor(\r\n        private backend : ChatBackendBase\r\n    ) {\r\n    }\r\n\r\n    private _source : ChatSourceBase;\r\n    private _subs = new Subscription();\r\n    user : User = null;\r\n\r\n    @Input() shouldInterceptMessageSend?: (message: ChatMessage, source: ChatSourceBase) => boolean | Promise<boolean>;\r\n    @Input() url: string;\r\n\r\n    ngOnInit() {\r\n        this._subs.add(this.backend.userChanged.subscribe(user => this.user = user));\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        this._subs.unsubscribe();\r\n    }\r\n\r\n    @Input()\r\n    get source() : ChatSourceBase {\r\n        return this._source;\r\n    }\r\n\r\n    set source(value) {\r\n        this._source = value;\r\n    }\r\n\r\n    @Input()\r\n    get topicID() : string {\r\n        return this._source.identifier;\r\n    }\r\n\r\n    set topicID(value) {\r\n        this.setSourceFromTopicID(value);\r\n    }\r\n\r\n    private _metadata: Record<string, any> = {};\r\n\r\n    /**\r\n     * Arbitrary metadata to send to the chat server. This can be used to provide context about the client to the server\r\n     * for things like validating authorization and other uses.\r\n     */\r\n    @Input() get metadata() { return this._metadata; }\r\n    set metadata(value) {\r\n        if (JSON.stringify(this._metadata) !== JSON.stringify(value)) {\r\n            this._metadata = value;\r\n            this.reloadSource();\r\n        }\r\n    }\r\n\r\n    private _reloadSourceTimeout;\r\n    private reloadSource() {\r\n        clearTimeout(this._reloadSourceTimeout);\r\n        this._reloadSourceTimeout = setTimeout(() => {\r\n            this.setSourceFromTopicID(this.topicID);\r\n        });\r\n    }\r\n\r\n    private async setSourceFromTopicID(topicID : string) {\r\n        if (this._source && this._source.close)\r\n            this._source.close();\r\n        this._source = null;\r\n        this._source = await this.backend.getSourceForTopic(topicID, { \r\n            metadata: this.metadata\r\n        });\r\n    }\r\n\r\n    @Input() signInLabel = 'Sign In';\r\n    @Input() sendLabel = 'Send';\r\n    @Input() permissionDeniedLabel = 'Send';\r\n    @Input() messageFieldPlaceholder = 'Chat';\r\n    @Input() emptyLabel = 'Be the first to chat';\r\n\r\n    private _selected = new Subject<ChatMessage>();\r\n    private _selected$ = this._selected.asObservable();\r\n    private _reported = new Subject<ChatMessage>();\r\n    private _reported$ = this._reported.asObservable();\r\n    private _upvoted = new Subject<ChatMessage>();\r\n    private _upvoted$ = this._upvoted.asObservable();\r\n    private _userSelected = new Subject<ChatMessage>();\r\n    private _userSelected$ = this._userSelected.asObservable();\r\n    private _permissionDeniedError = new Subject<string>();\r\n    private _permissionDeniedError$ = this._permissionDeniedError.asObservable();\r\n    private _signInSelected = new Subject<void>();\r\n    private _signInSelected$ = this._signInSelected.asObservable();\r\n    private _received = new Subject<ChatMessage>();\r\n    private _received$ = this._received.asObservable();\r\n\r\n    @Output() get selected() { return this._selected$; }\r\n    @Output() get reported() { return this._reported$; }\r\n    @Output() get upvoted() { return this._upvoted$; }\r\n    @Output() get userSelected() { return this._userSelected$; }\r\n    @Output() get permissionDeniedError() { return this._permissionDeniedError$; }\r\n    @Output() get signInSelected() { return this._signInSelected$; }\r\n    @Output() get received() { return this._received$; }\r\n\r\n    onReceived(message: ChatMessage) {\r\n        this._received.next(message);\r\n    }\r\n\r\n    showEmojiPanel = false;\r\n\r\n    showSignIn() {\r\n        this._signInSelected.next();\r\n    }\r\n\r\n    sendPermissionError(message: string) {\r\n        this._permissionDeniedError.next(message);\r\n    }\r\n\r\n    insertEmoji(emoji) {\r\n        let message = this.newMessage.message || '';\r\n\r\n        this.newMessage.message = message + emoji;\r\n    }\r\n\r\n    onKeyDown(event : KeyboardEvent) {\r\n        // TODO\r\n    }\r\n\r\n    @ViewChild('chatView') chatView : ChatViewComponent;\r\n    @ViewChild('input') inputElementRef: ElementRef<HTMLInputElement>;\r\n\r\n    jumpToMessage(message : ChatMessage) {\r\n        if (this.chatView)\r\n            this.chatView.jumpTo(message);\r\n    }\r\n\r\n    select(message : ChatMessage) {\r\n        this._selected.next(message);\r\n    }\r\n\r\n    selectUser(message : ChatMessage) {\r\n        this._userSelected.next(message);\r\n    }\r\n\r\n    report(message : ChatMessage) {\r\n        this._reported.next(message);\r\n    }\r\n\r\n    async upvote(message : ChatMessage) {\r\n        await this.source.likeMessage(message.id);\r\n        this._upvoted.next(message);\r\n    }\r\n\r\n    get canChat() {\r\n        if (!this.user)\r\n            return false;\r\n\r\n        // TODO\r\n        // if (!this.user.permissions)\r\n        //     return true;\r\n\r\n        // if (!this.user.permissions.canChat)\r\n        //     return true;\r\n\r\n        // return this.user.permissions?.canChat(this.source);\r\n        \r\n        return true;\r\n    }\r\n\r\n    newMessage : NewMessageForm = {};\r\n\r\n    async sendMessage() {\r\n        if (!this.source)\r\n            return;\r\n\r\n        let text = (this.newMessage.message || '').trim();\r\n        this.newMessage.message = '';\r\n\r\n        if (text === '')\r\n            return;\r\n\r\n        let message : ChatMessage = {\r\n            user: null,\r\n            sentAt: Date.now(),\r\n            likes: 0,\r\n            url: this.url ?? (typeof window !== 'undefined' ? location.href : undefined),\r\n            message: text\r\n        };\r\n\r\n        try {\r\n            const intercept = await this.shouldInterceptMessageSend?.(message, this.source);\r\n            if (!intercept) {\r\n                await this.source.send(message);\r\n            }\r\n\r\n            this.chatView.scrollToLatest();\r\n            this.inputElementRef.nativeElement.focus();\r\n        } catch (e) {\r\n            console.error(`Failed to send message: `, message);\r\n            console.error(e);\r\n        }\r\n    }\r\n}\r\n","<banta-chat-view \r\n    #chatView\r\n    [source]=\"source\"\r\n    [emptyLabel]=\"emptyLabel\"\r\n    (upvoted)=\"upvote($event)\"\r\n    (reported)=\"report($event)\"\r\n    (selected)=\"select($event)\"\r\n    (received)=\"onReceived($event)\"\r\n    (userSelected)=\"selectUser($event)\"\r\n    ></banta-chat-view>\r\n\r\n<form class=\"new-message\" (submit)=\"sendMessage()\">\r\n    \r\n    <div class=\"entry-container\">\r\n        <input\r\n            #input\r\n            type=\"text\"\r\n            name=\"message\" \r\n            autocomplete=\"off\"\r\n            enterkeyhint=\"send\"\r\n            [placeholder]=\"messageFieldPlaceholder\"\r\n            (keydown)=\"onKeyDown($event)\"\r\n            [(ngModel)]=\"newMessage.message\" />\r\n            \r\n        <emoji-selector-button\r\n            (selected)=\"insertEmoji($event)\"\r\n            overlayY=\"bottom\"\r\n            overlayX=\"end\"\r\n            originY=\"top\"\r\n            ></emoji-selector-button>\r\n    </div>\r\n\r\n    <div class=\"actions\">\r\n\r\n        <ng-container *ngIf=\"!user\">\r\n            <button type=\"button\" (click)=\"showSignIn()\" mat-raised-button color=\"primary\">{{signInLabel}}</button>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"user\">\r\n            <button *ngIf=\"canChat\" [disabled]=\"!newMessage.message\" mat-raised-button color=\"primary\">{{sendLabel}}</button>\r\n            <button *ngIf=\"!canChat\" type=\"button\" (click)=\"sendPermissionError()\" mat-raised-button color=\"primary\">{{permissionDeniedLabel}}</button>\r\n        </ng-container>\r\n    </div>\r\n</form>"]}
|