@banta/sdk 4.6.26 → 4.7.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/{esm2015/banta-sdk.js → esm2020/banta-sdk.mjs} +0 -0
- package/{esm2015/lib/attachment-scraper.js → esm2020/lib/attachment-scraper.mjs} +0 -0
- package/esm2020/lib/banta/banta.component.mjs +204 -0
- package/esm2020/lib/banta-logo.component.mjs +11 -0
- package/esm2020/lib/banta-sdk.module.mjs +144 -0
- package/esm2020/lib/chat/banta-chat/banta-chat.component.mjs +185 -0
- package/esm2020/lib/chat/chat-message/chat-message.component.mjs +62 -0
- package/esm2020/lib/chat/chat-view/chat-view.component.mjs +170 -0
- package/esm2020/lib/chat/chat.module.mjs +51 -0
- package/{esm2015/lib/chat/index.js → esm2020/lib/chat/index.mjs} +0 -0
- package/esm2020/lib/chat/live-chat-message.component.mjs +80 -0
- package/{esm2015/lib/chat-backend-base.js → esm2020/lib/chat-backend-base.mjs} +0 -0
- package/esm2020/lib/chat-backend.mjs +83 -0
- package/{esm2015/lib/chat-source-base.js → esm2020/lib/chat-source-base.mjs} +0 -0
- package/esm2020/lib/chat-source.mjs +169 -0
- package/esm2020/lib/comments/attachment-button/attachment-button.component.mjs +69 -0
- package/esm2020/lib/comments/attachment-scraper.directive.mjs +107 -0
- package/esm2020/lib/comments/banta-comments/banta-comments.component.mjs +666 -0
- package/esm2020/lib/comments/comment/comment.component.mjs +217 -0
- package/esm2020/lib/comments/comment-field/comment-field.component.mjs +377 -0
- package/esm2020/lib/comments/comment-sort/comment-sort.component.mjs +37 -0
- package/esm2020/lib/comments/comment-view/comment-view.component.mjs +379 -0
- package/esm2020/lib/comments/comments.module.mjs +111 -0
- package/{esm2015/lib/comments/index.js → esm2020/lib/comments/index.mjs} +0 -0
- package/esm2020/lib/comments/live-comment.component.mjs +80 -0
- package/esm2020/lib/comments/reply-send-options.directive.mjs +13 -0
- package/esm2020/lib/common/attachment/attachment.component.mjs +113 -0
- package/esm2020/lib/common/attachments/attachments.component.mjs +72 -0
- package/esm2020/lib/common/common.module.mjs +59 -0
- package/{esm2015/lib/common/index.js → esm2020/lib/common/index.mjs} +0 -0
- package/{esm2015/lib/common/lazy-connection.js → esm2020/lib/common/lazy-connection.mjs} +0 -0
- package/esm2020/lib/common/lightbox/lightbox.component.mjs +31 -0
- package/esm2020/lib/common/markdown-to-html.pipe.mjs +76 -0
- package/esm2020/lib/common/mention-linker.pipe.mjs +35 -0
- package/esm2020/lib/common/timestamp.component.mjs +113 -0
- package/esm2020/lib/common/trust-resource-url.pipe.mjs +22 -0
- package/esm2020/lib/emoji/emoji-selector-button.component.mjs +113 -0
- package/esm2020/lib/emoji/emoji-selector-panel/emoji-selector-panel.component.mjs +88 -0
- package/esm2020/lib/emoji/emoji.module.mjs +55 -0
- package/{esm2015/lib/emoji/emojis.js → esm2020/lib/emoji/emojis.mjs} +0 -0
- package/{esm2015/lib/emoji/index.js → esm2020/lib/emoji/index.mjs} +0 -0
- package/esm2020/lib/giphy-attachments.mjs +16 -0
- package/{esm2015/lib/index.js → esm2020/lib/index.mjs} +0 -0
- package/esm2020/lib/live-message.component.mjs +96 -0
- package/{esm2015/lib/message-menu-item.js → esm2020/lib/message-menu-item.mjs} +0 -0
- package/{esm2015/lib/sdk-options.js → esm2020/lib/sdk-options.mjs} +0 -0
- package/esm2020/lib/tweet-attachments.mjs +13 -0
- package/esm2020/lib/url-attachments.mjs +42 -0
- package/esm2020/lib/youtube-attachments.mjs +22 -0
- package/{esm2015/public-api.js → esm2020/public-api.mjs} +0 -0
- package/fesm2015/{banta-sdk.js → banta-sdk.mjs} +2323 -2008
- package/fesm2015/banta-sdk.mjs.map +1 -0
- package/fesm2020/banta-sdk.mjs +10490 -0
- package/fesm2020/banta-sdk.mjs.map +1 -0
- package/{banta-sdk.d.ts → index.d.ts} +1 -0
- package/lib/banta/banta.component.d.ts +3 -0
- package/lib/banta-logo.component.d.ts +3 -0
- package/lib/banta-sdk.module.d.ts +24 -0
- package/lib/chat/banta-chat/banta-chat.component.d.ts +3 -0
- package/lib/chat/chat-message/chat-message.component.d.ts +3 -0
- package/lib/chat/chat-view/chat-view.component.d.ts +3 -0
- package/lib/chat/chat.module.d.ts +13 -0
- package/lib/chat/live-chat-message.component.d.ts +3 -0
- package/lib/chat-backend.d.ts +3 -0
- package/lib/chat-source.d.ts +3 -3
- package/lib/comments/attachment-button/attachment-button.component.d.ts +3 -0
- package/lib/comments/attachment-scraper.directive.d.ts +3 -0
- package/lib/comments/banta-comments/banta-comments.component.d.ts +3 -0
- package/lib/comments/comment/comment.component.d.ts +3 -0
- package/lib/comments/comment-field/comment-field.component.d.ts +3 -0
- package/lib/comments/comment-sort/comment-sort.component.d.ts +3 -0
- package/lib/comments/comment-view/comment-view.component.d.ts +3 -0
- package/lib/comments/comments.module.d.ts +28 -0
- package/lib/comments/live-comment.component.d.ts +3 -0
- package/lib/comments/reply-send-options.directive.d.ts +3 -0
- package/lib/common/attachment/attachment.component.d.ts +3 -0
- package/lib/common/attachments/attachments.component.d.ts +3 -0
- package/lib/common/common.module.d.ts +15 -0
- package/lib/common/lightbox/lightbox.component.d.ts +3 -0
- package/lib/common/markdown-to-html.pipe.d.ts +3 -0
- package/lib/common/mention-linker.pipe.d.ts +3 -0
- package/lib/common/timestamp.component.d.ts +3 -0
- package/lib/common/trust-resource-url.pipe.d.ts +3 -0
- package/lib/emoji/emoji-selector-button.component.d.ts +3 -0
- package/lib/emoji/emoji-selector-panel/emoji-selector-panel.component.d.ts +3 -0
- package/lib/emoji/emoji.module.d.ts +14 -0
- package/lib/live-message.component.d.ts +3 -0
- package/lib/url-attachments.d.ts +3 -0
- package/package.json +22 -10
- package/banta-sdk.metadata.json +0 -1
- package/bundles/banta-sdk.umd.js +0 -11895
- package/bundles/banta-sdk.umd.js.map +0 -1
- package/bundles/banta-sdk.umd.min.js +0 -2
- package/bundles/banta-sdk.umd.min.js.map +0 -1
- package/esm2015/lib/banta/banta.component.js +0 -201
- package/esm2015/lib/banta-logo.component.js +0 -20
- package/esm2015/lib/banta-sdk.module.js +0 -98
- package/esm2015/lib/chat/banta-chat/banta-chat.component.js +0 -175
- package/esm2015/lib/chat/chat-message/chat-message.component.js +0 -56
- package/esm2015/lib/chat/chat-view/chat-view.component.js +0 -167
- package/esm2015/lib/chat/chat.module.js +0 -32
- package/esm2015/lib/chat/live-chat-message.component.js +0 -71
- package/esm2015/lib/chat-backend.js +0 -92
- package/esm2015/lib/chat-source.js +0 -205
- package/esm2015/lib/comments/attachment-button/attachment-button.component.js +0 -70
- package/esm2015/lib/comments/attachment-scraper.directive.js +0 -109
- package/esm2015/lib/comments/banta-comments/banta-comments.component.js +0 -678
- package/esm2015/lib/comments/comment/comment.component.js +0 -186
- package/esm2015/lib/comments/comment-field/comment-field.component.js +0 -350
- package/esm2015/lib/comments/comment-sort/comment-sort.component.js +0 -34
- package/esm2015/lib/comments/comment-view/comment-view.component.js +0 -364
- package/esm2015/lib/comments/comments.module.js +0 -62
- package/esm2015/lib/comments/live-comment.component.js +0 -71
- package/esm2015/lib/comments/reply-send-options.directive.js +0 -9
- package/esm2015/lib/common/attachment/attachment.component.js +0 -105
- package/esm2015/lib/common/attachments/attachments.component.js +0 -66
- package/esm2015/lib/common/common.module.js +0 -36
- package/esm2015/lib/common/lightbox/lightbox.component.js +0 -30
- package/esm2015/lib/common/markdown-to-html.pipe.js +0 -74
- package/esm2015/lib/common/mention-linker.pipe.js +0 -31
- package/esm2015/lib/common/timestamp.component.js +0 -106
- package/esm2015/lib/common/trust-resource-url.pipe.js +0 -21
- package/esm2015/lib/emoji/emoji-selector-button.component.js +0 -108
- package/esm2015/lib/emoji/emoji-selector-panel/emoji-selector-panel.component.js +0 -86
- package/esm2015/lib/emoji/emoji.module.js +0 -34
- package/esm2015/lib/giphy-attachments.js +0 -20
- package/esm2015/lib/live-message.component.js +0 -74
- package/esm2015/lib/tweet-attachments.js +0 -16
- package/esm2015/lib/url-attachments.js +0 -46
- package/esm2015/lib/youtube-attachments.js +0 -25
- package/fesm2015/banta-sdk.js.map +0 -1
|
@@ -1,364 +0,0 @@
|
|
|
1
|
-
import { __awaiter } from "tslib";
|
|
2
|
-
import { Component, Input, ViewChild, ElementRef, Output, HostBinding, ViewChildren, QueryList } from "@angular/core";
|
|
3
|
-
import { CommentsOrder } from '@banta/common';
|
|
4
|
-
import { Subject, Subscription } from 'rxjs';
|
|
5
|
-
import { ChatBackendBase } from "../../chat-backend-base";
|
|
6
|
-
import { CommentComponent } from "../comment/comment.component";
|
|
7
|
-
export class CommentViewComponent {
|
|
8
|
-
constructor(backend) {
|
|
9
|
-
this.backend = backend;
|
|
10
|
-
this._sourceSubs = new Subscription();
|
|
11
|
-
this._selected = new Subject();
|
|
12
|
-
this._liked = new Subject();
|
|
13
|
-
this._unliked = new Subject();
|
|
14
|
-
this._reported = new Subject();
|
|
15
|
-
this._userSelected = new Subject();
|
|
16
|
-
this._usernameSelected = new Subject();
|
|
17
|
-
this._avatarSelected = new Subject();
|
|
18
|
-
this._shared = new Subject();
|
|
19
|
-
this._deleted = new Subject();
|
|
20
|
-
this._messageEdited = new Subject();
|
|
21
|
-
this.showEmptyState = true;
|
|
22
|
-
this.allowReplies = true;
|
|
23
|
-
this.customMenuItems = [];
|
|
24
|
-
this.menuMessage = null;
|
|
25
|
-
this.messages = [];
|
|
26
|
-
this.customSortEnabled = false;
|
|
27
|
-
this.sourceLoaded = new Promise(r => this.markSourceLoaded = r);
|
|
28
|
-
this.maxMessages = 2000;
|
|
29
|
-
this.maxVisibleMessages = 200;
|
|
30
|
-
this.newestLast = false;
|
|
31
|
-
this.isViewingMore = false;
|
|
32
|
-
this.isLoadingMore = false;
|
|
33
|
-
this.hasMore = false;
|
|
34
|
-
this.newMessages = [];
|
|
35
|
-
this.olderMessages = [];
|
|
36
|
-
this.sortOrderChanged = new Subject();
|
|
37
|
-
}
|
|
38
|
-
get comments() {
|
|
39
|
-
return Array.from(this.commentsQuery);
|
|
40
|
-
}
|
|
41
|
-
/**
|
|
42
|
-
* Returns true if this message can be found within one of the message buffers (older, current, newer)
|
|
43
|
-
* @param message
|
|
44
|
-
*/
|
|
45
|
-
isMessageLoadedInContext(message) {
|
|
46
|
-
return this.olderMessages.find(x => x.id === message.id)
|
|
47
|
-
|| this.messages.find(x => x.id === message.id)
|
|
48
|
-
|| this.newMessages.find(x => x.id === message.id);
|
|
49
|
-
}
|
|
50
|
-
loadMessageInContext(message) {
|
|
51
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
52
|
-
yield this.sourceLoaded;
|
|
53
|
-
console.log(`Loading message ${message.id} in context...`);
|
|
54
|
-
while (this.hasMore && !this.isMessageLoadedInContext(message)) {
|
|
55
|
-
console.log(`...Need to load more comments to find ${message.id}`);
|
|
56
|
-
yield this.showMore();
|
|
57
|
-
}
|
|
58
|
-
if (!this.isMessageLoadedInContext(message)) {
|
|
59
|
-
console.error(`Error while loading message in context: Failed to find message ${message.id}, maybe it was deleted!`);
|
|
60
|
-
return false;
|
|
61
|
-
}
|
|
62
|
-
let pageSize = this.maxVisibleMessages;
|
|
63
|
-
let items = [].concat(this.olderMessages, this.messages, this.newMessages);
|
|
64
|
-
let index = items.findIndex(x => x.id === message.id);
|
|
65
|
-
if (index < 0) {
|
|
66
|
-
console.error(`Error while loading message in context: Message was not present in message list!`);
|
|
67
|
-
return false;
|
|
68
|
-
}
|
|
69
|
-
let startIndex = Math.max(0, index - pageSize / 2);
|
|
70
|
-
this.newMessages = items.splice(0, startIndex);
|
|
71
|
-
this.messages = items.splice(0, pageSize);
|
|
72
|
-
this.olderMessages = items;
|
|
73
|
-
this.isViewingMore = true;
|
|
74
|
-
});
|
|
75
|
-
}
|
|
76
|
-
/**
|
|
77
|
-
* Get the CommentComponent instantiated for the given ChatMessage,
|
|
78
|
-
* if it exists in the current view. Note that messages which are not
|
|
79
|
-
* currently shown to the user will not return a CommentComponent.
|
|
80
|
-
* @param message
|
|
81
|
-
* @returns
|
|
82
|
-
*/
|
|
83
|
-
getCommentComponentForMessage(message) {
|
|
84
|
-
if (!message)
|
|
85
|
-
throw new Error(`You must pass a valid ChatMessage`);
|
|
86
|
-
return this.comments.find(x => { var _a; return ((_a = x.message) === null || _a === void 0 ? void 0 : _a.id) === message.id; });
|
|
87
|
-
}
|
|
88
|
-
get selected() {
|
|
89
|
-
return this._selected;
|
|
90
|
-
}
|
|
91
|
-
get messageEdited() {
|
|
92
|
-
return this._messageEdited.asObservable();
|
|
93
|
-
}
|
|
94
|
-
saveEdit(message, newMessage) {
|
|
95
|
-
this._messageEdited.next({ message, newMessage });
|
|
96
|
-
}
|
|
97
|
-
get userSelected() { return this._userSelected; }
|
|
98
|
-
get reported() { return this._reported; }
|
|
99
|
-
get liked() { return this._liked; }
|
|
100
|
-
get unliked() { return this._unliked; }
|
|
101
|
-
get usernameSelected() { return this._usernameSelected; }
|
|
102
|
-
get avatarSelected() { return this._avatarSelected; }
|
|
103
|
-
get shared() { return this._shared; }
|
|
104
|
-
get deleted() { return this._deleted; }
|
|
105
|
-
get source() {
|
|
106
|
-
return this._source;
|
|
107
|
-
}
|
|
108
|
-
likeMessage(message) {
|
|
109
|
-
this._liked.next(message);
|
|
110
|
-
}
|
|
111
|
-
unlikeMessage(message) {
|
|
112
|
-
this._unliked.next(message);
|
|
113
|
-
}
|
|
114
|
-
reportMessage(message) {
|
|
115
|
-
this._reported.next(message);
|
|
116
|
-
}
|
|
117
|
-
selectMessage(message) {
|
|
118
|
-
this._selected.next(message);
|
|
119
|
-
}
|
|
120
|
-
selectMessageUser(message) {
|
|
121
|
-
this._userSelected.next(message);
|
|
122
|
-
}
|
|
123
|
-
selectUsername(user) {
|
|
124
|
-
this._usernameSelected.next(user);
|
|
125
|
-
}
|
|
126
|
-
selectAvatar(user) {
|
|
127
|
-
this._avatarSelected.next(user);
|
|
128
|
-
}
|
|
129
|
-
sharedMessage(message) {
|
|
130
|
-
this._shared.next(message);
|
|
131
|
-
}
|
|
132
|
-
startEditing(message) {
|
|
133
|
-
this.messages.forEach(m => m.transientState.editing = false);
|
|
134
|
-
message.transientState.editing = true;
|
|
135
|
-
}
|
|
136
|
-
deleteMessage(message) {
|
|
137
|
-
this._deleted.next(message);
|
|
138
|
-
}
|
|
139
|
-
set source(value) {
|
|
140
|
-
this.customSortEnabled = (value === null || value === void 0 ? void 0 : value.sortOrder) !== CommentsOrder.NEWEST;
|
|
141
|
-
this.newMessages = [];
|
|
142
|
-
this.olderMessages = [];
|
|
143
|
-
window.bantaSourceDebug = value;
|
|
144
|
-
if (this._sourceSubs) {
|
|
145
|
-
this._sourceSubs.unsubscribe();
|
|
146
|
-
this._sourceSubs = null;
|
|
147
|
-
}
|
|
148
|
-
this._source = value;
|
|
149
|
-
if (value) {
|
|
150
|
-
const messages = (value.messages || []).slice();
|
|
151
|
-
this.messages = messages;
|
|
152
|
-
this.olderMessages = messages.splice(this.maxVisibleMessages, messages.length);
|
|
153
|
-
this.hasMore = true; //this.olderMessages.length > 0;
|
|
154
|
-
this._sourceSubs = new Subscription();
|
|
155
|
-
this._sourceSubs.add(this._source.messageReceived.subscribe(msg => this.messageReceived(msg)));
|
|
156
|
-
this._sourceSubs.add(this._source.messageSent.subscribe(msg => this.messageSent(msg)));
|
|
157
|
-
this._sourceSubs.add(this.backend.userChanged.subscribe(user => this.currentUser = user));
|
|
158
|
-
this.getInitialMessages();
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
getInitialMessages() {
|
|
162
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
163
|
-
let messages = (yield this._source.getExistingMessages());
|
|
164
|
-
messages.forEach(m => { var _a; return (_a = m.transientState) !== null && _a !== void 0 ? _a : (m.transientState = {}); });
|
|
165
|
-
this.messages = this.newestLast ? messages.slice().reverse() : messages;
|
|
166
|
-
this.sortMessages();
|
|
167
|
-
if (this.markSourceLoaded)
|
|
168
|
-
this.markSourceLoaded();
|
|
169
|
-
});
|
|
170
|
-
}
|
|
171
|
-
messageIdentity(index, chatMessage) {
|
|
172
|
-
return chatMessage.id;
|
|
173
|
-
}
|
|
174
|
-
showNew() {
|
|
175
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
176
|
-
let naturalOrder = CommentsOrder.NEWEST;
|
|
177
|
-
if (this.source && this.source.sortOrder !== naturalOrder) {
|
|
178
|
-
this.sortOrderChanged.next(naturalOrder);
|
|
179
|
-
return;
|
|
180
|
-
}
|
|
181
|
-
this.isViewingMore = false;
|
|
182
|
-
if (this.newestLast)
|
|
183
|
-
this.messages = this.messages.concat(this.newMessages.splice(0, this.newMessages.length));
|
|
184
|
-
else
|
|
185
|
-
this.messages = this.newMessages.splice(0, this.newMessages.length).concat(this.messages);
|
|
186
|
-
let overflow = this.messages.splice(this.maxVisibleMessages, this.messages.length);
|
|
187
|
-
this.olderMessages = overflow.concat(this.olderMessages);
|
|
188
|
-
this.olderMessages.splice(this.maxMessages - this.maxVisibleMessages, this.olderMessages.length);
|
|
189
|
-
this.hasMore = this.olderMessages.length > 0;
|
|
190
|
-
});
|
|
191
|
-
}
|
|
192
|
-
showMore() {
|
|
193
|
-
var _a, _b;
|
|
194
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
195
|
-
this.isViewingMore = true;
|
|
196
|
-
if (this.olderMessages.length > 0) {
|
|
197
|
-
this.isLoadingMore = false;
|
|
198
|
-
this.messages = this.messages.concat(this.olderMessages.splice(0, 50));
|
|
199
|
-
}
|
|
200
|
-
this.isLoadingMore = true;
|
|
201
|
-
let nextPageSize = 20;
|
|
202
|
-
let lastMessage;
|
|
203
|
-
if (this.newestLast) {
|
|
204
|
-
lastMessage = (_a = this.olderMessages[0]) !== null && _a !== void 0 ? _a : this.messages[0];
|
|
205
|
-
}
|
|
206
|
-
else {
|
|
207
|
-
lastMessage = (_b = this.olderMessages[this.olderMessages.length - 1]) !== null && _b !== void 0 ? _b : this.messages[this.messages.length - 1];
|
|
208
|
-
}
|
|
209
|
-
if (!lastMessage) {
|
|
210
|
-
this.isLoadingMore = false;
|
|
211
|
-
this.hasMore = false;
|
|
212
|
-
return;
|
|
213
|
-
}
|
|
214
|
-
let messages = yield this.source.loadAfter(lastMessage, nextPageSize);
|
|
215
|
-
if (this.newestLast)
|
|
216
|
-
messages = messages.slice().reverse();
|
|
217
|
-
messages.forEach(m => { var _a; return (_a = m.transientState) !== null && _a !== void 0 ? _a : (m.transientState = {}); });
|
|
218
|
-
if (this.newestLast)
|
|
219
|
-
this.messages = messages.concat(this.messages);
|
|
220
|
-
else
|
|
221
|
-
this.messages = this.messages.concat(messages);
|
|
222
|
-
this.isLoadingMore = false;
|
|
223
|
-
if (messages.length === 0) {
|
|
224
|
-
console.log(`Reached the end of the list.`);
|
|
225
|
-
this.hasMore = false;
|
|
226
|
-
}
|
|
227
|
-
});
|
|
228
|
-
}
|
|
229
|
-
addMessage(message) {
|
|
230
|
-
var _a;
|
|
231
|
-
if (!message.transientState)
|
|
232
|
-
(_a = message.transientState) !== null && _a !== void 0 ? _a : (message.transientState = {});
|
|
233
|
-
let destination = this.messages;
|
|
234
|
-
let bucket = this.olderMessages;
|
|
235
|
-
let newestLast = this.newestLast;
|
|
236
|
-
if (this.isViewingMore) {
|
|
237
|
-
destination = this.newMessages;
|
|
238
|
-
bucket = null;
|
|
239
|
-
}
|
|
240
|
-
if (newestLast) {
|
|
241
|
-
destination.push(message);
|
|
242
|
-
let overflow = destination.splice(this.maxVisibleMessages, destination.length);
|
|
243
|
-
bucket === null || bucket === void 0 ? void 0 : bucket.push(...overflow);
|
|
244
|
-
}
|
|
245
|
-
else {
|
|
246
|
-
destination.unshift(message);
|
|
247
|
-
let overflow = destination.splice(this.maxVisibleMessages, destination.length);
|
|
248
|
-
bucket === null || bucket === void 0 ? void 0 : bucket.unshift(...overflow);
|
|
249
|
-
}
|
|
250
|
-
if ((bucket === null || bucket === void 0 ? void 0 : bucket.length) > 0)
|
|
251
|
-
this.hasMore = true;
|
|
252
|
-
message.pagingCursor = String(this.incrementPagingCursors());
|
|
253
|
-
this.sortMessages();
|
|
254
|
-
}
|
|
255
|
-
incrementPagingCursors() {
|
|
256
|
-
if (this.source.sortOrder !== CommentsOrder.NEWEST)
|
|
257
|
-
return;
|
|
258
|
-
let maxPagingCursor = 0;
|
|
259
|
-
for (let group of [this.messages, this.olderMessages, this.newMessages]) {
|
|
260
|
-
for (let message of group) {
|
|
261
|
-
if (message.pagingCursor) {
|
|
262
|
-
let pagingCursor = Number(message.pagingCursor) + 1;
|
|
263
|
-
if (pagingCursor > maxPagingCursor)
|
|
264
|
-
maxPagingCursor = pagingCursor;
|
|
265
|
-
message.pagingCursor = String(pagingCursor);
|
|
266
|
-
}
|
|
267
|
-
}
|
|
268
|
-
}
|
|
269
|
-
return maxPagingCursor;
|
|
270
|
-
}
|
|
271
|
-
/**
|
|
272
|
-
* Wait for all currently visible comments to be fully loaded, including all attachments.
|
|
273
|
-
* Doing this will prevent layout shift when scrolling to a specific comment.
|
|
274
|
-
*/
|
|
275
|
-
waitForAllCommentsToLoad() {
|
|
276
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
277
|
-
yield new Promise(r => setTimeout(r, 100));
|
|
278
|
-
yield this.sourceLoaded;
|
|
279
|
-
yield Promise.all(this.comments.map(x => x.waitForLoad()));
|
|
280
|
-
});
|
|
281
|
-
}
|
|
282
|
-
sortMessages() {
|
|
283
|
-
if (!this.source)
|
|
284
|
-
return;
|
|
285
|
-
let sorter;
|
|
286
|
-
if (this.source.sortOrder === CommentsOrder.LIKES)
|
|
287
|
-
sorter = (a, b) => b.likes - a.likes;
|
|
288
|
-
else if (this.source.sortOrder === CommentsOrder.NEWEST)
|
|
289
|
-
sorter = (a, b) => (b.sentAt - a.sentAt) * (this.newestLast ? -1 : 1);
|
|
290
|
-
else if (this.source.sortOrder === CommentsOrder.OLDEST)
|
|
291
|
-
sorter = (a, b) => (a.sentAt - b.sentAt) * (this.newestLast ? -1 : 1);
|
|
292
|
-
this.messages.sort(sorter);
|
|
293
|
-
this.olderMessages.sort(sorter);
|
|
294
|
-
this.newMessages.sort(sorter);
|
|
295
|
-
}
|
|
296
|
-
messageReceived(message) {
|
|
297
|
-
this.addMessage(message);
|
|
298
|
-
if (this.isScrolledToLatest())
|
|
299
|
-
setTimeout(() => this.scrollToLatest());
|
|
300
|
-
}
|
|
301
|
-
isScrolledToLatest() {
|
|
302
|
-
if (!this.messageContainer)
|
|
303
|
-
return false;
|
|
304
|
-
const el = this.messageContainer.nativeElement;
|
|
305
|
-
const currentScroll = el.scrollTop;
|
|
306
|
-
const currentTotal = el.scrollHeight - el.offsetHeight;
|
|
307
|
-
return currentScroll > currentTotal - 10;
|
|
308
|
-
}
|
|
309
|
-
messageSent(message) {
|
|
310
|
-
this.addMessage(message);
|
|
311
|
-
if (!this.messageContainer)
|
|
312
|
-
return;
|
|
313
|
-
this.scrollToLatest();
|
|
314
|
-
}
|
|
315
|
-
scrollToLatest() {
|
|
316
|
-
if (!this.messageContainer)
|
|
317
|
-
return;
|
|
318
|
-
const el = this.messageContainer.nativeElement;
|
|
319
|
-
el.scrollTop = el.scrollHeight;
|
|
320
|
-
}
|
|
321
|
-
mentionsMe(message) {
|
|
322
|
-
if (!this.currentUser)
|
|
323
|
-
return false;
|
|
324
|
-
if (message.message.includes(`@${this.currentUser.username}`))
|
|
325
|
-
return true;
|
|
326
|
-
return false;
|
|
327
|
-
}
|
|
328
|
-
}
|
|
329
|
-
CommentViewComponent.decorators = [
|
|
330
|
-
{ type: Component, args: [{
|
|
331
|
-
selector: 'banta-comment-view',
|
|
332
|
-
template: "<div class=\"message-container\">\r\n <ng-content select=\"[data-before]\"></ng-content>\r\n\r\n <a mat-button class=\"nav\" [class.visible]=\"!newestLast && (isViewingMore || customSortEnabled)\" href=\"javascript:;\" (click)=\"showNew()\">\r\n <mat-icon>file_upload</mat-icon>\r\n New\r\n <ng-container *ngIf=\"newMessages.length >= 1\">\r\n ({{newMessages.length}})\r\n </ng-container>\r\n </a>\r\n <a mat-button class=\"nav\" [class.visible]=\"newestLast && hasMore && !isLoadingMore\" href=\"javascript:;\" (click)=\"showMore()\">Show earlier</a>\r\n\r\n <ng-container *ngIf=\"messages.length === 0\">\r\n <div class=\"empty-state\" *ngIf=\"showEmptyState\">\r\n Be the first to comment!\r\n </div>\r\n </ng-container>\r\n <ng-container *ngFor=\"let message of messages; trackBy: messageIdentity\">\r\n <banta-comment\r\n *ngIf=\"!message.hidden\"\r\n class=\"abbreviated\"\r\n \r\n [customMenuItems]=\"customMenuItems\"\r\n [message]=\"message\"\r\n [mine]=\"currentUser?.id === message.user?.id\"\r\n [permissions]=\"source?.permissions\"\r\n [showReplyAction]=\"allowReplies\"\r\n [editing]=\"message.transientState.editing\"\r\n [genericAvatarUrl]=\"genericAvatarUrl\"\r\n (click)=\"isViewingMore = true\"\r\n (editStarted)=\"startEditing(message)\"\r\n (deleted)=\"deleteMessage(message)\"\r\n (editEnded)=\"message.transientState.editing = false\"\r\n (edited)=\"saveEdit(message, $event)\"\r\n (userSelected)=\"selectMessageUser(message)\"\r\n (avatarSelected)=\"selectAvatar($event)\"\r\n (usernameSelected)=\"selectUsername($event)\"\r\n (liked)=\"likeMessage(message)\"\r\n (unliked)=\"unlikeMessage(message)\"\r\n (reported)=\"reportMessage(message)\"\r\n (selected)=\"selectMessage(message)\"\r\n (shared)=\"sharedMessage($event)\"\r\n ></banta-comment>\r\n <div class=\"inline-replies-container\" *ngIf=\"selectedMessage === message\">\r\n <ng-content select=\".inline-replies\"></ng-content>\r\n </div>\r\n </ng-container>\r\n\r\n <a mat-button class=\"nav\" [class.visible]=\"newestLast && (isViewingMore || customSortEnabled)\" href=\"javascript:;\" (click)=\"showNew()\">\r\n <mat-icon>file_download</mat-icon>\r\n New\r\n <ng-container *ngIf=\"newMessages.length >= 1\">\r\n ({{newMessages.length}})\r\n </ng-container>\r\n </a>\r\n <a mat-button class=\"nav\" [class.visible]=\"!newestLast && hasMore && !isLoadingMore\" href=\"javascript:;\" (click)=\"showMore()\">Show more</a>\r\n\r\n <div class=\"loading-more\" *ngIf=\"isLoadingMore\">\r\n <mat-spinner></mat-spinner>\r\n </div>\r\n\r\n <!-- <div style=\"color: #666\">\r\n n={{newMessages.length}}, m={{messages.length}}, o={{olderMessages.length}},\r\n v={{maxVisibleMessages}}, M={{maxMessages}}\r\n </div> -->\r\n\r\n <ng-content select=\":not([data-before]):not(.inline-replies)\"></ng-content>\r\n</div>\r\n",
|
|
333
|
-
styles: [":host{flex-grow:1;display:flex;flex-direction:column;opacity:1;transition:opacity .2s ease-in}.message-container{flex-grow:1;overflow-x:hidden;color:#111;background:#fff;padding:.5em 1em 3em .5em;opacity:1;transition:opacity .5s ease-in-out;position:relative}.message-container.no-scroll{height:auto;overflow-y:visible}.message-container.faded{opacity:.25}.message-container .overlay{position:absolute;top:0;left:0;right:0;bottom:0;z-index:10}:host.fixed-height .message-container{overflow-y:auto}:host-context(.mat-dark-theme) .message-container{color:#fff;background:#111}.empty-state{text-align:center;margin:3em;color:#666}:host-context(.mat-dark-theme) .empty-state{color:#666}a.nav{position:absolute;right:.5em;z-index:10;text-align:center;opacity:0;transition:opacity .4s ease-in-out;pointer-events:none;border-radius:2em;background:#222}a.nav.visible{opacity:1;pointer-events:auto}.loading-more{padding:2em;text-align:center;margin:0 auto;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content}@media (max-width:400px){.message-container{padding:0 0 3em}}"]
|
|
334
|
-
},] }
|
|
335
|
-
];
|
|
336
|
-
CommentViewComponent.ctorParameters = () => [
|
|
337
|
-
{ type: ChatBackendBase }
|
|
338
|
-
];
|
|
339
|
-
CommentViewComponent.propDecorators = {
|
|
340
|
-
showEmptyState: [{ type: Input }],
|
|
341
|
-
allowReplies: [{ type: Input }],
|
|
342
|
-
customMenuItems: [{ type: Input }],
|
|
343
|
-
commentsQuery: [{ type: ViewChildren, args: [CommentComponent,] }],
|
|
344
|
-
fixedHeight: [{ type: Input }, { type: HostBinding, args: ['class.fixed-height',] }],
|
|
345
|
-
selectedMessage: [{ type: Input }],
|
|
346
|
-
selected: [{ type: Output }],
|
|
347
|
-
messageEdited: [{ type: Output }],
|
|
348
|
-
userSelected: [{ type: Output }],
|
|
349
|
-
reported: [{ type: Output }],
|
|
350
|
-
liked: [{ type: Output }],
|
|
351
|
-
unliked: [{ type: Output }],
|
|
352
|
-
usernameSelected: [{ type: Output }],
|
|
353
|
-
avatarSelected: [{ type: Output }],
|
|
354
|
-
shared: [{ type: Output }],
|
|
355
|
-
deleted: [{ type: Output }],
|
|
356
|
-
source: [{ type: Input }],
|
|
357
|
-
genericAvatarUrl: [{ type: Input }],
|
|
358
|
-
messageContainer: [{ type: ViewChild, args: ['messageContainer',] }],
|
|
359
|
-
maxMessages: [{ type: Input }],
|
|
360
|
-
maxVisibleMessages: [{ type: Input }],
|
|
361
|
-
newestLast: [{ type: Input }],
|
|
362
|
-
sortOrderChanged: [{ type: Output }]
|
|
363
|
-
};
|
|
364
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"comment-view.component.js","sourceRoot":"","sources":["../../../../../../projects/sdk/src/lib/comments/comment-view/comment-view.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ViewChild, ElementRef, Output, HostBinding, ViewChildren, QueryList } from \"@angular/core\";\r\nimport { User, ChatMessage, CommentsOrder } from '@banta/common';\r\nimport { Subject, Subscription } from 'rxjs';\r\nimport { ChatBackendBase } from \"../../chat-backend-base\";\r\nimport { ChatSourceBase } from \"../../chat-source-base\";\r\nimport { MessageMenuItem } from \"../../message-menu-item\";\r\nimport { CommentComponent } from \"../comment/comment.component\";\r\n\r\nexport interface EditEvent {\r\n    message: ChatMessage;\r\n    newMessage: string;\r\n}\r\n\r\n@Component({\r\n    selector: 'banta-comment-view',\r\n    templateUrl: './comment-view.component.html',\r\n    styleUrls: ['./comment-view.component.scss']\r\n})\r\nexport class CommentViewComponent {\r\n    constructor(\r\n        private backend: ChatBackendBase\r\n    ) {\r\n\r\n    }\r\n\r\n    private _sourceSubs = new Subscription();\r\n    private _source: ChatSourceBase;\r\n    private _selected = new Subject<ChatMessage>();\r\n    private _liked = new Subject<ChatMessage>();\r\n    private _unliked = new Subject<ChatMessage>();\r\n    private _reported = new Subject<ChatMessage>();\r\n    private _userSelected = new Subject<ChatMessage>();\r\n    private _usernameSelected = new Subject<User>();\r\n    private _avatarSelected = new Subject<User>();\r\n    private _shared = new Subject<ChatMessage>();\r\n    private _deleted = new Subject<ChatMessage>();\r\n    private _messageEdited = new Subject<EditEvent>();\r\n\r\n    @Input()\r\n    showEmptyState = true;\r\n\r\n    @Input()\r\n    allowReplies = true;\r\n\r\n    @Input() customMenuItems: MessageMenuItem[] = [];\r\n\r\n    @ViewChildren(CommentComponent)\r\n    commentsQuery: QueryList<CommentComponent>;\r\n\r\n    get comments() {\r\n        return Array.from(this.commentsQuery);\r\n    }\r\n\r\n    /**\r\n     * Returns true if this message can be found within one of the message buffers (older, current, newer)\r\n     * @param message \r\n     */\r\n    isMessageLoadedInContext(message: ChatMessage) {\r\n        return this.olderMessages.find(x => x.id === message.id)\r\n            || this.messages.find(x => x.id === message.id)\r\n            || this.newMessages.find(x => x.id === message.id);\r\n    }\r\n\r\n    async loadMessageInContext(message: ChatMessage) {\r\n        await this.sourceLoaded;\r\n        \r\n        console.log(`Loading message ${message.id} in context...`);\r\n        while (this.hasMore && !this.isMessageLoadedInContext(message)) {\r\n            console.log(`...Need to load more comments to find ${message.id}`);\r\n            await this.showMore();\r\n        }\r\n\r\n        if (!this.isMessageLoadedInContext(message)) {\r\n            console.error(`Error while loading message in context: Failed to find message ${message.id}, maybe it was deleted!`);\r\n            return false;\r\n        }\r\n\r\n        let pageSize = this.maxVisibleMessages;\r\n        let items = [].concat(this.olderMessages, this.messages, this.newMessages);\r\n        let index = items.findIndex(x => x.id === message.id);\r\n\r\n        if (index < 0) {\r\n            console.error(`Error while loading message in context: Message was not present in message list!`);\r\n            return false;\r\n        }\r\n\r\n        let startIndex = Math.max(0, index - pageSize / 2);        \r\n        this.newMessages = items.splice(0, startIndex);\r\n        this.messages = items.splice(0, pageSize);\r\n        this.olderMessages = items;\r\n        this.isViewingMore = true;\r\n    }\r\n\r\n    /**\r\n     * Get the CommentComponent instantiated for the given ChatMessage,\r\n     * if it exists in the current view. Note that messages which are not \r\n     * currently shown to the user will not return a CommentComponent.\r\n     * @param message \r\n     * @returns \r\n     */\r\n    getCommentComponentForMessage(message: ChatMessage) {\r\n        if (!message)\r\n            throw new Error(`You must pass a valid ChatMessage`);\r\n        return this.comments.find(x => x.message?.id === message.id);\r\n    }\r\n\r\n    @Input()\r\n    @HostBinding('class.fixed-height')\r\n    fixedHeight: boolean;\r\n\r\n    @Input()\r\n    selectedMessage: ChatMessage;\r\n    \r\n    @Output()\r\n    get selected() {\r\n        return this._selected;\r\n    }\r\n\r\n    @Output() \r\n    get messageEdited() {\r\n        return this._messageEdited.asObservable();\r\n    }\r\n\r\n    saveEdit(message: ChatMessage, newMessage: string) {\r\n        this._messageEdited.next({ message, newMessage });\r\n    }\r\n\r\n    @Output() get userSelected() { return this._userSelected; }\r\n    @Output() get reported() { return this._reported; }\r\n    @Output() get liked() { return this._liked; }\r\n    @Output() get unliked() { return this._unliked; }\r\n    @Output() get usernameSelected() { return this._usernameSelected; }\r\n    @Output() get avatarSelected() { return this._avatarSelected; }\r\n    @Output() get shared() { return this._shared; }\r\n    @Output() get deleted() { return this._deleted; }\r\n\r\n    menuMessage: ChatMessage = null;\r\n    messages: ChatMessage[] = [];\r\n    currentUser: User;\r\n\r\n    @Input()\r\n    get source() {\r\n        return this._source;\r\n    }\r\n\r\n    likeMessage(message: ChatMessage) {\r\n        this._liked.next(message);\r\n    }\r\n\r\n    unlikeMessage(message: ChatMessage) {\r\n        this._unliked.next(message);\r\n    }\r\n\r\n    reportMessage(message: ChatMessage) {\r\n        this._reported.next(message);\r\n    }\r\n\r\n    selectMessage(message: ChatMessage) {\r\n        this._selected.next(message);\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    sharedMessage(message: ChatMessage) {\r\n        this._shared.next(message);\r\n    }\r\n\r\n    startEditing(message: ChatMessage) {\r\n        this.messages.forEach(m => m.transientState.editing = false);\r\n        message.transientState.editing = true;\r\n    }\r\n\r\n    deleteMessage(message: ChatMessage) {\r\n        this._deleted.next(message);\r\n    }\r\n\r\n    customSortEnabled = false;\r\n\r\n    markSourceLoaded: () => void;\r\n    sourceLoaded = new Promise<void>(r => this.markSourceLoaded = r);\r\n\r\n    set source(value) {\r\n        this.customSortEnabled = value?.sortOrder !== CommentsOrder.NEWEST;\r\n        this.newMessages = [];\r\n        this.olderMessages = [];\r\n\r\n        (window as any).bantaSourceDebug = value;\r\n\r\n        if (this._sourceSubs) {\r\n            this._sourceSubs.unsubscribe();\r\n            this._sourceSubs = null;\r\n        }\r\n        this._source = value;\r\n\r\n        if (value) {\r\n            const messages = (value.messages || []).slice();\r\n            this.messages = messages;\r\n            this.olderMessages = messages.splice(this.maxVisibleMessages, messages.length);\r\n            this.hasMore = true; //this.olderMessages.length > 0;\r\n\r\n            this._sourceSubs = new Subscription();\r\n            this._sourceSubs.add(this._source.messageReceived.subscribe(msg => this.messageReceived(msg)));\r\n            this._sourceSubs.add(this._source.messageSent.subscribe(msg => this.messageSent(msg)));\r\n\r\n            this._sourceSubs.add(\r\n                this.backend.userChanged.subscribe(user => this.currentUser = user)\r\n            );\r\n\r\n            this.getInitialMessages();\r\n        }\r\n    }\r\n\r\n    private async getInitialMessages() {\r\n        let messages = (await this._source.getExistingMessages());\r\n        messages.forEach(m => m.transientState ??= {});\r\n        this.messages = this.newestLast ? messages.slice().reverse() : messages;\r\n        this.sortMessages();\r\n        if (this.markSourceLoaded)\r\n            this.markSourceLoaded();\r\n    }\r\n\r\n    @Input()\r\n    genericAvatarUrl: string;\r\n\r\n    @ViewChild('messageContainer')\r\n    messageContainer: ElementRef<HTMLElement>;\r\n\r\n    @Input()\r\n    maxMessages = 2000;\r\n\r\n    @Input()\r\n    maxVisibleMessages: number = 200;\r\n\r\n    @Input()\r\n    newestLast = false;\r\n\r\n    isViewingMore = false;\r\n    isLoadingMore = false;\r\n    hasMore = false;\r\n\r\n    newMessages: ChatMessage[] = [];\r\n    olderMessages: ChatMessage[] = [];\r\n\r\n    messageIdentity(index: number, chatMessage: ChatMessage) {\r\n        return chatMessage.id;\r\n    }\r\n\r\n    @Output()\r\n    sortOrderChanged = new Subject<CommentsOrder>();\r\n\r\n    async showNew() {\r\n        let naturalOrder = CommentsOrder.NEWEST;\r\n        if (this.source && this.source.sortOrder !== naturalOrder) {\r\n            this.sortOrderChanged.next(naturalOrder);\r\n            return;\r\n        }\r\n\r\n        this.isViewingMore = false;\r\n\r\n        if (this.newestLast)\r\n            this.messages = this.messages.concat(this.newMessages.splice(0, this.newMessages.length));\r\n        else\r\n            this.messages = this.newMessages.splice(0, this.newMessages.length).concat(this.messages);\r\n        let overflow = this.messages.splice(this.maxVisibleMessages, this.messages.length);\r\n        this.olderMessages = overflow.concat(this.olderMessages);\r\n        this.olderMessages.splice(this.maxMessages - this.maxVisibleMessages, this.olderMessages.length);\r\n        this.hasMore = this.olderMessages.length > 0;\r\n    }\r\n\r\n    async showMore() {\r\n        this.isViewingMore = true;\r\n\r\n        if (this.olderMessages.length > 0) {\r\n            this.isLoadingMore = false;\r\n            this.messages = this.messages.concat(this.olderMessages.splice(0, 50));\r\n        }\r\n        this.isLoadingMore = true;\r\n\r\n        let nextPageSize = 20;\r\n        let lastMessage: ChatMessage;\r\n\r\n        if (this.newestLast) {\r\n            lastMessage = this.olderMessages[0] ?? this.messages[0];\r\n        } else {\r\n            lastMessage = this.olderMessages[this.olderMessages.length - 1] ?? this.messages[this.messages.length - 1];\r\n        }\r\n\r\n        if (!lastMessage) {\r\n            this.isLoadingMore = false;\r\n            this.hasMore = false;\r\n            return;\r\n        }\r\n\r\n        let messages = await this.source.loadAfter(lastMessage, nextPageSize);\r\n\r\n        if (this.newestLast)\r\n            messages = messages.slice().reverse();\r\n        \r\n        messages.forEach(m => m.transientState ??= {});\r\n\r\n        if (this.newestLast)\r\n            this.messages = messages.concat(this.messages);\r\n        else\r\n            this.messages = this.messages.concat(messages);\r\n        this.isLoadingMore = false;\r\n        if (messages.length === 0) {\r\n            console.log(`Reached the end of the list.`);\r\n            this.hasMore = false;\r\n        }\r\n    }\r\n\r\n    private addMessage(message: ChatMessage) {\r\n\r\n        if (!message.transientState)\r\n            message.transientState ??= {};\r\n        \r\n        let destination = this.messages;\r\n        let bucket = this.olderMessages;\r\n        let newestLast = this.newestLast;\r\n\r\n        if (this.isViewingMore) {\r\n            destination = this.newMessages;\r\n            bucket = null;\r\n        }\r\n\r\n        \r\n        if (newestLast) {\r\n            destination.push(message);\r\n            let overflow = destination.splice(this.maxVisibleMessages, destination.length);\r\n            bucket?.push(...overflow);\r\n        } else {\r\n            destination.unshift(message);\r\n            let overflow = destination.splice(this.maxVisibleMessages, destination.length);\r\n            bucket?.unshift(...overflow);\r\n        }\r\n\r\n        if (bucket?.length > 0)\r\n            this.hasMore = true;\r\n\r\n        message.pagingCursor = String(this.incrementPagingCursors());\r\n        this.sortMessages();\r\n    }\r\n\r\n    private incrementPagingCursors() {\r\n        if (this.source.sortOrder !== CommentsOrder.NEWEST)\r\n            return;\r\n        \r\n        let maxPagingCursor = 0;\r\n        for (let group of [this.messages, this.olderMessages, this.newMessages]) {\r\n            for (let message of group) {\r\n                if (message.pagingCursor) {\r\n                    let pagingCursor = Number(message.pagingCursor) + 1;\r\n                    if (pagingCursor > maxPagingCursor)\r\n                        maxPagingCursor = pagingCursor;\r\n                    message.pagingCursor = String(pagingCursor);\r\n                }\r\n            }\r\n        }\r\n\r\n        return maxPagingCursor;\r\n    }\r\n\r\n    /**\r\n     * Wait for all currently visible comments to be fully loaded, including all attachments.\r\n     * Doing this will prevent layout shift when scrolling to a specific comment.\r\n     */\r\n    async waitForAllCommentsToLoad() {\r\n        await new Promise(r => setTimeout(r, 100));\r\n        await this.sourceLoaded;\r\n        await Promise.all(this.comments.map(x => x.waitForLoad()));\r\n    }\r\n\r\n    private sortMessages() {\r\n        if (!this.source)\r\n            return;\r\n        \r\n        let sorter: (a: ChatMessage, b: ChatMessage) => number;\r\n\r\n        if (this.source.sortOrder === CommentsOrder.LIKES)\r\n            sorter = (a, b) => b.likes - a.likes;\r\n        else if (this.source.sortOrder === CommentsOrder.NEWEST)\r\n            sorter = (a, b) => (b.sentAt - a.sentAt) * (this.newestLast ? -1 : 1);\r\n        else if (this.source.sortOrder === CommentsOrder.OLDEST)\r\n            sorter = (a, b) => (a.sentAt - b.sentAt) * (this.newestLast ? -1 : 1);\r\n\r\n        this.messages.sort(sorter);\r\n        this.olderMessages.sort(sorter);\r\n        this.newMessages.sort(sorter);\r\n    }\r\n\r\n    private messageReceived(message: ChatMessage) {\r\n        this.addMessage(message);\r\n\r\n        if (this.isScrolledToLatest())\r\n            setTimeout(() => this.scrollToLatest());\r\n    }\r\n\r\n    isScrolledToLatest() {\r\n        if (!this.messageContainer)\r\n            return false;\r\n\r\n        const el = this.messageContainer.nativeElement;\r\n        const currentScroll = el.scrollTop;\r\n        const currentTotal = el.scrollHeight - el.offsetHeight;\r\n\r\n        return currentScroll > currentTotal - 10;\r\n    }\r\n\r\n    private messageSent(message: ChatMessage) {\r\n        this.addMessage(message);\r\n\r\n        if (!this.messageContainer)\r\n            return;\r\n\r\n        this.scrollToLatest();\r\n    }\r\n\r\n    scrollToLatest() {\r\n        if (!this.messageContainer)\r\n            return;\r\n\r\n        const el = this.messageContainer.nativeElement;\r\n        el.scrollTop = el.scrollHeight;\r\n    }\r\n\r\n    mentionsMe(message: ChatMessage) {\r\n        if (!this.currentUser)\r\n            return false;\r\n\r\n        if (message.message.includes(`@${this.currentUser.username}`))\r\n            return true;\r\n\r\n        return false;\r\n    }\r\n}\r\n"]}
|
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
import { NgModule } from '@angular/core';
|
|
2
|
-
import { CommentComponent } from './comment/comment.component';
|
|
3
|
-
import { CommentViewComponent } from './comment-view/comment-view.component';
|
|
4
|
-
import { BantaCommentsComponent } from './banta-comments/banta-comments.component';
|
|
5
|
-
import { CommonModule } from '@angular/common';
|
|
6
|
-
import { FormsModule } from '@angular/forms';
|
|
7
|
-
import { BantaCommonModule } from '../common';
|
|
8
|
-
import { LiveCommentComponent } from './live-comment.component';
|
|
9
|
-
import { EmojiModule } from '../emoji';
|
|
10
|
-
import { MatIconModule } from '@angular/material/icon';
|
|
11
|
-
import { MatButtonModule } from '@angular/material/button';
|
|
12
|
-
import { MatMenuModule } from '@angular/material/menu';
|
|
13
|
-
import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
|
|
14
|
-
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
15
|
-
import { MatInputModule } from '@angular/material/input';
|
|
16
|
-
import { TextFieldModule } from '@angular/cdk/text-field';
|
|
17
|
-
import { CommentFieldComponent } from './comment-field/comment-field.component';
|
|
18
|
-
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
19
|
-
import { CommentSortComponent } from "./comment-sort/comment-sort.component";
|
|
20
|
-
import { MatSelectModule } from "@angular/material/select";
|
|
21
|
-
import { AttachmentButtonComponent } from './attachment-button/attachment-button.component';
|
|
22
|
-
import { BantaReplySendOptionsDirective } from './reply-send-options.directive';
|
|
23
|
-
import { OverlayModule } from '@angular/cdk/overlay';
|
|
24
|
-
import { PortalModule } from '@angular/cdk/portal';
|
|
25
|
-
import { AttachmentScraperDirective } from './attachment-scraper.directive';
|
|
26
|
-
const COMPONENTS = [
|
|
27
|
-
CommentComponent,
|
|
28
|
-
CommentViewComponent,
|
|
29
|
-
BantaCommentsComponent,
|
|
30
|
-
LiveCommentComponent,
|
|
31
|
-
CommentFieldComponent,
|
|
32
|
-
CommentSortComponent,
|
|
33
|
-
AttachmentButtonComponent,
|
|
34
|
-
BantaReplySendOptionsDirective,
|
|
35
|
-
AttachmentScraperDirective
|
|
36
|
-
];
|
|
37
|
-
export class CommentsModule {
|
|
38
|
-
}
|
|
39
|
-
CommentsModule.decorators = [
|
|
40
|
-
{ type: NgModule, args: [{
|
|
41
|
-
declarations: COMPONENTS,
|
|
42
|
-
imports: [
|
|
43
|
-
CommonModule,
|
|
44
|
-
TextFieldModule,
|
|
45
|
-
FormsModule,
|
|
46
|
-
MatIconModule,
|
|
47
|
-
MatFormFieldModule,
|
|
48
|
-
MatInputModule,
|
|
49
|
-
MatButtonModule,
|
|
50
|
-
MatMenuModule,
|
|
51
|
-
MatProgressSpinnerModule,
|
|
52
|
-
BantaCommonModule,
|
|
53
|
-
EmojiModule,
|
|
54
|
-
MatTooltipModule,
|
|
55
|
-
MatSelectModule,
|
|
56
|
-
OverlayModule,
|
|
57
|
-
PortalModule
|
|
58
|
-
],
|
|
59
|
-
exports: COMPONENTS
|
|
60
|
-
},] }
|
|
61
|
-
];
|
|
62
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbWVudHMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2RrL3NyYy9saWIvY29tbWVudHMvY29tbWVudHMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDL0QsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDN0UsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDbkYsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFDOUMsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDaEUsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUN2QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUM5RSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzFELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQ2hGLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLDJCQUEyQixDQUFDO0FBQzNELE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLHVDQUF1QyxDQUFDO0FBQzNFLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUN6RCxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxpREFBaUQsQ0FBQztBQUM1RixPQUFPLEVBQUUsOEJBQThCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNoRixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDckQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ25ELE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBRTVFLE1BQU0sVUFBVSxHQUFHO0lBQ2YsZ0JBQWdCO0lBQ2hCLG9CQUFvQjtJQUNwQixzQkFBc0I7SUFDdEIsb0JBQW9CO0lBQ3BCLHFCQUFxQjtJQUNyQixvQkFBb0I7SUFDcEIseUJBQXlCO0lBQ3pCLDhCQUE4QjtJQUM5QiwwQkFBMEI7Q0FDN0IsQ0FBQztBQXVCRixNQUFNLE9BQU8sY0FBYzs7O1lBckIxQixRQUFRLFNBQUM7Z0JBQ04sWUFBWSxFQUFFLFVBQVU7Z0JBQzFCLE9BQU8sRUFBRTtvQkFDUCxZQUFZO29CQUNaLGVBQWU7b0JBQ2YsV0FBVztvQkFDWCxhQUFhO29CQUNiLGtCQUFrQjtvQkFDbEIsY0FBYztvQkFDZCxlQUFlO29CQUNmLGFBQWE7b0JBQ2Isd0JBQXdCO29CQUN4QixpQkFBaUI7b0JBQ2pCLFdBQVc7b0JBQ1gsZ0JBQWdCO29CQUNoQixlQUFlO29CQUNmLGFBQWE7b0JBQ2IsWUFBWTtpQkFDYjtnQkFDQyxPQUFPLEVBQUUsVUFBVTthQUN0QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1lbnRDb21wb25lbnQgfSBmcm9tICcuL2NvbW1lbnQvY29tbWVudC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBDb21tZW50Vmlld0NvbXBvbmVudCB9IGZyb20gJy4vY29tbWVudC12aWV3L2NvbW1lbnQtdmlldy5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBCYW50YUNvbW1lbnRzQ29tcG9uZW50IH0gZnJvbSAnLi9iYW50YS1jb21tZW50cy9iYW50YS1jb21tZW50cy5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgQmFudGFDb21tb25Nb2R1bGUgfSBmcm9tICcuLi9jb21tb24nO1xyXG5pbXBvcnQgeyBMaXZlQ29tbWVudENvbXBvbmVudCB9IGZyb20gJy4vbGl2ZS1jb21tZW50LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEVtb2ppTW9kdWxlIH0gZnJvbSAnLi4vZW1vamknO1xyXG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XHJcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XHJcbmltcG9ydCB7IE1hdE1lbnVNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9tZW51JztcclxuaW1wb3J0IHsgTWF0UHJvZ3Jlc3NTcGlubmVyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvcHJvZ3Jlc3Mtc3Bpbm5lcic7XHJcbmltcG9ydCB7IE1hdEZvcm1GaWVsZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2Zvcm0tZmllbGQnO1xyXG5pbXBvcnQgeyBNYXRJbnB1dE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2lucHV0JztcclxuaW1wb3J0IHsgVGV4dEZpZWxkTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL3RleHQtZmllbGQnO1xyXG5pbXBvcnQgeyBDb21tZW50RmllbGRDb21wb25lbnQgfSBmcm9tICcuL2NvbW1lbnQtZmllbGQvY29tbWVudC1maWVsZC5jb21wb25lbnQnO1xyXG5pbXBvcnQge01hdFRvb2x0aXBNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3Rvb2x0aXAnO1xyXG5pbXBvcnQge0NvbW1lbnRTb3J0Q29tcG9uZW50fSBmcm9tIFwiLi9jb21tZW50LXNvcnQvY29tbWVudC1zb3J0LmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge01hdFNlbGVjdE1vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL21hdGVyaWFsL3NlbGVjdFwiO1xyXG5pbXBvcnQgeyBBdHRhY2htZW50QnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi9hdHRhY2htZW50LWJ1dHRvbi9hdHRhY2htZW50LWJ1dHRvbi5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBCYW50YVJlcGx5U2VuZE9wdGlvbnNEaXJlY3RpdmUgfSBmcm9tICcuL3JlcGx5LXNlbmQtb3B0aW9ucy5kaXJlY3RpdmUnO1xyXG5pbXBvcnQgeyBPdmVybGF5TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xyXG5pbXBvcnQgeyBQb3J0YWxNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvcG9ydGFsJztcclxuaW1wb3J0IHsgQXR0YWNobWVudFNjcmFwZXJEaXJlY3RpdmUgfSBmcm9tICcuL2F0dGFjaG1lbnQtc2NyYXBlci5kaXJlY3RpdmUnO1xyXG5cclxuY29uc3QgQ09NUE9ORU5UUyA9IFtcclxuICAgIENvbW1lbnRDb21wb25lbnQsXHJcbiAgICBDb21tZW50Vmlld0NvbXBvbmVudCxcclxuICAgIEJhbnRhQ29tbWVudHNDb21wb25lbnQsXHJcbiAgICBMaXZlQ29tbWVudENvbXBvbmVudCxcclxuICAgIENvbW1lbnRGaWVsZENvbXBvbmVudCxcclxuICAgIENvbW1lbnRTb3J0Q29tcG9uZW50LFxyXG4gICAgQXR0YWNobWVudEJ1dHRvbkNvbXBvbmVudCxcclxuICAgIEJhbnRhUmVwbHlTZW5kT3B0aW9uc0RpcmVjdGl2ZSxcclxuICAgIEF0dGFjaG1lbnRTY3JhcGVyRGlyZWN0aXZlXHJcbl07XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgZGVjbGFyYXRpb25zOiBDT01QT05FTlRTLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIFRleHRGaWVsZE1vZHVsZSxcclxuICAgIEZvcm1zTW9kdWxlLFxyXG4gICAgTWF0SWNvbk1vZHVsZSxcclxuICAgIE1hdEZvcm1GaWVsZE1vZHVsZSxcclxuICAgIE1hdElucHV0TW9kdWxlLFxyXG4gICAgTWF0QnV0dG9uTW9kdWxlLFxyXG4gICAgTWF0TWVudU1vZHVsZSxcclxuICAgIE1hdFByb2dyZXNzU3Bpbm5lck1vZHVsZSxcclxuICAgIEJhbnRhQ29tbW9uTW9kdWxlLFxyXG4gICAgRW1vamlNb2R1bGUsXHJcbiAgICBNYXRUb29sdGlwTW9kdWxlLFxyXG4gICAgTWF0U2VsZWN0TW9kdWxlLFxyXG4gICAgT3ZlcmxheU1vZHVsZSxcclxuICAgIFBvcnRhbE1vZHVsZVxyXG4gIF0sXHJcbiAgICBleHBvcnRzOiBDT01QT05FTlRTXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDb21tZW50c01vZHVsZSB7XHJcbn1cclxuIl19
|
|
@@ -1,71 +0,0 @@
|
|
|
1
|
-
import { Component, Input, Output } from '@angular/core';
|
|
2
|
-
import { Subject, Observable } from 'rxjs';
|
|
3
|
-
import { ChatBackendBase } from '../chat-backend-base';
|
|
4
|
-
export class LiveCommentComponent {
|
|
5
|
-
constructor(backend) {
|
|
6
|
-
this.backend = backend;
|
|
7
|
-
this._upvoted = new Subject();
|
|
8
|
-
this._reported = new Subject();
|
|
9
|
-
this._selected = new Subject();
|
|
10
|
-
}
|
|
11
|
-
get upvoted() {
|
|
12
|
-
return this._upvoted;
|
|
13
|
-
}
|
|
14
|
-
get reported() {
|
|
15
|
-
return this._reported;
|
|
16
|
-
}
|
|
17
|
-
get selected() {
|
|
18
|
-
return this._selected;
|
|
19
|
-
}
|
|
20
|
-
get message() {
|
|
21
|
-
return this._message;
|
|
22
|
-
}
|
|
23
|
-
set message(value) {
|
|
24
|
-
let originalId = null;
|
|
25
|
-
if (this._message)
|
|
26
|
-
originalId = this._message.id;
|
|
27
|
-
this._message = value;
|
|
28
|
-
if (value && originalId === value.id) {
|
|
29
|
-
return;
|
|
30
|
-
}
|
|
31
|
-
if (this.unsubscribe)
|
|
32
|
-
this.unsubscribe();
|
|
33
|
-
if (value) {
|
|
34
|
-
this.unsubscribe = this.backend.watchMessage(value, message => this.message = message);
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
report() {
|
|
38
|
-
this._reported.next();
|
|
39
|
-
}
|
|
40
|
-
upvote() {
|
|
41
|
-
this._upvoted.next();
|
|
42
|
-
}
|
|
43
|
-
select() {
|
|
44
|
-
this._selected.next();
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
LiveCommentComponent.decorators = [
|
|
48
|
-
{ type: Component, args: [{
|
|
49
|
-
selector: 'banta-live-comment',
|
|
50
|
-
template: `
|
|
51
|
-
<banta-comment
|
|
52
|
-
*ngIf="message"
|
|
53
|
-
[message]="message"
|
|
54
|
-
(upvoted)="upvote()"
|
|
55
|
-
(reported)="report()"
|
|
56
|
-
(selected)="select()"
|
|
57
|
-
></banta-comment>
|
|
58
|
-
`,
|
|
59
|
-
styles: [``]
|
|
60
|
-
},] }
|
|
61
|
-
];
|
|
62
|
-
LiveCommentComponent.ctorParameters = () => [
|
|
63
|
-
{ type: ChatBackendBase }
|
|
64
|
-
];
|
|
65
|
-
LiveCommentComponent.propDecorators = {
|
|
66
|
-
upvoted: [{ type: Output }],
|
|
67
|
-
reported: [{ type: Output }],
|
|
68
|
-
selected: [{ type: Output }],
|
|
69
|
-
message: [{ type: Input }]
|
|
70
|
-
};
|
|
71
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGl2ZS1jb21tZW50LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Nkay9zcmMvbGliL2NvbW1lbnRzL2xpdmUtY29tbWVudC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpELE9BQU8sRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQWV2RCxNQUFNLE9BQU8sb0JBQW9CO0lBQzdCLFlBQ1ksT0FBeUI7UUFBekIsWUFBTyxHQUFQLE9BQU8sQ0FBa0I7UUFNN0IsYUFBUSxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFDL0IsY0FBUyxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFDaEMsY0FBUyxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7SUFMeEMsQ0FBQztJQU9ELElBQ0ksT0FBTztRQUNQLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQztJQUN6QixDQUFDO0lBRUQsSUFDSSxRQUFRO1FBQ1IsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQzFCLENBQUM7SUFFRCxJQUNJLFFBQVE7UUFDUixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDMUIsQ0FBQztJQUVELElBQ0ksT0FBTztRQUNQLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQztJQUN6QixDQUFDO0lBSUQsSUFBSSxPQUFPLENBQUMsS0FBSztRQUNiLElBQUksVUFBVSxHQUFHLElBQUksQ0FBQztRQUN0QixJQUFJLElBQUksQ0FBQyxRQUFRO1lBQ2IsVUFBVSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDO1FBRWxDLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDO1FBRXRCLElBQUksS0FBSyxJQUFJLFVBQVUsS0FBSyxLQUFLLENBQUMsRUFBRSxFQUFFO1lBQ2xDLE9BQU87U0FDVjtRQUVELElBQUksSUFBSSxDQUFDLFdBQVc7WUFDaEIsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBRXZCLElBQUksS0FBSyxFQUFFO1lBQ1AsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLFlBQVksQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQyxDQUFDO1NBQzFGO0lBQ0wsQ0FBQztJQUVELE1BQU07UUFDRixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzFCLENBQUM7SUFFRCxNQUFNO1FBQ0YsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUN6QixDQUFDO0lBRUQsTUFBTTtRQUNGLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDMUIsQ0FBQzs7O1lBNUVKLFNBQVMsU0FBQztnQkFDUCxRQUFRLEVBQUUsb0JBQW9CO2dCQUM5QixRQUFRLEVBQUU7Ozs7Ozs7O0tBUVQ7eUJBQ1EsRUFBRTthQUNkOzs7WUFkUSxlQUFlOzs7c0JBMkJuQixNQUFNO3VCQUtOLE1BQU07dUJBS04sTUFBTTtzQkFLTixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENoYXRNZXNzYWdlIH0gZnJvbSAnQGJhbnRhL2NvbW1vbic7XHJcbmltcG9ydCB7IFN1YmplY3QsIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgQ2hhdEJhY2tlbmRCYXNlIH0gZnJvbSAnLi4vY2hhdC1iYWNrZW5kLWJhc2UnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2JhbnRhLWxpdmUtY29tbWVudCcsXHJcbiAgICB0ZW1wbGF0ZTogYFxyXG4gICAgICAgIDxiYW50YS1jb21tZW50IFxyXG4gICAgICAgICAgICAqbmdJZj1cIm1lc3NhZ2VcIlxyXG4gICAgICAgICAgICBbbWVzc2FnZV09XCJtZXNzYWdlXCJcclxuICAgICAgICAgICAgKHVwdm90ZWQpPVwidXB2b3RlKClcIlxyXG4gICAgICAgICAgICAocmVwb3J0ZWQpPVwicmVwb3J0KClcIlxyXG4gICAgICAgICAgICAoc2VsZWN0ZWQpPVwic2VsZWN0KClcIlxyXG4gICAgICAgICAgICA+PC9iYW50YS1jb21tZW50PlxyXG4gICAgYCxcclxuICAgIHN0eWxlczogW2BgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgTGl2ZUNvbW1lbnRDb21wb25lbnQge1xyXG4gICAgY29uc3RydWN0b3IoXHJcbiAgICAgICAgcHJpdmF0ZSBiYWNrZW5kIDogQ2hhdEJhY2tlbmRCYXNlXHJcbiAgICApIHtcclxuXHJcbiAgICB9XHJcblxyXG4gICAgcHJpdmF0ZSBfbWVzc2FnZSA6IENoYXRNZXNzYWdlO1xyXG4gICAgcHJpdmF0ZSBfdXB2b3RlZCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XHJcbiAgICBwcml2YXRlIF9yZXBvcnRlZCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XHJcbiAgICBwcml2YXRlIF9zZWxlY3RlZCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XHJcblxyXG4gICAgQE91dHB1dCgpXHJcbiAgICBnZXQgdXB2b3RlZCgpIDogT2JzZXJ2YWJsZTx2b2lkPiB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuX3Vwdm90ZWQ7XHJcbiAgICB9XHJcbiAgICBcclxuICAgIEBPdXRwdXQoKVxyXG4gICAgZ2V0IHJlcG9ydGVkKCkgOiBPYnNlcnZhYmxlPHZvaWQ+IHtcclxuICAgICAgICByZXR1cm4gdGhpcy5fcmVwb3J0ZWQ7XHJcbiAgICB9XHJcblxyXG4gICAgQE91dHB1dCgpXHJcbiAgICBnZXQgc2VsZWN0ZWQoKSA6IE9ic2VydmFibGU8dm9pZD4ge1xyXG4gICAgICAgIHJldHVybiB0aGlzLl9zZWxlY3RlZDtcclxuICAgIH1cclxuICAgIFxyXG4gICAgQElucHV0KClcclxuICAgIGdldCBtZXNzYWdlKCkgOiBDaGF0TWVzc2FnZSB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuX21lc3NhZ2U7XHJcbiAgICB9XHJcblxyXG4gICAgcHJpdmF0ZSB1bnN1YnNjcmliZSA6IEZ1bmN0aW9uO1xyXG5cclxuICAgIHNldCBtZXNzYWdlKHZhbHVlKSB7XHJcbiAgICAgICAgbGV0IG9yaWdpbmFsSWQgPSBudWxsO1xyXG4gICAgICAgIGlmICh0aGlzLl9tZXNzYWdlKVxyXG4gICAgICAgICAgICBvcmlnaW5hbElkID0gdGhpcy5fbWVzc2FnZS5pZDtcclxuICAgICAgICBcclxuICAgICAgICB0aGlzLl9tZXNzYWdlID0gdmFsdWU7XHJcblxyXG4gICAgICAgIGlmICh2YWx1ZSAmJiBvcmlnaW5hbElkID09PSB2YWx1ZS5pZCkge1xyXG4gICAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgfVxyXG4gICAgICAgIFxyXG4gICAgICAgIGlmICh0aGlzLnVuc3Vic2NyaWJlKVxyXG4gICAgICAgICAgICB0aGlzLnVuc3Vic2NyaWJlKCk7XHJcbiAgICAgICAgXHJcbiAgICAgICAgaWYgKHZhbHVlKSB7XHJcbiAgICAgICAgICAgIHRoaXMudW5zdWJzY3JpYmUgPSB0aGlzLmJhY2tlbmQud2F0Y2hNZXNzYWdlKHZhbHVlLCBtZXNzYWdlID0+IHRoaXMubWVzc2FnZSA9IG1lc3NhZ2UpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICByZXBvcnQoKSB7XHJcbiAgICAgICAgdGhpcy5fcmVwb3J0ZWQubmV4dCgpO1xyXG4gICAgfVxyXG4gICAgXHJcbiAgICB1cHZvdGUoKSB7XHJcbiAgICAgICAgdGhpcy5fdXB2b3RlZC5uZXh0KCk7XHJcbiAgICB9XHJcblxyXG4gICAgc2VsZWN0KCkge1xyXG4gICAgICAgIHRoaXMuX3NlbGVjdGVkLm5leHQoKTtcclxuICAgIH1cclxufSJdfQ==
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { Directive } from "@angular/core";
|
|
2
|
-
export class BantaReplySendOptionsDirective {
|
|
3
|
-
}
|
|
4
|
-
BantaReplySendOptionsDirective.decorators = [
|
|
5
|
-
{ type: Directive, args: [{
|
|
6
|
-
selector: `[bantaReplySendOptions]`
|
|
7
|
-
},] }
|
|
8
|
-
];
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVwbHktc2VuZC1vcHRpb25zLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Nkay9zcmMvbGliL2NvbW1lbnRzL3JlcGx5LXNlbmQtb3B0aW9ucy5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUsxQyxNQUFNLE9BQU8sOEJBQThCOzs7WUFIMUMsU0FBUyxTQUFDO2dCQUNQLFFBQVEsRUFBRSx5QkFBeUI7YUFDdEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5cclxuQERpcmVjdGl2ZSh7XHJcbiAgICBzZWxlY3RvcjogYFtiYW50YVJlcGx5U2VuZE9wdGlvbnNdYFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQmFudGFSZXBseVNlbmRPcHRpb25zRGlyZWN0aXZlIHt9Il19
|