@banta/sdk 3.0.1 → 3.1.2
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/bundles/banta-sdk.umd.js +501 -46
- 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/lib/banta/banta.component.js +2 -4
- package/esm2015/lib/chat/banta-chat/banta-chat.component.js +5 -1
- package/esm2015/lib/comments/banta-comments/banta-comments.component.js +106 -22
- package/esm2015/lib/comments/comment/comment.component.js +24 -5
- package/esm2015/lib/comments/comment-field/comment-field.component.js +235 -0
- package/esm2015/lib/comments/comment-view/comment-view.component.js +4 -4
- package/esm2015/lib/comments/comments.module.js +4 -2
- package/esm2015/lib/comments/index.js +2 -1
- package/esm2015/lib/emoji/emoji-selector-button.component.js +22 -8
- package/esm2015/lib/emoji/emoji-selector-panel/emoji-selector-panel.component.js +31 -3
- package/esm2015/lib/emoji/emoji.module.js +8 -2
- package/fesm2015/banta-sdk.js +426 -44
- package/fesm2015/banta-sdk.js.map +1 -1
- package/lib/comments/banta-comments/banta-comments.component.d.ts +25 -4
- package/lib/comments/comment/comment.component.d.ts +4 -0
- package/lib/comments/comment-field/comment-field.component.d.ts +51 -0
- package/lib/comments/comment-view/comment-view.component.d.ts +1 -1
- package/lib/comments/index.d.ts +1 -0
- package/lib/emoji/emoji-selector-button.component.d.ts +4 -0
- package/lib/emoji/emoji-selector-panel/emoji-selector-panel.component.d.ts +8 -0
- package/package.json +1 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, Output, Input } from "@angular/core";
|
|
1
|
+
import { Component, Output, Input, HostBinding } from "@angular/core";
|
|
2
2
|
import { Subject } from 'rxjs';
|
|
3
3
|
export class CommentComponent {
|
|
4
4
|
constructor() {
|
|
@@ -6,8 +6,20 @@ export class CommentComponent {
|
|
|
6
6
|
this._selected = new Subject();
|
|
7
7
|
this._upvoted = new Subject();
|
|
8
8
|
this._userSelected = new Subject();
|
|
9
|
+
this.isNew = false;
|
|
10
|
+
this.visible = false;
|
|
9
11
|
this.showReplyAction = true;
|
|
10
12
|
}
|
|
13
|
+
ngOnInit() {
|
|
14
|
+
let maxTime = 500;
|
|
15
|
+
let minTime = 0;
|
|
16
|
+
let randomTime = minTime + Math.random() * (maxTime - minTime);
|
|
17
|
+
setTimeout(() => {
|
|
18
|
+
this.isNew = true;
|
|
19
|
+
this.visible = true;
|
|
20
|
+
setTimeout(() => this.isNew = false, 1000);
|
|
21
|
+
}, randomTime);
|
|
22
|
+
}
|
|
11
23
|
get userSelected() {
|
|
12
24
|
return this._userSelected;
|
|
13
25
|
}
|
|
@@ -20,6 +32,10 @@ export class CommentComponent {
|
|
|
20
32
|
get selected() {
|
|
21
33
|
return this._selected;
|
|
22
34
|
}
|
|
35
|
+
get commentId() {
|
|
36
|
+
var _a;
|
|
37
|
+
return (_a = this.message) === null || _a === void 0 ? void 0 : _a.id;
|
|
38
|
+
}
|
|
23
39
|
report() {
|
|
24
40
|
this._reported.next();
|
|
25
41
|
}
|
|
@@ -43,16 +59,19 @@ export class CommentComponent {
|
|
|
43
59
|
CommentComponent.decorators = [
|
|
44
60
|
{ type: Component, args: [{
|
|
45
61
|
selector: 'banta-comment',
|
|
46
|
-
template: "\r\n<mat-menu #pointItemMenu=\"matMenu\">\r\n <button mat-menu-item (click)=\"report()\">Report</button>\r\n <button mat-menu-item>Help</button>\r\n</mat-menu>\r\n\r\n<div class=\"message-content\">\r\n <div class=\"user\">\r\n <
|
|
47
|
-
styles: [":host{display:flex;flex-direction:column;padding:.5em;position:relative}:host:hover{background:#eee}:host .message-content .content{margin-left:4em;margin-right:3em}:host.abbreviated .message-content .content{max-height:8.5em;overflow-y:hidden;text-overflow:ellipsis}:host .actions{align-items:center;display:flex;margin-left:4em;padding-right:10px}:host .actions button{color:#666}:host .actions banta-timestamp{color:#666;font-size:10pt}.user{align-items:center;display:flex;margin:1em 0 0;position:relative}.user
|
|
62
|
+
template: "\r\n<mat-menu #pointItemMenu=\"matMenu\">\r\n <button mat-menu-item (click)=\"report()\">Report</button>\r\n <button mat-menu-item>Help</button>\r\n</mat-menu>\r\n\r\n<div class=\"message-content\">\r\n <div class=\"user\">\r\n <a \r\n href=\"javascript:;\"\r\n class=\"avatar\"\r\n (click)=\"selectUser()\"\r\n [style.background-image]=\"avatarForUser(message.user)\"></a>\r\n <a href=\"javascript:;\" class=\"display-name\" (click)=\"selectUser()\">{{message.user.displayName}}</a>\r\n <a href=\"javascript:;\" class=\"username\" (click)=\"selectUser()\">@{{message.user.username}}</a>\r\n\r\n <button mat-icon-button [matMenuTriggerFor]=\"pointItemMenu\">\r\n <mat-icon [inline]=\"true\">more_vert</mat-icon>\r\n </button>\r\n </div>\r\n <div class=\"content\">\r\n {{message.message}}\r\n </div>\r\n \r\n <div class=\"actions\">\r\n <banta-timestamp [value]=\"message.sentAt\"></banta-timestamp>\r\n <div class=\"spacer\"></div>\r\n <div class=\"counted-action\" *ngIf=\"showReplyAction\">\r\n <div class=\"count-indicator\">\r\n {{message.submessages?.length || 0}}\r\n </div>\r\n <button mat-icon-button matTooltip=\"Comment\" matTooltipPosition=\"below\" (click)=\"select()\">\r\n <mat-icon [inline]=\"true\">comment</mat-icon>\r\n </button>\r\n </div>\r\n <div class=\"counted-action\">\r\n <div class=\"count-indicator\"> \r\n {{message.upvotes}}\r\n </div>\r\n <button mat-icon-button matTooltip=\"Upvote\" matTooltipPosition=\"below\" (click)=\"upvote()\">\r\n <mat-icon [inline]=\"true\">thumb_up</mat-icon>\r\n </button>\r\n </div>\r\n </div>\r\n</div>\r\n",
|
|
63
|
+
styles: ["@-webkit-keyframes comment-appear{0%{transform:translate(100vw)}to{transform:translate(0)}}@keyframes comment-appear{0%{transform:translate(100vw)}to{transform:translate(0)}}:host{display:flex;flex-direction:column;padding:.5em;position:relative;visibility:hidden}:host.new{-webkit-animation-duration:.4s;-webkit-animation-fill-mode:both;-webkit-animation-name:comment-appear;animation-duration:.4s;animation-fill-mode:both;animation-name:comment-appear}:host.new,:host.visible{visibility:visible}:host:hover{background:#eee}:host .message-content .content{margin-left:4em;margin-right:3em}:host.abbreviated .message-content .content{max-height:8.5em;overflow-y:hidden;text-overflow:ellipsis}:host .actions{align-items:center;display:flex;margin-left:4em;padding-right:10px}:host .actions button{color:#666}:host .actions banta-timestamp{color:#666;font-size:10pt}.user{align-items:center;display:flex;margin:1em 0 0;position:relative}.user .display-name,.user .username{color:#000;display:block;flex-grow:0;flex-shrink:1;font-size:10pt;margin:0 auto 0 0;max-width:100%;overflow:hidden;padding:0 0 0 1em;position:relative;text-overflow:ellipsis;white-space:nowrap;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content;z-index:1}.user .display-name.username,.user .username.username{color:#666;flex-grow:1;flex-shrink:0}.avatar{background-color:#333;background-position:50%;background-size:cover;border-radius:100%;flex-grow:0;flex-shrink:0;height:3em;width:3em}.counted-action{align-items:center;display:flex}.count-indicator{border:1px solid #ccc;border-radius:3px;color:#666;font-size:9pt;padding:0 3px}:host-context(.mat-dark-theme) .count-indicator{border-color:#333}:host-context(.mat-dark-theme):hover{background:#060606}:host-context(.mat-dark-theme) .user .display-name,:host-context(.mat-dark-theme) .user .username{color:#fff}"]
|
|
48
64
|
},] }
|
|
49
65
|
];
|
|
50
66
|
CommentComponent.propDecorators = {
|
|
67
|
+
isNew: [{ type: HostBinding, args: ['class.new',] }],
|
|
68
|
+
visible: [{ type: HostBinding, args: ['class.visible',] }],
|
|
51
69
|
message: [{ type: Input }],
|
|
52
70
|
showReplyAction: [{ type: Input }],
|
|
53
71
|
userSelected: [{ type: Output }],
|
|
54
72
|
reported: [{ type: Output }],
|
|
55
73
|
upvoted: [{ type: Output }],
|
|
56
|
-
selected: [{ type: Output }]
|
|
74
|
+
selected: [{ type: Output }],
|
|
75
|
+
commentId: [{ type: HostBinding, args: ['attr.data-comment-id',] }]
|
|
57
76
|
};
|
|
58
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
77
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbWVudC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiRDovRGV2L2FzdHJvbmF1dGxhYnMvYmFudGEvcGFja2FnZXMvZnJvbnRlbmQvcHJvamVjdHMvc2RrL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9jb21tZW50cy9jb21tZW50L2NvbW1lbnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdEUsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQVEvQixNQUFNLE9BQU8sZ0JBQWdCO0lBTDdCO1FBTVksY0FBUyxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFDaEMsY0FBUyxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFDaEMsYUFBUSxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFDL0Isa0JBQWEsR0FBRyxJQUFJLE9BQU8sRUFBUSxDQUFDO1FBZTVDLFVBQUssR0FBRyxLQUFLLENBQUM7UUFHZCxZQUFPLEdBQUcsS0FBSyxDQUFDO1FBTWhCLG9CQUFlLEdBQUcsSUFBSSxDQUFDO0lBbUQzQixDQUFDO0lBekVHLFFBQVE7UUFDSixJQUFJLE9BQU8sR0FBRyxHQUFHLENBQUM7UUFDbEIsSUFBSSxPQUFPLEdBQUcsQ0FBQyxDQUFDO1FBQ2hCLElBQUksVUFBVSxHQUFHLE9BQU8sR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLEdBQUcsQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDLENBQUM7UUFFL0QsVUFBVSxDQUFDLEdBQUcsRUFBRTtZQUNaLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDO1lBQ2xCLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDO1lBQ3BCLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQztRQUMvQyxDQUFDLEVBQUUsVUFBVSxDQUFDLENBQUM7SUFDbkIsQ0FBQztJQWNELElBQ0ksWUFBWTtRQUNaLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQztJQUM5QixDQUFDO0lBRUQsSUFDSSxRQUFRO1FBQ1IsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQzFCLENBQUM7SUFFRCxJQUNJLE9BQU87UUFDUCxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUM7SUFDekIsQ0FBQztJQUVELElBQ0ksUUFBUTtRQUNSLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUMxQixDQUFDO0lBRUQsSUFDSSxTQUFTOztRQUNULGFBQU8sSUFBSSxDQUFDLE9BQU8sMENBQUUsRUFBRSxDQUFDO0lBQzVCLENBQUM7SUFFRCxNQUFNO1FBQ0YsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUMxQixDQUFDO0lBRUQsTUFBTTtRQUNGLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDekIsQ0FBQztJQUVELE1BQU07UUFDRixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzFCLENBQUM7SUFFRCxVQUFVO1FBQ04sT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3JDLENBQUM7SUFFRCxhQUFhLENBQUMsSUFBVztRQUNyQixJQUFJLElBQUksSUFBSSxJQUFJLENBQUMsU0FBUyxFQUFFO1lBQ3hCLElBQUksR0FBRyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUM7WUFDekIsT0FBTyxPQUFPLEdBQUcsR0FBRyxDQUFDO1NBQ3hCO1FBRUQsT0FBTyxJQUFJLENBQUM7SUFDaEIsQ0FBQzs7O1lBbkZKLFNBQVMsU0FBQztnQkFDUCxRQUFRLEVBQUUsZUFBZTtnQkFDekIsdzJEQUF1Qzs7YUFFMUM7OztvQkFtQkksV0FBVyxTQUFDLFdBQVc7c0JBR3ZCLFdBQVcsU0FBQyxlQUFlO3NCQUczQixLQUFLOzhCQUdMLEtBQUs7MkJBR0wsTUFBTTt1QkFLTixNQUFNO3NCQUtOLE1BQU07dUJBS04sTUFBTTt3QkFLTixXQUFXLFNBQUMsc0JBQXNCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPdXRwdXQsIElucHV0LCBIb3N0QmluZGluZyB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IFN1YmplY3QgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgQ2hhdE1lc3NhZ2UsIFVzZXIgfSBmcm9tICdAYmFudGEvY29tbW9uJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICdiYW50YS1jb21tZW50JyxcclxuICAgIHRlbXBsYXRlVXJsOiAnLi9jb21tZW50LmNvbXBvbmVudC5odG1sJyxcclxuICAgIHN0eWxlVXJsczogWycuL2NvbW1lbnQuY29tcG9uZW50LnNjc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ29tbWVudENvbXBvbmVudCB7XHJcbiAgICBwcml2YXRlIF9yZXBvcnRlZCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XHJcbiAgICBwcml2YXRlIF9zZWxlY3RlZCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XHJcbiAgICBwcml2YXRlIF91cHZvdGVkID0gbmV3IFN1YmplY3Q8dm9pZD4oKTtcclxuICAgIHByaXZhdGUgX3VzZXJTZWxlY3RlZCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XHJcbiAgICBcclxuICAgIG5nT25Jbml0KCkge1xyXG4gICAgICAgIGxldCBtYXhUaW1lID0gNTAwO1xyXG4gICAgICAgIGxldCBtaW5UaW1lID0gMDtcclxuICAgICAgICBsZXQgcmFuZG9tVGltZSA9IG1pblRpbWUgKyBNYXRoLnJhbmRvbSgpICogKG1heFRpbWUgLSBtaW5UaW1lKTtcclxuXHJcbiAgICAgICAgc2V0VGltZW91dCgoKSA9PiB7XHJcbiAgICAgICAgICAgIHRoaXMuaXNOZXcgPSB0cnVlO1xyXG4gICAgICAgICAgICB0aGlzLnZpc2libGUgPSB0cnVlO1xyXG4gICAgICAgICAgICBzZXRUaW1lb3V0KCgpID0+IHRoaXMuaXNOZXcgPSBmYWxzZSwgMTAwMCk7XHJcbiAgICAgICAgfSwgcmFuZG9tVGltZSk7XHJcbiAgICB9XHJcblxyXG4gICAgQEhvc3RCaW5kaW5nKCdjbGFzcy5uZXcnKVxyXG4gICAgaXNOZXcgPSBmYWxzZTtcclxuXHJcbiAgICBASG9zdEJpbmRpbmcoJ2NsYXNzLnZpc2libGUnKVxyXG4gICAgdmlzaWJsZSA9IGZhbHNlO1xyXG5cclxuICAgIEBJbnB1dCgpXHJcbiAgICBtZXNzYWdlIDogQ2hhdE1lc3NhZ2U7XHJcblxyXG4gICAgQElucHV0KClcclxuICAgIHNob3dSZXBseUFjdGlvbiA9IHRydWU7XHJcblxyXG4gICAgQE91dHB1dCgpXHJcbiAgICBnZXQgdXNlclNlbGVjdGVkKCkge1xyXG4gICAgICAgIHJldHVybiB0aGlzLl91c2VyU2VsZWN0ZWQ7XHJcbiAgICB9XHJcblxyXG4gICAgQE91dHB1dCgpXHJcbiAgICBnZXQgcmVwb3J0ZWQoKSB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuX3JlcG9ydGVkO1xyXG4gICAgfVxyXG4gICAgXHJcbiAgICBAT3V0cHV0KClcclxuICAgIGdldCB1cHZvdGVkKCkge1xyXG4gICAgICAgIHJldHVybiB0aGlzLl91cHZvdGVkO1xyXG4gICAgfVxyXG5cclxuICAgIEBPdXRwdXQoKVxyXG4gICAgZ2V0IHNlbGVjdGVkKCkge1xyXG4gICAgICAgIHJldHVybiB0aGlzLl9zZWxlY3RlZDtcclxuICAgIH1cclxuXHJcbiAgICBASG9zdEJpbmRpbmcoJ2F0dHIuZGF0YS1jb21tZW50LWlkJylcclxuICAgIGdldCBjb21tZW50SWQoKSB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMubWVzc2FnZT8uaWQ7XHJcbiAgICB9XHJcblxyXG4gICAgcmVwb3J0KCkge1xyXG4gICAgICAgIHRoaXMuX3JlcG9ydGVkLm5leHQoKTtcclxuICAgIH1cclxuICAgIFxyXG4gICAgdXB2b3RlKCkge1xyXG4gICAgICAgIHRoaXMuX3Vwdm90ZWQubmV4dCgpO1xyXG4gICAgfVxyXG5cclxuICAgIHNlbGVjdCgpIHtcclxuICAgICAgICB0aGlzLl9zZWxlY3RlZC5uZXh0KCk7XHJcbiAgICB9XHJcblxyXG4gICAgc2VsZWN0VXNlcigpIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5fdXNlclNlbGVjdGVkLm5leHQoKTtcclxuICAgIH1cclxuICAgIFxyXG4gICAgYXZhdGFyRm9yVXNlcih1c2VyIDogVXNlcikge1xyXG4gICAgICAgIGlmICh1c2VyICYmIHVzZXIuYXZhdGFyVXJsKSB7XHJcbiAgICAgICAgICAgIGxldCB1cmwgPSB1c2VyLmF2YXRhclVybDtcclxuICAgICAgICAgICAgcmV0dXJuIGB1cmwoJHt1cmx9KWA7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICByZXR1cm4gbnVsbDtcclxuICAgIH1cclxufSJdfQ==
|
|
@@ -0,0 +1,235 @@
|
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { Component, ElementRef, Input, Output, ViewChild } from "@angular/core";
|
|
3
|
+
import { Subject } from "rxjs";
|
|
4
|
+
import { EMOJIS } from "../../emoji";
|
|
5
|
+
export class CommentFieldComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.canComment = true;
|
|
8
|
+
this.signInSelected = new Subject();
|
|
9
|
+
this.editAvatarSelected = new Subject();
|
|
10
|
+
this.sending = false;
|
|
11
|
+
this.expandError = false;
|
|
12
|
+
this.text = '';
|
|
13
|
+
this.sendLabel = 'Send';
|
|
14
|
+
this.sendingLabel = 'Sending';
|
|
15
|
+
this.label = 'Post a comment';
|
|
16
|
+
this.permissionDeniedLabel = 'Unavailable';
|
|
17
|
+
this.signInLabel = 'Sign In';
|
|
18
|
+
this.participants = [];
|
|
19
|
+
this.autocompleteVisible = false;
|
|
20
|
+
this.autocompleteOptions = [];
|
|
21
|
+
this.autoCompleteSelected = 0;
|
|
22
|
+
}
|
|
23
|
+
ngAfterViewInit() {
|
|
24
|
+
let root = document.body.querySelector('[ng-version]') || document.body;
|
|
25
|
+
root.appendChild(this.autocompleteEl.nativeElement);
|
|
26
|
+
}
|
|
27
|
+
showAutoComplete(options) {
|
|
28
|
+
this.autoCompleteSelected = 0;
|
|
29
|
+
this.autocompleteOptions = options;
|
|
30
|
+
let pos = this.autocompleteContainerEl.nativeElement.getBoundingClientRect();
|
|
31
|
+
let size = this.autocompleteEl.nativeElement.getBoundingClientRect();
|
|
32
|
+
this.autocompleteEl.nativeElement.style.left = `${pos.left}px`;
|
|
33
|
+
this.autocompleteEl.nativeElement.style.top = `${pos.top}px`;
|
|
34
|
+
this.autocompleteEl.nativeElement.style.width = `${pos.width}px`;
|
|
35
|
+
this.autocompleteVisible = true;
|
|
36
|
+
}
|
|
37
|
+
activateAutoComplete(option) {
|
|
38
|
+
option.action();
|
|
39
|
+
this.dismissAutoComplete();
|
|
40
|
+
}
|
|
41
|
+
dismissAutoComplete() {
|
|
42
|
+
this.autocompleteVisible = false;
|
|
43
|
+
this.completionFunc = null;
|
|
44
|
+
this.completionPrefix = '';
|
|
45
|
+
}
|
|
46
|
+
indicateError(message) {
|
|
47
|
+
this.sendError = new Error(message);
|
|
48
|
+
setTimeout(() => {
|
|
49
|
+
this.expandError = true;
|
|
50
|
+
setTimeout(() => {
|
|
51
|
+
this.expandError = false;
|
|
52
|
+
}, 5 * 1000);
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
autocomplete(replacement) {
|
|
56
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
57
|
+
let el = this.textareaEl.nativeElement;
|
|
58
|
+
this.text = this.text.slice(0, el.selectionStart - this.completionPrefix.length) + replacement + this.text.slice(el.selectionStart);
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
insert(str) {
|
|
62
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
63
|
+
let el = this.textareaEl.nativeElement;
|
|
64
|
+
this.text = this.text.slice(0, el.selectionStart) + str + this.text.slice(el.selectionStart);
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
onKeyDown(event) {
|
|
68
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
69
|
+
console.log(event.key);
|
|
70
|
+
if (this.autocompleteVisible) {
|
|
71
|
+
if (event.key === 'Escape') {
|
|
72
|
+
this.dismissAutoComplete();
|
|
73
|
+
return;
|
|
74
|
+
}
|
|
75
|
+
if (event.key === 'Shift') {
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
if (event.key === 'Enter') {
|
|
79
|
+
this.activateAutoComplete(this.autocompleteOptions[this.autoCompleteSelected]);
|
|
80
|
+
event.stopPropagation();
|
|
81
|
+
event.preventDefault();
|
|
82
|
+
return;
|
|
83
|
+
}
|
|
84
|
+
if (event.key === 'ArrowUp') {
|
|
85
|
+
if (this.autoCompleteSelected === 0)
|
|
86
|
+
this.autoCompleteSelected = this.autocompleteOptions.length - 1;
|
|
87
|
+
else
|
|
88
|
+
this.autoCompleteSelected = this.autoCompleteSelected - 1;
|
|
89
|
+
event.stopPropagation();
|
|
90
|
+
event.preventDefault();
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
else if (event.key === 'ArrowDown') {
|
|
94
|
+
this.autoCompleteSelected = (this.autoCompleteSelected + 1) % this.autocompleteOptions.length;
|
|
95
|
+
event.stopPropagation();
|
|
96
|
+
event.preventDefault();
|
|
97
|
+
return;
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
if (event.key === 'Enter' && event.ctrlKey) {
|
|
101
|
+
yield this.sendMessage();
|
|
102
|
+
return;
|
|
103
|
+
}
|
|
104
|
+
if (this.completionFunc) {
|
|
105
|
+
if (event.key === 'Backspace') {
|
|
106
|
+
this.completionPrefix = this.completionPrefix.slice(0, this.completionPrefix.length - 1);
|
|
107
|
+
if (this.completionPrefix === '') {
|
|
108
|
+
this.dismissAutoComplete();
|
|
109
|
+
return;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
else if (event.key === ' ' || event.key.length > 1) {
|
|
113
|
+
this.dismissAutoComplete();
|
|
114
|
+
return;
|
|
115
|
+
}
|
|
116
|
+
else {
|
|
117
|
+
this.completionPrefix += event.key;
|
|
118
|
+
}
|
|
119
|
+
this.showAutoComplete(this.completionFunc(this.completionPrefix));
|
|
120
|
+
}
|
|
121
|
+
else {
|
|
122
|
+
if (event.key === ':') {
|
|
123
|
+
this.startAutoComplete(event, prefix => {
|
|
124
|
+
prefix = prefix.slice(1);
|
|
125
|
+
// makes :-), :-( etc work (as they are ":)" etc in the db)
|
|
126
|
+
if (prefix.startsWith('-'))
|
|
127
|
+
prefix = prefix.slice(1);
|
|
128
|
+
return Object.keys(EMOJIS)
|
|
129
|
+
.filter(k => k.includes(prefix) || EMOJIS[k].keywords.some(kw => kw.includes(prefix)))
|
|
130
|
+
.map(k => ({
|
|
131
|
+
label: `${EMOJIS[k].char} ${k}`,
|
|
132
|
+
action: () => this.autocomplete(EMOJIS[k].char)
|
|
133
|
+
}))
|
|
134
|
+
.slice(0, 5);
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
else if (event.key === '@') {
|
|
138
|
+
this.startAutoComplete(event, prefix => {
|
|
139
|
+
prefix = prefix.slice(1);
|
|
140
|
+
return this.participants.filter(x => x.username.includes(prefix))
|
|
141
|
+
.map(p => ({
|
|
142
|
+
label: `@${p.username} -- ${p.displayName}`,
|
|
143
|
+
action: () => this.autocomplete(`@${p.username}`)
|
|
144
|
+
}));
|
|
145
|
+
});
|
|
146
|
+
}
|
|
147
|
+
else if (event.key === '#') {
|
|
148
|
+
this.startAutoComplete(event, prefix => {
|
|
149
|
+
prefix = prefix.slice(1);
|
|
150
|
+
return this.hashtags
|
|
151
|
+
.filter(ht => ht.hashtag.includes(prefix))
|
|
152
|
+
.map(ht => ({
|
|
153
|
+
label: `#${ht.hashtag}${ht.description ? ` -- ${ht.description}` : ``}`,
|
|
154
|
+
action: () => this.autocomplete(`#${ht.hashtag}`)
|
|
155
|
+
}))
|
|
156
|
+
.slice(0, 5);
|
|
157
|
+
});
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
});
|
|
161
|
+
}
|
|
162
|
+
startAutoComplete(event, completionFunc) {
|
|
163
|
+
this.completionPrefix = event.key;
|
|
164
|
+
this.completionFunc = completionFunc;
|
|
165
|
+
this.showAutoComplete(this.completionFunc(this.completionPrefix));
|
|
166
|
+
}
|
|
167
|
+
onBlur() {
|
|
168
|
+
setTimeout(() => this.dismissAutoComplete(), 250);
|
|
169
|
+
}
|
|
170
|
+
insertEmoji(text) {
|
|
171
|
+
this.text += text;
|
|
172
|
+
}
|
|
173
|
+
showSignIn() {
|
|
174
|
+
this.signInSelected.next();
|
|
175
|
+
}
|
|
176
|
+
showEditAvatar() {
|
|
177
|
+
this.editAvatarSelected.next();
|
|
178
|
+
}
|
|
179
|
+
sendMessage() {
|
|
180
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
181
|
+
if (!this.source)
|
|
182
|
+
return;
|
|
183
|
+
this.sending = true;
|
|
184
|
+
this.sendError = null;
|
|
185
|
+
try {
|
|
186
|
+
let text = (this.text || '').trim();
|
|
187
|
+
if (text === '')
|
|
188
|
+
return;
|
|
189
|
+
let message = {
|
|
190
|
+
user: this.user,
|
|
191
|
+
sentAt: Date.now(),
|
|
192
|
+
upvotes: 0,
|
|
193
|
+
message: text
|
|
194
|
+
};
|
|
195
|
+
try {
|
|
196
|
+
yield this.source.send(message);
|
|
197
|
+
this.text = '';
|
|
198
|
+
}
|
|
199
|
+
catch (e) {
|
|
200
|
+
this.indicateError(`Could not send: ${e.message}`);
|
|
201
|
+
console.error(`Failed to send message: `, message);
|
|
202
|
+
console.error(e);
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
finally {
|
|
206
|
+
this.sending = false;
|
|
207
|
+
}
|
|
208
|
+
});
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
CommentFieldComponent.decorators = [
|
|
212
|
+
{ type: Component, args: [{
|
|
213
|
+
selector: 'banta-comment-field',
|
|
214
|
+
template: "<form class=\"new-message\" (submit)=\"sendMessage()\">\r\n <div class=\"avatar-container\">\r\n <a href=\"javascript:;\" \r\n class=\"avatar\" \r\n (click)=\"showEditAvatar()\" \r\n [style.background-image]=\"'url(' + user?.avatarUrl + ')'\"\r\n ></a>\r\n </div>\r\n <div class=\"text-container\">\r\n <div class=\"field-container\">\r\n <mat-form-field appearance=\"outline\" floatLabel=\"always\">\r\n <mat-label>{{label}}</mat-label>\r\n <textarea \r\n #textarea\r\n name=\"message\" \r\n placeholder=\"Type your comment\"\r\n matInput\r\n cdkTextareaAutosize \r\n (keydown)=\"onKeyDown($event)\"\r\n (blur)=\"onBlur()\"\r\n [disabled]=\"sending\"\r\n [(ngModel)]=\"text\"></textarea>\r\n </mat-form-field>\r\n <div #autocompleteContainer class=\"autocomplete-container\">\r\n <div #autocomplete class=\"autocomplete\" [class.visible]=\"autocompleteVisible\">\r\n\r\n <div>\r\n <strong>{{completionPrefix}}</strong>...\r\n </div>\r\n\r\n <a \r\n mat-button \r\n *ngFor=\"let option of autocompleteOptions; index as index\" \r\n (click)=\"activateAutoComplete(option)\"\r\n [class.active]=\"autoCompleteSelected === index\" \r\n >\r\n {{option.label}}\r\n </a>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <mat-spinner *ngIf=\"sending\" class=\"icon loading\" diameter=\"18\" strokeWidth=\"2\"></mat-spinner>\r\n <div *ngIf=\"sendError\" class=\"error-message\" [class.expanded]=\"expandError\">\r\n <mat-icon *ngIf=\"sendError\">error</mat-icon>\r\n {{sendError.message}}\r\n </div>\r\n <emoji-selector-button \r\n class=\"top-right\"\r\n (selected)=\"insertEmoji($event)\"\r\n ></emoji-selector-button>\r\n </div>\r\n <div class=\"actions\">\r\n <ng-container *ngIf=\"!user\">\r\n <button \r\n mat-raised-button \r\n color=\"primary\"\r\n type=\"button\"\r\n (click)=\"showSignIn()\"\r\n >{{signInLabel}}</button>\r\n </ng-container>\r\n <ng-container *ngIf=\"user\">\r\n <button \r\n *ngIf=\"canComment\"\r\n mat-raised-button \r\n class=\"send\"\r\n color=\"primary\"\r\n [disabled]=\"!text || sending\" \r\n >\r\n <mat-icon *ngIf=\"!sending\">chevron_right</mat-icon>\r\n <mat-spinner *ngIf=\"sending\" class=\"icon\" diameter=\"18\" strokeWidth=\"2\"></mat-spinner>\r\n <ng-container *ngIf=\"!sending\">\r\n {{sendLabel}}\r\n </ng-container>\r\n <ng-container *ngIf=\"sending\">\r\n {{sendingLabel}}\r\n </ng-container>\r\n\r\n </button>\r\n <button \r\n *ngIf=\"!canComment\"\r\n type=\"button\"\r\n (click)=\"showPermissionDenied()\"\r\n mat-raised-button \r\n color=\"primary\"\r\n >{{permissionDeniedLabel}}</button>\r\n </ng-container>\r\n </div>\r\n</form>\r\n",
|
|
215
|
+
styles: ["@-webkit-keyframes comment-field-appear{0%{opacity:0;transform:translateY(128px)}to{opacity:1;transform:translate(0)}}@keyframes comment-field-appear{0%{opacity:0;transform:translateY(128px)}to{opacity:1;transform:translate(0)}}:host{-webkit-animation-delay:.4s;-webkit-animation-duration:.8s;-webkit-animation-fill-mode:both;-webkit-animation-name:comment-field-appear;animation-delay:.4s;animation-duration:.8s;animation-fill-mode:both;animation-name:comment-field-appear;display:block;margin:0 2em 0 0}.avatar-container{display:flex;justify-content:flex-end;width:calc(48px + 1.75em)}.avatar-container .avatar{background:pink;background-position:50%;background-repeat:no-repeat;background-size:cover;border-radius:100%;height:48px;margin-right:.75em;margin-top:.75em;width:48px}form{align-items:center;display:flex;padding:.5em 0}form .text-container{display:flex;flex-grow:1;position:relative}form .text-container textarea{font-size:14pt;width:100%}form .text-container textarea[disabled]{opacity:.5}form .text-container mat-form-field{margin-bottom:1em}form .text-container emoji-selector-button{bottom:0;position:absolute;right:0}form .text-container .error-message,form .text-container mat-spinner.loading{bottom:.5em;left:.5em;position:absolute}form .text-container .error-message{color:#683333;max-width:1.5em;overflow-x:hidden;transition:max-width 2s ease-in-out;white-space:nowrap}form .text-container .error-message.expanded,form .text-container .error-message:hover{max-width:100%}form .text-container .error-message mat-icon{vertical-align:middle}form input[type=text]{background:#000;border:1px solid #333;color:#fff;height:1em;width:100%}form .actions{margin-left:1em}form button{display:block;margin:0 0 0 auto}form.new-message{align-items:flex-start;display:flex}form.new-message .field-container{display:flex;flex-direction:column;flex-grow:1}form.new-message mat-form-field{width:100%}form.new-message button{margin:1.25em 0 0 1em}button.send{min-width:9em}textarea{max-height:7em}.autocomplete-container{pointer-events:none;position:relative;top:-2em;width:calc(100% - 2em)}.autocomplete{background:#333;display:flex;flex-direction:column;padding:.5em;pointer-events:none;position:absolute;visibility:hidden;z-index:100}.autocomplete.visible{pointer-events:auto;visibility:visible}.autocomplete a{text-align:left;width:100%}.autocomplete a.active{background:#555}"]
|
|
216
|
+
},] }
|
|
217
|
+
];
|
|
218
|
+
CommentFieldComponent.propDecorators = {
|
|
219
|
+
source: [{ type: Input }],
|
|
220
|
+
user: [{ type: Input }],
|
|
221
|
+
canComment: [{ type: Input }],
|
|
222
|
+
signInSelected: [{ type: Output }],
|
|
223
|
+
editAvatarSelected: [{ type: Output }],
|
|
224
|
+
sendLabel: [{ type: Input }],
|
|
225
|
+
sendingLabel: [{ type: Input }],
|
|
226
|
+
label: [{ type: Input }],
|
|
227
|
+
permissionDeniedLabel: [{ type: Input }],
|
|
228
|
+
signInLabel: [{ type: Input }],
|
|
229
|
+
autocompleteEl: [{ type: ViewChild, args: ['autocomplete',] }],
|
|
230
|
+
autocompleteContainerEl: [{ type: ViewChild, args: ['autocompleteContainer',] }],
|
|
231
|
+
textareaEl: [{ type: ViewChild, args: ['textarea',] }],
|
|
232
|
+
hashtags: [{ type: Input }],
|
|
233
|
+
participants: [{ type: Input }]
|
|
234
|
+
};
|
|
235
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"comment-field.component.js","sourceRoot":"D:/Dev/astronautlabs/banta/packages/frontend/projects/sdk/src/","sources":["lib/comments/comment-field/comment-field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, Output, ViewChild } from \"@angular/core\";\r\nimport { ChatMessage, ChatSource, User } from \"@banta/common\";\r\nimport { Subject } from \"rxjs\";\r\nimport { EMOJIS } from \"../../emoji\";\r\n\r\nexport interface AutoCompleteOption {\r\n    label : string;\r\n    action? : () => void;\r\n}\r\n\r\nexport interface HashTag {\r\n    hashtag : string;\r\n    description : string;\r\n}\r\n\r\n@Component({\r\n    selector: 'banta-comment-field',\r\n    templateUrl: './comment-field.component.html',\r\n    styleUrls: ['./comment-field.component.scss']\r\n})\r\nexport class CommentFieldComponent {\r\n\r\n    @Input() source : ChatSource;\r\n    @Input() user : User;\r\n    @Input() canComment = true;\r\n\r\n    @Output() signInSelected = new Subject<void>();\r\n    @Output() editAvatarSelected = new Subject<void>();\r\n\r\n    sending = false;\r\n    sendError : Error;\r\n    expandError = false;\r\n    text : string = '';\r\n    @Input() sendLabel = 'Send';\r\n    @Input() sendingLabel = 'Sending';\r\n    @Input() label = 'Post a comment';\r\n    @Input() permissionDeniedLabel = 'Unavailable'\r\n    @Input() signInLabel = 'Sign In';\r\n    @ViewChild('autocomplete') autocompleteEl : ElementRef<HTMLElement>;\r\n    @ViewChild('autocompleteContainer') autocompleteContainerEl : ElementRef<HTMLElement>;\r\n    @ViewChild('textarea') textareaEl : ElementRef<HTMLTextAreaElement>;\r\n\r\n    @Input() hashtags : HashTag[];\r\n    @Input() participants : User[] = [];\r\n\r\n    ngAfterViewInit() {\r\n        let root = document.body.querySelector('[ng-version]') || document.body;\r\n        root.appendChild(this.autocompleteEl.nativeElement);\r\n    }\r\n\r\n    showAutoComplete(options : AutoCompleteOption[]) {\r\n        this.autoCompleteSelected = 0;\r\n        this.autocompleteOptions = options;\r\n        let pos = this.autocompleteContainerEl.nativeElement.getBoundingClientRect();\r\n        let size = this.autocompleteEl.nativeElement.getBoundingClientRect();\r\n\r\n        this.autocompleteEl.nativeElement.style.left = `${pos.left}px`;\r\n        this.autocompleteEl.nativeElement.style.top = `${pos.top}px`;\r\n        this.autocompleteEl.nativeElement.style.width = `${pos.width}px`;\r\n        this.autocompleteVisible = true;\r\n    }\r\n\r\n    autocompleteVisible = false;\r\n    autocompleteOptions : AutoCompleteOption[] = [];\r\n\r\n    activateAutoComplete(option : AutoCompleteOption) {\r\n        option.action();\r\n        this.dismissAutoComplete();\r\n    }\r\n\r\n    dismissAutoComplete() {\r\n        this.autocompleteVisible = false;\r\n        this.completionFunc = null;\r\n        this.completionPrefix = '';\r\n    }\r\n\r\n    indicateError(message : string) {\r\n        this.sendError = new Error(message);\r\n        setTimeout(() => {\r\n            this.expandError = true;\r\n            setTimeout(() => {\r\n                this.expandError = false;\r\n            }, 5*1000);\r\n        });\r\n    }\r\n\r\n    completionFunc : (str : string) => AutoCompleteOption[];\r\n\r\n    completionPrefix : string;\r\n    autoCompleteSelected : number = 0;\r\n\r\n    async autocomplete(replacement : string) {\r\n        let el = this.textareaEl.nativeElement;\r\n        this.text = this.text.slice(0, el.selectionStart - this.completionPrefix.length) + replacement + this.text.slice(el.selectionStart);\r\n    }\r\n\r\n    async insert(str : string) {\r\n        let el = this.textareaEl.nativeElement;\r\n        this.text = this.text.slice(0, el.selectionStart) + str + this.text.slice(el.selectionStart);\r\n    }\r\n\r\n    async onKeyDown(event : KeyboardEvent) {\r\n        console.log(event.key);\r\n\r\n\r\n        if (this.autocompleteVisible) {\r\n            if (event.key === 'Escape') {\r\n                this.dismissAutoComplete();\r\n                return;\r\n            }\r\n\r\n            if (event.key === 'Shift') {\r\n                return;\r\n            }\r\n\r\n            if (event.key === 'Enter') {\r\n                this.activateAutoComplete(this.autocompleteOptions[this.autoCompleteSelected]);\r\n                event.stopPropagation();\r\n                event.preventDefault();\r\n                return;\r\n            }\r\n\r\n            if (event.key === 'ArrowUp') {\r\n                if (this.autoCompleteSelected === 0)\r\n                    this.autoCompleteSelected = this.autocompleteOptions.length - 1;\r\n                else\r\n                    this.autoCompleteSelected = this.autoCompleteSelected - 1;\r\n                event.stopPropagation();\r\n                event.preventDefault();\r\n                return;\r\n            } else if (event.key === 'ArrowDown') {\r\n                this.autoCompleteSelected = (this.autoCompleteSelected + 1) % this.autocompleteOptions.length;\r\n                event.stopPropagation();\r\n                event.preventDefault();\r\n                return;\r\n            }\r\n        }\r\n\r\n        if (event.key === 'Enter' && event.ctrlKey) {\r\n            await this.sendMessage();\r\n            return;\r\n        }\r\n        \r\n        if (this.completionFunc) {\r\n            if (event.key === 'Backspace') {\r\n                this.completionPrefix = this.completionPrefix.slice(0, this.completionPrefix.length - 1);\r\n\r\n                if (this.completionPrefix === '') {\r\n                    this.dismissAutoComplete();\r\n                    return;\r\n                }\r\n            } else if (event.key === ' ' || event.key.length > 1) {\r\n                this.dismissAutoComplete();\r\n                return;\r\n            } else {\r\n                this.completionPrefix += event.key;\r\n            }\r\n\r\n            this.showAutoComplete(this.completionFunc(this.completionPrefix));\r\n        } else {\r\n            if (event.key === ':') {\r\n                this.startAutoComplete(event, prefix => {\r\n                    prefix = prefix.slice(1);\r\n\r\n                    // makes :-), :-( etc work (as they are \":)\" etc in the db)\r\n                    if (prefix.startsWith('-'))\r\n                        prefix = prefix.slice(1);\r\n        \r\n                    return Object.keys(EMOJIS)\r\n                        .filter(k => k.includes(prefix) || EMOJIS[k].keywords.some(kw => kw.includes(prefix)))\r\n                        .map(k => ({\r\n                            label: `${EMOJIS[k].char} ${k}`,\r\n                            action: () => this.autocomplete(EMOJIS[k].char)\r\n                        }))\r\n                        .slice(0, 5)\r\n                    ;\r\n                });\r\n            } else if (event.key === '@') {\r\n                this.startAutoComplete(event, prefix => {\r\n                    prefix = prefix.slice(1);\r\n                    return this.participants.filter(x => x.username.includes(prefix))\r\n                        .map(p => ({\r\n                            label: `@${p.username} -- ${p.displayName}`,\r\n                            action: () => this.autocomplete(`@${p.username}`)\r\n                        }))\r\n                    ;\r\n                });\r\n            } else if (event.key === '#') {\r\n                this.startAutoComplete(event, prefix => {\r\n                    prefix = prefix.slice(1);\r\n        \r\n                    return this.hashtags\r\n                        .filter(ht => ht.hashtag.includes(prefix))\r\n                        .map(ht => ({\r\n                            label: `#${ht.hashtag}${ht.description ? ` -- ${ht.description}` : ``}`,\r\n                            action: () => this.autocomplete(`#${ht.hashtag}`)\r\n                        }))\r\n                        .slice(0, 5)\r\n                    ;\r\n                });\r\n            }\r\n        }\r\n    }\r\n\r\n    startAutoComplete(event : KeyboardEvent, completionFunc : (str : string) => AutoCompleteOption[]) {\r\n        this.completionPrefix = event.key;\r\n        this.completionFunc = completionFunc;\r\n        this.showAutoComplete(this.completionFunc(this.completionPrefix));\r\n    }\r\n\r\n    onBlur() {\r\n        setTimeout(() => this.dismissAutoComplete(), 250);\r\n    }\r\n\r\n    insertEmoji(text : string) {\r\n        this.text += text;\r\n    }\r\n\r\n    showSignIn() {\r\n        this.signInSelected.next();\r\n    }\r\n\r\n    showEditAvatar() {\r\n        this.editAvatarSelected.next();\r\n    }\r\n\r\n    async sendMessage() {\r\n        if (!this.source)\r\n            return;\r\n        \r\n        this.sending = true;\r\n        this.sendError = null;\r\n        try {\r\n            let text = (this.text || '').trim();\r\n\r\n            if (text === '')\r\n                return;\r\n\r\n            let message : ChatMessage = {\r\n                user: this.user,\r\n                sentAt: Date.now(),\r\n                upvotes: 0,\r\n                message: text\r\n            };\r\n\r\n            try {\r\n                await this.source.send(message);\r\n                this.text = '';\r\n            } catch (e) {\r\n                this.indicateError(`Could not send: ${e.message}`);\r\n                console.error(`Failed to send message: `, message);\r\n                console.error(e);\r\n            }\r\n        } finally {\r\n            this.sending = false;\r\n        }\r\n    }\r\n\r\n}"]}
|
|
@@ -73,7 +73,7 @@ export class CommentViewComponent {
|
|
|
73
73
|
}
|
|
74
74
|
}
|
|
75
75
|
}
|
|
76
|
-
messageIdentity(chatMessage) {
|
|
76
|
+
messageIdentity(index, chatMessage) {
|
|
77
77
|
return chatMessage.id;
|
|
78
78
|
}
|
|
79
79
|
showNew() {
|
|
@@ -170,8 +170,8 @@ export class CommentViewComponent {
|
|
|
170
170
|
CommentViewComponent.decorators = [
|
|
171
171
|
{ type: Component, args: [{
|
|
172
172
|
selector: 'banta-comment-view',
|
|
173
|
-
template: "<div class=\"message-container\">\r\n <ng-content select=\"[data-before]\"></ng-content>\r\n \r\n <a mat-button class=\"nav\"
|
|
174
|
-
styles: [":host{display:flex;flex-direction:column;flex-grow:1;opacity:1;transition:opacity .2s ease-in}.message-container{background:#fff;color:#
|
|
173
|
+
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 Show \r\n <ng-container *ngIf=\"newMessages.length === 1\">\r\n {{newMessages.length}} new message\r\n </ng-container>\r\n <ng-container *ngIf=\"newMessages.length > 1\">\r\n {{newMessages.length}} new messages\r\n </ng-container>\r\n <ng-container *ngIf=\"newMessages.length === 0\">\r\n new messages\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 <banta-comment \r\n *ngFor=\"let message of messages; trackBy: messageIdentity\"\r\n class=\"abbreviated\"\r\n [message]=\"message\"\r\n (click)=\"isViewingMore = true\"\r\n [showReplyAction]=\"allowReplies\"\r\n (userSelected)=\"selectMessageUser(message)\"\r\n (upvoted)=\"upvoteMessage(message)\"\r\n (reported)=\"reportMessage(message)\"\r\n (selected)=\"selectMessage(message)\"\r\n ></banta-comment>\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>",
|
|
174
|
+
styles: [":host{display:flex;flex-direction:column;flex-grow:1;opacity:1;transition:opacity .2s ease-in}.message-container{background:#fff;color:#111;flex-grow:1;opacity:1;overflow-x:hidden;padding:.5em 1em .5em .5em;position:relative;transition:opacity .5s ease-in-out}.message-container.no-scroll{height:auto;overflow-y:visible}.message-container.faded{opacity:.25}.message-container .overlay{bottom:0;left:0;position:absolute;right:0;top:0;z-index:10}:host.fixed-height .message-container{overflow-y:auto}:host-context(.mat-dark-theme) .message-container{background:#111;color:#fff}.empty-state{color:#666;margin:3em;text-align:center}:host-context(.mat-dark-theme) .empty-state{color:#666}a.nav{opacity:0;pointer-events:none;text-align:center;text-transform:uppercase;transition:opacity .4s ease-in-out;width:100%}a.nav.visible{opacity:1;pointer-events:auto}.loading-more{margin:0 auto;padding:2em;text-align:center;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content}"]
|
|
175
175
|
},] }
|
|
176
176
|
];
|
|
177
177
|
CommentViewComponent.ctorParameters = () => [
|
|
@@ -192,4 +192,4 @@ CommentViewComponent.propDecorators = {
|
|
|
192
192
|
maxVisibleMessages: [{ type: Input }],
|
|
193
193
|
newestLast: [{ type: Input }]
|
|
194
194
|
};
|
|
195
|
-
//# 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":"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","sourcesContent":["import { Component, Input, ViewChild, ElementRef, Output, HostBinding } from \"@angular/core\";\r\nimport { User, ChatMessage, ChatSource } from '@banta/common';\r\nimport { SubSink } from 'subsink';\r\nimport { Subject } 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 SubSink();\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\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    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    async 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    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            let 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 SubSink();\r\n            this._sourceSubs.add(\r\n                this._source.messageReceived\r\n                    .subscribe(msg => this.messageReceived(msg)),\r\n                this._source.messageSent\r\n                    .subscribe(msg => this.messageSent(msg))\r\n            );\r\n\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(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        let el = this.messageContainer.nativeElement;\r\n        let currentScroll = el.scrollTop;\r\n        let 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        let 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}"]}
|
|
195
|
+
//# 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":"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","sourcesContent":["import { Component, Input, ViewChild, ElementRef, Output, HostBinding } from \"@angular/core\";\r\nimport { User, ChatMessage, ChatSource } from '@banta/common';\r\nimport { SubSink } from 'subsink';\r\nimport { Subject } 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 SubSink();\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\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    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    async 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    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            let 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 SubSink();\r\n            this._sourceSubs.add(\r\n                this._source.messageReceived\r\n                    .subscribe(msg => this.messageReceived(msg)),\r\n                this._source.messageSent\r\n                    .subscribe(msg => this.messageSent(msg))\r\n            );\r\n\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        let el = this.messageContainer.nativeElement;\r\n        let currentScroll = el.scrollTop;\r\n        let 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        let 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}"]}
|
|
@@ -14,11 +14,13 @@ import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
|
|
|
14
14
|
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
15
15
|
import { MatInputModule } from '@angular/material/input';
|
|
16
16
|
import { TextFieldModule } from '@angular/cdk/text-field';
|
|
17
|
+
import { CommentFieldComponent } from './comment-field/comment-field.component';
|
|
17
18
|
const COMPONENTS = [
|
|
18
19
|
CommentComponent,
|
|
19
20
|
CommentViewComponent,
|
|
20
21
|
BantaCommentsComponent,
|
|
21
|
-
LiveCommentComponent
|
|
22
|
+
LiveCommentComponent,
|
|
23
|
+
CommentFieldComponent
|
|
22
24
|
];
|
|
23
25
|
export class CommentsModule {
|
|
24
26
|
}
|
|
@@ -41,4 +43,4 @@ CommentsModule.decorators = [
|
|
|
41
43
|
exports: COMPONENTS
|
|
42
44
|
},] }
|
|
43
45
|
];
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbWVudHMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IkQ6L0Rldi9hc3Ryb25hdXRsYWJzL2JhbnRhL3BhY2thZ2VzL2Zyb250ZW5kL3Byb2plY3RzL3Nkay9zcmMvIiwic291cmNlcyI6WyJsaWIvY29tbWVudHMvY29tbWVudHMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDL0QsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDN0UsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDbkYsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM1RCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQ3ZDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3ZELE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQzlFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDMUQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFFaEYsTUFBTSxVQUFVLEdBQUc7SUFDZixnQkFBZ0I7SUFDaEIsb0JBQW9CO0lBQ3BCLHNCQUFzQjtJQUN0QixvQkFBb0I7SUFDcEIscUJBQXFCO0NBQ3hCLENBQUM7QUFtQkYsTUFBTSxPQUFPLGNBQWM7OztZQWpCMUIsUUFBUSxTQUFDO2dCQUNOLFlBQVksRUFBRSxVQUFVO2dCQUN4QixPQUFPLEVBQUU7b0JBQ0wsWUFBWTtvQkFDWixlQUFlO29CQUNmLFdBQVc7b0JBQ1gsYUFBYTtvQkFDYixrQkFBa0I7b0JBQ2xCLGNBQWM7b0JBQ2QsZUFBZTtvQkFDZixhQUFhO29CQUNiLHdCQUF3QjtvQkFDeEIsaUJBQWlCO29CQUNqQixXQUFXO2lCQUNkO2dCQUNELE9BQU8sRUFBRSxVQUFVO2FBQ3RCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbWVudENvbXBvbmVudCB9IGZyb20gJy4vY29tbWVudC9jb21tZW50LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IENvbW1lbnRWaWV3Q29tcG9uZW50IH0gZnJvbSAnLi9jb21tZW50LXZpZXcvY29tbWVudC12aWV3LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEJhbnRhQ29tbWVudHNDb21wb25lbnQgfSBmcm9tICcuL2JhbnRhLWNvbW1lbnRzL2JhbnRhLWNvbW1lbnRzLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBCYW50YUNvbW1vbk1vZHVsZSB9IGZyb20gJy4uL2NvbW1vbi9jb21tb24ubW9kdWxlJztcclxuaW1wb3J0IHsgTGl2ZUNvbW1lbnRDb21wb25lbnQgfSBmcm9tICcuL2xpdmUtY29tbWVudC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBFbW9qaU1vZHVsZSB9IGZyb20gJy4uL2Vtb2ppJztcclxuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xyXG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xyXG5pbXBvcnQgeyBNYXRNZW51TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvbWVudSc7XHJcbmltcG9ydCB7IE1hdFByb2dyZXNzU3Bpbm5lck1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3Byb2dyZXNzLXNwaW5uZXInO1xyXG5pbXBvcnQgeyBNYXRGb3JtRmllbGRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9mb3JtLWZpZWxkJztcclxuaW1wb3J0IHsgTWF0SW5wdXRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pbnB1dCc7XHJcbmltcG9ydCB7IFRleHRGaWVsZE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay90ZXh0LWZpZWxkJztcclxuaW1wb3J0IHsgQ29tbWVudEZpZWxkQ29tcG9uZW50IH0gZnJvbSAnLi9jb21tZW50LWZpZWxkL2NvbW1lbnQtZmllbGQuY29tcG9uZW50JztcclxuXHJcbmNvbnN0IENPTVBPTkVOVFMgPSBbXHJcbiAgICBDb21tZW50Q29tcG9uZW50LFxyXG4gICAgQ29tbWVudFZpZXdDb21wb25lbnQsXHJcbiAgICBCYW50YUNvbW1lbnRzQ29tcG9uZW50LFxyXG4gICAgTGl2ZUNvbW1lbnRDb21wb25lbnQsXHJcbiAgICBDb21tZW50RmllbGRDb21wb25lbnRcclxuXTtcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgICBkZWNsYXJhdGlvbnM6IENPTVBPTkVOVFMsXHJcbiAgICBpbXBvcnRzOiBbXHJcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgICAgIFRleHRGaWVsZE1vZHVsZSxcclxuICAgICAgICBGb3Jtc01vZHVsZSxcclxuICAgICAgICBNYXRJY29uTW9kdWxlLFxyXG4gICAgICAgIE1hdEZvcm1GaWVsZE1vZHVsZSxcclxuICAgICAgICBNYXRJbnB1dE1vZHVsZSxcclxuICAgICAgICBNYXRCdXR0b25Nb2R1bGUsXHJcbiAgICAgICAgTWF0TWVudU1vZHVsZSxcclxuICAgICAgICBNYXRQcm9ncmVzc1NwaW5uZXJNb2R1bGUsXHJcbiAgICAgICAgQmFudGFDb21tb25Nb2R1bGUsXHJcbiAgICAgICAgRW1vamlNb2R1bGVcclxuICAgIF0sXHJcbiAgICBleHBvcnRzOiBDT01QT05FTlRTXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDb21tZW50c01vZHVsZSB7XHJcbn0iXX0=
|
|
@@ -2,5 +2,6 @@ export * from './comment/comment.component';
|
|
|
2
2
|
export * from './comment-view/comment-view.component';
|
|
3
3
|
export * from './banta-comments/banta-comments.component';
|
|
4
4
|
export * from './live-comment.component';
|
|
5
|
+
export * from './comment-field/comment-field.component';
|
|
5
6
|
export * from './comments.module';
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiRDovRGV2L2FzdHJvbmF1dGxhYnMvYmFudGEvcGFja2FnZXMvZnJvbnRlbmQvcHJvamVjdHMvc2RrL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9jb21tZW50cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMseUNBQXlDLENBQUM7QUFFeEQsY0FBYyxtQkFBbUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY29tbWVudC9jb21tZW50LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY29tbWVudC12aWV3L2NvbW1lbnQtdmlldy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2JhbnRhLWNvbW1lbnRzL2JhbnRhLWNvbW1lbnRzLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGl2ZS1jb21tZW50LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY29tbWVudC1maWVsZC9jb21tZW50LWZpZWxkLmNvbXBvbmVudCc7XHJcblxyXG5leHBvcnQgKiBmcm9tICcuL2NvbW1lbnRzLm1vZHVsZSc7Il19
|