@banta/sdk 5.4.0 → 5.5.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (138) hide show
  1. package/{esm2020 → esm2022}/banta-sdk.mjs +4 -4
  2. package/{esm2020 → esm2022}/lib/attachment-scraper.mjs +1 -1
  3. package/esm2022/lib/banta/banta.component.mjs +204 -0
  4. package/{esm2020 → esm2022}/lib/banta-logo.component.mjs +11 -11
  5. package/{esm2020 → esm2022}/lib/banta-sdk.module.mjs +135 -135
  6. package/esm2022/lib/chat/banta-chat/banta-chat.component.mjs +209 -0
  7. package/esm2022/lib/chat/chat-message/chat-message.component.mjs +62 -0
  8. package/esm2022/lib/chat/chat-view/chat-view.component.mjs +170 -0
  9. package/{esm2020 → esm2022}/lib/chat/chat.module.mjs +51 -51
  10. package/{esm2020 → esm2022}/lib/chat/index.mjs +5 -5
  11. package/esm2022/lib/chat/live-chat-message.component.mjs +80 -0
  12. package/{esm2020 → esm2022}/lib/chat-backend-base.mjs +30 -30
  13. package/esm2022/lib/chat-backend.mjs +194 -0
  14. package/{esm2020 → esm2022}/lib/chat-source-base.mjs +1 -1
  15. package/esm2022/lib/chat-source.mjs +233 -0
  16. package/esm2022/lib/comments/attachment-button/attachment-button.component.mjs +76 -0
  17. package/esm2022/lib/comments/attachment-scraper.directive.mjs +107 -0
  18. package/esm2022/lib/comments/banta-comments/banta-comments.component.mjs +748 -0
  19. package/esm2022/lib/comments/comment/comment.component.mjs +175 -0
  20. package/esm2022/lib/comments/comment-field/comment-field.component.mjs +401 -0
  21. package/esm2022/lib/comments/comment-sort/comment-sort.component.mjs +37 -0
  22. package/esm2022/lib/comments/comment-view/comment-view.component.mjs +470 -0
  23. package/{esm2020 → esm2022}/lib/comments/comments.module.mjs +111 -111
  24. package/{esm2020 → esm2022}/lib/comments/index.mjs +10 -10
  25. package/esm2022/lib/comments/live-comment.component.mjs +80 -0
  26. package/{esm2020 → esm2022}/lib/comments/reply-send-options.directive.mjs +13 -13
  27. package/esm2022/lib/common/attachment/attachment.component.mjs +128 -0
  28. package/{esm2020 → esm2022}/lib/common/attachments/attachments.component.mjs +75 -75
  29. package/{esm2020 → esm2022}/lib/common/common.module.mjs +68 -68
  30. package/{esm2020 → esm2022}/lib/common/index.mjs +10 -10
  31. package/{esm2020 → esm2022}/lib/common/lazy-connection.mjs +14 -14
  32. package/esm2022/lib/common/lightbox/lightbox.component.mjs +31 -0
  33. package/esm2022/lib/common/markdown-to-html.pipe.mjs +88 -0
  34. package/esm2022/lib/common/mention-linker.pipe.mjs +35 -0
  35. package/esm2022/lib/common/timer-pool.service.mjs +85 -0
  36. package/esm2022/lib/common/timestamp.component.mjs +124 -0
  37. package/{esm2020 → esm2022}/lib/common/trust-resource-url.pipe.mjs +22 -22
  38. package/esm2022/lib/emoji/emoji-selector-button.component.mjs +115 -0
  39. package/esm2022/lib/emoji/emoji-selector-panel/emoji-selector-panel.component.mjs +98 -0
  40. package/{esm2020 → esm2022}/lib/emoji/emoji.module.mjs +55 -55
  41. package/{esm2020 → esm2022}/lib/emoji/emojis.mjs +6507 -6507
  42. package/{esm2020 → esm2022}/lib/emoji/index.mjs +4 -4
  43. package/esm2022/lib/giphy-attachments.mjs +16 -0
  44. package/{esm2020 → esm2022}/lib/index.mjs +19 -19
  45. package/{esm2020 → esm2022}/lib/live-message.component.mjs +61 -61
  46. package/{esm2020 → esm2022}/lib/message-menu-item.mjs +1 -1
  47. package/{esm2020 → esm2022}/lib/sdk-options.mjs +1 -1
  48. package/esm2022/lib/static-chat-source.mjs +71 -0
  49. package/esm2022/lib/tweet-attachments.mjs +13 -0
  50. package/esm2022/lib/url-attachments.mjs +42 -0
  51. package/esm2022/lib/youtube-attachments.mjs +29 -0
  52. package/{esm2020 → esm2022}/public-api.mjs +4 -4
  53. package/{fesm2020 → fesm2022}/banta-sdk.mjs +10825 -10823
  54. package/fesm2022/banta-sdk.mjs.map +1 -0
  55. package/index.d.ts +5 -5
  56. package/lib/attachment-scraper.d.ts +15 -15
  57. package/lib/banta/banta.component.d.ts +58 -58
  58. package/lib/banta-logo.component.d.ts +5 -5
  59. package/lib/banta-sdk.module.d.ts +31 -31
  60. package/lib/chat/banta-chat/banta-chat.component.d.ts +79 -79
  61. package/lib/chat/chat-message/chat-message.component.d.ts +21 -21
  62. package/lib/chat/chat-view/chat-view.component.d.ts +52 -52
  63. package/lib/chat/chat.module.d.ts +15 -15
  64. package/lib/chat/index.d.ts +5 -5
  65. package/lib/chat/live-chat-message.component.d.ts +23 -23
  66. package/lib/chat-backend-base.d.ts +72 -72
  67. package/lib/chat-backend.d.ts +67 -67
  68. package/lib/chat-source-base.d.ts +44 -44
  69. package/lib/chat-source.d.ts +65 -65
  70. package/lib/comments/attachment-button/attachment-button.component.d.ts +17 -17
  71. package/lib/comments/attachment-scraper.directive.d.ts +21 -21
  72. package/lib/comments/banta-comments/banta-comments.component.d.ts +203 -203
  73. package/lib/comments/comment/comment.component.d.ts +72 -72
  74. package/lib/comments/comment-field/comment-field.component.d.ts +89 -89
  75. package/lib/comments/comment-sort/comment-sort.component.d.ts +16 -16
  76. package/lib/comments/comment-view/comment-view.component.d.ts +121 -121
  77. package/lib/comments/comments.module.d.ts +30 -30
  78. package/lib/comments/index.d.ts +10 -10
  79. package/lib/comments/live-comment.component.d.ts +23 -23
  80. package/lib/comments/reply-send-options.directive.d.ts +5 -5
  81. package/lib/common/attachment/attachment.component.d.ts +34 -34
  82. package/lib/common/attachments/attachments.component.d.ts +26 -26
  83. package/lib/common/common.module.d.ts +19 -19
  84. package/lib/common/index.d.ts +10 -10
  85. package/lib/common/lazy-connection.d.ts +6 -6
  86. package/lib/common/lightbox/lightbox.component.d.ts +14 -14
  87. package/lib/common/markdown-to-html.pipe.d.ts +15 -15
  88. package/lib/common/mention-linker.pipe.d.ts +13 -13
  89. package/lib/common/timer-pool.service.d.ts +15 -15
  90. package/lib/common/timestamp.component.d.ts +19 -19
  91. package/lib/common/trust-resource-url.pipe.d.ts +10 -10
  92. package/lib/emoji/emoji-selector-button.component.d.ts +30 -30
  93. package/lib/emoji/emoji-selector-panel/emoji-selector-panel.component.d.ts +26 -26
  94. package/lib/emoji/emoji.module.d.ts +16 -16
  95. package/lib/emoji/emojis.d.ts +6507 -6507
  96. package/lib/emoji/index.d.ts +4 -4
  97. package/lib/giphy-attachments.d.ts +5 -5
  98. package/lib/index.d.ts +19 -19
  99. package/lib/live-message.component.d.ts +22 -22
  100. package/lib/message-menu-item.d.ts +6 -6
  101. package/lib/sdk-options.d.ts +5 -5
  102. package/lib/static-chat-source.d.ts +42 -42
  103. package/lib/tweet-attachments.d.ts +5 -5
  104. package/lib/url-attachments.d.ts +14 -14
  105. package/lib/youtube-attachments.d.ts +5 -5
  106. package/package.json +5 -11
  107. package/public-api.d.ts +1 -1
  108. package/esm2020/lib/banta/banta.component.mjs +0 -204
  109. package/esm2020/lib/chat/banta-chat/banta-chat.component.mjs +0 -209
  110. package/esm2020/lib/chat/chat-message/chat-message.component.mjs +0 -62
  111. package/esm2020/lib/chat/chat-view/chat-view.component.mjs +0 -170
  112. package/esm2020/lib/chat/live-chat-message.component.mjs +0 -80
  113. package/esm2020/lib/chat-backend.mjs +0 -194
  114. package/esm2020/lib/chat-source.mjs +0 -233
  115. package/esm2020/lib/comments/attachment-button/attachment-button.component.mjs +0 -76
  116. package/esm2020/lib/comments/attachment-scraper.directive.mjs +0 -107
  117. package/esm2020/lib/comments/banta-comments/banta-comments.component.mjs +0 -749
  118. package/esm2020/lib/comments/comment/comment.component.mjs +0 -175
  119. package/esm2020/lib/comments/comment-field/comment-field.component.mjs +0 -401
  120. package/esm2020/lib/comments/comment-sort/comment-sort.component.mjs +0 -37
  121. package/esm2020/lib/comments/comment-view/comment-view.component.mjs +0 -470
  122. package/esm2020/lib/comments/live-comment.component.mjs +0 -80
  123. package/esm2020/lib/common/attachment/attachment.component.mjs +0 -128
  124. package/esm2020/lib/common/lightbox/lightbox.component.mjs +0 -31
  125. package/esm2020/lib/common/markdown-to-html.pipe.mjs +0 -88
  126. package/esm2020/lib/common/mention-linker.pipe.mjs +0 -35
  127. package/esm2020/lib/common/timer-pool.service.mjs +0 -83
  128. package/esm2020/lib/common/timestamp.component.mjs +0 -123
  129. package/esm2020/lib/emoji/emoji-selector-button.component.mjs +0 -116
  130. package/esm2020/lib/emoji/emoji-selector-panel/emoji-selector-panel.component.mjs +0 -98
  131. package/esm2020/lib/giphy-attachments.mjs +0 -16
  132. package/esm2020/lib/static-chat-source.mjs +0 -71
  133. package/esm2020/lib/tweet-attachments.mjs +0 -13
  134. package/esm2020/lib/url-attachments.mjs +0 -42
  135. package/esm2020/lib/youtube-attachments.mjs +0 -29
  136. package/fesm2015/banta-sdk.mjs +0 -11258
  137. package/fesm2015/banta-sdk.mjs.map +0 -1
  138. package/fesm2020/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
- BantaSdkModulefac = 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}"]}
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
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: BantaSdkModule, deps: [{ token: i1.ChatBackendBase }], target: i0.ɵɵFactoryTarget.NgModule }); }
53
+ static { thismod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.9", ngImport: i0, type: BantaSdkModule, declarations: [BantaComponent,
54
+ BantaLogoComponent,
55
+ LiveMessageComponent], imports: [CommonModule,
56
+ FormsModule, i2.BantaCommonModule, CommentsModule,
57
+ ChatModule,
58
+ EmojiModule,
59
+ MatIconModule,
60
+ MatButtonModule,
61
+ MatTooltipModule,
62
+ MatMenuModule,
63
+ MatDialogModule,
64
+ MatFormFieldModule,
65
+ MatInputModule,
66
+ MatProgressSpinnerModule,
67
+ MatSnackBarModule,
68
+ OverlayModule,
69
+ PortalModule], exports: [BantaComponent,
70
+ BantaLogoComponent,
71
+ LiveMessageComponent,
72
+ BantaCommonModule,
73
+ ChatModule,
74
+ CommentsModule,
75
+ EmojiModule] }); }
76
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: BantaSdkModule, imports: [CommonModule,
77
+ FormsModule,
78
+ BantaCommonModule.forRoot(),
79
+ CommentsModule,
80
+ ChatModule,
81
+ EmojiModule,
82
+ MatIconModule,
83
+ MatButtonModule,
84
+ MatTooltipModule,
85
+ MatMenuModule,
86
+ MatDialogModule,
87
+ MatFormFieldModule,
88
+ MatInputModule,
89
+ MatProgressSpinnerModule,
90
+ MatSnackBarModule,
91
+ OverlayModule,
92
+ PortalModule, BantaCommonModule,
93
+ ChatModule,
94
+ CommentsModule,
95
+ EmojiModule] }); }
96
+ }
97
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", 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: () => [{ 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
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.9", ngImport: i0, type: BantaChatComponent, deps: [{ token: i1.ChatBackendBase }], target: i0.ɵɵFactoryTarget.Component }); }
163
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.9", 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;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:#000;color:#fff;border:1px solid #333;min-height:6em;width:100%}form input[type=text]{background:#fff;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:#000;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-flat-button], button[mat-stroked-button] ", 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"] }] }); }
164
+ }
165
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.9", 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;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:#000;color:#fff;border:1px solid #333;min-height:6em;width:100%}form input[type=text]{background:#fff;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:#000;color:#fff;border:1px solid #333}\n"] }]
168
+ }], ctorParameters: () => [{ 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>"]}