@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
|
@@ -1,22 +1,27 @@
|
|
|
1
1
|
import { __awaiter } from "tslib";
|
|
2
2
|
import { Component, Input, ViewChild, ElementRef, Output, HostBinding } from "@angular/core";
|
|
3
|
+
import { CommentsOrder } from '@banta/common';
|
|
3
4
|
import { Subject, Subscription } from 'rxjs';
|
|
4
|
-
import {
|
|
5
|
+
import { ChatBackendBase } from "../../chat-backend-base";
|
|
5
6
|
export class CommentViewComponent {
|
|
6
7
|
constructor(backend) {
|
|
7
8
|
this.backend = backend;
|
|
8
9
|
this._sourceSubs = new Subscription();
|
|
9
10
|
this._selected = new Subject();
|
|
10
|
-
this.
|
|
11
|
+
this._liked = new Subject();
|
|
12
|
+
this._unliked = new Subject();
|
|
11
13
|
this._reported = new Subject();
|
|
12
14
|
this._userSelected = new Subject();
|
|
13
15
|
this._usernameSelected = new Subject();
|
|
14
16
|
this._avatarSelected = new Subject();
|
|
15
17
|
this._shared = new Subject();
|
|
18
|
+
this._deleted = new Subject();
|
|
19
|
+
this._messageEdited = new Subject();
|
|
16
20
|
this.showEmptyState = true;
|
|
17
21
|
this.allowReplies = true;
|
|
18
22
|
this.menuMessage = null;
|
|
19
23
|
this.messages = [];
|
|
24
|
+
this.customSortEnabled = false;
|
|
20
25
|
this.maxMessages = 2000;
|
|
21
26
|
this.maxVisibleMessages = 200;
|
|
22
27
|
this.newestLast = false;
|
|
@@ -25,33 +30,33 @@ export class CommentViewComponent {
|
|
|
25
30
|
this.hasMore = false;
|
|
26
31
|
this.newMessages = [];
|
|
27
32
|
this.olderMessages = [];
|
|
33
|
+
this.sortOrderChanged = new Subject();
|
|
28
34
|
}
|
|
29
35
|
get selected() {
|
|
30
36
|
return this._selected;
|
|
31
37
|
}
|
|
32
|
-
get
|
|
33
|
-
return this.
|
|
38
|
+
get messageEdited() {
|
|
39
|
+
return this._messageEdited.asObservable();
|
|
34
40
|
}
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
}
|
|
38
|
-
get upvoted() {
|
|
39
|
-
return this._upvoted;
|
|
40
|
-
}
|
|
41
|
-
get usernameSelected() {
|
|
42
|
-
return this._usernameSelected;
|
|
43
|
-
}
|
|
44
|
-
get avatarSelected() {
|
|
45
|
-
return this._avatarSelected;
|
|
46
|
-
}
|
|
47
|
-
get shared() {
|
|
48
|
-
return this._shared;
|
|
41
|
+
saveEdit(message, newMessage) {
|
|
42
|
+
this._messageEdited.next({ message, newMessage });
|
|
49
43
|
}
|
|
44
|
+
get userSelected() { return this._userSelected; }
|
|
45
|
+
get reported() { return this._reported; }
|
|
46
|
+
get liked() { return this._liked; }
|
|
47
|
+
get unliked() { return this._unliked; }
|
|
48
|
+
get usernameSelected() { return this._usernameSelected; }
|
|
49
|
+
get avatarSelected() { return this._avatarSelected; }
|
|
50
|
+
get shared() { return this._shared; }
|
|
51
|
+
get deleted() { return this._deleted; }
|
|
50
52
|
get source() {
|
|
51
53
|
return this._source;
|
|
52
54
|
}
|
|
53
|
-
|
|
54
|
-
this.
|
|
55
|
+
likeMessage(message) {
|
|
56
|
+
this._liked.next(message);
|
|
57
|
+
}
|
|
58
|
+
unlikeMessage(message) {
|
|
59
|
+
this._unliked.next(message);
|
|
55
60
|
}
|
|
56
61
|
reportMessage(message) {
|
|
57
62
|
this._reported.next(message);
|
|
@@ -71,31 +76,51 @@ export class CommentViewComponent {
|
|
|
71
76
|
sharedMessage(message) {
|
|
72
77
|
this._shared.next(message);
|
|
73
78
|
}
|
|
79
|
+
startEditing(message) {
|
|
80
|
+
this.messages.forEach(m => m.transientState.editing = false);
|
|
81
|
+
message.transientState.editing = true;
|
|
82
|
+
}
|
|
83
|
+
deleteMessage(message) {
|
|
84
|
+
this._deleted.next(message);
|
|
85
|
+
}
|
|
74
86
|
set source(value) {
|
|
87
|
+
this.customSortEnabled = (value === null || value === void 0 ? void 0 : value.sortOrder) !== CommentsOrder.NEWEST;
|
|
88
|
+
this.newMessages = [];
|
|
89
|
+
this.olderMessages = [];
|
|
90
|
+
window.bantaSourceDebug = value;
|
|
75
91
|
if (this._sourceSubs) {
|
|
76
92
|
this._sourceSubs.unsubscribe();
|
|
77
93
|
this._sourceSubs = null;
|
|
78
94
|
}
|
|
79
95
|
this._source = value;
|
|
80
96
|
if (value) {
|
|
81
|
-
console.log(`[banta-comment-view] Subscribing to source...`);
|
|
82
97
|
const messages = (value.messages || []).slice();
|
|
83
98
|
this.messages = messages;
|
|
84
99
|
this.olderMessages = messages.splice(this.maxVisibleMessages, messages.length);
|
|
85
|
-
this.hasMore = this.olderMessages.length > 0;
|
|
100
|
+
this.hasMore = true; //this.olderMessages.length > 0;
|
|
86
101
|
this._sourceSubs = new Subscription();
|
|
87
102
|
this._sourceSubs.add(this._source.messageReceived.subscribe(msg => this.messageReceived(msg)));
|
|
88
103
|
this._sourceSubs.add(this._source.messageSent.subscribe(msg => this.messageSent(msg)));
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
}
|
|
104
|
+
this._sourceSubs.add(this.backend.userChanged.subscribe(user => this.currentUser = user));
|
|
105
|
+
this.getInitialMessages();
|
|
92
106
|
}
|
|
93
107
|
}
|
|
108
|
+
getInitialMessages() {
|
|
109
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
110
|
+
let messages = (yield this._source.getExistingMessages());
|
|
111
|
+
messages.forEach(m => { var _a; return (_a = m.transientState) !== null && _a !== void 0 ? _a : (m.transientState = {}); });
|
|
112
|
+
this.messages = messages;
|
|
113
|
+
});
|
|
114
|
+
}
|
|
94
115
|
messageIdentity(index, chatMessage) {
|
|
95
116
|
return chatMessage.id;
|
|
96
117
|
}
|
|
97
118
|
showNew() {
|
|
98
119
|
return __awaiter(this, void 0, void 0, function* () {
|
|
120
|
+
if (this.source && this.source.sortOrder !== CommentsOrder.NEWEST) {
|
|
121
|
+
this.sortOrderChanged.next(CommentsOrder.NEWEST);
|
|
122
|
+
return;
|
|
123
|
+
}
|
|
99
124
|
this.isViewingMore = false;
|
|
100
125
|
this.messages = this.newMessages.splice(0, this.newMessages.length).concat(this.messages);
|
|
101
126
|
let overflow = this.messages.splice(this.maxVisibleMessages, this.messages.length);
|
|
@@ -111,29 +136,38 @@ export class CommentViewComponent {
|
|
|
111
136
|
this.messages = this.messages.concat(this.olderMessages.splice(0, 50));
|
|
112
137
|
}
|
|
113
138
|
else {
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
139
|
+
this.isLoadingMore = true;
|
|
140
|
+
let nextPageSize = 20;
|
|
141
|
+
let lastMessage;
|
|
142
|
+
lastMessage = this.messages[this.messages.length - 1];
|
|
143
|
+
if (!lastMessage) {
|
|
119
144
|
this.isLoadingMore = false;
|
|
120
|
-
|
|
121
|
-
|
|
145
|
+
this.hasMore = false;
|
|
146
|
+
return;
|
|
122
147
|
}
|
|
123
|
-
|
|
148
|
+
let messages = yield this.source.loadAfter(lastMessage, nextPageSize);
|
|
149
|
+
messages.forEach(m => { var _a; return (_a = m.transientState) !== null && _a !== void 0 ? _a : (m.transientState = {}); });
|
|
150
|
+
this.messages = this.messages.concat(messages);
|
|
151
|
+
this.isLoadingMore = false;
|
|
152
|
+
if (messages.length === 0) {
|
|
153
|
+
console.log(`Reached the end of the list.`);
|
|
124
154
|
this.hasMore = false;
|
|
125
155
|
}
|
|
126
156
|
}
|
|
127
157
|
});
|
|
128
158
|
}
|
|
129
159
|
addMessage(message) {
|
|
160
|
+
var _a;
|
|
161
|
+
if (!message.transientState)
|
|
162
|
+
(_a = message.transientState) !== null && _a !== void 0 ? _a : (message.transientState = {});
|
|
130
163
|
let destination = this.messages;
|
|
131
164
|
let bucket = this.olderMessages;
|
|
132
165
|
if (this.isViewingMore) {
|
|
133
166
|
destination = this.newMessages;
|
|
134
167
|
bucket = null;
|
|
135
168
|
}
|
|
136
|
-
|
|
169
|
+
let newestLast = this.newestLast;
|
|
170
|
+
if (newestLast) {
|
|
137
171
|
destination.push(message);
|
|
138
172
|
let overflow = destination.splice(this.maxVisibleMessages, destination.length);
|
|
139
173
|
bucket === null || bucket === void 0 ? void 0 : bucket.push(...overflow);
|
|
@@ -188,29 +222,33 @@ export class CommentViewComponent {
|
|
|
188
222
|
CommentViewComponent.decorators = [
|
|
189
223
|
{ type: Component, args: [{
|
|
190
224
|
selector: 'banta-comment-view',
|
|
191
|
-
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]=\"isViewingMore\" 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\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 [message]=\"message\"\r\n (click)=\"isViewingMore = true\"\r\n [showReplyAction]=\"allowReplies\"\r\n (userSelected)=\"selectMessageUser(message)\"\r\n (avatarSelected)=\"selectAvatar($event)\"\r\n (usernameSelected)=\"selectUsername($event)\"\r\n (
|
|
192
|
-
styles: [":host{display:flex;flex-direction:column;
|
|
225
|
+
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]=\"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\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 [message]=\"message\"\r\n [mine]=\"currentUser?.id === message.user?.id\"\r\n [permissions]=\"source?.permissions\"\r\n (click)=\"isViewingMore = true\"\r\n [showReplyAction]=\"allowReplies\"\r\n [editing]=\"message.transientState.editing\"\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 </ng-container>\r\n\r\n <a mat-button class=\"nav\" [class.visible]=\"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])\"></ng-content>\r\n</div>\r\n",
|
|
226
|
+
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}}"]
|
|
193
227
|
},] }
|
|
194
228
|
];
|
|
195
229
|
CommentViewComponent.ctorParameters = () => [
|
|
196
|
-
{ type:
|
|
230
|
+
{ type: ChatBackendBase }
|
|
197
231
|
];
|
|
198
232
|
CommentViewComponent.propDecorators = {
|
|
199
233
|
showEmptyState: [{ type: Input }],
|
|
200
234
|
allowReplies: [{ type: Input }],
|
|
201
235
|
fixedHeight: [{ type: Input }, { type: HostBinding, args: ['class.fixed-height',] }],
|
|
202
236
|
selected: [{ type: Output }],
|
|
237
|
+
messageEdited: [{ type: Output }],
|
|
203
238
|
userSelected: [{ type: Output }],
|
|
204
239
|
reported: [{ type: Output }],
|
|
205
|
-
|
|
240
|
+
liked: [{ type: Output }],
|
|
241
|
+
unliked: [{ type: Output }],
|
|
206
242
|
usernameSelected: [{ type: Output }],
|
|
207
243
|
avatarSelected: [{ type: Output }],
|
|
208
244
|
shared: [{ type: Output }],
|
|
245
|
+
deleted: [{ type: Output }],
|
|
209
246
|
source: [{ type: Input }],
|
|
210
247
|
genericAvatarUrl: [{ type: Input }],
|
|
211
248
|
messageContainer: [{ type: ViewChild, args: ['messageContainer',] }],
|
|
212
249
|
maxMessages: [{ type: Input }],
|
|
213
250
|
maxVisibleMessages: [{ type: Input }],
|
|
214
|
-
newestLast: [{ type: Input }]
|
|
251
|
+
newestLast: [{ type: Input }],
|
|
252
|
+
sortOrderChanged: [{ type: Output }]
|
|
215
253
|
};
|
|
216
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"comment-view.component.js","sourceRoot":"D:/Dev/astronautlabs/banta/packages/frontend/projects/sdk/src/","sources":["lib/comments/comment-view/comment-view.component.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAE7F,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAC;AAC7C,OAAO,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAOlD,MAAM,OAAO,oBAAoB;IAC7B,YACY,OAA2B;QAA3B,YAAO,GAAP,OAAO,CAAoB;QAK/B,gBAAW,GAAG,IAAI,YAAY,EAAE,CAAC;QAEjC,cAAS,GAAG,IAAI,OAAO,EAAe,CAAC;QACvC,aAAQ,GAAG,IAAI,OAAO,EAAe,CAAC;QACtC,cAAS,GAAG,IAAI,OAAO,EAAe,CAAC;QACvC,kBAAa,GAAG,IAAI,OAAO,EAAe,CAAC;QAC3C,sBAAiB,GAAG,IAAI,OAAO,EAAQ,CAAC;QACxC,oBAAe,GAAG,IAAI,OAAO,EAAQ,CAAC;QACtC,YAAO,GAAG,IAAI,OAAO,EAAe,CAAC;QAG7C,mBAAc,GAAG,IAAI,CAAC;QAGtB,iBAAY,GAAG,IAAI,CAAC;QAyCpB,gBAAW,GAAgB,IAAI,CAAC;QAChC,aAAQ,GAAkB,EAAE,CAAC;QAqE7B,gBAAW,GAAG,IAAI,CAAC;QAGnB,uBAAkB,GAAW,GAAG,CAAC;QAGjC,eAAU,GAAG,KAAK,CAAC;QAEnB,kBAAa,GAAG,KAAK,CAAC;QACtB,kBAAa,GAAG,KAAK,CAAC;QACtB,YAAO,GAAG,KAAK,CAAC;QAEhB,gBAAW,GAAkB,EAAE,CAAC;QAChC,kBAAa,GAAkB,EAAE,CAAC;IA5IlC,CAAC;IAsBD,IACI,QAAQ;QACR,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAED,IACI,YAAY;QACZ,OAAO,IAAI,CAAC,aAAa,CAAC;IAC9B,CAAC;IAED,IACI,QAAQ;QACR,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAED,IACI,OAAO;QACP,OAAO,IAAI,CAAC,QAAQ,CAAC;IACzB,CAAC;IAED,IACI,gBAAgB;QAChB,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAClC,CAAC;IAED,IACI,cAAc;QACd,OAAO,IAAI,CAAC,eAAe,CAAC;IAChC,CAAC;IAED,IACI,MAAM;QACN,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAMD,IACI,MAAM;QACN,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAED,aAAa,CAAC,OAAoB;QAC9B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAChC,CAAC;IAED,aAAa,CAAC,OAAoB;QAC9B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACjC,CAAC;IAED,aAAa,CAAC,OAAoB;QAC9B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACjC,CAAC;IAED,iBAAiB,CAAC,OAAoB;QAClC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACrC,CAAC;IAED,cAAc,CAAC,IAAU;QACrB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACtC,CAAC;IAED,YAAY,CAAC,IAAU;QACnB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC;IAED,aAAa,CAAC,OAAoB;QAC9B,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC/B,CAAC;IAED,IAAI,MAAM,CAAC,KAAK;QACZ,IAAI,IAAI,CAAC,WAAW,EAAE;YAClB,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC;YAC/B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;SAC3B;QACD,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QAErB,IAAI,KAAK,EAAE;YACP,OAAO,CAAC,GAAG,CAAC,+CAA+C,CAAC,CAAC;YAC7D,MAAM,QAAQ,GAAG,CAAC,KAAK,CAAC,QAAQ,IAAI,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC;YAChD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;YACzB,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,kBAAkB,EAAE,QAAQ,CAAC,MAAM,CAAC,CAAC;YAC/E,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC;YAE7C,IAAI,CAAC,WAAW,GAAG,IAAI,YAAY,EAAE,CAAC;YACtC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAC/F,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAEvF,IAAI,IAAI,CAAC,OAAO,CAAC,kBAAkB,EAAE;gBACjC,IAAI,CAAC,WAAW,CAAC,GAAG,CAChB,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,CAC7E,CAAC;aACL;SACJ;IACL,CAAC;IAwBD,eAAe,CAAC,KAAa,EAAE,WAAwB;QACnD,OAAO,WAAW,CAAC,EAAE,CAAC;IAC1B,CAAC;IAEK,OAAO;;YACT,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;YAC3B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAC1F,IAAI,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,kBAAkB,EAAE,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;YACnF,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;YACzD,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,kBAAkB,EAAE,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;QACrG,CAAC;KAAA;IAEK,QAAQ;;YACV,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;YAE1B,IAAI,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE;gBAC/B,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;gBAC3B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;aAC1E;iBAAM;gBACH,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE;oBACvB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;oBAE1B,IAAI,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;oBAC1D,IAAI,QAAQ,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,WAAW,EAAE,GAAG,CAAC,CAAC;oBAC7D,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;oBAC/C,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;oBAC3B,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC;wBACrB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;iBAE5B;qBAAM;oBACH,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;iBACxB;aACJ;QACL,CAAC;KAAA;IAEO,UAAU,CAAC,OAAoB;QACnC,IAAI,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC;QAChC,IAAI,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC;QAEhC,IAAI,IAAI,CAAC,aAAa,EAAE;YACpB,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;YAC/B,MAAM,GAAG,IAAI,CAAC;SACjB;QAED,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC1B,IAAI,QAAQ,GAAG,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,kBAAkB,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC;YAC/E,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,IAAI,CAAC,GAAG,QAAQ,EAAE;SAC7B;aAAM;YACH,WAAW,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;YAC7B,IAAI,QAAQ,GAAG,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,kBAAkB,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC;YAC/E,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,OAAO,CAAC,GAAG,QAAQ,EAAE;SAChC;QAED,IAAI,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,MAAM,IAAG,CAAC;YAClB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;IAC5B,CAAC;IAEO,eAAe,CAAC,OAAoB;QACxC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;QAEzB,IAAI,IAAI,CAAC,kBAAkB,EAAE;YACzB,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;IAChD,CAAC;IAED,kBAAkB;QACd,IAAI,CAAC,IAAI,CAAC,gBAAgB;YACtB,OAAO,KAAK,CAAC;QAEjB,MAAM,EAAE,GAAG,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC;QAC/C,MAAM,aAAa,GAAG,EAAE,CAAC,SAAS,CAAC;QACnC,MAAM,YAAY,GAAG,EAAE,CAAC,YAAY,GAAG,EAAE,CAAC,YAAY,CAAC;QAEvD,OAAO,aAAa,GAAG,YAAY,GAAG,EAAE,CAAC;IAC7C,CAAC;IAEO,WAAW,CAAC,OAAoB;QACpC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;QAEzB,IAAI,CAAC,IAAI,CAAC,gBAAgB;YACtB,OAAO;QAEX,IAAI,CAAC,cAAc,EAAE,CAAC;IAC1B,CAAC;IAED,cAAc;QACV,IAAI,CAAC,IAAI,CAAC,gBAAgB;YACtB,OAAO;QAEX,MAAM,EAAE,GAAG,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC;QAC/C,EAAE,CAAC,SAAS,GAAG,EAAE,CAAC,YAAY,CAAC;IACnC,CAAC;IAED,UAAU,CAAC,OAAoB;QAC3B,IAAI,CAAC,IAAI,CAAC,WAAW;YACjB,OAAO,KAAK,CAAC;QAEjB,IAAI,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC;YACzD,OAAO,IAAI,CAAC;QAEhB,OAAO,KAAK,CAAC;IACjB,CAAC;IAED,aAAa,CAAC,IAAU;QACpB,IAAI,GAAG,GAAG,IAAI,CAAC,gBAAgB,CAAC;QAEhC,IAAI,IAAI,IAAI,IAAI,CAAC,SAAS;YACtB,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC;QAEzB,OAAO,OAAO,GAAG,GAAG,CAAC;IACzB,CAAC;;;YAtQJ,SAAS,SAAC;gBACP,QAAQ,EAAE,oBAAoB;gBAC9B,+4DAA4C;;aAE/C;;;YANQ,kBAAkB;;;6BAwBtB,KAAK;2BAGL,KAAK;0BAGL,KAAK,YACL,WAAW,SAAC,oBAAoB;uBAGhC,MAAM;2BAKN,MAAM;uBAKN,MAAM;sBAKN,MAAM;+BAKN,MAAM;6BAKN,MAAM;qBAKN,MAAM;qBASN,KAAK;+BA2DL,KAAK;+BAGL,SAAS,SAAC,kBAAkB;0BAG5B,KAAK;iCAGL,KAAK;yBAGL,KAAK","sourcesContent":["import { Component, Input, ViewChild, ElementRef, Output, HostBinding } from \"@angular/core\";\r\nimport { User, ChatMessage, ChatSource } from '@banta/common';\r\nimport { Subject, Subscription } from 'rxjs';\r\nimport { ChatBackendService } from \"../../common\";\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: ChatBackendService\r\n    ) {\r\n\r\n    }\r\n\r\n    private _sourceSubs = new Subscription();\r\n    private _source: ChatSource;\r\n    private _selected = new Subject<ChatMessage>();\r\n    private _upvoted = 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\r\n    @Input()\r\n    showEmptyState = true;\r\n\r\n    @Input()\r\n    allowReplies = true;\r\n\r\n    @Input()\r\n    @HostBinding('class.fixed-height')\r\n    fixedHeight: boolean;\r\n\r\n    @Output()\r\n    get selected() {\r\n        return this._selected;\r\n    }\r\n\r\n    @Output()\r\n    get userSelected() {\r\n        return this._userSelected;\r\n    }\r\n\r\n    @Output()\r\n    get reported() {\r\n        return this._reported;\r\n    }\r\n\r\n    @Output()\r\n    get upvoted() {\r\n        return this._upvoted;\r\n    }\r\n\r\n    @Output()\r\n    get usernameSelected() {\r\n        return this._usernameSelected;\r\n    }\r\n\r\n    @Output()\r\n    get avatarSelected() {\r\n        return this._avatarSelected;\r\n    }\r\n\r\n    @Output()\r\n    get shared() {\r\n        return this._shared;\r\n    }\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    upvoteMessage(message: ChatMessage) {\r\n        this._upvoted.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    set source(value) {\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            console.log(`[banta-comment-view] Subscribing to source...`);\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 = 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            if (this._source.currentUserChanged) {\r\n                this._sourceSubs.add(\r\n                    this._source.currentUserChanged.subscribe(user => this.currentUser = user)\r\n                );\r\n            }\r\n        }\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    async showNew() {\r\n        this.isViewingMore = false;\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    }\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        } else {\r\n            if (this.source.loadAfter) {\r\n                this.isLoadingMore = true;\r\n\r\n                let lastMessage = this.messages[this.messages.length - 1];\r\n                let messages = await this.source.loadAfter(lastMessage, 100);\r\n                this.messages = this.messages.concat(messages);\r\n                this.isLoadingMore = false;\r\n                if (messages.length === 0)\r\n                    this.hasMore = false;\r\n\r\n            } else {\r\n                this.hasMore = false;\r\n            }\r\n        }\r\n    }\r\n\r\n    private addMessage(message: ChatMessage) {\r\n        let destination = this.messages;\r\n        let bucket = this.olderMessages;\r\n\r\n        if (this.isViewingMore) {\r\n            destination = this.newMessages;\r\n            bucket = null;\r\n        }\r\n\r\n        if (this.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\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    avatarForUser(user: User) {\r\n        let url = this.genericAvatarUrl;\r\n\r\n        if (user && user.avatarUrl)\r\n            url = user.avatarUrl;\r\n\r\n        return `url(${url})`;\r\n    }\r\n}\r\n"]}
|
|
254
|
+
//# 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 } 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\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()\r\n    @HostBinding('class.fixed-height')\r\n    fixedHeight: boolean;\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    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 = messages;\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        if (this.source && this.source.sortOrder !== CommentsOrder.NEWEST) {\r\n            this.sortOrderChanged.next(CommentsOrder.NEWEST);\r\n            return;\r\n        }\r\n\r\n        this.isViewingMore = false;\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    }\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        } else {\r\n            this.isLoadingMore = true;\r\n\r\n            let nextPageSize = 20;\r\n            let lastMessage: ChatMessage;\r\n\r\n            lastMessage = this.messages[this.messages.length - 1];\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            messages.forEach(m => m.transientState ??= {});\r\n\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\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\r\n        if (this.isViewingMore) {\r\n            destination = this.newMessages;\r\n            bucket = null;\r\n        }\r\n\r\n        let newestLast = this.newestLast;\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\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    avatarForUser(user: User) {\r\n        let url = this.genericAvatarUrl;\r\n\r\n        if (user && user.avatarUrl)\r\n            url = user.avatarUrl;\r\n\r\n        return `url(${url})`;\r\n    }\r\n}\r\n"]}
|
|
@@ -49,4 +49,4 @@ CommentsModule.decorators = [
|
|
|
49
49
|
exports: COMPONENTS
|
|
50
50
|
},] }
|
|
51
51
|
];
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbWVudHMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2RrL3NyYy9saWIvY29tbWVudHMvY29tbWVudHMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDL0QsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDN0UsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDbkYsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFDOUMsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDaEUsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUN2QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUM5RSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUNsRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzFELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQ2hGLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLDJCQUEyQixDQUFDO0FBQzNELE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLHVDQUF1QyxDQUFDO0FBQzNFLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUV6RCxNQUFNLFVBQVUsR0FBRztJQUNmLGdCQUFnQjtJQUNoQixvQkFBb0I7SUFDcEIsc0JBQXNCO0lBQ3RCLG9CQUFvQjtJQUNwQixxQkFBcUI7SUFDckIsb0JBQW9CO0NBQ3ZCLENBQUM7QUFxQkYsTUFBTSxPQUFPLGNBQWM7OztZQW5CMUIsUUFBUSxTQUFDO2dCQUNOLFlBQVksRUFBRSxVQUFVO2dCQUMxQixPQUFPLEVBQUU7b0JBQ1AsWUFBWTtvQkFDWixlQUFlO29CQUNmLFdBQVc7b0JBQ1gsYUFBYTtvQkFDYixrQkFBa0I7b0JBQ2xCLGNBQWM7b0JBQ2QsZUFBZTtvQkFDZixhQUFhO29CQUNiLHdCQUF3QjtvQkFDeEIsaUJBQWlCO29CQUNqQixXQUFXO29CQUNYLGdCQUFnQjtvQkFDaEIsZUFBZTtpQkFDaEI7Z0JBQ0MsT0FBTyxFQUFFLFVBQVU7YUFDdEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21tZW50Q29tcG9uZW50IH0gZnJvbSAnLi9jb21tZW50L2NvbW1lbnQuY29tcG9uZW50JztcclxuaW1wb3J0IHsgQ29tbWVudFZpZXdDb21wb25lbnQgfSBmcm9tICcuL2NvbW1lbnQtdmlldy9jb21tZW50LXZpZXcuY29tcG9uZW50JztcclxuaW1wb3J0IHsgQmFudGFDb21tZW50c0NvbXBvbmVudCB9IGZyb20gJy4vYmFudGEtY29tbWVudHMvYmFudGEtY29tbWVudHMuY29tcG9uZW50JztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IEJhbnRhQ29tbW9uTW9kdWxlIH0gZnJvbSAnLi4vY29tbW9uJztcclxuaW1wb3J0IHsgTGl2ZUNvbW1lbnRDb21wb25lbnQgfSBmcm9tICcuL2xpdmUtY29tbWVudC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBFbW9qaU1vZHVsZSB9IGZyb20gJy4uL2Vtb2ppJztcclxuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xyXG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xyXG5pbXBvcnQgeyBNYXRNZW51TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvbWVudSc7XHJcbmltcG9ydCB7IE1hdFByb2dyZXNzU3Bpbm5lck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3Byb2dyZXNzLXNwaW5uZXInO1xyXG5pbXBvcnQgeyBNYXRGb3JtRmllbGRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9mb3JtLWZpZWxkJztcclxuaW1wb3J0IHsgTWF0SW5wdXRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pbnB1dCc7XHJcbmltcG9ydCB7IFRleHRGaWVsZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay90ZXh0LWZpZWxkJztcclxuaW1wb3J0IHsgQ29tbWVudEZpZWxkQ29tcG9uZW50IH0gZnJvbSAnLi9jb21tZW50LWZpZWxkL2NvbW1lbnQtZmllbGQuY29tcG9uZW50JztcclxuaW1wb3J0IHtNYXRUb29sdGlwTW9kdWxlfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90b29sdGlwJztcclxuaW1wb3J0IHtDb21tZW50U29ydENvbXBvbmVudH0gZnJvbSBcIi4vY29tbWVudC1zb3J0L2NvbW1lbnQtc29ydC5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtNYXRTZWxlY3RNb2R1bGV9IGZyb20gXCJAYW5ndWxhci9tYXRlcmlhbC9zZWxlY3RcIjtcclxuXHJcbmNvbnN0IENPTVBPTkVOVFMgPSBbXHJcbiAgICBDb21tZW50Q29tcG9uZW50LFxyXG4gICAgQ29tbWVudFZpZXdDb21wb25lbnQsXHJcbiAgICBCYW50YUNvbW1lbnRzQ29tcG9uZW50LFxyXG4gICAgTGl2ZUNvbW1lbnRDb21wb25lbnQsXHJcbiAgICBDb21tZW50RmllbGRDb21wb25lbnQsXHJcbiAgICBDb21tZW50U29ydENvbXBvbmVudFxyXG5dO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICAgIGRlY2xhcmF0aW9uczogQ09NUE9ORU5UUyxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBUZXh0RmllbGRNb2R1bGUsXHJcbiAgICBGb3Jtc01vZHVsZSxcclxuICAgIE1hdEljb25Nb2R1bGUsXHJcbiAgICBNYXRGb3JtRmllbGRNb2R1bGUsXHJcbiAgICBNYXRJbnB1dE1vZHVsZSxcclxuICAgIE1hdEJ1dHRvbk1vZHVsZSxcclxuICAgIE1hdE1lbnVNb2R1bGUsXHJcbiAgICBNYXRQcm9ncmVzc1NwaW5uZXJNb2R1bGUsXHJcbiAgICBCYW50YUNvbW1vbk1vZHVsZSxcclxuICAgIEVtb2ppTW9kdWxlLFxyXG4gICAgTWF0VG9vbHRpcE1vZHVsZSxcclxuICAgIE1hdFNlbGVjdE1vZHVsZVxyXG4gIF0sXHJcbiAgICBleHBvcnRzOiBDT01QT05FTlRTXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDb21tZW50c01vZHVsZSB7XHJcbn1cclxuIl19
|
|
@@ -5,4 +5,4 @@ export * from './live-comment.component';
|
|
|
5
5
|
export * from './comment-field/comment-field.component';
|
|
6
6
|
export * from './comment-sort/comment-sort.component';
|
|
7
7
|
export * from './comments.module';
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zZGsvc3JjL2xpYi9jb21tZW50cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyx1Q0FBdUMsQ0FBQztBQUV0RCxjQUFjLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jb21tZW50L2NvbW1lbnQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9jb21tZW50LXZpZXcvY29tbWVudC12aWV3LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vYmFudGEtY29tbWVudHMvYmFudGEtY29tbWVudHMuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saXZlLWNvbW1lbnQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9jb21tZW50LWZpZWxkL2NvbW1lbnQtZmllbGQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9jb21tZW50LXNvcnQvY29tbWVudC1zb3J0LmNvbXBvbmVudCc7XHJcblxyXG5leHBvcnQgKiBmcm9tICcuL2NvbW1lbnRzLm1vZHVsZSc7Il19
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Component, Input, Output } from '@angular/core';
|
|
2
2
|
import { Subject, Observable } from 'rxjs';
|
|
3
|
-
import {
|
|
3
|
+
import { ChatBackendBase } from '../chat-backend-base';
|
|
4
4
|
export class LiveCommentComponent {
|
|
5
5
|
constructor(backend) {
|
|
6
6
|
this.backend = backend;
|
|
@@ -60,7 +60,7 @@ LiveCommentComponent.decorators = [
|
|
|
60
60
|
},] }
|
|
61
61
|
];
|
|
62
62
|
LiveCommentComponent.ctorParameters = () => [
|
|
63
|
-
{ type:
|
|
63
|
+
{ type: ChatBackendBase }
|
|
64
64
|
];
|
|
65
65
|
LiveCommentComponent.propDecorators = {
|
|
66
66
|
upvoted: [{ type: Output }],
|
|
@@ -68,4 +68,4 @@ LiveCommentComponent.propDecorators = {
|
|
|
68
68
|
selected: [{ type: Output }],
|
|
69
69
|
message: [{ type: Input }]
|
|
70
70
|
};
|
|
71
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
71
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGl2ZS1jb21tZW50LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Nkay9zcmMvbGliL2NvbW1lbnRzL2xpdmUtY29tbWVudC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpELE9BQU8sRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQWV2RCxNQUFNLE9BQU8sb0JBQW9CO0lBQzdCLFlBQ1ksT0FBeUI7UUFBekIsWUFBTyxHQUFQLE9BQU8sQ0FBa0I7UUFNN0IsYUFBUSxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFDL0IsY0FBUyxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFDaEMsY0FBUyxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7SUFMeEMsQ0FBQztJQU9ELElBQ0ksT0FBTztRQUNQLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQztJQUN6QixDQUFDO0lBRUQsSUFDSSxRQUFRO1FBQ1IsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQzFCLENBQUM7SUFFRCxJQUNJLFFBQVE7UUFDUixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDMUIsQ0FBQztJQUVELElBQ0ksT0FBTztRQUNQLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQztJQUN6QixDQUFDO0lBSUQsSUFBSSxPQUFPLENBQUMsS0FBSztRQUNiLElBQUksVUFBVSxHQUFHLElBQUksQ0FBQztRQUN0QixJQUFJLElBQUksQ0FBQyxRQUFRO1lBQ2IsVUFBVSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDO1FBRWxDLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDO1FBRXRCLElBQUksS0FBSyxJQUFJLFVBQVUsS0FBSyxLQUFLLENBQUMsRUFBRSxFQUFFO1lBQ2xDLE9BQU87U0FDVjtRQUVELElBQUksSUFBSSxDQUFDLFdBQVc7WUFDaEIsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBRXZCLElBQUksS0FBSyxFQUFFO1lBQ1AsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLFlBQVksQ0FBQyxLQUFLLEVBQUUsT0FBTyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQyxDQUFDO1NBQzFGO0lBQ0wsQ0FBQztJQUVELE1BQU07UUFDRixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzFCLENBQUM7SUFFRCxNQUFNO1FBQ0YsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUN6QixDQUFDO0lBRUQsTUFBTTtRQUNGLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDMUIsQ0FBQzs7O1lBNUVKLFNBQVMsU0FBQztnQkFDUCxRQUFRLEVBQUUsb0JBQW9CO2dCQUM5QixRQUFRLEVBQUU7Ozs7Ozs7O0tBUVQ7eUJBQ1EsRUFBRTthQUNkOzs7WUFkUSxlQUFlOzs7c0JBMkJuQixNQUFNO3VCQUtOLE1BQU07dUJBS04sTUFBTTtzQkFLTixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENoYXRNZXNzYWdlIH0gZnJvbSAnQGJhbnRhL2NvbW1vbic7XHJcbmltcG9ydCB7IFN1YmplY3QsIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgQ2hhdEJhY2tlbmRCYXNlIH0gZnJvbSAnLi4vY2hhdC1iYWNrZW5kLWJhc2UnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2JhbnRhLWxpdmUtY29tbWVudCcsXHJcbiAgICB0ZW1wbGF0ZTogYFxyXG4gICAgICAgIDxiYW50YS1jb21tZW50IFxyXG4gICAgICAgICAgICAqbmdJZj1cIm1lc3NhZ2VcIlxyXG4gICAgICAgICAgICBbbWVzc2FnZV09XCJtZXNzYWdlXCJcclxuICAgICAgICAgICAgKHVwdm90ZWQpPVwidXB2b3RlKClcIlxyXG4gICAgICAgICAgICAocmVwb3J0ZWQpPVwicmVwb3J0KClcIlxyXG4gICAgICAgICAgICAoc2VsZWN0ZWQpPVwic2VsZWN0KClcIlxyXG4gICAgICAgICAgICA+PC9iYW50YS1jb21tZW50PlxyXG4gICAgYCxcclxuICAgIHN0eWxlczogW2BgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgTGl2ZUNvbW1lbnRDb21wb25lbnQge1xyXG4gICAgY29uc3RydWN0b3IoXHJcbiAgICAgICAgcHJpdmF0ZSBiYWNrZW5kIDogQ2hhdEJhY2tlbmRCYXNlXHJcbiAgICApIHtcclxuXHJcbiAgICB9XHJcblxyXG4gICAgcHJpdmF0ZSBfbWVzc2FnZSA6IENoYXRNZXNzYWdlO1xyXG4gICAgcHJpdmF0ZSBfdXB2b3RlZCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XHJcbiAgICBwcml2YXRlIF9yZXBvcnRlZCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XHJcbiAgICBwcml2YXRlIF9zZWxlY3RlZCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XHJcblxyXG4gICAgQE91dHB1dCgpXHJcbiAgICBnZXQgdXB2b3RlZCgpIDogT2JzZXJ2YWJsZTx2b2lkPiB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuX3Vwdm90ZWQ7XHJcbiAgICB9XHJcbiAgICBcclxuICAgIEBPdXRwdXQoKVxyXG4gICAgZ2V0IHJlcG9ydGVkKCkgOiBPYnNlcnZhYmxlPHZvaWQ+IHtcclxuICAgICAgICByZXR1cm4gdGhpcy5fcmVwb3J0ZWQ7XHJcbiAgICB9XHJcblxyXG4gICAgQE91dHB1dCgpXHJcbiAgICBnZXQgc2VsZWN0ZWQoKSA6IE9ic2VydmFibGU8dm9pZD4ge1xyXG4gICAgICAgIHJldHVybiB0aGlzLl9zZWxlY3RlZDtcclxuICAgIH1cclxuICAgIFxyXG4gICAgQElucHV0KClcclxuICAgIGdldCBtZXNzYWdlKCkgOiBDaGF0TWVzc2FnZSB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuX21lc3NhZ2U7XHJcbiAgICB9XHJcblxyXG4gICAgcHJpdmF0ZSB1bnN1YnNjcmliZSA6IEZ1bmN0aW9uO1xyXG5cclxuICAgIHNldCBtZXNzYWdlKHZhbHVlKSB7XHJcbiAgICAgICAgbGV0IG9yaWdpbmFsSWQgPSBudWxsO1xyXG4gICAgICAgIGlmICh0aGlzLl9tZXNzYWdlKVxyXG4gICAgICAgICAgICBvcmlnaW5hbElkID0gdGhpcy5fbWVzc2FnZS5pZDtcclxuICAgICAgICBcclxuICAgICAgICB0aGlzLl9tZXNzYWdlID0gdmFsdWU7XHJcblxyXG4gICAgICAgIGlmICh2YWx1ZSAmJiBvcmlnaW5hbElkID09PSB2YWx1ZS5pZCkge1xyXG4gICAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgfVxyXG4gICAgICAgIFxyXG4gICAgICAgIGlmICh0aGlzLnVuc3Vic2NyaWJlKVxyXG4gICAgICAgICAgICB0aGlzLnVuc3Vic2NyaWJlKCk7XHJcbiAgICAgICAgXHJcbiAgICAgICAgaWYgKHZhbHVlKSB7XHJcbiAgICAgICAgICAgIHRoaXMudW5zdWJzY3JpYmUgPSB0aGlzLmJhY2tlbmQud2F0Y2hNZXNzYWdlKHZhbHVlLCBtZXNzYWdlID0+IHRoaXMubWVzc2FnZSA9IG1lc3NhZ2UpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICByZXBvcnQoKSB7XHJcbiAgICAgICAgdGhpcy5fcmVwb3J0ZWQubmV4dCgpO1xyXG4gICAgfVxyXG4gICAgXHJcbiAgICB1cHZvdGUoKSB7XHJcbiAgICAgICAgdGhpcy5fdXB2b3RlZC5uZXh0KCk7XHJcbiAgICB9XHJcblxyXG4gICAgc2VsZWN0KCkge1xyXG4gICAgICAgIHRoaXMuX3NlbGVjdGVkLm5leHQoKTtcclxuICAgIH1cclxufSJdfQ==
|
|
@@ -15,4 +15,4 @@ BantaCommonModule.decorators = [
|
|
|
15
15
|
exports: COMPONENTS
|
|
16
16
|
},] }
|
|
17
17
|
];
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Nkay9zcmMvbGliL2NvbW1vbi9jb21tb24ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDM0QsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRS9DLE1BQU0sVUFBVSxHQUFHO0lBQ2Ysa0JBQWtCO0NBQ3JCLENBQUM7QUFTRixNQUFNLE9BQU8saUJBQWlCOzs7WUFQN0IsUUFBUSxTQUFDO2dCQUNOLFlBQVksRUFBRSxVQUFVO2dCQUN4QixPQUFPLEVBQUU7b0JBQ0wsWUFBWTtpQkFDZjtnQkFDRCxPQUFPLEVBQUUsVUFBVTthQUN0QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFRpbWVzdGFtcENvbXBvbmVudCB9IGZyb20gJy4vdGltZXN0YW1wLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcblxyXG5jb25zdCBDT01QT05FTlRTID0gW1xyXG4gICAgVGltZXN0YW1wQ29tcG9uZW50XHJcbl07XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgZGVjbGFyYXRpb25zOiBDT01QT05FTlRTLFxyXG4gICAgaW1wb3J0czogW1xyXG4gICAgICAgIENvbW1vbk1vZHVsZVxyXG4gICAgXSxcclxuICAgIGV4cG9ydHM6IENPTVBPTkVOVFNcclxufSlcclxuZXhwb3J0IGNsYXNzIEJhbnRhQ29tbW9uTW9kdWxlIHtcclxufSJdfQ==
|
|
@@ -1,6 +1,4 @@
|
|
|
1
1
|
export * from './lazy-connection';
|
|
2
|
-
export * from './banta.service';
|
|
3
2
|
export * from './timestamp.component';
|
|
4
|
-
export * from './chat-backend.service';
|
|
5
3
|
export * from './common.module';
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9zZGsvc3JjL2xpYi9jb21tb24vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLHVCQUF1QixDQUFDO0FBRXRDLGNBQWMsaUJBQWlCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xhenktY29ubmVjdGlvbic7XHJcbmV4cG9ydCAqIGZyb20gJy4vdGltZXN0YW1wLmNvbXBvbmVudCc7XHJcblxyXG5leHBvcnQgKiBmcm9tICcuL2NvbW1vbi5tb2R1bGUnOyJdfQ==
|
|
@@ -12,4 +12,4 @@ export function lazyConnection(options) {
|
|
|
12
12
|
});
|
|
13
13
|
return obs.pipe(publish()).refCount();
|
|
14
14
|
}
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF6eS1jb25uZWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2RrL3NyYy9saWIvY29tbW9uL2xhenktY29ubmVjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsT0FBTyxFQUFFLFVBQVUsRUFBeUIsTUFBTSxNQUFNLENBQUM7QUFDbEUsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBT3pDLE1BQU0sVUFBVSxjQUFjLENBQUksT0FBa0M7SUFFaEUsSUFBSSxHQUFHLEdBQUcsSUFBSSxVQUFVLENBQUMsUUFBUSxDQUFDLEVBQUU7UUFDaEMsSUFBSSxPQUFPLEdBQUcsSUFBSSxPQUFPLEVBQUssQ0FBQztRQUMvQixJQUFJLFlBQVksR0FBRyxPQUFPLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBRS9DLE9BQU8sQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDdkIsT0FBTyxHQUFHLEVBQUU7WUFDUixZQUFZLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDM0IsT0FBTyxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ25CLENBQUMsQ0FBQztJQUNOLENBQUMsQ0FBQyxDQUFDO0lBRUgsT0FBa0MsR0FBRyxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBRSxDQUFDLFFBQVEsRUFBRSxDQUFDO0FBQ3RFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTdWJqZWN0LCBPYnNlcnZhYmxlLCBDb25uZWN0YWJsZU9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgcHVibGlzaCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgTGF6eUNvbm5lY3Rpb25PcHRpb25zPFQ+IHtcclxuICAgIHN0YXJ0IDogKHN1YmplY3QgOiBTdWJqZWN0PFQ+KSA9PiB2b2lkO1xyXG4gICAgc3RvcCA6ICgpID0+IHZvaWQ7XHJcbn1cclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBsYXp5Q29ubmVjdGlvbjxUPihvcHRpb25zIDogTGF6eUNvbm5lY3Rpb25PcHRpb25zPFQ+KTogT2JzZXJ2YWJsZTxUPiB7XHJcblxyXG4gICAgbGV0IG9icyA9IG5ldyBPYnNlcnZhYmxlKG9ic2VydmVyID0+IHtcclxuICAgICAgICBsZXQgc3ViamVjdCA9IG5ldyBTdWJqZWN0PFQ+KCk7XHJcbiAgICAgICAgbGV0IHN1YnNjcmlwdGlvbiA9IHN1YmplY3Quc3Vic2NyaWJlKG9ic2VydmVyKTtcclxuXHJcbiAgICAgICAgb3B0aW9ucy5zdGFydChzdWJqZWN0KTtcclxuICAgICAgICByZXR1cm4gKCkgPT4ge1xyXG4gICAgICAgICAgICBzdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKTtcclxuICAgICAgICAgICAgb3B0aW9ucy5zdG9wKCk7XHJcbiAgICAgICAgfTtcclxuICAgIH0pO1xyXG4gICAgXHJcbiAgICByZXR1cm4gKDxDb25uZWN0YWJsZU9ic2VydmFibGU8VD4+b2JzLnBpcGUocHVibGlzaCgpKSkucmVmQ291bnQoKTtcclxufSJdfQ==
|
|
@@ -103,4 +103,4 @@ TimestampComponent.decorators = [
|
|
|
103
103
|
TimestampComponent.propDecorators = {
|
|
104
104
|
value: [{ type: Input }]
|
|
105
105
|
};
|
|
106
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
106
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timestamp.component.js","sourceRoot":"","sources":["../../../../../projects/sdk/src/lib/common/timestamp.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from \"@angular/core\";\r\n\r\n@Component({\r\n    selector: 'banta-timestamp',\r\n    template: `\r\n        <span *ngIf=\"showAbsolute\" [title]=\"value | date : 'short'\">\r\n            {{value | date : 'shortDate'}}\r\n        </span>\r\n        <span *ngIf=\"!showAbsolute\" [title]=\"value | date : 'short'\">\r\n            {{relative}}\r\n        </span>\r\n    `,\r\n    styles: [``]\r\n})\r\nexport class TimestampComponent {\r\n    private _value : number;\r\n    relative = '';\r\n    tooltip = '';\r\n\r\n    private updateInterval = null;\r\n\r\n    ngOnDestroy() {\r\n        if (this.updateInterval)\r\n            clearInterval(this.updateInterval);\r\n    }\r\n\r\n    @Input()\r\n    get value() {\r\n        return this._value;\r\n    }\r\n\r\n    showAbsolute = false;\r\n\r\n    update() {\r\n        \r\n        let now = Date.now();\r\n        let diff = now - this.value;\r\n        let minute = 1000*60;\r\n        let hour = minute * 60;\r\n        let day = hour * 24;\r\n        let week = day * 7;\r\n        let month = day * 30;\r\n        let year = day * 365;\r\n        this.showAbsolute = false;\r\n        let updateTime = 0;\r\n\r\n        if (diff > year) {\r\n            this.showAbsolute = true;\r\n            this.relative = 'abs';\r\n            return;\r\n        }\r\n\r\n        if (diff > month) {\r\n            let months = Math.floor(diff / month);\r\n\r\n            if (months === 1)\r\n                this.relative = `${months} month ago`;\r\n            else\r\n                this.relative = `${months} months ago`;\r\n            \r\n        } else if (diff > week) {\r\n            let weeks = Math.floor(diff / week);\r\n\r\n            if (weeks === 1)\r\n                this.relative = `${weeks} week ago`;\r\n            else\r\n                this.relative = `${weeks} weeks ago`;\r\n        } else if (diff > day) {\r\n            let days = Math.floor(diff / day);\r\n            if (days === 1)\r\n                this.relative = `${days} day ago`;\r\n            else\r\n                this.relative = `${days} days ago`;\r\n        } else if (diff > hour) {\r\n            let hours = Math.floor(diff / hour);\r\n            if (hours === 1)\r\n                this.relative = `${hours} hour ago`;\r\n            else\r\n                this.relative = `${hours} hours ago`;\r\n            \r\n            updateTime = 1000 * 60 * 30;\r\n        } else if (diff > minute) {\r\n            let minutes = Math.floor(diff / minute);\r\n            if (minutes === 1)\r\n                this.relative = `${minutes} minute ago`;\r\n            else\r\n                this.relative = `${minutes} minutes ago`;\r\n            updateTime = 1000 * 45;\r\n        } else if (diff > 30_000) {\r\n            this.relative = `about a minute ago`;\r\n            updateTime = 1000 * 60;\r\n        } else {\r\n            this.relative = `just now`;\r\n            updateTime = 1000 * 30;\r\n        }\r\n        \r\n        if (typeof window !== 'undefined') {\r\n            clearInterval(this.updateInterval);\r\n            if (updateTime > 0) {\r\n                this.updateInterval = setInterval(() => this.update());\r\n            }\r\n        }\r\n    }\r\n\r\n    set value(v) {\r\n        this._value = v;\r\n        this.update();\r\n    }\r\n}"]}
|
|
@@ -126,4 +126,4 @@ EmojiSelectorButtonComponent.propDecorators = {
|
|
|
126
126
|
panelElement: [{ type: ViewChild, args: ['panel', { read: ElementRef },] }],
|
|
127
127
|
buttonElement: [{ type: ViewChild, args: ['button', { read: ElementRef },] }]
|
|
128
128
|
};
|
|
129
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
129
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"emoji-selector-button.component.js","sourceRoot":"","sources":["../../../../../projects/sdk/src/lib/emoji/emoji-selector-button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Output, ViewChild } from '@angular/core';\r\nimport { Subject, Observable } from 'rxjs';\r\n\r\n@Component({\r\n    selector: 'emoji-selector-button',\r\n    template: `\r\n        <button #button type=\"button\" mat-icon-button (click)=\"show()\">\r\n            <mat-icon>emoji_emotions</mat-icon>\r\n        </button>\r\n        <emoji-selector-panel \r\n            #panel\r\n            (selected)=\"insert($event)\"\r\n            [class.visible]=\"showEmojiPanel\"\r\n            ></emoji-selector-panel>\r\n    `,\r\n    styles: [`\r\n        :host {\r\n            display: block;\r\n            position: relative;\r\n        }\r\n\r\n        emoji-selector-panel {\r\n            position: absolute;\r\n            /* bottom: 2.5em;\r\n            right: 0; */\r\n            opacity: 0;\r\n            pointer-events: none;\r\n            z-index: 10;\r\n        }\r\n\r\n        emoji-selector-panel.visible {\r\n            pointer-events: initial;\r\n            opacity: 1;\r\n        }\r\n\r\n        button {\r\n            color: #666\r\n        }\r\n\r\n        /* :host.bottom-left emoji-selector-panel {\r\n            right: auto;\r\n            left: 0;\r\n        }\r\n\r\n        :host.top-right emoji-selector-panel {\r\n            top: 2.4em;\r\n            bottom: auto;\r\n        }\r\n\r\n        :host.top-left emoji-selector-panel {\r\n            top: 2.4em;\r\n            bottom: auto;\r\n            left: 0;\r\n            right: auto;\r\n        } */\r\n    `]\r\n})\r\nexport class EmojiSelectorButtonComponent {\r\n\r\n    private _selected = new Subject<string>();\r\n    private clickListener : any;\r\n    private resizeListener : any;\r\n    showEmojiPanel = false;\r\n\r\n    @Output()\r\n    get selected() : Observable<string> {\r\n        return this._selected;\r\n    }\r\n\r\n    @ViewChild('panel', { read: ElementRef })\r\n    panelElement : ElementRef<HTMLElement>;\r\n\r\n    @ViewChild('button', { read: ElementRef })\r\n    buttonElement : ElementRef<HTMLElement>;\r\n\r\n    ngOnDestroy() {\r\n        this.removeListener();\r\n        this.panelElement.nativeElement.remove();\r\n    }\r\n\r\n    ngAfterViewInit() {\r\n        let root = document.body.querySelector('[ng-version]') || document.body;\r\n        root.appendChild(this.panelElement.nativeElement);\r\n    }\r\n\r\n    private removeListener() {\r\n        document.removeEventListener('click', this.clickListener);\r\n        window.removeEventListener('resize', this.resizeListener);\r\n    }\r\n\r\n    place() {\r\n        let pos = this.buttonElement.nativeElement.getBoundingClientRect();\r\n        let size = this.panelElement.nativeElement.getBoundingClientRect();\r\n        let left = window.scrollX + pos.left + pos.width - size.width;\r\n        if (left < 0)\r\n            left = (window.scrollX + window.innerWidth) / 2 - size.width / 2;\r\n\r\n        Object.assign(\r\n            this.panelElement.nativeElement.style,\r\n            {\r\n                top: `${window.scrollY + pos.top + pos.height}px`,\r\n                left: `${Math.max(0, left)}px`\r\n            }\r\n        );\r\n    }\r\n\r\n    show() {\r\n        if (this.showEmojiPanel) {\r\n            this.showEmojiPanel = false;\r\n            return;\r\n        }\r\n\r\n        this.showEmojiPanel = true;\r\n        this.place();\r\n\r\n        setTimeout(() => {\r\n            this.resizeListener = () => {\r\n                if (!this.showEmojiPanel)\r\n                    return;\r\n                this.place();\r\n            };\r\n\r\n            this.clickListener = (ev : MouseEvent) => {\r\n\r\n                let parent = <HTMLElement> ev.target;\r\n                let isInDialog = false;\r\n                \r\n                while (parent) {\r\n                    if (parent.matches('emoji-selector-panel'))\r\n                        isInDialog = true;\r\n\r\n                    parent = parent.parentElement;\r\n                }\r\n\r\n                if (isInDialog)\r\n                    return;\r\n\r\n                this.showEmojiPanel = false;\r\n                this.removeListener();\r\n            };\r\n    \r\n            document.addEventListener('click', this.clickListener);\r\n            window.addEventListener('resize', this.resizeListener);\r\n        });\r\n    }\r\n\r\n    insert(str) {\r\n        this._selected.next(str);\r\n    }\r\n}"]}
|
|
@@ -74,7 +74,7 @@ EmojiSelectorPanelComponent.decorators = [
|
|
|
74
74
|
{ type: Component, args: [{
|
|
75
75
|
selector: 'emoji-selector-panel',
|
|
76
76
|
template: "<div class=\"search-box\" *ngIf=\"searchVisible\">\r\n\t<a mat-icon-button href=\"javascript:;\" (click)=\"hideSearch()\">\r\n\t\t<mat-icon>arrow_back</mat-icon>\r\n\t</a>\r\n\t<mat-form-field appearance=\"outline\" floatLabel=\"always\">\r\n\t\t<mat-label>Search for emoji</mat-label>\r\n\t\t<input name=\"search\" type=\"text\" matInput placeholder=\"Start typing\" [(ngModel)]=\"searchQuery\" />\r\n\t</mat-form-field>\r\n</div>\r\n\r\n<div class=\"selector\">\r\n\t<ng-container *ngIf=\"searchVisible\">\r\n\t\t<div class=\"emoji-list\">\r\n\t\t\t<a href=\"javascript:;\" (click)=\"select(emoji.char)\" \r\n\t\t\t\t*ngFor=\"let emoji of searchResults\" [innerHtml]=\"emoji.html || ''\">\r\n\t\t\t</a>\r\n\t\t</div>\r\n\t</ng-container>\r\n\t<ng-container *ngIf=\"!searchVisible\">\r\n\t\t<div class=\"categories\">\r\n\t\t\t<ng-container *ngIf=\"!searchVisible\">\r\n\t\t\t\t<a [title]=\"humanize(category.name)\" [class.active]=\"activeCategory === category.name\" mat-icon-button *ngFor=\"let category of categories\" (click)=\"activeCategory = category.name\">\r\n\t\t\t\t\t<mat-icon>{{category.icon}}</mat-icon>\r\n\t\t\t\t</a>\r\n\r\n\t\t\t\t<a title=\"Search\" [class.active] mat-icon-button (click)=\"showSearch()\">\r\n\t\t\t\t\t<mat-icon>search</mat-icon>\r\n\t\t\t\t</a>\r\n\t\t\t</ng-container>\r\n\t\t</div>\r\n\t\t<ng-container *ngFor=\"let category of categories\">\r\n\t\t\t<div class=\"emoji-list\" *ngIf=\"activeCategory && activeCategory == category.name\">\r\n\t\t\t\t<a href=\"javascript:;\" (click)=\"select(emoji.char)\" \r\n\t\t\t\t\t*ngFor=\"let emoji of category.emojis\" [innerHtml]=\"emoji.html || ''\">\r\n\t\t\t\t</a>\r\n\t\t\t</div>\r\n\t\t</ng-container>\r\n\t</ng-container>\r\n</div>",
|
|
77
|
-
styles: [":host{background:#111;border:1px solid #333;border-radius:5px;
|
|
77
|
+
styles: [":host{background:#111;color:#fff;border:1px solid #333;border-radius:5px;padding:.5em;width:calc(9*(32px + 1em));max-width:calc(100vw - 1.5em)}.selector{display:flex;flex-direction:column}.categories a{opacity:.25;transition:opacity .4s ease-in-out}.categories a:hover{opacity:.5}.categories a.active{opacity:1}.emoji-list{flex-grow:1;overflow-y:auto;height:20em}.emoji-list a{display:inline-block;padding:2px;margin:4px;background-color:#111}.emoji-list a ::ng-deep .emoji{width:32px;height:32px}.emoji-list a:hover{background-color:#333}.search-box{display:flex;align-items:baseline}.search-box mat-form-field{flex-grow:1}@media (max-width:500px){.selector{flex-direction:row;height:27em}.emoji-list{height:auto}}"]
|
|
78
78
|
},] }
|
|
79
79
|
];
|
|
80
80
|
EmojiSelectorPanelComponent.ctorParameters = () => [
|
|
@@ -83,4 +83,4 @@ EmojiSelectorPanelComponent.ctorParameters = () => [
|
|
|
83
83
|
EmojiSelectorPanelComponent.propDecorators = {
|
|
84
84
|
selected: [{ type: Output }]
|
|
85
85
|
};
|
|
86
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1vamktc2VsZWN0b3ItcGFuZWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2RrL3NyYy9saWIvZW1vamkvZW1vamktc2VsZWN0b3ItcGFuZWwvZW1vamktc2VsZWN0b3ItcGFuZWwuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBLE9BQU8sRUFBRSxTQUFTLEVBQVUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFELE9BQU8sRUFBRSxZQUFZLEVBQVksTUFBTSwyQkFBMkIsQ0FBQztBQUNuRSxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBUy9CLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFPbkMsTUFBTSxPQUFPLDJCQUEyQjtJQUV2QyxZQUNTLFNBQXdCO1FBQXhCLGNBQVMsR0FBVCxTQUFTLENBQWU7UUFJakMsbUJBQWMsR0FBWSxRQUFRLENBQUM7UUFDbkMsa0JBQWEsR0FBVyxFQUFFLENBQUM7UUFDeEIsa0JBQWEsR0FBRyxLQUFLLENBQUM7UUFHakIsYUFBUSxHQUFxQixJQUFJLE9BQU8sRUFBRSxDQUFDO0lBUi9DLENBQUM7SUFZTCxJQUFJLFdBQVc7UUFDZCxPQUFPLElBQUksQ0FBQyxZQUFZLENBQUM7SUFDMUIsQ0FBQztJQUVELElBQUksV0FBVyxDQUFDLEtBQUs7UUFDcEIsSUFBSSxDQUFDLFlBQVksR0FBRyxLQUFLLENBQUM7UUFDMUIsVUFBVSxDQUFDLEdBQUcsRUFBRTtZQUNmLElBQUksQ0FBQyxhQUFhLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FB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UUFBUSxFQUFFLHNCQUFzQjtnQkFDaEMsb3NEQUFvRDs7YUFFcEQ7OztZQWhCUSxZQUFZOzs7dUJBNEJuQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiZGVjbGFyZSB2YXIgdHdlbW9qaToge1xyXG4gICAgcGFyc2Uoc3RyOiBzdHJpbmcsIG9wdGlvbnM/OiB7IGZvbGRlcjogc3RyaW5nLCBleHQ6IHN0cmluZyB9KTogc3RyaW5nO1xyXG59XHJcblxyXG5pbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IERvbVNhbml0aXplciwgU2FmZUh0bWwgfSBmcm9tICdAYW5ndWxhci9wbGF0Zm9ybS1icm93c2VyJztcclxuaW1wb3J0IHsgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xyXG5cclxuaW50ZXJmYWNlIEVtb2ppIHtcclxuXHRrZXl3b3JkcyA6IHN0cmluZ1tdO1xyXG5cdGNoYXIgOiBzdHJpbmc7XHJcblx0aHRtbD8gOiBTYWZlSHRtbDtcclxuXHRjYXRlZ29yeSA6IHN0cmluZztcclxufVxyXG5cclxuaW1wb3J0IHsgRU1PSklTIH0gZnJvbSAnLi4vZW1vamlzJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG5cdHNlbGVjdG9yOiAnZW1vamktc2VsZWN0b3ItcGFuZWwnLFxyXG5cdHRlbXBsYXRlVXJsOiAnLi9lbW9qaS1zZWxlY3Rvci1wYW5lbC5jb21wb25lbnQuaHRtbCcsXHJcblx0c3R5bGVVcmxzOiBbJy4vZW1vamktc2VsZWN0b3ItcGFuZWwuY29tcG9uZW50LnNjc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgRW1vamlTZWxlY3RvclBhbmVsQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcclxuXHJcblx0Y29uc3RydWN0b3IoXHJcblx0XHRwcml2YXRlIHNhbml0aXplciA6IERvbVNhbml0aXplclxyXG5cdCkgeyB9XHJcblxyXG5cdGNhdGVnb3JpZXMgOiBhbnlbXTtcclxuXHRhY3RpdmVDYXRlZ29yeSA6IHN0cmluZyA9ICdwZW9wbGUnO1xyXG5cdHNlYXJjaFJlc3VsdHMgOiBhbnlbXSA9IFtdO1xyXG4gICAgc2VhcmNoVmlzaWJsZSA9IGZhbHNlO1xyXG5cdFxyXG5cdEBPdXRwdXQoKVxyXG5cdHByaXZhdGUgc2VsZWN0ZWQgOiBTdWJqZWN0PHN0cmluZz4gPSBuZXcgU3ViamVjdCgpO1xyXG5cclxuXHRwcml2YXRlIF9zZWFyY2hRdWVyeSA6IHN0cmluZztcclxuXHJcblx0Z2V0IHNlYXJjaFF1ZXJ5KCkge1xyXG5cdFx0cmV0dXJuIHRoaXMuX3NlYXJjaFF1ZXJ5O1xyXG5cdH1cclxuXHJcblx0c2V0IHNlYXJjaFF1ZXJ5KHZhbHVlKSB7XHJcblx0XHR0aGlzLl9zZWFyY2hRdWVyeSA9IHZhbHVlO1xyXG5cdFx0c2V0VGltZW91dCgoKSA9PiB7XHJcblx0XHRcdHRoaXMuc2VhcmNoUmVzdWx0cyA9IE9iamVjdC5rZXlzKEVNT0pJUykuZmlsdGVyKGsgPT4gay5pbmNsdWRlcyh2YWx1ZSkpLm1hcChrID0+IEVNT0pJU1trXSk7XHJcblx0XHRcdHRoaXMuc2VhcmNoUmVzdWx0cy5zcGxpY2UoNTAsIHRoaXMuc2VhcmNoUmVzdWx0cy5sZW5ndGgpO1xyXG5cdFx0XHRjb25zb2xlLmxvZyhgbG9va2luZyBmb3IgJyR7dmFsdWV9JyA9PiAke3RoaXMuc2VhcmNoUmVzdWx0cy5sZW5ndGh9IHJlc3VsdHNgKTtcclxuXHRcdH0pO1xyXG5cdH1cclxuXHJcblx0aHVtYW5pemUoc3RyIDogc3RyaW5nKSB7XHJcblx0XHRyZXR1cm4gc3RyLnJlcGxhY2UoLyhefCApW2Etel0vZywgayA9PiBrLnRvVXBwZXJDYXNlKCkpLnJlcGxhY2UoL18vZywgJyAnKTtcclxuXHR9XHJcblxyXG5cdHNlbGVjdChjaGFyIDogc3RyaW5nKSB7XHJcblx0XHR0aGlzLnNlbGVjdGVkLm5leHQoY2hhcik7XHJcblx0fVxyXG5cclxuXHRwYWlycyhvYmplY3QpIHtcclxuXHRcdHJldHVybiBPYmplY3Qua2V5cyhvYmplY3QpLm1hcChrZXkgPT4gW2tleSwgb2JqZWN0W2tleV1dKTtcclxuXHR9XHJcblxyXG5cdGhpZGVTZWFyY2goKSB7XHJcblx0XHQvLyBiZWNhdXNlIG9mIHRoZSBcIm91dHNpZGUgY2xpY2sgZGV0ZWN0aW9uXCJcclxuICAgICAgICBzZXRUaW1lb3V0KCgpID0+IHtcclxuICAgICAgICAgICAgdGhpcy5zZWFyY2hWaXNpYmxlID0gZmFsc2U7XHJcbiAgICAgICAgfSk7XHJcblx0fVxyXG5cdFxyXG4gICAgc2hvd1NlYXJjaCgpIHtcclxuXHRcdC8vIGJlY2F1c2Ugb2YgdGhlIFwib3V0c2lkZSBjbGljayBkZXRlY3Rpb25cIlxyXG4gICAgICAgIHNldFRpbWVvdXQoKCkgPT4ge1xyXG4gICAgICAgICAgICB0aGlzLnNlYXJjaFZpc2libGUgPSB0cnVlO1xyXG4gICAgICAgIH0pO1xyXG4gICAgfVxyXG5cclxuXHRuZ09uSW5pdCgpIHtcclxuXHJcblx0XHRsZXQgY2F0cyA9IHt9O1xyXG5cdFx0bGV0IGNhdGVnb3J5SWNvbnMgPSB7XHJcblx0XHRcdHN5bWJvbHM6ICd3YXJuaW5nJyxcclxuXHRcdFx0cGVvcGxlOiAncGVvcGxlJyxcclxuXHRcdFx0YW5pbWFsc19hbmRfbmF0dXJlOiAnbmF0dXJlJyxcclxuXHRcdFx0dHJhdmVsX2FuZF9wbGFjZXM6ICdsb2NhdGlvbl9vbicsXHJcblx0XHRcdGFjdGl2aXR5OiAnbG9jYWxfYWN0aXZpdHknLFxyXG5cdFx0XHRmb29kX2FuZF9kcmluazogJ3Jlc3RhdXJhbnQnLFxyXG5cdFx0XHRvYmplY3RzOiAnY29tcHV0ZXInLFxyXG5cdFx0XHRmbGFnczogJ2ZsYWcnXHJcblx0XHR9O1xyXG5cdFx0Zm9yIChsZXQgcGFpciBvZiB0aGlzLnBhaXJzKEVNT0pJUykpIHtcclxuXHRcdFx0bGV0IG5hbWUgPSBwYWlyWzBdO1xyXG5cdFx0XHRsZXQgZW1vamkgOiBFbW9qaSA9IHBhaXJbMV07XHJcblxyXG5cdFx0XHRpZiAoIWNhdHNbZW1vamkuY2F0ZWdvcnldKSB7XHJcblx0XHRcdFx0Y2F0c1tlbW9qaS5jYXRlZ29yeV0gPSB7XHJcblx0XHRcdFx0XHRuYW1lOiBlbW9qaS5jYXRlZ29yeSxcclxuXHRcdFx0XHRcdGljb246IGNhdGVnb3J5SWNvbnNbZW1vamkuY2F0ZWdvcnldIHx8ICdjb2RlJyxcclxuXHRcdFx0XHRcdGVtb2ppczogW11cclxuXHRcdFx0XHR9XHJcblx0XHRcdH1cclxuXHJcblx0XHRcdGVtb2ppLmh0bWwgPSB0aGlzLnNhbml0aXplci5ieXBhc3NTZWN1cml0eVRydXN0SHRtbCh0d2Vtb2ppLnBhcnNlKGVtb2ppLmNoYXIgfHwgJycpKTtcclxuXHJcblx0XHRcdGNhdHNbZW1vamkuY2F0ZWdvcnldLmVtb2ppcy5wdXNoKGVtb2ppKTtcclxuXHRcdH1cclxuXHJcblx0XHR0aGlzLmNhdGVnb3JpZXMgPSB0aGlzLnBhaXJzKGNhdHMpLm1hcChwYWlyID0+IHBhaXJbMV0pO1xyXG5cdH1cclxuXHJcbn1cclxuIl19
|