@banta/sdk 0.0.35 → 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/banta-sdk.metadata.json +1 -1
- package/bundles/banta-sdk.umd.js +238 -509
- package/bundles/banta-sdk.umd.js.map +1 -1
- package/bundles/banta-sdk.umd.min.js +2 -2
- package/bundles/banta-sdk.umd.min.js.map +1 -1
- package/esm2015/lib/banta/banta.component.js +217 -0
- package/esm2015/lib/banta-logo.component.js +22 -0
- package/esm2015/lib/banta-sdk.module.js +17 -12
- package/esm2015/lib/chat/banta-chat/banta-chat.component.js +197 -0
- package/esm2015/lib/chat/chat-message/chat-message.component.js +2 -2
- package/esm2015/lib/chat/chat-view/chat-view.component.js +5 -5
- package/esm2015/lib/chat/chat.module.js +3 -3
- package/esm2015/lib/chat/index.js +2 -2
- package/esm2015/lib/chat/live-chat-message.component.js +4 -4
- package/esm2015/lib/comments/banta-comments/banta-comments.component.js +180 -0
- package/esm2015/lib/comments/comment/comment.component.js +4 -4
- package/esm2015/lib/comments/comment-view/comment-view.component.js +3 -3
- package/esm2015/lib/comments/comments.module.js +5 -5
- package/esm2015/lib/comments/index.js +2 -2
- package/esm2015/lib/comments/live-comment.component.js +4 -4
- package/esm2015/lib/common/common.module.js +7 -7
- package/esm2015/lib/common/timestamp.component.js +2 -2
- package/esm2015/lib/index.js +3 -3
- package/esm2015/lib/live-message.component.js +6 -6
- package/esm5/lib/banta/banta.component.js +283 -0
- package/esm5/lib/banta-logo.component.js +16 -0
- package/esm5/lib/banta-sdk.module.js +17 -12
- package/esm5/lib/chat/banta-chat/banta-chat.component.js +245 -0
- package/esm5/lib/chat/chat-message/chat-message.component.js +2 -2
- package/esm5/lib/chat/chat-view/chat-view.component.js +5 -5
- package/esm5/lib/chat/chat.module.js +3 -3
- package/esm5/lib/chat/index.js +2 -2
- package/esm5/lib/chat/live-chat-message.component.js +3 -3
- package/esm5/lib/comments/banta-comments/banta-comments.component.js +228 -0
- package/esm5/lib/comments/comment/comment.component.js +4 -4
- package/esm5/lib/comments/comment-view/comment-view.component.js +3 -3
- package/esm5/lib/comments/comments.module.js +5 -5
- package/esm5/lib/comments/index.js +2 -2
- package/esm5/lib/comments/live-comment.component.js +3 -3
- package/esm5/lib/common/common.module.js +11 -11
- package/esm5/lib/common/timestamp.component.js +2 -2
- package/esm5/lib/index.js +3 -3
- package/esm5/lib/live-message.component.js +3 -3
- package/fesm2015/banta-sdk.js +143 -387
- package/fesm2015/banta-sdk.js.map +1 -1
- package/fesm5/banta-sdk.js +234 -502
- package/fesm5/banta-sdk.js.map +1 -1
- package/lib/banta/banta.component.d.ts +55 -0
- package/lib/banta-logo.component.d.ts +2 -0
- package/lib/chat/{firehose-chat/firehose-chat.component.d.ts → banta-chat/banta-chat.component.d.ts} +7 -1
- package/lib/chat/index.d.ts +1 -1
- package/lib/comments/{comments-box/comments-box.component.d.ts → banta-comments/banta-comments.component.d.ts} +8 -2
- package/lib/comments/index.d.ts +1 -1
- package/lib/common/common.module.d.ts +2 -2
- package/lib/index.d.ts +2 -2
- package/package.json +2 -3
- package/esm2015/lib/chat/firehose-chat/firehose-chat.component.js +0 -175
- package/esm2015/lib/comments/comments-box/comments-box.component.js +0 -158
- package/esm2015/lib/engage/engage.component.js +0 -510
- package/esm2015/lib/engage-logo.component.js +0 -22
- package/esm5/lib/chat/firehose-chat/firehose-chat.component.js +0 -209
- package/esm5/lib/comments/comments-box/comments-box.component.js +0 -192
- package/esm5/lib/engage/engage.component.js +0 -631
- package/esm5/lib/engage-logo.component.js +0 -16
- package/lib/engage/engage.component.d.ts +0 -98
- package/lib/engage-logo.component.d.ts +0 -2
|
@@ -0,0 +1,228 @@
|
|
|
1
|
+
import { __awaiter, __decorate, __generator, __metadata } from "tslib";
|
|
2
|
+
import { Component, Input, Output } from '@angular/core';
|
|
3
|
+
import { Subject, Observable } from 'rxjs';
|
|
4
|
+
import { SubSink } from 'subsink';
|
|
5
|
+
import { ChatBackendService } from '../../chat-backend.service';
|
|
6
|
+
import { BantaService } from '../../common';
|
|
7
|
+
/**
|
|
8
|
+
* Comments component
|
|
9
|
+
*/
|
|
10
|
+
var BantaCommentsComponent = /** @class */ (function () {
|
|
11
|
+
function BantaCommentsComponent(banta, backend) {
|
|
12
|
+
this.banta = banta;
|
|
13
|
+
this.backend = backend;
|
|
14
|
+
this._upvoted = new Subject();
|
|
15
|
+
this._reported = new Subject();
|
|
16
|
+
this._selected = new Subject();
|
|
17
|
+
this._userSelected = new Subject();
|
|
18
|
+
this._subs = new SubSink();
|
|
19
|
+
this.signInLabel = 'Sign In';
|
|
20
|
+
this.sendLabel = 'Send';
|
|
21
|
+
this.permissionDeniedLabel = 'Send';
|
|
22
|
+
this._signInSelected = new Subject();
|
|
23
|
+
this._permissionDeniedError = new Subject();
|
|
24
|
+
}
|
|
25
|
+
BantaCommentsComponent.prototype.ngOnInit = function () {
|
|
26
|
+
var _this = this;
|
|
27
|
+
this._subs.add(this.banta.userChanged.subscribe(function (user) { return _this.user = user; }));
|
|
28
|
+
};
|
|
29
|
+
BantaCommentsComponent.prototype.ngOnDestroy = function () {
|
|
30
|
+
this._subs.unsubscribe();
|
|
31
|
+
};
|
|
32
|
+
Object.defineProperty(BantaCommentsComponent.prototype, "source", {
|
|
33
|
+
get: function () {
|
|
34
|
+
return this._source;
|
|
35
|
+
},
|
|
36
|
+
set: function (value) {
|
|
37
|
+
this._source = value;
|
|
38
|
+
},
|
|
39
|
+
enumerable: true,
|
|
40
|
+
configurable: true
|
|
41
|
+
});
|
|
42
|
+
Object.defineProperty(BantaCommentsComponent.prototype, "topicID", {
|
|
43
|
+
get: function () {
|
|
44
|
+
return this._source.identifier;
|
|
45
|
+
},
|
|
46
|
+
set: function (value) {
|
|
47
|
+
this.setSourceFromTopicID(value);
|
|
48
|
+
},
|
|
49
|
+
enumerable: true,
|
|
50
|
+
configurable: true
|
|
51
|
+
});
|
|
52
|
+
BantaCommentsComponent.prototype.setSourceFromTopicID = function (topicID) {
|
|
53
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
54
|
+
var _a;
|
|
55
|
+
return __generator(this, function (_b) {
|
|
56
|
+
switch (_b.label) {
|
|
57
|
+
case 0:
|
|
58
|
+
if (this._source && this._source.close)
|
|
59
|
+
this._source.close();
|
|
60
|
+
this._source = null;
|
|
61
|
+
_a = this;
|
|
62
|
+
return [4 /*yield*/, this.backend.getSourceForTopic(topicID)];
|
|
63
|
+
case 1:
|
|
64
|
+
_a._source = _b.sent();
|
|
65
|
+
return [2 /*return*/];
|
|
66
|
+
}
|
|
67
|
+
});
|
|
68
|
+
});
|
|
69
|
+
};
|
|
70
|
+
BantaCommentsComponent.prototype.showSignIn = function () {
|
|
71
|
+
this._signInSelected.next();
|
|
72
|
+
};
|
|
73
|
+
Object.defineProperty(BantaCommentsComponent.prototype, "signInSelected", {
|
|
74
|
+
get: function () {
|
|
75
|
+
return this._signInSelected;
|
|
76
|
+
},
|
|
77
|
+
enumerable: true,
|
|
78
|
+
configurable: true
|
|
79
|
+
});
|
|
80
|
+
Object.defineProperty(BantaCommentsComponent.prototype, "permissionDeniedError", {
|
|
81
|
+
get: function () {
|
|
82
|
+
return this._permissionDeniedError;
|
|
83
|
+
},
|
|
84
|
+
enumerable: true,
|
|
85
|
+
configurable: true
|
|
86
|
+
});
|
|
87
|
+
BantaCommentsComponent.prototype.showPermissionDenied = function () {
|
|
88
|
+
this._permissionDeniedError.next();
|
|
89
|
+
};
|
|
90
|
+
Object.defineProperty(BantaCommentsComponent.prototype, "canComment", {
|
|
91
|
+
get: function () {
|
|
92
|
+
var _a;
|
|
93
|
+
if (!this.user.permissions)
|
|
94
|
+
return true;
|
|
95
|
+
return (_a = this.user.permissions) === null || _a === void 0 ? void 0 : _a.canComment(this.source);
|
|
96
|
+
},
|
|
97
|
+
enumerable: true,
|
|
98
|
+
configurable: true
|
|
99
|
+
});
|
|
100
|
+
Object.defineProperty(BantaCommentsComponent.prototype, "upvoted", {
|
|
101
|
+
get: function () {
|
|
102
|
+
return this._upvoted;
|
|
103
|
+
},
|
|
104
|
+
enumerable: true,
|
|
105
|
+
configurable: true
|
|
106
|
+
});
|
|
107
|
+
Object.defineProperty(BantaCommentsComponent.prototype, "reported", {
|
|
108
|
+
get: function () {
|
|
109
|
+
return this._reported;
|
|
110
|
+
},
|
|
111
|
+
enumerable: true,
|
|
112
|
+
configurable: true
|
|
113
|
+
});
|
|
114
|
+
Object.defineProperty(BantaCommentsComponent.prototype, "selected", {
|
|
115
|
+
get: function () {
|
|
116
|
+
return this._selected;
|
|
117
|
+
},
|
|
118
|
+
enumerable: true,
|
|
119
|
+
configurable: true
|
|
120
|
+
});
|
|
121
|
+
Object.defineProperty(BantaCommentsComponent.prototype, "userSelected", {
|
|
122
|
+
get: function () {
|
|
123
|
+
return this._userSelected;
|
|
124
|
+
},
|
|
125
|
+
enumerable: true,
|
|
126
|
+
configurable: true
|
|
127
|
+
});
|
|
128
|
+
BantaCommentsComponent.prototype.onKeyDown = function (event) {
|
|
129
|
+
};
|
|
130
|
+
BantaCommentsComponent.prototype.insertEmoji = function (text) {
|
|
131
|
+
this.newMessageText += text;
|
|
132
|
+
};
|
|
133
|
+
BantaCommentsComponent.prototype.sendMessage = function () {
|
|
134
|
+
if (!this.source)
|
|
135
|
+
return;
|
|
136
|
+
var text = (this.newMessageText || '').trim();
|
|
137
|
+
this.newMessageText = '';
|
|
138
|
+
if (text === '')
|
|
139
|
+
return;
|
|
140
|
+
var message = {
|
|
141
|
+
user: this.user,
|
|
142
|
+
sentAt: Date.now(),
|
|
143
|
+
upvotes: 0,
|
|
144
|
+
message: text
|
|
145
|
+
};
|
|
146
|
+
this.source.send(message);
|
|
147
|
+
};
|
|
148
|
+
BantaCommentsComponent.prototype.upvoteMessage = function (message) {
|
|
149
|
+
this._upvoted.next(message);
|
|
150
|
+
};
|
|
151
|
+
BantaCommentsComponent.prototype.reportMessage = function (message) {
|
|
152
|
+
this._reported.next(message);
|
|
153
|
+
};
|
|
154
|
+
BantaCommentsComponent.prototype.selectMessage = function (message) {
|
|
155
|
+
this._selected.next(message);
|
|
156
|
+
};
|
|
157
|
+
BantaCommentsComponent.prototype.selectMessageUser = function (message) {
|
|
158
|
+
this._userSelected.next(message);
|
|
159
|
+
};
|
|
160
|
+
BantaCommentsComponent.ctorParameters = function () { return [
|
|
161
|
+
{ type: BantaService },
|
|
162
|
+
{ type: ChatBackendService }
|
|
163
|
+
]; };
|
|
164
|
+
__decorate([
|
|
165
|
+
Input(),
|
|
166
|
+
__metadata("design:type", Object),
|
|
167
|
+
__metadata("design:paramtypes", [Object])
|
|
168
|
+
], BantaCommentsComponent.prototype, "source", null);
|
|
169
|
+
__decorate([
|
|
170
|
+
Input(),
|
|
171
|
+
__metadata("design:type", String),
|
|
172
|
+
__metadata("design:paramtypes", [Object])
|
|
173
|
+
], BantaCommentsComponent.prototype, "topicID", null);
|
|
174
|
+
__decorate([
|
|
175
|
+
Input(),
|
|
176
|
+
__metadata("design:type", Object)
|
|
177
|
+
], BantaCommentsComponent.prototype, "signInLabel", void 0);
|
|
178
|
+
__decorate([
|
|
179
|
+
Input(),
|
|
180
|
+
__metadata("design:type", Object)
|
|
181
|
+
], BantaCommentsComponent.prototype, "sendLabel", void 0);
|
|
182
|
+
__decorate([
|
|
183
|
+
Input(),
|
|
184
|
+
__metadata("design:type", Object)
|
|
185
|
+
], BantaCommentsComponent.prototype, "permissionDeniedLabel", void 0);
|
|
186
|
+
__decorate([
|
|
187
|
+
Output(),
|
|
188
|
+
__metadata("design:type", Observable),
|
|
189
|
+
__metadata("design:paramtypes", [])
|
|
190
|
+
], BantaCommentsComponent.prototype, "signInSelected", null);
|
|
191
|
+
__decorate([
|
|
192
|
+
Output(),
|
|
193
|
+
__metadata("design:type", Observable),
|
|
194
|
+
__metadata("design:paramtypes", [])
|
|
195
|
+
], BantaCommentsComponent.prototype, "permissionDeniedError", null);
|
|
196
|
+
__decorate([
|
|
197
|
+
Output(),
|
|
198
|
+
__metadata("design:type", Object),
|
|
199
|
+
__metadata("design:paramtypes", [])
|
|
200
|
+
], BantaCommentsComponent.prototype, "upvoted", null);
|
|
201
|
+
__decorate([
|
|
202
|
+
Output(),
|
|
203
|
+
__metadata("design:type", Object),
|
|
204
|
+
__metadata("design:paramtypes", [])
|
|
205
|
+
], BantaCommentsComponent.prototype, "reported", null);
|
|
206
|
+
__decorate([
|
|
207
|
+
Output(),
|
|
208
|
+
__metadata("design:type", Object),
|
|
209
|
+
__metadata("design:paramtypes", [])
|
|
210
|
+
], BantaCommentsComponent.prototype, "selected", null);
|
|
211
|
+
__decorate([
|
|
212
|
+
Output(),
|
|
213
|
+
__metadata("design:type", Object),
|
|
214
|
+
__metadata("design:paramtypes", [])
|
|
215
|
+
], BantaCommentsComponent.prototype, "userSelected", null);
|
|
216
|
+
BantaCommentsComponent = __decorate([
|
|
217
|
+
Component({
|
|
218
|
+
selector: 'banta-comments',
|
|
219
|
+
template: "\r\n<form class=\"new-message\" (submit)=\"sendMessage()\">\r\n <div class=\"text-container\">\r\n <textarea \r\n name=\"message\" \r\n (keydown)=\"onKeyDown($event)\"\r\n [(ngModel)]=\"newMessageText\"></textarea>\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\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 color=\"primary\"\r\n [disabled]=\"!newMessageText\" \r\n >{{sendLabel}}</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\r\n<banta-comment-view \r\n [source]=\"source\"\r\n (userSelected)=\"selectMessageUser($event)\"\r\n (selected)=\"selectMessage($event)\"\r\n (upvoted)=\"upvoteMessage($event)\"\r\n (reported)=\"reportMessage($event)\"\r\n ></banta-comment-view>",
|
|
220
|
+
styles: [":host{display:flex;flex-direction:column}form{display:flex;padding:.5em 0;align-items:center}form .text-container{position:relative;display:flex;flex-grow:1}form .text-container textarea{font-size:14pt;background-color:#fff;color:#333;border:1px solid #ccc;min-height:6em;width:100%}form .text-container emoji-selector-button{bottom:0;right:0;position:absolute}form input[type=text]{background:#000;color:#fff;border:1px solid #333;width:100%;height:1em}form .actions{margin-left:1em}form button{display:block;margin:0 0 0 auto}:host-context(.mat-dark-theme) form .text-container textarea{background:#000;color:#fff;border-color:#333}"]
|
|
221
|
+
}),
|
|
222
|
+
__metadata("design:paramtypes", [BantaService,
|
|
223
|
+
ChatBackendService])
|
|
224
|
+
], BantaCommentsComponent);
|
|
225
|
+
return BantaCommentsComponent;
|
|
226
|
+
}());
|
|
227
|
+
export { BantaCommentsComponent };
|
|
228
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"banta-comments.component.js","sourceRoot":"ng://@banta/sdk/","sources":["lib/comments/banta-comments/banta-comments.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output } from '@angular/core';\r\nimport { User, ChatSource, ChatMessage, UserAccount } from '@banta/common';\r\nimport { Subject, Observable } from 'rxjs';\r\nimport { SubSink } from 'subsink';\r\nimport { ChatBackendService } from '../../chat-backend.service';\r\nimport { BantaService } from '../../common';\r\n\r\n/**\r\n * Comments component\r\n */\r\n@Component({\r\n    selector: 'banta-comments',\r\n    templateUrl: './banta-comments.component.html',\r\n    styleUrls: ['./banta-comments.component.scss']\r\n})\r\nexport class BantaCommentsComponent {\r\n    constructor(\r\n        private banta : BantaService,\r\n        private backend : ChatBackendService\r\n    ) {\r\n    }\r\n\r\n    private _upvoted = new Subject<ChatMessage>();\r\n    private _reported = new Subject<ChatMessage>();\r\n    private _selected = new Subject<ChatMessage>();\r\n    private _userSelected = new Subject<ChatMessage>();\r\n    private _source : ChatSource;\r\n\r\n    private _subs = new SubSink();\r\n\r\n    ngOnInit() {\r\n        this._subs.add(\r\n            this.banta.userChanged.subscribe(user => this.user = user)\r\n        )\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        this._subs.unsubscribe();\r\n    }\r\n\r\n    @Input()\r\n    get source() : ChatSource {\r\n        return this._source;\r\n    }\r\n\r\n    set source(value) {\r\n        this._source = value;\r\n    }\r\n\r\n    @Input()\r\n    get topicID() : string {\r\n        return this._source.identifier;\r\n    }\r\n\r\n    set topicID(value) {\r\n        this.setSourceFromTopicID(value);\r\n    }\r\n\r\n    private async setSourceFromTopicID(topicID : string) {\r\n        if (this._source && this._source.close)\r\n            this._source.close();\r\n        this._source = null;\r\n        this._source = await this.backend.getSourceForTopic(topicID);\r\n    }\r\n\r\n    showSignIn() {\r\n        this._signInSelected.next();\r\n    }\r\n\r\n    user : UserAccount;\r\n    newMessageText : string;\r\n\r\n    @Input() signInLabel = 'Sign In';\r\n    @Input() sendLabel = 'Send';\r\n    @Input() permissionDeniedLabel = 'Send';\r\n\r\n    private _signInSelected = new Subject<void>();\r\n    private _permissionDeniedError = new Subject<void>();\r\n\r\n    @Output()\r\n    get signInSelected(): Observable<void> {\r\n        return this._signInSelected;\r\n    }\r\n\r\n    @Output()\r\n    get permissionDeniedError(): Observable<void> {\r\n        return this._permissionDeniedError;\r\n    }\r\n\r\n    showPermissionDenied() {\r\n        this._permissionDeniedError.next();\r\n    }\r\n    \r\n    get canComment() {\r\n        if (!this.user.permissions)\r\n            return true;\r\n        \r\n        return this.user.permissions?.canComment(this.source);\r\n    }\r\n\r\n    @Output()\r\n    get upvoted() {\r\n        return this._upvoted;\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 selected() {\r\n        return this._selected;\r\n    }\r\n    @Output()\r\n    get userSelected() {\r\n        return this._userSelected;\r\n    }\r\n\r\n    onKeyDown(event : KeyboardEvent) {\r\n    }\r\n\r\n    insertEmoji(text : string) {\r\n        this.newMessageText += text;\r\n    }\r\n\r\n    sendMessage() {\r\n        if (!this.source)\r\n            return;\r\n        \r\n        let text = (this.newMessageText || '').trim();\r\n        this.newMessageText = '';\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        this.source.send(message);\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}"]}
|
|
@@ -86,12 +86,12 @@ var CommentComponent = /** @class */ (function () {
|
|
|
86
86
|
], CommentComponent.prototype, "selected", null);
|
|
87
87
|
CommentComponent = __decorate([
|
|
88
88
|
Component({
|
|
89
|
-
selector: '
|
|
90
|
-
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 <div class=\"avatar\" \r\n (click)=\"selectUser()\"\r\n [style.background-image]=\"avatarForUser(message.user)\"></div>\r\n <label class=\"display-name\" (click)=\"selectUser()\">{{message.user.displayName}}</label>\r\n <label class=\"username\" (click)=\"selectUser()\">@{{message.user.username}}</label>\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\" (click)=\"select()\">\r\n {{message.message}}\r\n </div>\r\n \r\n <div class=\"actions\">\r\n <
|
|
91
|
-
styles: [":host{display:flex;flex-direction:column;position:relative;padding:.5em}:host:hover{background:#eee}:host .message-content .content{margin-left:4em;margin-right:3em}:host.abbreviated .message-content .content{max-height:8.5em;text-overflow:ellipsis;overflow-y:hidden}:host .actions{display:flex;padding-right:10px;margin-left:4em;align-items:center}:host .actions button{color:#666}:host .actions
|
|
89
|
+
selector: 'banta-comment',
|
|
90
|
+
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 <div class=\"avatar\" \r\n (click)=\"selectUser()\"\r\n [style.background-image]=\"avatarForUser(message.user)\"></div>\r\n <label class=\"display-name\" (click)=\"selectUser()\">{{message.user.displayName}}</label>\r\n <label class=\"username\" (click)=\"selectUser()\">@{{message.user.username}}</label>\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\" (click)=\"select()\">\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",
|
|
91
|
+
styles: [":host{display:flex;flex-direction:column;position:relative;padding:.5em}:host:hover{background:#eee}:host .message-content .content{margin-left:4em;margin-right:3em}:host.abbreviated .message-content .content{max-height:8.5em;text-overflow:ellipsis;overflow-y:hidden}:host .actions{display:flex;padding-right:10px;margin-left:4em;align-items:center}:host .actions button{color:#666}:host .actions banta-timestamp{color:#666;font-size:10pt}.user{position:relative;margin:1em 0 0;display:flex;align-items:center}.user label{z-index:1;position:relative;padding:0 0 0 1em;font-size:10pt;color:#000;margin:0 auto 0 0;display:block;width:-webkit-fit-content;width:-moz-fit-content;width:fit-content;max-width:100%;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;flex-shrink:1;flex-grow:0}.user label.username{color:#666;flex-shrink:0;flex-grow:1}.avatar{height:3em;width:3em;background-position:center;background-size:cover;background-color:#333;border-radius:100%;flex-shrink:0;flex-grow:0}.counted-action{display:flex;align-items:center}.count-indicator{font-size:9pt;padding:0 3px;border-radius:3px;border:1px solid #ccc;color:#666}:host-context(.mat-dark-theme) .count-indicator{border-color:#333}:host-context(.mat-dark-theme):hover{background:#060606}:host-context(.mat-dark-theme) .user label{color:#fff}"]
|
|
92
92
|
})
|
|
93
93
|
], CommentComponent);
|
|
94
94
|
return CommentComponent;
|
|
95
95
|
}());
|
|
96
96
|
export { CommentComponent };
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbWVudC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AYmFudGEvc2RrLyIsInNvdXJjZXMiOlsibGliL2NvbW1lbnRzL2NvbW1lbnQvY29tbWVudC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6RCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBUS9CO0lBQUE7UUFDWSxjQUFTLEdBQUcsSUFBSSxPQUFPLEVBQVEsQ0FBQztRQUNoQyxjQUFTLEdBQUcsSUFBSSxPQUFPLEVBQVEsQ0FBQztRQUNoQyxhQUFRLEdBQUcsSUFBSSxPQUFPLEVBQVEsQ0FBQztRQUMvQixrQkFBYSxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFNNUMsb0JBQWUsR0FBRyxJQUFJLENBQUM7SUE4QzNCLENBQUM7SUEzQ0csc0JBQUksMENBQVk7YUFBaEI7WUFDSSxPQUFPLElBQUksQ0FBQyxhQUFhLENBQUM7UUFDOUIsQ0FBQzs7O09BQUE7SUFHRCxzQkFBSSxzQ0FBUTthQUFaO1lBQ0ksT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO1FBQzFCLENBQUM7OztPQUFBO0lBR0Qsc0JBQUkscUNBQU87YUFBWDtZQUNJLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQztRQUN6QixDQUFDOzs7T0FBQTtJQUdELHNCQUFJLHNDQUFRO2FBQVo7WUFDSSxPQUFPLElBQUksQ0FBQyxTQUFTLENBQUM7UUFDMUIsQ0FBQzs7O09BQUE7SUFFRCxpQ0FBTSxHQUFOO1FBQ0ksSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUMxQixDQUFDO0lBRUQsaUNBQU0sR0FBTjtRQUNJLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDekIsQ0FBQztJQUVELGlDQUFNLEdBQU47UUFDSSxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzFCLENBQUM7SUFFRCxxQ0FBVSxHQUFWO1FBQ0ksT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3JDLENBQUM7SUFFRCx3Q0FBYSxHQUFiLFVBQWMsSUFBVztRQUNyQixJQUFJLElBQUksSUFBSSxJQUFJLENBQUMsU0FBUyxFQUFFO1lBQ3hCLElBQUksR0FBRyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUM7WUFDekIsT0FBTyxTQUFPLEdBQUcsTUFBRyxDQUFDO1NBQ3hCO1FBRUQsT0FBTyxJQUFJLENBQUM7SUFDaEIsQ0FBQztJQWhERDtRQURDLEtBQUssRUFBRTs7cURBQ2M7SUFHdEI7UUFEQyxLQUFLLEVBQUU7OzZEQUNlO0lBR3ZCO1FBREMsTUFBTSxFQUFFOzs7d0RBR1I7SUFHRDtRQURDLE1BQU0sRUFBRTs7O29EQUdSO0lBR0Q7UUFEQyxNQUFNLEVBQUU7OzttREFHUjtJQUdEO1FBREMsTUFBTSxFQUFFOzs7b0RBR1I7SUE5QlEsZ0JBQWdCO1FBTDVCLFNBQVMsQ0FBQztZQUNQLFFBQVEsRUFBRSxlQUFlO1lBQ3pCLGl6REFBdUM7O1NBRTFDLENBQUM7T0FDVyxnQkFBZ0IsQ0F3RDVCO0lBQUQsdUJBQUM7Q0FBQSxBQXhERCxJQXdEQztTQXhEWSxnQkFBZ0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE91dHB1dCwgSW5wdXQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IENoYXRNZXNzYWdlLCBVc2VyIH0gZnJvbSAnQGJhbnRhL2NvbW1vbic7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAnYmFudGEtY29tbWVudCcsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vY29tbWVudC5jb21wb25lbnQuaHRtbCcsXHJcbiAgICBzdHlsZVVybHM6IFsnLi9jb21tZW50LmNvbXBvbmVudC5zY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIENvbW1lbnRDb21wb25lbnQge1xyXG4gICAgcHJpdmF0ZSBfcmVwb3J0ZWQgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xyXG4gICAgcHJpdmF0ZSBfc2VsZWN0ZWQgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xyXG4gICAgcHJpdmF0ZSBfdXB2b3RlZCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XHJcbiAgICBwcml2YXRlIF91c2VyU2VsZWN0ZWQgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xyXG4gICAgXHJcbiAgICBASW5wdXQoKVxyXG4gICAgbWVzc2FnZSA6IENoYXRNZXNzYWdlO1xyXG5cclxuICAgIEBJbnB1dCgpXHJcbiAgICBzaG93UmVwbHlBY3Rpb24gPSB0cnVlO1xyXG5cclxuICAgIEBPdXRwdXQoKVxyXG4gICAgZ2V0IHVzZXJTZWxlY3RlZCgpIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5fdXNlclNlbGVjdGVkO1xyXG4gICAgfVxyXG5cclxuICAgIEBPdXRwdXQoKVxyXG4gICAgZ2V0IHJlcG9ydGVkKCkge1xyXG4gICAgICAgIHJldHVybiB0aGlzLl9yZXBvcnRlZDtcclxuICAgIH1cclxuICAgIFxyXG4gICAgQE91dHB1dCgpXHJcbiAgICBnZXQgdXB2b3RlZCgpIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5fdXB2b3RlZDtcclxuICAgIH1cclxuXHJcbiAgICBAT3V0cHV0KClcclxuICAgIGdldCBzZWxlY3RlZCgpIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5fc2VsZWN0ZWQ7XHJcbiAgICB9XHJcblxyXG4gICAgcmVwb3J0KCkge1xyXG4gICAgICAgIHRoaXMuX3JlcG9ydGVkLm5leHQoKTtcclxuICAgIH1cclxuICAgIFxyXG4gICAgdXB2b3RlKCkge1xyXG4gICAgICAgIHRoaXMuX3Vwdm90ZWQubmV4dCgpO1xyXG4gICAgfVxyXG5cclxuICAgIHNlbGVjdCgpIHtcclxuICAgICAgICB0aGlzLl9zZWxlY3RlZC5uZXh0KCk7XHJcbiAgICB9XHJcblxyXG4gICAgc2VsZWN0VXNlcigpIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5fdXNlclNlbGVjdGVkLm5leHQoKTtcclxuICAgIH1cclxuICAgIFxyXG4gICAgYXZhdGFyRm9yVXNlcih1c2VyIDogVXNlcikge1xyXG4gICAgICAgIGlmICh1c2VyICYmIHVzZXIuYXZhdGFyVXJsKSB7XHJcbiAgICAgICAgICAgIGxldCB1cmwgPSB1c2VyLmF2YXRhclVybDtcclxuICAgICAgICAgICAgcmV0dXJuIGB1cmwoJHt1cmx9KWA7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICByZXR1cm4gbnVsbDtcclxuICAgIH1cclxufSJdfQ==
|
|
@@ -179,8 +179,8 @@ var CommentViewComponent = /** @class */ (function () {
|
|
|
179
179
|
], CommentViewComponent.prototype, "newestLast", void 0);
|
|
180
180
|
CommentViewComponent = __decorate([
|
|
181
181
|
Component({
|
|
182
|
-
selector: '
|
|
183
|
-
template: "<div class=\"message-container\">\r\n <ng-content select=\"[data-before]\"></ng-content>\r\n <
|
|
182
|
+
selector: 'banta-comment-view',
|
|
183
|
+
template: "<div class=\"message-container\">\r\n <ng-content select=\"[data-before]\"></ng-content>\r\n <banta-comment \r\n *ngFor=\"let message of messages\"\r\n class=\"abbreviated\"\r\n [message]=\"message\"\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 <ng-content select=\":not([data-before])\"></ng-content>\r\n</div>",
|
|
184
184
|
styles: [":host{flex-grow:1;display:flex;flex-direction:column;opacity:1;transition:opacity .2s ease-in}.message-container{flex-grow:1;overflow-y:auto;overflow-x:hidden;height:10em;color:#000;background:#fff;padding:.5em 1em .5em .5em}.message-container.no-scroll{height:auto;overflow-y:visible}:host-context(.mat-dark-theme) .message-container{color:#fff;background:#000}"]
|
|
185
185
|
}),
|
|
186
186
|
__metadata("design:paramtypes", [])
|
|
@@ -188,4 +188,4 @@ var CommentViewComponent = /** @class */ (function () {
|
|
|
188
188
|
return CommentViewComponent;
|
|
189
189
|
}());
|
|
190
190
|
export { CommentViewComponent };
|
|
191
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"comment-view.component.js","sourceRoot":"ng://@banta/sdk/","sources":["lib/comments/comment-view/comment-view.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ViewChild, ElementRef, Output } from \"@angular/core\";\r\nimport { User, ChatMessage, ChatSource } from '@banta/common';\r\nimport { SubSink } from 'subsink';\r\nimport { Subject } from 'rxjs';\r\n\r\n@Component({\r\n    selector: 'engage-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\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    allowReplies = true;\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    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 || [];\r\n\r\n            this._sourceSubs = new SubSink();\r\n            this.messages = messages.slice();\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 = 200;\r\n\r\n    @Input()\r\n    newestLast = false;\r\n\r\n    private addMessage(message : ChatMessage) {\r\n        if (this.newestLast) {\r\n            while (this.messages.length + 1 > this.maxMessages)\r\n                this.messages.shift();\r\n                \r\n            this.messages.push(message);\r\n        } else {\r\n            while (this.messages.length + 1 > this.maxMessages)\r\n                this.messages.pop();\r\n                \r\n            this.messages.unshift(message);\r\n        }\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}"]}
|
|
191
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"comment-view.component.js","sourceRoot":"ng://@banta/sdk/","sources":["lib/comments/comment-view/comment-view.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ViewChild, ElementRef, Output } from \"@angular/core\";\r\nimport { User, ChatMessage, ChatSource } from '@banta/common';\r\nimport { SubSink } from 'subsink';\r\nimport { Subject } from 'rxjs';\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\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    allowReplies = true;\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    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 || [];\r\n\r\n            this._sourceSubs = new SubSink();\r\n            this.messages = messages.slice();\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 = 200;\r\n\r\n    @Input()\r\n    newestLast = false;\r\n\r\n    private addMessage(message : ChatMessage) {\r\n        if (this.newestLast) {\r\n            while (this.messages.length + 1 > this.maxMessages)\r\n                this.messages.shift();\r\n                \r\n            this.messages.push(message);\r\n        } else {\r\n            while (this.messages.length + 1 > this.maxMessages)\r\n                this.messages.pop();\r\n                \r\n            this.messages.unshift(message);\r\n        }\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}"]}
|
|
@@ -2,10 +2,10 @@ import { __decorate } from "tslib";
|
|
|
2
2
|
import { NgModule } from '@angular/core';
|
|
3
3
|
import { CommentComponent } from './comment/comment.component';
|
|
4
4
|
import { CommentViewComponent } from './comment-view/comment-view.component';
|
|
5
|
-
import {
|
|
5
|
+
import { BantaCommentsComponent } from './banta-comments/banta-comments.component';
|
|
6
6
|
import { CommonModule } from '@angular/common';
|
|
7
7
|
import { FormsModule } from '@angular/forms';
|
|
8
|
-
import {
|
|
8
|
+
import { BantaCommonModule } from '../common/common.module';
|
|
9
9
|
import { LiveCommentComponent } from './live-comment.component';
|
|
10
10
|
import { EmojiModule } from '../emoji';
|
|
11
11
|
import { MatIconModule } from '@angular/material/icon';
|
|
@@ -14,7 +14,7 @@ import { MatMenuModule } from '@angular/material/menu';
|
|
|
14
14
|
var COMPONENTS = [
|
|
15
15
|
CommentComponent,
|
|
16
16
|
CommentViewComponent,
|
|
17
|
-
|
|
17
|
+
BantaCommentsComponent,
|
|
18
18
|
LiveCommentComponent
|
|
19
19
|
];
|
|
20
20
|
var CommentsModule = /** @class */ (function () {
|
|
@@ -29,7 +29,7 @@ var CommentsModule = /** @class */ (function () {
|
|
|
29
29
|
MatIconModule,
|
|
30
30
|
MatButtonModule,
|
|
31
31
|
MatMenuModule,
|
|
32
|
-
|
|
32
|
+
BantaCommonModule,
|
|
33
33
|
EmojiModule
|
|
34
34
|
],
|
|
35
35
|
exports: COMPONENTS
|
|
@@ -38,4 +38,4 @@ var CommentsModule = /** @class */ (function () {
|
|
|
38
38
|
return CommentsModule;
|
|
39
39
|
}());
|
|
40
40
|
export { CommentsModule };
|
|
41
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbWVudHMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQGJhbnRhL3Nkay8iLCJzb3VyY2VzIjpbImxpYi9jb21tZW50cy9jb21tZW50cy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDL0QsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDN0UsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDbkYsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUM1RCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNoRSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQ3ZDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBRXZELElBQU0sVUFBVSxHQUFHO0lBQ2YsZ0JBQWdCO0lBQ2hCLG9CQUFvQjtJQUNwQixzQkFBc0I7SUFDdEIsb0JBQW9CO0NBQ3ZCLENBQUM7QUFlRjtJQUFBO0lBQ0EsQ0FBQztJQURZLGNBQWM7UUFiMUIsUUFBUSxDQUFDO1lBQ04sWUFBWSxFQUFFLFVBQVU7WUFDeEIsT0FBTyxFQUFFO2dCQUNMLFlBQVk7Z0JBQ1osV0FBVztnQkFDWCxhQUFhO2dCQUNiLGVBQWU7Z0JBQ2YsYUFBYTtnQkFDYixpQkFBaUI7Z0JBQ2pCLFdBQVc7YUFDZDtZQUNELE9BQU8sRUFBRSxVQUFVO1NBQ3RCLENBQUM7T0FDVyxjQUFjLENBQzFCO0lBQUQscUJBQUM7Q0FBQSxBQURELElBQ0M7U0FEWSxjQUFjIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbWVudENvbXBvbmVudCB9IGZyb20gJy4vY29tbWVudC9jb21tZW50LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IENvbW1lbnRWaWV3Q29tcG9uZW50IH0gZnJvbSAnLi9jb21tZW50LXZpZXcvY29tbWVudC12aWV3LmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEJhbnRhQ29tbWVudHNDb21wb25lbnQgfSBmcm9tICcuL2JhbnRhLWNvbW1lbnRzL2JhbnRhLWNvbW1lbnRzLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBCYW50YUNvbW1vbk1vZHVsZSB9IGZyb20gJy4uL2NvbW1vbi9jb21tb24ubW9kdWxlJztcclxuaW1wb3J0IHsgTGl2ZUNvbW1lbnRDb21wb25lbnQgfSBmcm9tICcuL2xpdmUtY29tbWVudC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBFbW9qaU1vZHVsZSB9IGZyb20gJy4uL2Vtb2ppJztcclxuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xyXG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xyXG5pbXBvcnQgeyBNYXRNZW51TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvbWVudSc7XHJcblxyXG5jb25zdCBDT01QT05FTlRTID0gW1xyXG4gICAgQ29tbWVudENvbXBvbmVudCxcclxuICAgIENvbW1lbnRWaWV3Q29tcG9uZW50LFxyXG4gICAgQmFudGFDb21tZW50c0NvbXBvbmVudCxcclxuICAgIExpdmVDb21tZW50Q29tcG9uZW50XHJcbl07XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgZGVjbGFyYXRpb25zOiBDT01QT05FTlRTLFxyXG4gICAgaW1wb3J0czogW1xyXG4gICAgICAgIENvbW1vbk1vZHVsZSxcclxuICAgICAgICBGb3Jtc01vZHVsZSxcclxuICAgICAgICBNYXRJY29uTW9kdWxlLFxyXG4gICAgICAgIE1hdEJ1dHRvbk1vZHVsZSxcclxuICAgICAgICBNYXRNZW51TW9kdWxlLFxyXG4gICAgICAgIEJhbnRhQ29tbW9uTW9kdWxlLFxyXG4gICAgICAgIEVtb2ppTW9kdWxlXHJcbiAgICBdLFxyXG4gICAgZXhwb3J0czogQ09NUE9ORU5UU1xyXG59KVxyXG5leHBvcnQgY2xhc3MgQ29tbWVudHNNb2R1bGUge1xyXG59Il19
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
export * from './comment/comment.component';
|
|
2
2
|
export * from './comment-view/comment-view.component';
|
|
3
|
-
export * from './comments-
|
|
3
|
+
export * from './banta-comments/banta-comments.component';
|
|
4
4
|
export * from './live-comment.component';
|
|
5
5
|
export * from './comments.module';
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AYmFudGEvc2RrLyIsInNvdXJjZXMiOlsibGliL2NvbW1lbnRzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsMEJBQTBCLENBQUM7QUFFekMsY0FBYyxtQkFBbUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY29tbWVudC9jb21tZW50LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY29tbWVudC12aWV3L2NvbW1lbnQtdmlldy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2JhbnRhLWNvbW1lbnRzL2JhbnRhLWNvbW1lbnRzLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGl2ZS1jb21tZW50LmNvbXBvbmVudCc7XHJcblxyXG5leHBvcnQgKiBmcm9tICcuL2NvbW1lbnRzLm1vZHVsZSc7Il19
|
|
@@ -86,8 +86,8 @@ var LiveCommentComponent = /** @class */ (function () {
|
|
|
86
86
|
], LiveCommentComponent.prototype, "message", null);
|
|
87
87
|
LiveCommentComponent = __decorate([
|
|
88
88
|
Component({
|
|
89
|
-
selector: '
|
|
90
|
-
template: "\n <
|
|
89
|
+
selector: 'banta-live-comment',
|
|
90
|
+
template: "\n <banta-comment \n *ngIf=\"message\"\n [message]=\"message\"\n (upvoted)=\"upvote()\"\n (reported)=\"report()\"\n (selected)=\"select()\"\n ></banta-comment>\n ",
|
|
91
91
|
styles: [""]
|
|
92
92
|
}),
|
|
93
93
|
__metadata("design:paramtypes", [ChatBackendService])
|
|
@@ -95,4 +95,4 @@ var LiveCommentComponent = /** @class */ (function () {
|
|
|
95
95
|
return LiveCommentComponent;
|
|
96
96
|
}());
|
|
97
97
|
export { LiveCommentComponent };
|
|
98
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGl2ZS1jb21tZW50LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BiYW50YS9zZGsvIiwic291cmNlcyI6WyJsaWIvY29tbWVudHMvbGl2ZS1jb21tZW50LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpELE9BQU8sRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBZTdEO0lBQ0ksOEJBQ1ksT0FBNEI7UUFBNUIsWUFBTyxHQUFQLE9BQU8sQ0FBcUI7UUFNaEMsYUFBUSxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFDL0IsY0FBUyxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFDaEMsY0FBUyxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7SUFMeEMsQ0FBQztJQVFELHNCQUFJLHlDQUFPO2FBQVg7WUFDSSxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUM7UUFDekIsQ0FBQzs7O09BQUE7SUFHRCxzQkFBSSwwQ0FBUTthQUFaO1lBQ0ksT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO1FBQzFCLENBQUM7OztPQUFBO0lBR0Qsc0JBQUksMENBQVE7YUFBWjtZQUNJLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQztRQUMxQixDQUFDOzs7T0FBQTtJQUdELHNCQUFJLHlDQUFPO2FBQVg7WUFDSSxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUM7UUFDekIsQ0FBQzthQUlELFVBQVksS0FBSztZQUFqQixpQkFpQkM7WUFoQkcsSUFBSSxVQUFVLEdBQUcsSUFBSSxDQUFDO1lBQ3RCLElBQUksSUFBSSxDQUFDLFFBQVE7Z0JBQ2IsVUFBVSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDO1lBRWxDLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDO1lBRXRCLElBQUksS0FBSyxJQUFJLFVBQVUsS0FBSyxLQUFLLENBQUMsRUFBRSxFQUFFO2dCQUNsQyxPQUFPO2FBQ1Y7WUFFRCxJQUFJLElBQUksQ0FBQyxXQUFXO2dCQUNoQixJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7WUFFdkIsSUFBSSxLQUFLLEVBQUU7Z0JBQ1AsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLFlBQVksQ0FBQyxLQUFLLEVBQUUsVUFBQSxPQUFPLElBQUksT0FBQSxLQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sRUFBdEIsQ0FBc0IsQ0FBQyxDQUFDO2FBQzFGO1FBQ0wsQ0FBQzs7O09BckJBO0lBdUJELHFDQUFNLEdBQU47UUFDSSxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzFCLENBQUM7SUFFRCxxQ0FBTSxHQUFOO1FBQ0ksSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUN6QixDQUFDO0lBRUQscUNBQU0sR0FBTjtRQUNJLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDMUIsQ0FBQzs7Z0JBN0RxQixrQkFBa0I7O0lBV3hDO1FBREMsTUFBTSxFQUFFO2tDQUNPLFVBQVU7O3VEQUV6QjtJQUdEO1FBREMsTUFBTSxFQUFFO2tDQUNRLFVBQVU7O3dEQUUxQjtJQUdEO1FBREMsTUFBTSxFQUFFO2tDQUNRLFVBQVU7O3dEQUUxQjtJQUdEO1FBREMsS0FBSyxFQUFFOzs7dURBR1A7SUE5QlEsb0JBQW9CO1FBYmhDLFNBQVMsQ0FBQztZQUNQLFFBQVEsRUFBRSxvQkFBb0I7WUFDOUIsUUFBUSxFQUFFLGdQQVFUO3FCQUNRLEVBQUU7U0FDZCxDQUFDO3lDQUd3QixrQkFBa0I7T0FGL0Isb0JBQW9CLENBZ0VoQztJQUFELDJCQUFDO0NBQUEsQUFoRUQsSUFnRUM7U0FoRVksb0JBQW9CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENoYXRNZXNzYWdlIH0gZnJvbSAnQGJhbnRhL2NvbW1vbic7XHJcbmltcG9ydCB7IFN1YmplY3QsIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgQ2hhdEJhY2tlbmRTZXJ2aWNlIH0gZnJvbSAnLi4vY2hhdC1iYWNrZW5kLnNlcnZpY2UnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2JhbnRhLWxpdmUtY29tbWVudCcsXHJcbiAgICB0ZW1wbGF0ZTogYFxyXG4gICAgICAgIDxiYW50YS1jb21tZW50IFxyXG4gICAgICAgICAgICAqbmdJZj1cIm1lc3NhZ2VcIlxyXG4gICAgICAgICAgICBbbWVzc2FnZV09XCJtZXNzYWdlXCJcclxuICAgICAgICAgICAgKHVwdm90ZWQpPVwidXB2b3RlKClcIlxyXG4gICAgICAgICAgICAocmVwb3J0ZWQpPVwicmVwb3J0KClcIlxyXG4gICAgICAgICAgICAoc2VsZWN0ZWQpPVwic2VsZWN0KClcIlxyXG4gICAgICAgICAgICA+PC9iYW50YS1jb21tZW50PlxyXG4gICAgYCxcclxuICAgIHN0eWxlczogW2BgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgTGl2ZUNvbW1lbnRDb21wb25lbnQge1xyXG4gICAgY29uc3RydWN0b3IoXHJcbiAgICAgICAgcHJpdmF0ZSBiYWNrZW5kIDogQ2hhdEJhY2tlbmRTZXJ2aWNlXHJcbiAgICApIHtcclxuXHJcbiAgICB9XHJcblxyXG4gICAgcHJpdmF0ZSBfbWVzc2FnZSA6IENoYXRNZXNzYWdlO1xyXG4gICAgcHJpdmF0ZSBfdXB2b3RlZCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XHJcbiAgICBwcml2YXRlIF9yZXBvcnRlZCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XHJcbiAgICBwcml2YXRlIF9zZWxlY3RlZCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XHJcblxyXG4gICAgQE91dHB1dCgpXHJcbiAgICBnZXQgdXB2b3RlZCgpIDogT2JzZXJ2YWJsZTx2b2lkPiB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuX3Vwdm90ZWQ7XHJcbiAgICB9XHJcbiAgICBcclxuICAgIEBPdXRwdXQoKVxyXG4gICAgZ2V0IHJlcG9ydGVkKCkgOiBPYnNlcnZhYmxlPHZvaWQ+IHtcclxuICAgICAgICByZXR1cm4gdGhpcy5fcmVwb3J0ZWQ7XHJcbiAgICB9XHJcblxyXG4gICAgQE91dHB1dCgpXHJcbiAgICBnZXQgc2VsZWN0ZWQoKSA6IE9ic2VydmFibGU8dm9pZD4ge1xyXG4gICAgICAgIHJldHVybiB0aGlzLl9zZWxlY3RlZDtcclxuICAgIH1cclxuICAgIFxyXG4gICAgQElucHV0KClcclxuICAgIGdldCBtZXNzYWdlKCkgOiBDaGF0TWVzc2FnZSB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuX21lc3NhZ2U7XHJcbiAgICB9XHJcblxyXG4gICAgcHJpdmF0ZSB1bnN1YnNjcmliZSA6IEZ1bmN0aW9uO1xyXG5cclxuICAgIHNldCBtZXNzYWdlKHZhbHVlKSB7XHJcbiAgICAgICAgbGV0IG9yaWdpbmFsSWQgPSBudWxsO1xyXG4gICAgICAgIGlmICh0aGlzLl9tZXNzYWdlKVxyXG4gICAgICAgICAgICBvcmlnaW5hbElkID0gdGhpcy5fbWVzc2FnZS5pZDtcclxuICAgICAgICBcclxuICAgICAgICB0aGlzLl9tZXNzYWdlID0gdmFsdWU7XHJcblxyXG4gICAgICAgIGlmICh2YWx1ZSAmJiBvcmlnaW5hbElkID09PSB2YWx1ZS5pZCkge1xyXG4gICAgICAgICAgICByZXR1cm47XHJcbiAgICAgICAgfVxyXG4gICAgICAgIFxyXG4gICAgICAgIGlmICh0aGlzLnVuc3Vic2NyaWJlKVxyXG4gICAgICAgICAgICB0aGlzLnVuc3Vic2NyaWJlKCk7XHJcbiAgICAgICAgXHJcbiAgICAgICAgaWYgKHZhbHVlKSB7XHJcbiAgICAgICAgICAgIHRoaXMudW5zdWJzY3JpYmUgPSB0aGlzLmJhY2tlbmQud2F0Y2hNZXNzYWdlKHZhbHVlLCBtZXNzYWdlID0+IHRoaXMubWVzc2FnZSA9IG1lc3NhZ2UpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICByZXBvcnQoKSB7XHJcbiAgICAgICAgdGhpcy5fcmVwb3J0ZWQubmV4dCgpO1xyXG4gICAgfVxyXG4gICAgXHJcbiAgICB1cHZvdGUoKSB7XHJcbiAgICAgICAgdGhpcy5fdXB2b3RlZC5uZXh0KCk7XHJcbiAgICB9XHJcblxyXG4gICAgc2VsZWN0KCkge1xyXG4gICAgICAgIHRoaXMuX3NlbGVjdGVkLm5leHQoKTtcclxuICAgIH1cclxufSJdfQ==
|
|
@@ -6,20 +6,20 @@ import { BantaService } from './banta.service';
|
|
|
6
6
|
var COMPONENTS = [
|
|
7
7
|
TimestampComponent
|
|
8
8
|
];
|
|
9
|
-
var
|
|
10
|
-
function
|
|
9
|
+
var BantaCommonModule = /** @class */ (function () {
|
|
10
|
+
function BantaCommonModule() {
|
|
11
11
|
}
|
|
12
|
-
|
|
13
|
-
|
|
12
|
+
BantaCommonModule_1 = BantaCommonModule;
|
|
13
|
+
BantaCommonModule.forRoot = function () {
|
|
14
14
|
return {
|
|
15
|
-
ngModule:
|
|
15
|
+
ngModule: BantaCommonModule_1,
|
|
16
16
|
providers: [
|
|
17
17
|
BantaService
|
|
18
18
|
]
|
|
19
19
|
};
|
|
20
20
|
};
|
|
21
|
-
var
|
|
22
|
-
|
|
21
|
+
var BantaCommonModule_1;
|
|
22
|
+
BantaCommonModule = BantaCommonModule_1 = __decorate([
|
|
23
23
|
NgModule({
|
|
24
24
|
declarations: COMPONENTS,
|
|
25
25
|
imports: [
|
|
@@ -27,8 +27,8 @@ var EngageCommonModule = /** @class */ (function () {
|
|
|
27
27
|
],
|
|
28
28
|
exports: COMPONENTS
|
|
29
29
|
})
|
|
30
|
-
],
|
|
31
|
-
return
|
|
30
|
+
], BantaCommonModule);
|
|
31
|
+
return BantaCommonModule;
|
|
32
32
|
}());
|
|
33
|
-
export {
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
33
|
+
export { BantaCommonModule };
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BiYW50YS9zZGsvIiwic291cmNlcyI6WyJsaWIvY29tbW9uL2NvbW1vbi5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBdUIsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzlELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzNELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFL0MsSUFBTSxVQUFVLEdBQUc7SUFDZixrQkFBa0I7Q0FDckIsQ0FBQztBQVNGO0lBQUE7SUFTQSxDQUFDOzBCQVRZLGlCQUFpQjtJQUNuQix5QkFBTyxHQUFkO1FBQ0ksT0FBTztZQUNILFFBQVEsRUFBRSxtQkFBaUI7WUFDM0IsU0FBUyxFQUFFO2dCQUNQLFlBQVk7YUFDZjtTQUNKLENBQUE7SUFDTCxDQUFDOztJQVJRLGlCQUFpQjtRQVA3QixRQUFRLENBQUM7WUFDTixZQUFZLEVBQUUsVUFBVTtZQUN4QixPQUFPLEVBQUU7Z0JBQ0wsWUFBWTthQUNmO1lBQ0QsT0FBTyxFQUFFLFVBQVU7U0FDdEIsQ0FBQztPQUNXLGlCQUFpQixDQVM3QjtJQUFELHdCQUFDO0NBQUEsQUFURCxJQVNDO1NBVFksaUJBQWlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTW9kdWxlV2l0aFByb3ZpZGVycywgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgVGltZXN0YW1wQ29tcG9uZW50IH0gZnJvbSAnLi90aW1lc3RhbXAuY29tcG9uZW50JztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgQmFudGFTZXJ2aWNlIH0gZnJvbSAnLi9iYW50YS5zZXJ2aWNlJztcclxuXHJcbmNvbnN0IENPTVBPTkVOVFMgPSBbXHJcbiAgICBUaW1lc3RhbXBDb21wb25lbnRcclxuXTtcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgICBkZWNsYXJhdGlvbnM6IENPTVBPTkVOVFMsXHJcbiAgICBpbXBvcnRzOiBbXHJcbiAgICAgICAgQ29tbW9uTW9kdWxlXHJcbiAgICBdLFxyXG4gICAgZXhwb3J0czogQ09NUE9ORU5UU1xyXG59KVxyXG5leHBvcnQgY2xhc3MgQmFudGFDb21tb25Nb2R1bGUge1xyXG4gICAgc3RhdGljIGZvclJvb3QoKTogTW9kdWxlV2l0aFByb3ZpZGVyczxCYW50YUNvbW1vbk1vZHVsZT4ge1xyXG4gICAgICAgIHJldHVybiB7XHJcbiAgICAgICAgICAgIG5nTW9kdWxlOiBCYW50YUNvbW1vbk1vZHVsZSxcclxuICAgICAgICAgICAgcHJvdmlkZXJzOiBbXHJcbiAgICAgICAgICAgICAgICBCYW50YVNlcnZpY2VcclxuICAgICAgICAgICAgXVxyXG4gICAgICAgIH1cclxuICAgIH1cclxufSJdfQ==
|
|
@@ -98,7 +98,7 @@ var TimestampComponent = /** @class */ (function () {
|
|
|
98
98
|
], TimestampComponent.prototype, "value", null);
|
|
99
99
|
TimestampComponent = __decorate([
|
|
100
100
|
Component({
|
|
101
|
-
selector: '
|
|
101
|
+
selector: 'banta-timestamp',
|
|
102
102
|
template: "\n <span *ngIf=\"showAbsolute\" [title]=\"value | date : 'short'\">\n {{value | date : 'shortDate'}}\n </span>\n <span *ngIf=\"!showAbsolute\" [title]=\"value | date : 'short'\">\n {{relative}}\n </span>\n ",
|
|
103
103
|
styles: [""]
|
|
104
104
|
})
|
|
@@ -106,4 +106,4 @@ var TimestampComponent = /** @class */ (function () {
|
|
|
106
106
|
return TimestampComponent;
|
|
107
107
|
}());
|
|
108
108
|
export { TimestampComponent };
|
|
109
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
109
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timestamp.component.js","sourceRoot":"ng://@banta/sdk/","sources":["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}"]}
|
package/esm5/lib/index.js
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
export * from './common';
|
|
2
2
|
export * from './emoji';
|
|
3
|
-
export * from './
|
|
4
|
-
export * from './
|
|
3
|
+
export * from './banta/banta.component';
|
|
4
|
+
export * from './banta-logo.component';
|
|
5
5
|
export * from './chat';
|
|
6
6
|
export * from './live-message.component';
|
|
7
7
|
export * from './comments';
|
|
8
8
|
export * from './chat-backend.service';
|
|
9
9
|
export * from './banta-sdk.module';
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AYmFudGEvc2RrLyIsInNvdXJjZXMiOlsibGliL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsU0FBUyxDQUFDO0FBQ3hCLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLFFBQVEsQ0FBQztBQUN2QixjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsd0JBQXdCLENBQUM7QUFFdkMsY0FBYyxvQkFBb0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY29tbW9uJztcclxuZXhwb3J0ICogZnJvbSAnLi9lbW9qaSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vYmFudGEvYmFudGEuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9iYW50YS1sb2dvLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY2hhdCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGl2ZS1tZXNzYWdlLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY29tbWVudHMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2NoYXQtYmFja2VuZC5zZXJ2aWNlJztcclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vYmFudGEtc2RrLm1vZHVsZSc7Il19
|