@banta/sdk 3.3.9 → 4.0.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/banta-sdk.metadata.json +1 -1
- package/bundles/banta-sdk.umd.js +1142 -410
- package/bundles/banta-sdk.umd.js.map +1 -1
- package/bundles/banta-sdk.umd.min.js +1 -1
- package/bundles/banta-sdk.umd.min.js.map +1 -1
- package/esm2015/banta-sdk.js +1 -1
- package/esm2015/lib/banta/banta.component.js +10 -16
- package/esm2015/lib/banta-logo.component.js +1 -1
- package/esm2015/lib/banta-sdk.module.js +10 -4
- package/esm2015/lib/chat/banta-chat/banta-chat.component.js +15 -18
- package/esm2015/lib/chat/chat-message/chat-message.component.js +3 -3
- package/esm2015/lib/chat/chat-view/chat-view.component.js +8 -7
- package/esm2015/lib/chat/chat.module.js +1 -1
- package/esm2015/lib/chat/index.js +1 -1
- package/esm2015/lib/chat/live-chat-message.component.js +3 -3
- package/esm2015/lib/chat-backend-base.js +17 -0
- package/esm2015/lib/chat-backend.js +74 -0
- package/esm2015/lib/chat-source-base.js +2 -0
- package/esm2015/lib/chat-source.js +151 -0
- package/esm2015/lib/comments/banta-comments/banta-comments.component.js +331 -172
- package/esm2015/lib/comments/comment/comment.component.js +56 -18
- package/esm2015/lib/comments/comment-field/comment-field.component.js +17 -15
- package/esm2015/lib/comments/comment-sort/comment-sort.component.js +1 -1
- package/esm2015/lib/comments/comment-view/comment-view.component.js +78 -40
- package/esm2015/lib/comments/comments.module.js +1 -1
- package/esm2015/lib/comments/index.js +1 -1
- package/esm2015/lib/comments/live-comment.component.js +3 -3
- package/esm2015/lib/common/common.module.js +1 -1
- package/esm2015/lib/common/index.js +1 -3
- package/esm2015/lib/common/lazy-connection.js +1 -1
- package/esm2015/lib/common/timestamp.component.js +1 -1
- package/esm2015/lib/emoji/emoji-selector-button.component.js +1 -1
- package/esm2015/lib/emoji/emoji-selector-panel/emoji-selector-panel.component.js +2 -2
- package/esm2015/lib/emoji/emoji.module.js +1 -1
- package/esm2015/lib/emoji/emojis.js +1 -1
- package/esm2015/lib/emoji/index.js +1 -1
- package/esm2015/lib/index.js +6 -1
- package/esm2015/lib/live-message.component.js +1 -1
- package/esm2015/lib/sdk-options.js +2 -0
- package/esm2015/public-api.js +1 -1
- package/fesm2015/banta-sdk.js +750 -308
- package/fesm2015/banta-sdk.js.map +1 -1
- package/lib/banta/banta.component.d.ts +8 -9
- package/lib/banta-sdk.module.d.ts +2 -1
- package/lib/chat/banta-chat/banta-chat.component.d.ts +8 -10
- package/lib/chat/chat-view/chat-view.component.d.ts +7 -4
- package/lib/chat/live-chat-message.component.d.ts +2 -2
- package/lib/chat-backend-base.d.ts +22 -0
- package/lib/chat-backend.d.ts +21 -0
- package/lib/chat-source-base.d.ts +31 -0
- package/lib/chat-source.d.ts +38 -0
- package/lib/comments/banta-comments/banta-comments.component.d.ts +65 -60
- package/lib/comments/comment/comment.component.d.ts +25 -5
- package/lib/comments/comment-field/comment-field.component.d.ts +7 -3
- package/lib/comments/comment-view/comment-view.component.d.ts +26 -8
- package/lib/comments/live-comment.component.d.ts +2 -2
- package/lib/common/index.d.ts +0 -2
- package/lib/index.d.ts +5 -0
- package/lib/sdk-options.d.ts +4 -0
- package/package.json +2 -2
- package/esm2015/lib/common/banta.service.js +0 -21
- package/esm2015/lib/common/chat-backend.service.js +0 -7
- package/lib/common/banta.service.d.ts +0 -9
- package/lib/common/chat-backend.service.d.ts +0 -14
|
@@ -2,18 +2,37 @@ import { __awaiter } from "tslib";
|
|
|
2
2
|
import { Component, ElementRef, Input, Output } from '@angular/core';
|
|
3
3
|
import { CommentsOrder } from '@banta/common';
|
|
4
4
|
import { Subject, Observable, Subscription } from 'rxjs';
|
|
5
|
-
import { ChatBackendService } from '../../common';
|
|
6
|
-
import { BantaService } from '../../common';
|
|
7
5
|
import { ActivatedRoute } from '@angular/router';
|
|
6
|
+
import { ChatBackendBase } from '../../chat-backend-base';
|
|
8
7
|
/**
|
|
9
8
|
* Comments component
|
|
10
9
|
*/
|
|
11
10
|
export class BantaCommentsComponent {
|
|
12
|
-
constructor(
|
|
13
|
-
this.banta = banta;
|
|
11
|
+
constructor(backend, elementRef, activatedRoute) {
|
|
14
12
|
this.backend = backend;
|
|
15
13
|
this.elementRef = elementRef;
|
|
16
14
|
this.activatedRoute = activatedRoute;
|
|
15
|
+
// Loading Screen
|
|
16
|
+
this._loadingMessage = '';
|
|
17
|
+
this.loadingMessageVisible = false;
|
|
18
|
+
this.loading = true;
|
|
19
|
+
this.showLoadingScreen = false;
|
|
20
|
+
this._loadingMessageIndex = 0;
|
|
21
|
+
this.loadingMessages = [
|
|
22
|
+
`Just a second...`,
|
|
23
|
+
`We're definitely working on it.`,
|
|
24
|
+
`There's no need to refresh.`,
|
|
25
|
+
`It's definitely worth the wait!`,
|
|
26
|
+
`This has never happened before.`,
|
|
27
|
+
`We'll keep trying, but it's not looking great.
|
|
28
|
+
Commenting & chat services may be down.
|
|
29
|
+
If you continue to experience issues, please contact support.
|
|
30
|
+
`
|
|
31
|
+
];
|
|
32
|
+
// Properties
|
|
33
|
+
this._signInSelected = new Subject();
|
|
34
|
+
this._permissionDeniedError = new Subject();
|
|
35
|
+
this._editAvatarSelected = new Subject();
|
|
17
36
|
this._upvoted = new Subject();
|
|
18
37
|
this._reported = new Subject();
|
|
19
38
|
this._selected = new Subject();
|
|
@@ -23,12 +42,8 @@ export class BantaCommentsComponent {
|
|
|
23
42
|
this._avatarSelected = new Subject();
|
|
24
43
|
this._subs = new Subscription();
|
|
25
44
|
this._sortOrder = CommentsOrder.NEWEST;
|
|
26
|
-
this.
|
|
27
|
-
|
|
28
|
-
{ hashtag: 'timeout', description: 'Cause a slow timeout error' },
|
|
29
|
-
{ hashtag: 'slow', description: 'Be slow when this message is posted' },
|
|
30
|
-
];
|
|
31
|
-
this.participants = [];
|
|
45
|
+
this.selectedMessageVisible = false;
|
|
46
|
+
// Inputs
|
|
32
47
|
this.signInLabel = 'Sign In';
|
|
33
48
|
this.sendLabel = 'Send';
|
|
34
49
|
this.replyLabel = 'Reply';
|
|
@@ -36,16 +51,166 @@ export class BantaCommentsComponent {
|
|
|
36
51
|
this.permissionDeniedLabel = 'Send';
|
|
37
52
|
this.postCommentLabel = 'Post a comment';
|
|
38
53
|
this.postReplyLabel = 'Post a reply';
|
|
39
|
-
this.
|
|
40
|
-
this.
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
54
|
+
this.participants = [];
|
|
55
|
+
this.hashtags = [
|
|
56
|
+
{ hashtag: 'error', description: 'Cause an error' },
|
|
57
|
+
{ hashtag: 'timeout', description: 'Cause a slow timeout error' },
|
|
58
|
+
{ hashtag: 'slow', description: 'Be slow when this message is posted' },
|
|
59
|
+
];
|
|
60
|
+
this.sendMessage = (message) => __awaiter(this, void 0, void 0, function* () {
|
|
61
|
+
var _a;
|
|
62
|
+
try {
|
|
63
|
+
const intercept = yield ((_a = this.shouldInterceptMessageSend) === null || _a === void 0 ? void 0 : _a.call(this, message, this.source));
|
|
64
|
+
if (!intercept) {
|
|
65
|
+
yield this.source.send(message);
|
|
66
|
+
}
|
|
67
|
+
if (this.source.sortOrder !== CommentsOrder.NEWEST) {
|
|
68
|
+
this.sortOrder = CommentsOrder.NEWEST;
|
|
69
|
+
}
|
|
70
|
+
return true;
|
|
71
|
+
}
|
|
72
|
+
catch (e) {
|
|
73
|
+
console.error(`Failed to send message: `, message);
|
|
74
|
+
console.error(e);
|
|
75
|
+
throw new Error(`Could not send: ${e.message}`);
|
|
76
|
+
}
|
|
77
|
+
});
|
|
78
|
+
this.sendReply = (message) => __awaiter(this, void 0, void 0, function* () {
|
|
79
|
+
var _b;
|
|
80
|
+
try {
|
|
81
|
+
const intercept = yield ((_b = this.shouldInterceptMessageSend) === null || _b === void 0 ? void 0 : _b.call(this, message, this.source));
|
|
82
|
+
if (!intercept) {
|
|
83
|
+
yield this.selectedMessageThread.send(message);
|
|
84
|
+
}
|
|
85
|
+
return true;
|
|
86
|
+
}
|
|
87
|
+
catch (e) {
|
|
88
|
+
console.error(`Failed to send message: `, message);
|
|
89
|
+
console.error(e);
|
|
90
|
+
throw new Error(`Could not send reply: ${e.message}`);
|
|
91
|
+
}
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
// Lifecycle Events / Initialization
|
|
95
|
+
ngOnInit() {
|
|
96
|
+
this._subs.add(this.backend.userChanged.subscribe(user => this.user = user));
|
|
97
|
+
this.startLoading();
|
|
98
|
+
console.log(`Checking...`);
|
|
99
|
+
if (typeof window !== 'undefined') {
|
|
100
|
+
let queryString = window.location.search.substring(1);
|
|
101
|
+
let query = queryString.split('&')
|
|
102
|
+
.map(s => s.split('='))
|
|
103
|
+
.reduce((o, [k, v]) => (o[k] = v, o), {});
|
|
104
|
+
console.log('here:');
|
|
105
|
+
console.dir(query);
|
|
106
|
+
const commentID = query['comment'];
|
|
107
|
+
if (commentID) {
|
|
108
|
+
this.sharedCommentID = commentID;
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
ngOnDestroy() {
|
|
113
|
+
this._subs.unsubscribe();
|
|
114
|
+
}
|
|
115
|
+
setSourceFromTopicID(topicID) {
|
|
116
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
117
|
+
if (this._source) {
|
|
118
|
+
this._source.close();
|
|
119
|
+
this._source = null;
|
|
120
|
+
}
|
|
121
|
+
setTimeout(() => __awaiter(this, void 0, void 0, function* () {
|
|
122
|
+
console.log(`[banta-comments] Subscribing to topic source '${topicID}'`);
|
|
123
|
+
this._source = yield this.backend.getSourceForTopic(topicID, { sortOrder: this.sortOrder });
|
|
124
|
+
if (this.sharedCommentID) {
|
|
125
|
+
this.navigateToSharedComment(this.sharedCommentID);
|
|
126
|
+
this.sharedCommentID = null;
|
|
127
|
+
}
|
|
128
|
+
this._source.messageReceived.subscribe(m => this.addParticipant(m));
|
|
129
|
+
this._source.messageSent.subscribe(m => this.addParticipant(m));
|
|
130
|
+
this._source.messages.forEach(m => this.addParticipant(m));
|
|
131
|
+
}));
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
get loadingMessage() {
|
|
135
|
+
return this._loadingMessage;
|
|
136
|
+
}
|
|
137
|
+
set loadingMessage(value) {
|
|
138
|
+
this.loadingMessageVisible = false;
|
|
139
|
+
setTimeout(() => {
|
|
140
|
+
this._loadingMessage = value;
|
|
141
|
+
this._loadingMessage = value;
|
|
142
|
+
setTimeout(() => {
|
|
143
|
+
this.loadingMessageVisible = true;
|
|
144
|
+
});
|
|
145
|
+
}, 500);
|
|
146
|
+
}
|
|
147
|
+
startLoading() {
|
|
148
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
149
|
+
this.loadingStartedAt = this.messageChangedAt = Date.now();
|
|
150
|
+
if (this.updateLoading())
|
|
151
|
+
return;
|
|
152
|
+
yield new Promise(resolve => setTimeout(() => resolve(), 100));
|
|
153
|
+
if (this.updateLoading())
|
|
154
|
+
return;
|
|
155
|
+
yield new Promise(resolve => setTimeout(() => resolve(), 250));
|
|
156
|
+
if (this.updateLoading())
|
|
157
|
+
return;
|
|
158
|
+
yield new Promise(resolve => setTimeout(() => resolve(), 500));
|
|
159
|
+
if (this.updateLoading())
|
|
160
|
+
return;
|
|
161
|
+
console.log(`[Banta] Loading is taking a long time! Showing loading screen.`);
|
|
162
|
+
this.showLoadingScreen = true;
|
|
163
|
+
if (typeof window !== 'undefined')
|
|
164
|
+
this._loadingTimer = setInterval(() => this.updateLoading(), 1000);
|
|
165
|
+
});
|
|
45
166
|
}
|
|
46
|
-
|
|
47
|
-
|
|
167
|
+
updateLoading() {
|
|
168
|
+
var _a, _b, _c;
|
|
169
|
+
if (((_a = this.source) === null || _a === void 0 ? void 0 : _a.state) && ((_b = this.source) === null || _b === void 0 ? void 0 : _b.state) !== 'connecting') {
|
|
170
|
+
clearInterval(this._loadingTimer);
|
|
171
|
+
this.loadingMessage = `Here we go!`;
|
|
172
|
+
setTimeout(() => {
|
|
173
|
+
this.loading = false;
|
|
174
|
+
}, 750);
|
|
175
|
+
return true;
|
|
176
|
+
}
|
|
177
|
+
console.log(`[Banta] Status check: ${((_c = this.source) === null || _c === void 0 ? void 0 : _c.state) || 'connecting'}`);
|
|
178
|
+
let messageSwitchTime = 5 * 1000;
|
|
179
|
+
if (this.messageChangedAt + messageSwitchTime < Date.now()) {
|
|
180
|
+
if (this.loadingMessages[this._loadingMessageIndex]) {
|
|
181
|
+
this.loadingMessage = this.loadingMessages[this._loadingMessageIndex++];
|
|
182
|
+
this.messageChangedAt = Date.now();
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
return false;
|
|
186
|
+
}
|
|
187
|
+
get source() { return this._source; }
|
|
188
|
+
set source(value) {
|
|
189
|
+
this._source = value;
|
|
190
|
+
if (value && this.sharedCommentID) {
|
|
191
|
+
this.navigateToSharedComment(this.sharedCommentID);
|
|
192
|
+
this.sharedCommentID = null;
|
|
193
|
+
}
|
|
48
194
|
}
|
|
195
|
+
get topicID() { return this._topicID; }
|
|
196
|
+
set topicID(value) {
|
|
197
|
+
if (this._topicID !== value) {
|
|
198
|
+
this._topicID = value;
|
|
199
|
+
setTimeout(() => this.setSourceFromTopicID(value));
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
// Outputs
|
|
203
|
+
get signInSelected() { return this._signInSelected; }
|
|
204
|
+
get editAvatarSelected() { return this._editAvatarSelected; }
|
|
205
|
+
get permissionDeniedError() { return this._permissionDeniedError; }
|
|
206
|
+
get upvoted() { return this._upvoted.asObservable(); }
|
|
207
|
+
get reported() { return this._reported.asObservable(); }
|
|
208
|
+
get selected() { return this._selected.asObservable(); }
|
|
209
|
+
get userSelected() { return this._userSelected.asObservable(); }
|
|
210
|
+
get usernameSelected() { return this._usernameSelected.asObservable(); }
|
|
211
|
+
get avatarSelected() { return this._avatarSelected.asObservable(); }
|
|
212
|
+
get shared() { return this._shared.asObservable(); }
|
|
213
|
+
get sortOrder() { return this._sortOrder; }
|
|
49
214
|
set sortOrder(value) {
|
|
50
215
|
if (this._sortOrder !== value) {
|
|
51
216
|
this._sortOrder = value;
|
|
@@ -54,60 +219,62 @@ export class BantaCommentsComponent {
|
|
|
54
219
|
});
|
|
55
220
|
}
|
|
56
221
|
}
|
|
57
|
-
|
|
58
|
-
this._subs.add(this.banta.userChanged.subscribe(user => this.user = user));
|
|
59
|
-
}
|
|
60
|
-
ngAfterViewInit() {
|
|
61
|
-
if (typeof window !== 'undefined')
|
|
62
|
-
this.checkForSharedComment();
|
|
63
|
-
}
|
|
222
|
+
// UI Interactions
|
|
64
223
|
scrollToComment(commentId) {
|
|
65
224
|
setTimeout(() => {
|
|
66
225
|
const comment = document.querySelectorAll(`[data-comment-id="${commentId}"]`);
|
|
67
|
-
console.
|
|
226
|
+
console.dir(comment);
|
|
68
227
|
if (comment.length > 0) {
|
|
69
228
|
// comment.item(0).scroll({behavior: 'smooth'});
|
|
70
229
|
comment.item(0).scrollIntoView();
|
|
71
230
|
}
|
|
72
231
|
}, 1000);
|
|
73
232
|
}
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
if (commentID)
|
|
77
|
-
this.scrollToComment(commentID);
|
|
78
|
-
}
|
|
79
|
-
ngOnDestroy() {
|
|
80
|
-
this._subs.unsubscribe();
|
|
81
|
-
}
|
|
82
|
-
get source() {
|
|
83
|
-
return this._source;
|
|
84
|
-
}
|
|
85
|
-
set source(value) {
|
|
86
|
-
this._source = value;
|
|
87
|
-
}
|
|
88
|
-
get topicID() {
|
|
89
|
-
return this._topicID;
|
|
90
|
-
}
|
|
91
|
-
set topicID(value) {
|
|
92
|
-
if (this._topicID !== value) {
|
|
93
|
-
this._topicID = value;
|
|
94
|
-
setTimeout(() => this.setSourceFromTopicID(value));
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
setSourceFromTopicID(topicID) {
|
|
98
|
-
var _a, _b;
|
|
233
|
+
navigateToSharedComment(id) {
|
|
234
|
+
var _a, _b, _c;
|
|
99
235
|
return __awaiter(this, void 0, void 0, function* () {
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
236
|
+
let source = this.source;
|
|
237
|
+
yield source.ready;
|
|
238
|
+
console.log(`Navigating to shared comment with ID '${id}'...`);
|
|
239
|
+
let message;
|
|
240
|
+
try {
|
|
241
|
+
message = yield this.source.get(id);
|
|
242
|
+
}
|
|
243
|
+
catch (e) {
|
|
244
|
+
console.error(`Failed to find comment from URL: ${e.message}`);
|
|
245
|
+
return;
|
|
246
|
+
}
|
|
247
|
+
(_a = message.transientState) !== null && _a !== void 0 ? _a : (message.transientState = {});
|
|
248
|
+
// If there is a parent message, we should instead focus that and let the
|
|
249
|
+
// scrollToComment and highlight do the work.
|
|
250
|
+
if (message.parentMessageId) {
|
|
251
|
+
let parentMessage = yield this.source.get(message.parentMessageId);
|
|
252
|
+
(_b = parentMessage.transientState) !== null && _b !== void 0 ? _b : (parentMessage.transientState = {});
|
|
253
|
+
let thread = yield this.selectMessage(parentMessage);
|
|
254
|
+
// Need to re-retrieve the message within the new chat source to affect its
|
|
255
|
+
// transient state.
|
|
256
|
+
yield thread.ready;
|
|
257
|
+
message = yield thread.get(message.id);
|
|
258
|
+
(_c = message.transientState) !== null && _c !== void 0 ? _c : (message.transientState = {});
|
|
259
|
+
message.transientState.highlighted = true;
|
|
260
|
+
console.dir(message);
|
|
261
|
+
yield new Promise(resolve => setTimeout(() => resolve(), 500));
|
|
262
|
+
}
|
|
263
|
+
else {
|
|
264
|
+
this.selectMessage(message);
|
|
265
|
+
}
|
|
266
|
+
this.scrollToComment(id);
|
|
109
267
|
});
|
|
110
268
|
}
|
|
269
|
+
showPermissionDenied() {
|
|
270
|
+
this._permissionDeniedError.next();
|
|
271
|
+
}
|
|
272
|
+
scrollToMessage(message) {
|
|
273
|
+
let el = this.elementRef.nativeElement.querySelector(`[data-comment-id="${message.id}"]`);
|
|
274
|
+
if (!el)
|
|
275
|
+
return;
|
|
276
|
+
el.scrollIntoView({ block: 'center', inline: 'start' });
|
|
277
|
+
}
|
|
111
278
|
addParticipant(message) {
|
|
112
279
|
if (!message || !message.user || !message.user.id)
|
|
113
280
|
return;
|
|
@@ -116,90 +283,46 @@ export class BantaCommentsComponent {
|
|
|
116
283
|
return;
|
|
117
284
|
this.participants.push(message.user);
|
|
118
285
|
}
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
}
|
|
122
|
-
showEditAvatar() {
|
|
123
|
-
this._editAvatarSelected.next();
|
|
124
|
-
}
|
|
125
|
-
get newMessageText() {
|
|
126
|
-
return this._newMessageText;
|
|
127
|
-
}
|
|
128
|
-
set newMessageText(value) {
|
|
129
|
-
this._newMessageText = value;
|
|
130
|
-
if (this._newMessageText === '' && this.sendError)
|
|
131
|
-
setTimeout(() => this.sendError = null);
|
|
132
|
-
}
|
|
133
|
-
get signInSelected() {
|
|
134
|
-
return this._signInSelected;
|
|
135
|
-
}
|
|
136
|
-
get editAvatarSelected() {
|
|
137
|
-
return this._editAvatarSelected;
|
|
138
|
-
}
|
|
139
|
-
get permissionDeniedError() {
|
|
140
|
-
return this._permissionDeniedError;
|
|
141
|
-
}
|
|
142
|
-
showPermissionDenied() {
|
|
143
|
-
this._permissionDeniedError.next();
|
|
144
|
-
}
|
|
145
|
-
get canComment() {
|
|
286
|
+
// Actions
|
|
287
|
+
likeMessage(source, message) {
|
|
146
288
|
var _a;
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
get selected() {
|
|
162
|
-
return this._selected.asObservable();
|
|
163
|
-
}
|
|
164
|
-
get userSelected() {
|
|
165
|
-
return this._userSelected.asObservable();
|
|
166
|
-
}
|
|
167
|
-
get usernameSelected() {
|
|
168
|
-
return this._usernameSelected.asObservable();
|
|
169
|
-
}
|
|
170
|
-
get avatarSelected() {
|
|
171
|
-
return this._avatarSelected.asObservable();
|
|
172
|
-
}
|
|
173
|
-
get shared() {
|
|
174
|
-
return this._shared.asObservable();
|
|
175
|
-
}
|
|
176
|
-
onKeyDown(event) {
|
|
177
|
-
}
|
|
178
|
-
insertEmoji(text) {
|
|
179
|
-
this.newMessageText += text;
|
|
180
|
-
}
|
|
181
|
-
onReplyKeyDown(event) {
|
|
182
|
-
}
|
|
183
|
-
insertReplyEmoji(text) {
|
|
184
|
-
this.replyMessage += text;
|
|
185
|
-
}
|
|
186
|
-
indicateError(message) {
|
|
187
|
-
this.sendError = new Error(message);
|
|
188
|
-
setTimeout(() => {
|
|
189
|
-
this.expandError = true;
|
|
190
|
-
setTimeout(() => {
|
|
191
|
-
this.expandError = false;
|
|
192
|
-
}, 5 * 1000);
|
|
289
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
290
|
+
this._upvoted.next(message);
|
|
291
|
+
message.transientState.liking = true;
|
|
292
|
+
if (!((_a = message.userState) === null || _a === void 0 ? void 0 : _a.liked))
|
|
293
|
+
message.likes = (message.likes || 0) + 1;
|
|
294
|
+
try {
|
|
295
|
+
yield source.likeMessage(message.id);
|
|
296
|
+
}
|
|
297
|
+
catch (e) {
|
|
298
|
+
alert(`Could not like this message: ${e.message}`);
|
|
299
|
+
return;
|
|
300
|
+
}
|
|
301
|
+
yield new Promise(resolve => setTimeout(() => resolve(), 250));
|
|
302
|
+
message.transientState.liking = false;
|
|
193
303
|
});
|
|
194
304
|
}
|
|
195
|
-
|
|
305
|
+
unlikeMessage(source, message) {
|
|
306
|
+
var _a;
|
|
196
307
|
return __awaiter(this, void 0, void 0, function* () {
|
|
197
308
|
this._upvoted.next(message);
|
|
198
|
-
|
|
309
|
+
message.transientState.liking = true;
|
|
310
|
+
if ((_a = message.userState) === null || _a === void 0 ? void 0 : _a.liked)
|
|
311
|
+
message.likes = (message.likes || 0) - 1;
|
|
312
|
+
try {
|
|
313
|
+
yield source.unlikeMessage(message.id);
|
|
314
|
+
}
|
|
315
|
+
catch (e) {
|
|
316
|
+
alert(`Failed to unlike message: ${e.message}`);
|
|
317
|
+
}
|
|
318
|
+
yield new Promise(resolve => setTimeout(() => resolve(), 250));
|
|
319
|
+
message.transientState.liking = false;
|
|
199
320
|
});
|
|
200
321
|
}
|
|
201
322
|
reportMessage(message) {
|
|
202
|
-
this
|
|
323
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
324
|
+
this._reported.next(message);
|
|
325
|
+
});
|
|
203
326
|
}
|
|
204
327
|
unselectMessage() {
|
|
205
328
|
return __awaiter(this, void 0, void 0, function* () {
|
|
@@ -219,69 +342,96 @@ export class BantaCommentsComponent {
|
|
|
219
342
|
return __awaiter(this, void 0, void 0, function* () {
|
|
220
343
|
this._selected.next(message);
|
|
221
344
|
this.selectedMessage = message;
|
|
345
|
+
let selectedMessageThread = yield this.backend.getSourceForThread(this.topicID, message.id);
|
|
222
346
|
setTimeout(() => this.selectedMessageVisible = true);
|
|
223
347
|
setTimeout(() => __awaiter(this, void 0, void 0, function* () {
|
|
224
|
-
this.selectedMessageThread =
|
|
348
|
+
this.selectedMessageThread = selectedMessageThread;
|
|
225
349
|
}), 250);
|
|
350
|
+
return selectedMessageThread;
|
|
351
|
+
});
|
|
352
|
+
}
|
|
353
|
+
showSignIn() {
|
|
354
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
355
|
+
this._signInSelected.next();
|
|
356
|
+
});
|
|
357
|
+
}
|
|
358
|
+
showEditAvatar() {
|
|
359
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
360
|
+
this._editAvatarSelected.next();
|
|
226
361
|
});
|
|
227
362
|
}
|
|
228
363
|
selectMessageUser(message) {
|
|
229
|
-
this
|
|
364
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
365
|
+
this._userSelected.next(message);
|
|
366
|
+
});
|
|
230
367
|
}
|
|
231
368
|
selectUsername(user) {
|
|
232
|
-
this
|
|
369
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
370
|
+
this._usernameSelected.next(user);
|
|
371
|
+
});
|
|
233
372
|
}
|
|
234
373
|
selectAvatar(user) {
|
|
235
|
-
this
|
|
374
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
375
|
+
this._avatarSelected.next(user);
|
|
376
|
+
});
|
|
236
377
|
}
|
|
237
378
|
shareMessage(message) {
|
|
238
|
-
this
|
|
379
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
380
|
+
this._shared.next(message);
|
|
381
|
+
});
|
|
239
382
|
}
|
|
240
|
-
|
|
383
|
+
deleteMessage(message) {
|
|
241
384
|
return __awaiter(this, void 0, void 0, function* () {
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
upvotes: 0,
|
|
246
|
-
user: this.user,
|
|
247
|
-
submessages: [],
|
|
248
|
-
topicId: this.topicID,
|
|
249
|
-
sentAt: Date.now(),
|
|
250
|
-
updatedAt: Date.now()
|
|
251
|
-
});
|
|
252
|
-
this.replyMessage = '';
|
|
385
|
+
if (!confirm("Are you sure you want to delete this comment? You cannot undo this action."))
|
|
386
|
+
return;
|
|
387
|
+
this.source.deleteMessage(message.id);
|
|
253
388
|
});
|
|
254
389
|
}
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
390
|
+
editMessage(source, message, newText) {
|
|
391
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
392
|
+
try {
|
|
393
|
+
yield source.editMessage(message.id, newText);
|
|
394
|
+
}
|
|
395
|
+
catch (e) {
|
|
396
|
+
alert(e.message);
|
|
397
|
+
return;
|
|
398
|
+
}
|
|
399
|
+
message.message = newText;
|
|
400
|
+
message.transientState.editing = false;
|
|
401
|
+
});
|
|
402
|
+
}
|
|
403
|
+
startEditing(message) {
|
|
404
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
405
|
+
this.selectedMessage.transientState.editing = false;
|
|
406
|
+
message.transientState.editing = true;
|
|
407
|
+
});
|
|
408
|
+
}
|
|
409
|
+
saveEdit(message, text) {
|
|
410
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
411
|
+
try {
|
|
412
|
+
yield this.source.editMessage(message.id, text);
|
|
413
|
+
message.transientState.editing = false;
|
|
414
|
+
}
|
|
415
|
+
catch (e) {
|
|
416
|
+
alert(`Could not edit message: ${e.message}`);
|
|
417
|
+
}
|
|
418
|
+
});
|
|
260
419
|
}
|
|
261
420
|
}
|
|
262
421
|
BantaCommentsComponent.decorators = [
|
|
263
422
|
{ type: Component, args: [{
|
|
264
423
|
selector: 'banta-comments',
|
|
265
|
-
template: "\r\n<div class=\"focused\" [class.visible]=\"selectedMessageVisible\" *ngIf=\"selectedMessage\">\r\n\r\n
|
|
266
|
-
styles: [":host{display:flex;flex-direction:column}@-webkit-keyframes select-comment{0%{transform:scale(1.15)}to{transform:scale(1)}}@keyframes select-comment{0%{transform:scale(1.15)}to{transform:scale(1)}}.focused{-webkit-animation-
|
|
424
|
+
template: "<ng-container *ngIf=\"loading\">\r\n <div class=\"loading-screen\" [class.visible]=\"showLoadingScreen\">\r\n <h1>Loading Comments</h1>\r\n <div>\r\n <mat-spinner [diameter]=\"300\" [strokeWidth]=\"2\"></mat-spinner>\r\n </div>\r\n\r\n <p class=\"loading-message\" [class.visible]=\"loadingMessageVisible\">{{loadingMessage}}</p>\r\n </div>\r\n</ng-container>\r\n<ng-container *ngIf=\"!loading\">\r\n <div class=\"focused\" [class.visible]=\"selectedMessageVisible\" *ngIf=\"selectedMessage\">\r\n\r\n <div>\r\n <a mat-button href=\"javascript:;\" (click)=\"unselectMessage()\">\r\n <mat-icon>arrow_back</mat-icon>\r\n Latest Comments\r\n </a>\r\n </div>\r\n\r\n <banta-comment\r\n [message]=\"selectedMessage\"\r\n [liking]=\"selectedMessage.transientState.liking\"\r\n [mine]=\"user?.id === selectedMessage.user?.id\"\r\n [permissions]=\"source?.permissions\"\r\n [showReplyAction]=\"false\"\r\n [editing]=\"selectedMessage.transientState.editing\"\r\n (editStarted)=\"startEditing(selectedMessage)\"\r\n (editEnded)=\"selectedMessage.transientState.editing = false\"\r\n (edited)=\"saveEdit(selectedMessage, $event)\"\r\n (userSelected)=\"selectMessageUser(selectedMessage)\"\r\n (avatarSelected)=\"selectAvatar($event)\"\r\n (usernameSelected)=\"selectUsername($event)\"\r\n (liked)=\"likeMessage(selectedMessage)\"\r\n (unliked)=\"unlikeMessage(selectedMessage)\"\r\n (reported)=\"reportMessage(selectedMessage)\"\r\n (selected)=\"selectMessage(selectedMessage)\"\r\n (shared)=\"shareMessage($event)\"\r\n (deleted)=\"deleteMessage(selectedMessage)\"\r\n ></banta-comment>\r\n\r\n <div class=\"replies\">\r\n\r\n <ng-container *ngIf=\"!selectedMessageThread\">\r\n <div class=\"loading\">\r\n <mat-spinner></mat-spinner>\r\n </div>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"selectedMessageThread\">\r\n <banta-comment-view\r\n [source]=\"selectedMessageThread\"\r\n [allowReplies]=\"false\"\r\n [fixedHeight]=\"false\"\r\n [showEmptyState]=\"false\"\r\n [newestLast]=\"true\"\r\n (liked)=\"likeMessage(selectedMessageThread, $event)\"\r\n (unliked)=\"unlikeMessage(selectedMessageThread, $event)\"\r\n (messageEdited)=\"editMessage(selectedMessageThread, $event.message, $event.newMessage)\"\r\n (reported)=\"reportMessage($event)\"\r\n (usernameSelected)=\"selectUsername($event)\"\r\n (avatarSelected)=\"selectAvatar($event)\"\r\n (shared)=\"shareMessage($event)\"\r\n (deleted)=\"deleteMessage($event)\"\r\n ></banta-comment-view>\r\n\r\n <banta-comment-field\r\n [sendLabel]=\"replyLabel\"\r\n [sendingLabel]=\"sendingLabel\"\r\n [hashtags]=\"hashtags\"\r\n [participants]=\"participants\"\r\n (signInSelected)=\"showSignIn()\"\r\n (editAvatarSelected)=\"showEditAvatar()\"\r\n [source]=\"selectedMessageThread\"\r\n [canComment]=\"source?.permissions?.canPost\"\r\n [signInLabel]=\"signInLabel\"\r\n [permissionDeniedLabel]=\"permissionDeniedLabel\"\r\n (permissionDeniedError)=\"showPermissionDenied()\"\r\n [shouldInterceptMessageSend]=\"shouldInterceptMessageSend\"\r\n [user]=\"user\"\r\n [label]=\"postReplyLabel\"\r\n [submit]=\"sendReply\"\r\n >\r\n <ng-content select=\".reply-send-options\"></ng-content>\r\n </banta-comment-field>\r\n </ng-container>\r\n </div>\r\n </div>\r\n\r\n <div class=\"main\" [class.hidden]=\"selectedMessage\">\r\n <banta-comment-field\r\n [source]=\"source\"\r\n [user]=\"user\"\r\n [sendLabel]=\"sendLabel\"\r\n [sendingLabel]=\"sendingLabel\"\r\n [signInLabel]=\"signInLabel\"\r\n [canComment]=\"source?.permissions?.canPost\"\r\n [hashtags]=\"hashtags\"\r\n [participants]=\"participants\"\r\n [label]=\"postCommentLabel\"\r\n (editAvatarSelected)=\"showEditAvatar()\"\r\n (signInSelected)=\"showSignIn()\"\r\n [permissionDeniedLabel]=\"permissionDeniedLabel\"\r\n (permissionDeniedError)=\"showPermissionDenied()\"\r\n [shouldInterceptMessageSend]=\"shouldInterceptMessageSend\"\r\n [submit]=\"sendMessage\"\r\n >\r\n \r\n </banta-comment-field>\r\n\r\n <banta-comment-sort\r\n [(sort)]=\"sortOrder\"></banta-comment-sort>\r\n\r\n <banta-comment-view\r\n [class.faded]=\"selectedMessage\"\r\n [source]=\"source\"\r\n [fixedHeight]=\"fixedHeight\"\r\n [maxMessages]=\"maxMessages\"\r\n [maxVisibleMessages]=\"maxVisibleMessages\"\r\n [genericAvatarUrl]=\"genericAvatarUrl\"\r\n (userSelected)=\"selectMessageUser($event)\"\r\n (sortOrderChanged)=\"sortOrder = $event\"\r\n (selected)=\"selectMessage($event)\"\r\n (liked)=\"likeMessage(source, $event)\"\r\n (unliked)=\"unlikeMessage(source, $event)\"\r\n (messageEdited)=\"editMessage(source, $event.message, $event.newMessage)\"\r\n (reported)=\"reportMessage($event)\"\r\n (usernameSelected)=\"selectUsername($event)\"\r\n (avatarSelected)=\"selectAvatar($event)\"\r\n (shared)=\"shareMessage($event)\"\r\n (deleted)=\"deleteMessage($event)\"\r\n ></banta-comment-view>\r\n </div>\r\n</ng-container>",
|
|
425
|
+
styles: [":host{display:flex;flex-direction:column}@-webkit-keyframes select-comment{0%{transform:scale(1.15)}to{transform:scale(1)}}@keyframes select-comment{0%{transform:scale(1.15)}to{transform:scale(1)}}.focused{-webkit-animation-name:select-comment;animation-name:select-comment;-webkit-animation-duration:.4s;animation-duration:.4s;-webkit-animation-fill-mode:both;animation-fill-mode:both}.focused .replies{margin-top:1em;margin-left:4em}banta-comment-view{opacity:1;transition:opacity .4s ease-in-out}banta-comment-view.faded{opacity:.25}.loading{display:block;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content;margin:0 auto;min-height:16em}.main.hidden{display:none}@media (max-width:500px){.focused .replies{margin-left:0}}.loading-screen{text-align:center;opacity:0;transition:opacity .25s ease-in-out}.loading-screen.visible{opacity:1}.loading-screen h1{font-weight:100}.loading-screen mat-spinner{margin:5em auto}.loading-screen .loading-message{opacity:0;transition:opacity .25s ease-in-out;width:500px;max-width:100%;margin:0 auto}.loading-screen .loading-message.visible{opacity:1}"]
|
|
267
426
|
},] }
|
|
268
427
|
];
|
|
269
428
|
BantaCommentsComponent.ctorParameters = () => [
|
|
270
|
-
{ type:
|
|
271
|
-
{ type: ChatBackendService },
|
|
429
|
+
{ type: ChatBackendBase },
|
|
272
430
|
{ type: ElementRef },
|
|
273
431
|
{ type: ActivatedRoute }
|
|
274
432
|
];
|
|
275
433
|
BantaCommentsComponent.propDecorators = {
|
|
276
|
-
|
|
277
|
-
participants: [{ type: Input }],
|
|
278
|
-
source: [{ type: Input }],
|
|
279
|
-
fixedHeight: [{ type: Input }],
|
|
280
|
-
maxMessages: [{ type: Input }],
|
|
281
|
-
maxVisibleMessages: [{ type: Input }],
|
|
282
|
-
genericAvatarUrl: [{ type: Input }],
|
|
283
|
-
shouldInterceptMessageSend: [{ type: Input }],
|
|
284
|
-
topicID: [{ type: Input }],
|
|
434
|
+
loadingMessages: [{ type: Input }],
|
|
285
435
|
signInLabel: [{ type: Input }],
|
|
286
436
|
sendLabel: [{ type: Input }],
|
|
287
437
|
replyLabel: [{ type: Input }],
|
|
@@ -289,6 +439,15 @@ BantaCommentsComponent.propDecorators = {
|
|
|
289
439
|
permissionDeniedLabel: [{ type: Input }],
|
|
290
440
|
postCommentLabel: [{ type: Input }],
|
|
291
441
|
postReplyLabel: [{ type: Input }],
|
|
442
|
+
fixedHeight: [{ type: Input }],
|
|
443
|
+
maxMessages: [{ type: Input }],
|
|
444
|
+
maxVisibleMessages: [{ type: Input }],
|
|
445
|
+
genericAvatarUrl: [{ type: Input }],
|
|
446
|
+
shouldInterceptMessageSend: [{ type: Input }],
|
|
447
|
+
participants: [{ type: Input }],
|
|
448
|
+
source: [{ type: Input }],
|
|
449
|
+
hashtags: [{ type: Input }],
|
|
450
|
+
topicID: [{ type: Input }],
|
|
292
451
|
signInSelected: [{ type: Output }],
|
|
293
452
|
editAvatarSelected: [{ type: Output }],
|
|
294
453
|
permissionDeniedError: [{ type: Output }],
|
|
@@ -300,4 +459,4 @@ BantaCommentsComponent.propDecorators = {
|
|
|
300
459
|
avatarSelected: [{ type: Output }],
|
|
301
460
|
shared: [{ type: Output }]
|
|
302
461
|
};
|
|
303
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"banta-comments.component.js","sourceRoot":"D:/Dev/astronautlabs/banta/packages/frontend/projects/sdk/src/","sources":["lib/comments/banta-comments/banta-comments.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, Input, Output } from '@angular/core';\r\nimport { User, ChatSource, ChatMessage, UserAccount, CommentsOrder } from '@banta/common';\r\nimport { HashTag } from '../comment-field/comment-field.component';\r\nimport { Subject, Observable, Subscription } from 'rxjs';\r\nimport { ChatBackendService } from '../../common';\r\nimport { BantaService } from '../../common';\r\nimport { ActivatedRoute } from '@angular/router';\r\n\r\n/**\r\n * Comments component\r\n */\r\n@Component({\r\n    selector: 'banta-comments',\r\n    templateUrl: './banta-comments.component.html',\r\n    styleUrls: ['./banta-comments.component.scss']\r\n})\r\nexport class BantaCommentsComponent implements AfterViewInit {\r\n    constructor(\r\n        private banta: BantaService,\r\n        private backend: ChatBackendService,\r\n        private elementRef: ElementRef<HTMLElement>,\r\n        private activatedRoute: ActivatedRoute\r\n    ) {\r\n    }\r\n\r\n    private _upvoted = new Subject<ChatMessage>();\r\n    private _reported = new Subject<ChatMessage>();\r\n    private _selected = new Subject<ChatMessage>();\r\n    private _userSelected = new Subject<ChatMessage>();\r\n    private _shared = new Subject<ChatMessage>();\r\n\r\n    private _usernameSelected = new Subject<User>();\r\n    private _avatarSelected = new Subject<User>();\r\n\r\n    private _source: ChatSource;\r\n\r\n    private _subs = new Subscription();\r\n\r\n    _sortOrder: CommentsOrder = CommentsOrder.NEWEST;\r\n\r\n    get sortOrder() {\r\n        return this._sortOrder;\r\n    }\r\n\r\n    set sortOrder(value) {\r\n        if (this._sortOrder !== value) {\r\n            this._sortOrder = value;\r\n            setTimeout(() => {\r\n                this.setSourceFromTopicID(this.topicID);\r\n            });\r\n        }\r\n    }\r\n\r\n    @Input() hashtags: HashTag[] = [\r\n        {hashtag: 'error', description: 'Cause an error'},\r\n        {hashtag: 'timeout', description: 'Cause a slow timeout error'},\r\n        {hashtag: 'slow', description: 'Be slow when this message is posted'},\r\n    ];\r\n\r\n    @Input() participants: User[] = [];\r\n\r\n    ngOnInit() {\r\n        this._subs.add(\r\n            this.banta.userChanged.subscribe(user => this.user = user)\r\n        );\r\n    }\r\n\r\n    ngAfterViewInit() {\r\n        if (typeof window !== 'undefined') this.checkForSharedComment();\r\n    }\r\n\r\n    scrollToComment(commentId: ChatMessage['id']): void {\r\n        setTimeout(() => {\r\n          const comment = document.querySelectorAll(`[data-comment-id=\"${commentId}\"]`);\r\n          console.log(comment)\r\n          if (comment.length > 0) {\r\n            // comment.item(0).scroll({behavior: 'smooth'});\r\n            comment.item(0).scrollIntoView();\r\n          }\r\n        }, 1000);\r\n    }\r\n\r\n    checkForSharedComment(): void {\r\n        const commentID = this.activatedRoute.snapshot.queryParamMap.get('comment');\r\n        if (commentID) this.scrollToComment(commentID);\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        this._subs.unsubscribe();\r\n    }\r\n\r\n    @Input()\r\n    get source(): ChatSource {\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() fixedHeight: boolean;\r\n    @Input() maxMessages: number;\r\n    @Input() maxVisibleMessages: number;\r\n    @Input() genericAvatarUrl: string;\r\n\r\n    @Input() shouldInterceptMessageSend?: (message: ChatMessage, source: ChatSource) => boolean | Promise<boolean>;\r\n\r\n    @Input()\r\n    get topicID(): string {\r\n        return this._topicID;\r\n    }\r\n\r\n    private _topicID: string;\r\n\r\n    set topicID(value) {\r\n        if (this._topicID !== value) {\r\n            this._topicID = value;\r\n            setTimeout(() => this.setSourceFromTopicID(value));\r\n        }\r\n    }\r\n\r\n    private async setSourceFromTopicID(topicID: string) {\r\n        this._source?.close?.();\r\n        this._source = null;\r\n        setTimeout(async () => {\r\n            this._source = await this.backend.getSourceForTopic(topicID, { sortOrder: this.sortOrder });\r\n\r\n            console.log(`[banta-comments] Subscribing to source for topic '${topicID}'`);\r\n\r\n            this._source.messageReceived.subscribe(m => this.addParticipant(m));\r\n            this._source.messageSent.subscribe(m => this.addParticipant(m));\r\n            this._source.messages.forEach(m => this.addParticipant(m));\r\n        });\r\n    }\r\n\r\n    private addParticipant(message: ChatMessage) {\r\n        if (!message || !message.user || !message.user.id)\r\n            return;\r\n\r\n        let existing = this.participants.find(x => x.id === message.user.id);\r\n        if (existing)\r\n            return;\r\n        this.participants.push(message.user);\r\n    }\r\n\r\n    showSignIn() {\r\n        this._signInSelected.next();\r\n    }\r\n\r\n    showEditAvatar() {\r\n        this._editAvatarSelected.next();\r\n    }\r\n\r\n    user: UserAccount;\r\n\r\n    private _newMessageText: string;\r\n\r\n    get newMessageText(): string {\r\n        return this._newMessageText;\r\n    }\r\n\r\n    set newMessageText(value) {\r\n        this._newMessageText = value;\r\n        if (this._newMessageText === '' && this.sendError)\r\n            setTimeout(() => this.sendError = null);\r\n    }\r\n\r\n    @Input() signInLabel = 'Sign In';\r\n    @Input() sendLabel = 'Send';\r\n    @Input() replyLabel = 'Reply';\r\n    @Input() sendingLabel = 'Sending';\r\n    @Input() permissionDeniedLabel = 'Send';\r\n    @Input() postCommentLabel = 'Post a comment';\r\n    @Input() postReplyLabel = 'Post a reply';\r\n\r\n    private _signInSelected = new Subject<void>();\r\n    private _permissionDeniedError = new Subject<void>();\r\n    private _editAvatarSelected = new Subject<void>();\r\n\r\n    @Output()\r\n    get signInSelected(): Observable<void> {\r\n        return this._signInSelected;\r\n    }\r\n\r\n    @Output()\r\n    get editAvatarSelected() {\r\n        return this._editAvatarSelected;\r\n    }\r\n\r\n    @Output()\r\n    get permissionDeniedError(): Observable<void> {\r\n        return this._permissionDeniedError;\r\n    }\r\n\r\n    showPermissionDenied() {\r\n        this._permissionDeniedError.next();\r\n    }\r\n\r\n    get canComment() {\r\n        if (!this.user)\r\n            return false;\r\n\r\n        if (!this.user.permissions)\r\n            return true;\r\n\r\n        if (!this.user.permissions.canComment)\r\n            return true;\r\n\r\n        return this.user.permissions?.canComment(this.source);\r\n    }\r\n\r\n    @Output()\r\n    get upvoted() {\r\n        return this._upvoted.asObservable();\r\n    }\r\n\r\n    @Output()\r\n    get reported() {\r\n        return this._reported.asObservable();\r\n    }\r\n\r\n    @Output()\r\n    get selected() {\r\n        return this._selected.asObservable();\r\n    }\r\n\r\n    @Output()\r\n    get userSelected() {\r\n        return this._userSelected.asObservable();\r\n    }\r\n\r\n    @Output()\r\n    get usernameSelected() {\r\n        return this._usernameSelected.asObservable();\r\n    }\r\n\r\n    @Output()\r\n    get avatarSelected() {\r\n        return this._avatarSelected.asObservable();\r\n    }\r\n\r\n    @Output()\r\n    get shared() {\r\n        return this._shared.asObservable();\r\n    }\r\n\r\n    onKeyDown(event: KeyboardEvent) {\r\n    }\r\n\r\n    insertEmoji(text: string) {\r\n        this.newMessageText += text;\r\n    }\r\n\r\n    onReplyKeyDown(event: KeyboardEvent) {\r\n    }\r\n\r\n    insertReplyEmoji(text: string) {\r\n        this.replyMessage += text;\r\n    }\r\n\r\n    sending = false;\r\n    sendError: Error;\r\n    expandError = false;\r\n\r\n    indicateError(message: string) {\r\n        this.sendError = new Error(message);\r\n        setTimeout(() => {\r\n            this.expandError = true;\r\n            setTimeout(() => {\r\n                this.expandError = false;\r\n            }, 5 * 1000);\r\n        });\r\n    }\r\n\r\n    async upvoteMessage(message: ChatMessage) {\r\n        this._upvoted.next(message);\r\n        await this.backend.upvoteMessage(message.topicId, message.parentMessageId ? message.parentMessageId : message.id, message.parentMessageId ? message.id : undefined);\r\n    }\r\n\r\n    reportMessage(message: ChatMessage) {\r\n        this._reported.next(message);\r\n    }\r\n\r\n    selectedMessage: ChatMessage;\r\n    selectedMessageThread: ChatSource;\r\n\r\n    replyMessage: string;\r\n\r\n    async unselectMessage() {\r\n        let message = this.selectedMessage;\r\n\r\n        this._selected.next(null);\r\n        this.selectedMessage = null;\r\n        if (this.selectedMessageThread) {\r\n            if (this.selectedMessageThread.close)\r\n                this.selectedMessageThread.close();\r\n            this.selectedMessageThread = null;\r\n        }\r\n\r\n        if (message)\r\n            setTimeout(() => this.scrollToMessage(message));\r\n    }\r\n\r\n    selectedMessageVisible = false;\r\n\r\n    async selectMessage(message: ChatMessage) {\r\n        this._selected.next(message);\r\n        this.selectedMessage = message;\r\n        setTimeout(() => this.selectedMessageVisible = true);\r\n        setTimeout(async () => {\r\n            this.selectedMessageThread = await this.backend.getSourceForThread(this.topicID, message.id);\r\n        }, 250);\r\n    }\r\n\r\n    selectMessageUser(message: ChatMessage) {\r\n        this._userSelected.next(message);\r\n    }\r\n\r\n    selectUsername(user: User) {\r\n        this._usernameSelected.next(user);\r\n    }\r\n\r\n    selectAvatar(user: User) {\r\n        this._avatarSelected.next(user);\r\n    }\r\n\r\n    shareMessage(message: ChatMessage) {\r\n        this._shared.next(message);\r\n    }\r\n\r\n    async sendReply() {\r\n        await this.selectedMessageThread.send({\r\n            message: this.replyMessage,\r\n            parentMessageId: this.selectedMessage.id,\r\n            upvotes: 0,\r\n            user: this.user,\r\n            submessages: [],\r\n            topicId: this.topicID,\r\n            sentAt: Date.now(),\r\n            updatedAt: Date.now()\r\n        })\r\n        this.replyMessage = '';\r\n    }\r\n\r\n    scrollToMessage(message: ChatMessage) {\r\n        let el = this.elementRef.nativeElement.querySelector(`[data-comment-id=\"${message.id}\"]`);\r\n        if (!el)\r\n            return;\r\n        el.scrollIntoView({block: 'center', inline: 'start'});\r\n    }\r\n}\r\n"]}
|
|
462
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"banta-comments.component.js","sourceRoot":"","sources":["../../../../../../projects/sdk/src/lib/comments/banta-comments/banta-comments.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, Input, Output } from '@angular/core';\r\nimport { User, ChatMessage, CommentsOrder } from '@banta/common';\r\nimport { HashTag } from '../comment-field/comment-field.component';\r\nimport { Subject, Observable, Subscription } from 'rxjs';\r\nimport { ActivatedRoute } from '@angular/router';\r\nimport { ChatBackendBase } from '../../chat-backend-base';\r\nimport { ChatSourceBase } from '../../chat-source-base';\r\nimport { EditEvent } from '../comment-view/comment-view.component';\r\n\r\n/**\r\n * Comments component\r\n */\r\n@Component({\r\n    selector: 'banta-comments',\r\n    templateUrl: './banta-comments.component.html',\r\n    styleUrls: ['./banta-comments.component.scss']\r\n})\r\nexport class BantaCommentsComponent {\r\n    constructor(\r\n        private backend: ChatBackendBase,\r\n        private elementRef: ElementRef<HTMLElement>,\r\n        private activatedRoute: ActivatedRoute\r\n    ) {\r\n        this.sendMessage = async (message: ChatMessage) => {\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                if (this.source.sortOrder !== CommentsOrder.NEWEST) {\r\n                    this.sortOrder = CommentsOrder.NEWEST;\r\n                }\r\n                return true;\r\n            } catch (e) {\r\n                console.error(`Failed to send message: `, message);\r\n                console.error(e);\r\n\r\n                throw new Error(`Could not send: ${e.message}`);\r\n            }\r\n        }\r\n\r\n        this.sendReply = async (message: ChatMessage) => {\r\n            try {\r\n                const intercept = await this.shouldInterceptMessageSend?.(message, this.source);\r\n                if (!intercept) {\r\n                    await this.selectedMessageThread.send(message);\r\n                }\r\n                return true;\r\n            } catch (e) {\r\n                console.error(`Failed to send message: `, message);\r\n                console.error(e);\r\n\r\n                throw new Error(`Could not send reply: ${e.message}`);\r\n            }\r\n        }\r\n    }\r\n\r\n    // Lifecycle Events / Initialization\r\n\r\n    ngOnInit() {\r\n        this._subs.add(this.backend.userChanged.subscribe(user => this.user = user));\r\n        this.startLoading();\r\n\r\n        console.log(`Checking...`);\r\n        if (typeof window !== 'undefined') {\r\n            let queryString = window.location.search.substring(1);\r\n            let query = queryString.split('&')\r\n                .map(s => s.split('='))\r\n                .reduce((o, [k, v]) => (o[k] = v, o), {})\r\n            ;\r\n\r\n            console.log('here:');\r\n            console.dir(query);\r\n            const commentID = query['comment'];\r\n            if (commentID) {\r\n                this.sharedCommentID = commentID;\r\n            }\r\n        }\r\n    }\r\n\r\n    sharedCommentID: string;\r\n\r\n    ngOnDestroy() {\r\n        this._subs.unsubscribe();\r\n    }\r\n\r\n    private async setSourceFromTopicID(topicID: string) {\r\n        if (this._source) {\r\n            this._source.close();\r\n            this._source = null;\r\n        }\r\n\r\n        setTimeout(async () => {\r\n            console.log(`[banta-comments] Subscribing to topic source '${topicID}'`);\r\n            this._source = await this.backend.getSourceForTopic(topicID, { sortOrder: this.sortOrder });\r\n\r\n            if (this.sharedCommentID) {\r\n                this.navigateToSharedComment(this.sharedCommentID);\r\n                this.sharedCommentID = null;\r\n            }\r\n\r\n            this._source.messageReceived.subscribe(m => this.addParticipant(m));\r\n            this._source.messageSent.subscribe(m => this.addParticipant(m));\r\n            this._source.messages.forEach(m => this.addParticipant(m));\r\n        });\r\n    }\r\n\r\n    // Loading Screen\r\n    private _loadingMessage = '';\r\n    loadingMessageVisible = false;\r\n\r\n    get loadingMessage() {\r\n        return this._loadingMessage;\r\n    }\r\n\r\n    set loadingMessage(value) {\r\n        this.loadingMessageVisible = false;\r\n        setTimeout(() => {\r\n            this._loadingMessage = value;\r\n            this._loadingMessage = value;\r\n            setTimeout(() => {\r\n                this.loadingMessageVisible = true;\r\n            })\r\n        }, 500);\r\n    }\r\n\r\n    loading: boolean = true;\r\n    showLoadingScreen = false;\r\n    loadingStartedAt: number;\r\n    messageChangedAt: number;\r\n\r\n    private async startLoading() {\r\n        this.loadingStartedAt = this.messageChangedAt = Date.now();\r\n\r\n        if (this.updateLoading()) return;\r\n        await new Promise<void>(resolve => setTimeout(() => resolve(), 100));\r\n        if (this.updateLoading()) return;\r\n        await new Promise<void>(resolve => setTimeout(() => resolve(), 250));\r\n        if (this.updateLoading()) return;\r\n        await new Promise<void>(resolve => setTimeout(() => resolve(), 500));\r\n        if (this.updateLoading()) return;\r\n\r\n        console.log(`[Banta] Loading is taking a long time! Showing loading screen.`);\r\n        this.showLoadingScreen = true;\r\n        if (typeof window !== 'undefined')\r\n            this._loadingTimer = setInterval(() => this.updateLoading(), 1000);\r\n    }\r\n    \r\n    private _loadingTimer;\r\n    private _loadingMessageIndex = 0;\r\n\r\n    @Input() loadingMessages: string[] = [\r\n        `Just a second...`,\r\n        `We're definitely working on it.`,\r\n        `There's no need to refresh.`,\r\n        `It's definitely worth the wait!`,\r\n        `This has never happened before.`,\r\n        `We'll keep trying, but it's not looking great. \r\n            Commenting & chat services may be down. \r\n            If you continue to experience issues, please contact support.\r\n        `\r\n    ];\r\n\r\n    private updateLoading(): boolean {\r\n        if (this.source?.state && this.source?.state !== 'connecting') {\r\n            clearInterval(this._loadingTimer);\r\n            this.loadingMessage = `Here we go!`;\r\n            setTimeout(() => {\r\n                this.loading = false;\r\n            }, 750);\r\n            return true;\r\n        }\r\n\r\n        console.log(`[Banta] Status check: ${this.source?.state || 'connecting'}`);\r\n\r\n        let messageSwitchTime = 5*1000;\r\n        if (this.messageChangedAt + messageSwitchTime < Date.now()) {\r\n            if (this.loadingMessages[this._loadingMessageIndex]) {\r\n                this.loadingMessage = this.loadingMessages[this._loadingMessageIndex++];\r\n                this.messageChangedAt = Date.now();\r\n            }\r\n        }\r\n\r\n        return false;\r\n    }\r\n\r\n    // Properties\r\n\r\n    private _signInSelected = new Subject<void>();\r\n    private _permissionDeniedError = new Subject<void>();\r\n    private _editAvatarSelected = new Subject<void>();\r\n    private _upvoted = new Subject<ChatMessage>();\r\n    private _reported = new Subject<ChatMessage>();\r\n    private _selected = new Subject<ChatMessage>();\r\n    private _userSelected = new Subject<ChatMessage>();\r\n    private _shared = new Subject<ChatMessage>();\r\n    private _usernameSelected = new Subject<User>();\r\n    private _avatarSelected = new Subject<User>();\r\n    private _source: ChatSourceBase;\r\n    private _subs = new Subscription();\r\n    private _sortOrder: CommentsOrder = CommentsOrder.NEWEST;\r\n    private _topicID: string;\r\n    \r\n    user: User;\r\n    selectedMessage: ChatMessage;\r\n    selectedMessageThread: ChatSourceBase;\r\n    selectedMessageVisible = false;\r\n\r\n    // Inputs\r\n\r\n    @Input() signInLabel = 'Sign In';\r\n    @Input() sendLabel = 'Send';\r\n    @Input() replyLabel = 'Reply';\r\n    @Input() sendingLabel = 'Sending';\r\n    @Input() permissionDeniedLabel = 'Send';\r\n    @Input() postCommentLabel = 'Post a comment';\r\n    @Input() postReplyLabel = 'Post a reply';\r\n    @Input() fixedHeight: boolean;\r\n    @Input() maxMessages: number;\r\n    @Input() maxVisibleMessages: number;\r\n    @Input() genericAvatarUrl: string;\r\n    @Input() shouldInterceptMessageSend?: (message: ChatMessage, source: ChatSourceBase) => boolean | Promise<boolean>;\r\n    @Input() participants: User[] = [];\r\n\r\n    @Input()\r\n    get source(): ChatSourceBase { return this._source; }\r\n    set source(value) { \r\n        this._source = value;\r\n        if (value && this.sharedCommentID) {\r\n            this.navigateToSharedComment(this.sharedCommentID);\r\n            this.sharedCommentID = null;\r\n        }\r\n    }\r\n    @Input() \r\n    hashtags: HashTag[] = [\r\n        {hashtag: 'error', description: 'Cause an error'},\r\n        {hashtag: 'timeout', description: 'Cause a slow timeout error'},\r\n        {hashtag: 'slow', description: 'Be slow when this message is posted'},\r\n    ];\r\n    @Input()\r\n    get topicID(): string { return this._topicID; }\r\n    set topicID(value) {\r\n        if (this._topicID !== value) {\r\n            this._topicID = value;\r\n            setTimeout(() => this.setSourceFromTopicID(value));\r\n        }\r\n    }\r\n\r\n    // Outputs\r\n\r\n    @Output() get signInSelected(): Observable<void> { return this._signInSelected; }\r\n    @Output() get editAvatarSelected() { return this._editAvatarSelected; }\r\n    @Output() get permissionDeniedError(): Observable<void> { return this._permissionDeniedError; }\r\n    @Output() get upvoted() { return this._upvoted.asObservable(); }\r\n    @Output() get reported() { return this._reported.asObservable(); }\r\n    @Output() get selected() { return this._selected.asObservable(); }\r\n    @Output() get userSelected() { return this._userSelected.asObservable(); }\r\n    @Output() get usernameSelected() { return this._usernameSelected.asObservable(); }\r\n    @Output() get avatarSelected() { return this._avatarSelected.asObservable(); }\r\n    @Output() get shared() { return this._shared.asObservable(); }\r\n\r\n    get sortOrder() { return this._sortOrder; }\r\n    set sortOrder(value) {\r\n        if (this._sortOrder !== value) {\r\n            this._sortOrder = value;\r\n            setTimeout(() => {\r\n                this.setSourceFromTopicID(this.topicID);\r\n            });\r\n        }\r\n    }\r\n\r\n    sendMessage: (message: ChatMessage) => void;\r\n    sendReply: (message: ChatMessage) => void;\r\n\r\n    // UI Interactions\r\n\r\n    scrollToComment(commentId: ChatMessage['id']): void {\r\n        setTimeout(() => {\r\n          const comment = document.querySelectorAll(`[data-comment-id=\"${commentId}\"]`);\r\n          console.dir(comment)\r\n          if (comment.length > 0) {\r\n            // comment.item(0).scroll({behavior: 'smooth'});\r\n            comment.item(0).scrollIntoView();\r\n          }\r\n        }, 1000);\r\n    }\r\n\r\n    async navigateToSharedComment(id: string) {\r\n        let source = this.source;\r\n\r\n        await source.ready;\r\n\r\n        console.log(`Navigating to shared comment with ID '${id}'...`);\r\n        let message: ChatMessage;\r\n        \r\n        try {\r\n            message = await this.source.get(id);\r\n        } catch (e) {\r\n            console.error(`Failed to find comment from URL: ${e.message}`);\r\n            return;\r\n        }\r\n\r\n        message.transientState ??= {};\r\n\r\n        // If there is a parent message, we should instead focus that and let the \r\n        // scrollToComment and highlight do the work.\r\n\r\n        if (message.parentMessageId) {\r\n\r\n            let parentMessage = await this.source.get(message.parentMessageId);\r\n            parentMessage.transientState ??= {};\r\n            let thread = await this.selectMessage(parentMessage); \r\n\r\n            // Need to re-retrieve the message within the new chat source to affect its\r\n            // transient state.\r\n            await thread.ready;\r\n            message = await thread.get(message.id);\r\n            message.transientState ??= {};\r\n            message.transientState.highlighted = true;\r\n            console.dir(message);\r\n            await new Promise<void>(resolve => setTimeout(() => resolve(), 500));\r\n\r\n        } else {\r\n            this.selectMessage(message);\r\n        }\r\n\r\n        this.scrollToComment(id);\r\n    }\r\n\r\n    showPermissionDenied() {\r\n        this._permissionDeniedError.next();\r\n    }\r\n\r\n    scrollToMessage(message: ChatMessage) {\r\n        let el = this.elementRef.nativeElement.querySelector(`[data-comment-id=\"${message.id}\"]`);\r\n        if (!el)\r\n            return;\r\n        el.scrollIntoView({block: 'center', inline: 'start'});\r\n    }\r\n\r\n    private addParticipant(message: ChatMessage) {\r\n        if (!message || !message.user || !message.user.id)\r\n            return;\r\n\r\n        let existing = this.participants.find(x => x.id === message.user.id);\r\n        if (existing)\r\n            return;\r\n        this.participants.push(message.user);\r\n    }\r\n\r\n    // Actions\r\n\r\n    async likeMessage(source: ChatSourceBase, message: ChatMessage) {\r\n        this._upvoted.next(message);\r\n        message.transientState.liking = true;\r\n\r\n        if (!message.userState?.liked)\r\n            message.likes = (message.likes || 0) + 1;\r\n        try {\r\n            await source.likeMessage(message.id);\r\n        } catch (e) {\r\n            alert(`Could not like this message: ${e.message}`);\r\n            return;\r\n        }\r\n        \r\n        await new Promise<void>(resolve => setTimeout(() => resolve(), 250));\r\n        message.transientState.liking = false;\r\n    }\r\n\r\n    async unlikeMessage(source: ChatSourceBase, message: ChatMessage) {\r\n        this._upvoted.next(message);\r\n        message.transientState.liking = true;\r\n\r\n        if (message.userState?.liked)\r\n            message.likes = (message.likes || 0) - 1;\r\n\r\n        try {\r\n            await source.unlikeMessage(message.id);\r\n        } catch (e) {\r\n            alert(`Failed to unlike message: ${e.message}`);\r\n        }\r\n\r\n        await new Promise<void>(resolve => setTimeout(() => resolve(), 250));\r\n        message.transientState.liking = false;\r\n    }\r\n\r\n    async reportMessage(message: ChatMessage) {\r\n        this._reported.next(message);\r\n    }\r\n\r\n    async unselectMessage() {\r\n        let message = this.selectedMessage;\r\n\r\n        this._selected.next(null);\r\n        this.selectedMessage = null;\r\n        if (this.selectedMessageThread) {\r\n            if (this.selectedMessageThread.close)\r\n                this.selectedMessageThread.close();\r\n            this.selectedMessageThread = null;\r\n        }\r\n\r\n        if (message)\r\n            setTimeout(() => this.scrollToMessage(message));\r\n    }\r\n\r\n    async selectMessage(message: ChatMessage) {\r\n        this._selected.next(message);\r\n        this.selectedMessage = message;\r\n        let selectedMessageThread = await this.backend.getSourceForThread(this.topicID, message.id);\r\n\r\n        setTimeout(() => this.selectedMessageVisible = true);\r\n        setTimeout(async () => {\r\n            this.selectedMessageThread = selectedMessageThread;\r\n        }, 250);\r\n\r\n        return selectedMessageThread;\r\n    }\r\n\r\n    async showSignIn() {\r\n        this._signInSelected.next();\r\n    }\r\n\r\n    async showEditAvatar() {\r\n        this._editAvatarSelected.next();\r\n    }\r\n\r\n    async selectMessageUser(message: ChatMessage) {\r\n        this._userSelected.next(message);\r\n    }\r\n\r\n    async selectUsername(user: User) {\r\n        this._usernameSelected.next(user);\r\n    }\r\n\r\n    async selectAvatar(user: User) {\r\n        this._avatarSelected.next(user);\r\n    }\r\n\r\n    async shareMessage(message: ChatMessage) {\r\n        this._shared.next(message);\r\n    }\r\n\r\n    async deleteMessage(message: ChatMessage) {\r\n        if (!confirm(\"Are you sure you want to delete this comment? You cannot undo this action.\"))\r\n            return;\r\n\r\n        this.source.deleteMessage(message.id);\r\n    }\r\n\r\n    async editMessage(source: ChatSourceBase, message: ChatMessage, newText: string) {\r\n        try {\r\n            await source.editMessage(message.id, newText);\r\n        } catch (e) {\r\n            alert(e.message);\r\n            return;\r\n        }\r\n\r\n        message.message = newText;\r\n        message.transientState.editing = false;\r\n    }\r\n\r\n    async startEditing(message: ChatMessage) {\r\n        this.selectedMessage.transientState.editing = false;\r\n        message.transientState.editing = true;\r\n    }\r\n\r\n    async saveEdit(message: ChatMessage, text: string) {\r\n        try {\r\n            await this.source.editMessage(message.id, text);\r\n            message.transientState.editing = false;\r\n        } catch (e) {\r\n            alert(`Could not edit message: ${e.message}`);\r\n        }\r\n    }\r\n}\r\n"]}
|