@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,245 @@
|
|
|
1
|
+
import { __awaiter, __decorate, __generator, __metadata } from "tslib";
|
|
2
|
+
import { Component, Input, Output, ElementRef, ViewChild } from "@angular/core";
|
|
3
|
+
import { Subject, Observable } from 'rxjs';
|
|
4
|
+
import { SubSink } from 'subsink';
|
|
5
|
+
import { ChatViewComponent } from '../chat-view/chat-view.component';
|
|
6
|
+
import { BantaService } from '../../common';
|
|
7
|
+
import { ChatBackendService } from "../../chat-backend.service";
|
|
8
|
+
/**
|
|
9
|
+
* Chat component
|
|
10
|
+
*/
|
|
11
|
+
var BantaChatComponent = /** @class */ (function () {
|
|
12
|
+
function BantaChatComponent(banta, backend, elementRef) {
|
|
13
|
+
this.banta = banta;
|
|
14
|
+
this.backend = backend;
|
|
15
|
+
this.elementRef = elementRef;
|
|
16
|
+
this._subs = new SubSink();
|
|
17
|
+
this.user = null;
|
|
18
|
+
this.signInLabel = 'Sign In';
|
|
19
|
+
this.sendLabel = 'Send';
|
|
20
|
+
this.permissionDeniedLabel = 'Send';
|
|
21
|
+
this._selected = new Subject();
|
|
22
|
+
this._reported = new Subject();
|
|
23
|
+
this._upvoted = new Subject();
|
|
24
|
+
this._userSelected = new Subject();
|
|
25
|
+
this._signInSelected = new Subject();
|
|
26
|
+
this._permissionDeniedError = new Subject();
|
|
27
|
+
this.showEmojiPanel = false;
|
|
28
|
+
this.newMessage = {};
|
|
29
|
+
}
|
|
30
|
+
BantaChatComponent.prototype.ngOnInit = function () {
|
|
31
|
+
var _this = this;
|
|
32
|
+
this._subs.add(this.banta.userChanged.subscribe(function (user) { return _this.user = user; }));
|
|
33
|
+
};
|
|
34
|
+
BantaChatComponent.prototype.ngOnDestroy = function () {
|
|
35
|
+
this._subs.unsubscribe();
|
|
36
|
+
};
|
|
37
|
+
Object.defineProperty(BantaChatComponent.prototype, "source", {
|
|
38
|
+
get: function () {
|
|
39
|
+
return this._source;
|
|
40
|
+
},
|
|
41
|
+
set: function (value) {
|
|
42
|
+
this._source = value;
|
|
43
|
+
},
|
|
44
|
+
enumerable: true,
|
|
45
|
+
configurable: true
|
|
46
|
+
});
|
|
47
|
+
Object.defineProperty(BantaChatComponent.prototype, "topicID", {
|
|
48
|
+
get: function () {
|
|
49
|
+
return this._source.identifier;
|
|
50
|
+
},
|
|
51
|
+
set: function (value) {
|
|
52
|
+
this.setSourceFromTopicID(value);
|
|
53
|
+
},
|
|
54
|
+
enumerable: true,
|
|
55
|
+
configurable: true
|
|
56
|
+
});
|
|
57
|
+
BantaChatComponent.prototype.setSourceFromTopicID = function (topicID) {
|
|
58
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
59
|
+
var _a;
|
|
60
|
+
return __generator(this, function (_b) {
|
|
61
|
+
switch (_b.label) {
|
|
62
|
+
case 0:
|
|
63
|
+
if (this._source && this._source.close)
|
|
64
|
+
this._source.close();
|
|
65
|
+
this._source = null;
|
|
66
|
+
_a = this;
|
|
67
|
+
return [4 /*yield*/, this.backend.getSourceForTopic(topicID)];
|
|
68
|
+
case 1:
|
|
69
|
+
_a._source = _b.sent();
|
|
70
|
+
return [2 /*return*/];
|
|
71
|
+
}
|
|
72
|
+
});
|
|
73
|
+
});
|
|
74
|
+
};
|
|
75
|
+
Object.defineProperty(BantaChatComponent.prototype, "signInSelected", {
|
|
76
|
+
get: function () {
|
|
77
|
+
return this._signInSelected;
|
|
78
|
+
},
|
|
79
|
+
enumerable: true,
|
|
80
|
+
configurable: true
|
|
81
|
+
});
|
|
82
|
+
Object.defineProperty(BantaChatComponent.prototype, "permissionDeniedError", {
|
|
83
|
+
get: function () {
|
|
84
|
+
return this._permissionDeniedError;
|
|
85
|
+
},
|
|
86
|
+
enumerable: true,
|
|
87
|
+
configurable: true
|
|
88
|
+
});
|
|
89
|
+
BantaChatComponent.prototype.showSignIn = function () {
|
|
90
|
+
this._signInSelected.next();
|
|
91
|
+
};
|
|
92
|
+
BantaChatComponent.prototype.sendPermissionError = function () {
|
|
93
|
+
this._permissionDeniedError.next();
|
|
94
|
+
};
|
|
95
|
+
BantaChatComponent.prototype.insertEmoji = function (emoji) {
|
|
96
|
+
var message = this.newMessage.message || '';
|
|
97
|
+
this.newMessage.message = message + emoji;
|
|
98
|
+
};
|
|
99
|
+
BantaChatComponent.prototype.onKeyDown = function (event) {
|
|
100
|
+
// TODO
|
|
101
|
+
};
|
|
102
|
+
BantaChatComponent.prototype.jumpToMessage = function (message) {
|
|
103
|
+
if (this.chatView)
|
|
104
|
+
this.chatView.jumpTo(message);
|
|
105
|
+
};
|
|
106
|
+
BantaChatComponent.prototype.select = function (message) {
|
|
107
|
+
this._selected.next(message);
|
|
108
|
+
};
|
|
109
|
+
BantaChatComponent.prototype.selectUser = function (message) {
|
|
110
|
+
this._userSelected.next(message);
|
|
111
|
+
};
|
|
112
|
+
BantaChatComponent.prototype.report = function (message) {
|
|
113
|
+
this._reported.next(message);
|
|
114
|
+
};
|
|
115
|
+
BantaChatComponent.prototype.upvote = function (message) {
|
|
116
|
+
this._upvoted.next(message);
|
|
117
|
+
};
|
|
118
|
+
Object.defineProperty(BantaChatComponent.prototype, "selected", {
|
|
119
|
+
get: function () {
|
|
120
|
+
return this._selected;
|
|
121
|
+
},
|
|
122
|
+
enumerable: true,
|
|
123
|
+
configurable: true
|
|
124
|
+
});
|
|
125
|
+
Object.defineProperty(BantaChatComponent.prototype, "reported", {
|
|
126
|
+
get: function () {
|
|
127
|
+
return this._reported;
|
|
128
|
+
},
|
|
129
|
+
enumerable: true,
|
|
130
|
+
configurable: true
|
|
131
|
+
});
|
|
132
|
+
Object.defineProperty(BantaChatComponent.prototype, "upvoted", {
|
|
133
|
+
get: function () {
|
|
134
|
+
return this._upvoted;
|
|
135
|
+
},
|
|
136
|
+
enumerable: true,
|
|
137
|
+
configurable: true
|
|
138
|
+
});
|
|
139
|
+
Object.defineProperty(BantaChatComponent.prototype, "userSelected", {
|
|
140
|
+
get: function () {
|
|
141
|
+
return this._userSelected;
|
|
142
|
+
},
|
|
143
|
+
enumerable: true,
|
|
144
|
+
configurable: true
|
|
145
|
+
});
|
|
146
|
+
Object.defineProperty(BantaChatComponent.prototype, "canChat", {
|
|
147
|
+
get: function () {
|
|
148
|
+
var _a;
|
|
149
|
+
if (!this.user.permissions)
|
|
150
|
+
return true;
|
|
151
|
+
return (_a = this.user.permissions) === null || _a === void 0 ? void 0 : _a.canChat(this.source);
|
|
152
|
+
},
|
|
153
|
+
enumerable: true,
|
|
154
|
+
configurable: true
|
|
155
|
+
});
|
|
156
|
+
BantaChatComponent.prototype.sendMessage = function () {
|
|
157
|
+
if (!this.source)
|
|
158
|
+
return;
|
|
159
|
+
var text = (this.newMessage.message || '').trim();
|
|
160
|
+
this.newMessage.message = '';
|
|
161
|
+
if (text === '')
|
|
162
|
+
return;
|
|
163
|
+
var message = {
|
|
164
|
+
user: null,
|
|
165
|
+
sentAt: Date.now(),
|
|
166
|
+
upvotes: 0,
|
|
167
|
+
message: text
|
|
168
|
+
};
|
|
169
|
+
this.source.send(message);
|
|
170
|
+
};
|
|
171
|
+
BantaChatComponent.ctorParameters = function () { return [
|
|
172
|
+
{ type: BantaService },
|
|
173
|
+
{ type: ChatBackendService },
|
|
174
|
+
{ type: ElementRef }
|
|
175
|
+
]; };
|
|
176
|
+
__decorate([
|
|
177
|
+
Input(),
|
|
178
|
+
__metadata("design:type", Object),
|
|
179
|
+
__metadata("design:paramtypes", [Object])
|
|
180
|
+
], BantaChatComponent.prototype, "source", null);
|
|
181
|
+
__decorate([
|
|
182
|
+
Input(),
|
|
183
|
+
__metadata("design:type", String),
|
|
184
|
+
__metadata("design:paramtypes", [Object])
|
|
185
|
+
], BantaChatComponent.prototype, "topicID", null);
|
|
186
|
+
__decorate([
|
|
187
|
+
Input(),
|
|
188
|
+
__metadata("design:type", Object)
|
|
189
|
+
], BantaChatComponent.prototype, "signInLabel", void 0);
|
|
190
|
+
__decorate([
|
|
191
|
+
Input(),
|
|
192
|
+
__metadata("design:type", Object)
|
|
193
|
+
], BantaChatComponent.prototype, "sendLabel", void 0);
|
|
194
|
+
__decorate([
|
|
195
|
+
Input(),
|
|
196
|
+
__metadata("design:type", Object)
|
|
197
|
+
], BantaChatComponent.prototype, "permissionDeniedLabel", void 0);
|
|
198
|
+
__decorate([
|
|
199
|
+
Output(),
|
|
200
|
+
__metadata("design:type", Observable),
|
|
201
|
+
__metadata("design:paramtypes", [])
|
|
202
|
+
], BantaChatComponent.prototype, "signInSelected", null);
|
|
203
|
+
__decorate([
|
|
204
|
+
Output(),
|
|
205
|
+
__metadata("design:type", Observable),
|
|
206
|
+
__metadata("design:paramtypes", [])
|
|
207
|
+
], BantaChatComponent.prototype, "permissionDeniedError", null);
|
|
208
|
+
__decorate([
|
|
209
|
+
ViewChild('chatView', { static: true }),
|
|
210
|
+
__metadata("design:type", ChatViewComponent)
|
|
211
|
+
], BantaChatComponent.prototype, "chatView", void 0);
|
|
212
|
+
__decorate([
|
|
213
|
+
Output(),
|
|
214
|
+
__metadata("design:type", Object),
|
|
215
|
+
__metadata("design:paramtypes", [])
|
|
216
|
+
], BantaChatComponent.prototype, "selected", null);
|
|
217
|
+
__decorate([
|
|
218
|
+
Output(),
|
|
219
|
+
__metadata("design:type", Object),
|
|
220
|
+
__metadata("design:paramtypes", [])
|
|
221
|
+
], BantaChatComponent.prototype, "reported", null);
|
|
222
|
+
__decorate([
|
|
223
|
+
Output(),
|
|
224
|
+
__metadata("design:type", Object),
|
|
225
|
+
__metadata("design:paramtypes", [])
|
|
226
|
+
], BantaChatComponent.prototype, "upvoted", null);
|
|
227
|
+
__decorate([
|
|
228
|
+
Output(),
|
|
229
|
+
__metadata("design:type", Object),
|
|
230
|
+
__metadata("design:paramtypes", [])
|
|
231
|
+
], BantaChatComponent.prototype, "userSelected", null);
|
|
232
|
+
BantaChatComponent = __decorate([
|
|
233
|
+
Component({
|
|
234
|
+
selector: 'banta-chat',
|
|
235
|
+
template: "<banta-chat-view \r\n #chatView\r\n [source]=\"source\"\r\n (upvoted)=\"upvote($event)\"\r\n (reported)=\"report($event)\"\r\n (selected)=\"select($event)\"\r\n (userSelected)=\"selectUser($event)\"\r\n ></banta-chat-view>\r\n\r\n<form class=\"new-message\" (submit)=\"sendMessage()\">\r\n \r\n <div class=\"entry-container\">\r\n <input\r\n type=\"text\"\r\n name=\"message\" \r\n (keydown)=\"onKeyDown($event)\"\r\n [(ngModel)]=\"newMessage.message\" />\r\n \r\n <emoji-selector-button\r\n (selected)=\"insertEmoji($event)\"\r\n ></emoji-selector-button>\r\n </div>\r\n\r\n <div class=\"actions\">\r\n\r\n <ng-container *ngIf=\"!user\">\r\n <button type=\"button\" (click)=\"showSignIn()\" mat-raised-button color=\"primary\">{{signInLabel}}</button>\r\n </ng-container>\r\n <ng-container *ngIf=\"user\">\r\n <button *ngIf=\"canChat\" [disabled]=\"!newMessage.message\" mat-raised-button color=\"primary\">{{sendLabel}}</button>\r\n <button *ngIf=\"!canChat\" type=\"button\" (click)=\"sendPermissionError()\" mat-raised-button color=\"primary\">{{permissionDeniedLabel}}</button>\r\n </ng-container>\r\n </div>\r\n</form>",
|
|
236
|
+
styles: [":host{display:flex;flex-direction:column;border-radius:5px;padding:10px;flex-grow:1;font-size:10pt}.entry-container{display:flex;flex-direction:row;flex-grow:1;position:relative}.entry-container emoji-selector-button{position:absolute;right:0;top:.15em}.entry-container input{height:2.6em;font-size:12pt;padding-left:1em}.entry-container input:-webkit-autofill,.entry-container input:-webkit-autofill:focus,.entry-container input:-webkit-autofill:hover{outline:#9da302 solid 1px;-webkit-text-fill-color:#9da302;-webkit-box-shadow:0 0 0 1000px #211e07 inset;-webkit-transition:background-color 5000s ease-in-out;transition:background-color 5000s ease-in-out;caret-color:#9da302}.entry-container emoji-selector-panel{pointer-events:none;opacity:0;position:absolute;bottom:3.5em;right:0}.entry-container emoji-selector-panel.visible{opacity:1;pointer-events:initial}form{display:flex;padding:.5em 0;align-items:center}form textarea{font-size:14pt;background:#000;color:#fff;border:1px solid #333;min-height:6em;width:100%}form input[type=text]{background:#fff;color:#000;border:1px solid #ccc;width:100%;height:2.5em}form .actions{margin-left:1em}form button{display:block;margin:0 0 0 auto}:host-context(.mat-dark-theme) form input[type=text]{background:#000;color:#fff;border:1px solid #333}"]
|
|
237
|
+
}),
|
|
238
|
+
__metadata("design:paramtypes", [BantaService,
|
|
239
|
+
ChatBackendService,
|
|
240
|
+
ElementRef])
|
|
241
|
+
], BantaChatComponent);
|
|
242
|
+
return BantaChatComponent;
|
|
243
|
+
}());
|
|
244
|
+
export { BantaChatComponent };
|
|
245
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"banta-chat.component.js","sourceRoot":"ng://@banta/sdk/","sources":["lib/chat/banta-chat/banta-chat.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, ElementRef, ViewChild } from \"@angular/core\";\r\nimport { Subject, Observable } from 'rxjs';\r\n\r\nimport { User, ChatSource, ChatMessage, NewMessageForm, UserAccount } from '@banta/common';\r\nimport { SubSink } from 'subsink';\r\nimport { ChatViewComponent } from '../chat-view/chat-view.component';\r\nimport { BantaService } from '../../common';\r\nimport { ChatBackendService } from \"../../chat-backend.service\";\r\n\r\n/**\r\n * Chat component\r\n */\r\n@Component({\r\n    selector: 'banta-chat',\r\n    templateUrl: './banta-chat.component.html',\r\n    styleUrls: ['./banta-chat.component.scss']\r\n})\r\nexport class BantaChatComponent {\r\n    constructor(\r\n        private banta : BantaService,\r\n        private backend : ChatBackendService,\r\n        private elementRef : ElementRef<HTMLElement>\r\n    ) {\r\n    }\r\n\r\n    private _source : ChatSource;\r\n    private _subs = new SubSink();\r\n    user : UserAccount = null;\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    @Input() signInLabel = 'Sign In';\r\n    @Input() sendLabel = 'Send';\r\n    @Input() permissionDeniedLabel = 'Send';\r\n\r\n    private _selected = new Subject<ChatMessage>();\r\n    private _reported = new Subject<ChatMessage>();\r\n    private _upvoted = new Subject<ChatMessage>();\r\n    private _userSelected = new Subject<ChatMessage>();\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    showEmojiPanel = false;\r\n\r\n    showSignIn() {\r\n        this._signInSelected.next();\r\n    }\r\n\r\n    sendPermissionError() {\r\n        this._permissionDeniedError.next();\r\n    }\r\n\r\n    insertEmoji(emoji) {\r\n        let message = this.newMessage.message || '';\r\n\r\n        this.newMessage.message = message + emoji;\r\n    }\r\n\r\n    onKeyDown(event : KeyboardEvent) {\r\n        // TODO\r\n    }\r\n\r\n    @ViewChild('chatView', { static: true })\r\n    chatView : ChatViewComponent;\r\n\r\n    jumpToMessage(message : ChatMessage) {\r\n        if (this.chatView)\r\n            this.chatView.jumpTo(message);\r\n    }\r\n\r\n    select(message : ChatMessage) {\r\n        this._selected.next(message);\r\n    }\r\n\r\n    selectUser(message : ChatMessage) {\r\n        this._userSelected.next(message);\r\n    }\r\n    \r\n    report(message : ChatMessage) {\r\n        this._reported.next(message);\r\n    }\r\n    \r\n    upvote(message : ChatMessage) {\r\n        this._upvoted.next(message);\r\n    }\r\n\r\n    @Output()\r\n    get selected() {\r\n        return this._selected;\r\n    }\r\n\r\n    @Output()\r\n    get reported() {\r\n        return this._reported;\r\n    }\r\n\r\n    @Output()\r\n    get upvoted() {\r\n        return this._upvoted;\r\n    }\r\n\r\n    @Output()\r\n    get userSelected() {\r\n        return this._userSelected;\r\n    }\r\n\r\n    get canChat() {\r\n        if (!this.user.permissions)\r\n            return true;\r\n        \r\n        return this.user.permissions?.canChat(this.source);\r\n    }\r\n\r\n    newMessage : NewMessageForm = {};\r\n\r\n    sendMessage() {\r\n        if (!this.source)\r\n            return;\r\n\r\n        let text = (this.newMessage.message || '').trim();\r\n        this.newMessage.message = '';\r\n\r\n        if (text === '')\r\n            return;\r\n\r\n        let message : ChatMessage = { \r\n            user: null,\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}"]}
|
|
@@ -81,7 +81,7 @@ var ChatMessageComponent = /** @class */ (function () {
|
|
|
81
81
|
], ChatMessageComponent.prototype, "upvoted", null);
|
|
82
82
|
ChatMessageComponent = __decorate([
|
|
83
83
|
Component({
|
|
84
|
-
selector: '
|
|
84
|
+
selector: 'banta-chat-message',
|
|
85
85
|
template: "<div class=\"message-content\">\r\n <div class=\"user\" (click)=\"selectUser()\">\r\n <div class=\"avatar\" [style.background-image]=\"avatarForUser(message.user)\"></div>\r\n <label>{{message.user.username}}</label>\r\n </div>\r\n <div class=\"content\">\r\n <div (click)=\"select()\">\r\n {{message.message}}\r\n </div>\r\n <div class=\"status\">\r\n <div class=\"count-indicator\" *ngIf=\"message.upvotes > 0\">\r\n {{message.upvotes}} <mat-icon [inline]=\"true\">star</mat-icon>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n<div class=\"actions\">\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 <button mat-icon-button matTooltip=\"Report\" matTooltipPosition=\"below\" (click)=\"report()\">\r\n <mat-icon [inline]=\"true\">report</mat-icon>\r\n </button>\r\n</div>",
|
|
86
86
|
styles: [":host{display:flex;flex-direction:row;align-items:center;padding:0 1em;background-color:#fff;color:#000;transition:background-color .4s ease-out}:host:hover{background-color:#ddd}:host.highlight{background:#00121b}:host.highlight:hover{background:#01324d}:host:nth-child(2n){background-color:#eee}:host:nth-child(2n):hover{background:#ddd}:host:nth-child(2n) .message-content .content{color:#222}:host:nth-child(2n).highlight{background:#001a2a}:host:nth-child(2n).highlight:hover{background:#002b44}:host .message-content{display:flex;flex-direction:row;flex-grow:1;align-items:center}:host .message-content .content{color:#111;display:flex;flex-direction:row;padding:5px 0}:host .message-content .content .status{display:flex;flex-direction:row;align-items:center;margin-left:1em}:host .message-content .content .status mat-icon{margin-left:.5em}:host .user{color:#999;font-weight:400;text-align:right;margin-right:.25em;flex-shrink:0;display:flex;align-items:center}:host .user .avatar{background-position:center;background-size:cover;background-color:#333;border-radius:100%;flex-shrink:0;flex-grow:0;margin-right:1em;width:2em;height:2em}:host .user:after{content:\":\";margin-right:1em}:host .content{flex-grow:1}:host .actions{flex-shrink:0;white-space:nowrap;opacity:0;transition:opacity .4s ease-out}:host:hover .actions{opacity:1}.count-indicator{white-space:nowrap}:host-context(.mat-dark-theme){background-color:#000;color:#fff}:host-context(.mat-dark-theme) .message-content .content{color:#ddd}:host-context(.mat-dark-theme):hover{background-color:#111}:host-context(.mat-dark-theme):nth-child(2n).highlight{background:#001a2a}:host-context(.mat-dark-theme):nth-child(2n).highlight:hover{background:#002b44}:host-context(.mat-dark-theme):nth-child(2n):hover{background-color:#111}:host-context(.mat-dark-theme):nth-child(2n){background-color:#080808}:host-context(.mat-dark-theme):nth-child(2n) .message-content .content{color:#eee}label{margin:0}"]
|
|
87
87
|
})
|
|
@@ -89,4 +89,4 @@ var ChatMessageComponent = /** @class */ (function () {
|
|
|
89
89
|
return ChatMessageComponent;
|
|
90
90
|
}());
|
|
91
91
|
export { ChatMessageComponent };
|
|
92
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhdC1tZXNzYWdlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BiYW50YS9zZGsvIiwic291cmNlcyI6WyJsaWIvY2hhdC9jaGF0LW1lc3NhZ2UvY2hhdC1tZXNzYWdlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFPL0I7SUFBQTtRQUNZLGNBQVMsR0FBRyxJQUFJLE9BQU8sRUFBUSxDQUFDO1FBQ2hDLGNBQVMsR0FBRyxJQUFJLE9BQU8sRUFBUSxDQUFDO1FBQ2hDLGFBQVEsR0FBRyxJQUFJLE9BQU8sRUFBUSxDQUFDO1FBQy9CLGtCQUFhLEdBQUcsSUFBSSxPQUFPLEVBQVEsQ0FBQztJQWtEaEQsQ0FBQztJQTVDRyxzQkFBSSw4Q0FBWTthQUFoQjtZQUNJLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQztRQUM5QixDQUFDOzs7T0FBQTtJQUdELHNCQUFJLDBDQUFRO2FBQVo7WUFDSSxPQUFPLElBQUksQ0FBQyxTQUFTLENBQUM7UUFDMUIsQ0FBQzs7O09BQUE7SUFHRCxzQkFBSSwwQ0FBUTthQUFaO1lBQ0ksT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO1FBQzFCLENBQUM7OztPQUFBO0lBR0Qsc0JBQUkseUNBQU87YUFBWDtZQUNJLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQztRQUN6QixDQUFDOzs7T0FBQTtJQUVELDRDQUFhLEdBQWIsVUFBYyxJQUFXO1FBQ3JCLElBQUksSUFBSSxJQUFJLElBQUksQ0FBQyxTQUFTLEVBQUU7WUFDeEIsSUFBSSxHQUFHLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQztZQUN6QixPQUFPLFNBQU8sR0FBRyxNQUFHLENBQUM7U0FDeEI7UUFFRCxPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDO0lBRUQscUNBQU0sR0FBTjtRQUNJLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDekIsQ0FBQztJQUVELHFDQUFNLEdBQU47UUFDSSxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzFCLENBQUM7SUFFRCxxQ0FBTSxHQUFOO1FBQ0ksSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUMxQixDQUFDO0lBRUQseUNBQVUsR0FBVjtRQUNJLElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDOUIsQ0FBQztJQTdDRDtRQURDLEtBQUssRUFBRTs7eURBQ2M7SUFHdEI7UUFEQyxNQUFNLEVBQUU7Ozs0REFHUjtJQUdEO1FBREMsTUFBTSxFQUFFOzs7d0RBR1I7SUFHRDtRQURDLE1BQU0sRUFBRTs7O3dEQUdSO0lBR0Q7UUFEQyxNQUFNLEVBQUU7Ozt1REFHUjtJQTNCUSxvQkFBb0I7UUFMaEMsU0FBUyxDQUFDO1lBQ1AsUUFBUSxFQUFFLG9CQUFvQjtZQUM5QiwwZ0NBQTRDOztTQUUvQyxDQUFDO09BQ1csb0JBQW9CLENBc0RoQztJQUFELDJCQUFDO0NBQUEsQUF0REQsSUFzREM7U0F0RFksb0JBQW9CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT3V0cHV0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgVXNlciwgQ2hhdE1lc3NhZ2UgfSBmcm9tICdAYmFudGEvY29tbW9uJztcclxuaW1wb3J0IHsgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2JhbnRhLWNoYXQtbWVzc2FnZScsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vY2hhdC1tZXNzYWdlLmNvbXBvbmVudC5odG1sJyxcclxuICAgIHN0eWxlVXJsczogWycuL2NoYXQtbWVzc2FnZS5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDaGF0TWVzc2FnZUNvbXBvbmVudCB7XHJcbiAgICBwcml2YXRlIF9zZWxlY3RlZCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XHJcbiAgICBwcml2YXRlIF9yZXBvcnRlZCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XHJcbiAgICBwcml2YXRlIF91cHZvdGVkID0gbmV3IFN1YmplY3Q8dm9pZD4oKTtcclxuICAgIHByaXZhdGUgX3VzZXJTZWxlY3RlZCA9IG5ldyBTdWJqZWN0PFVzZXI+KCk7XHJcblxyXG4gICAgQElucHV0KClcclxuICAgIG1lc3NhZ2UgOiBDaGF0TWVzc2FnZTtcclxuICAgIFxyXG4gICAgQE91dHB1dCgpIFxyXG4gICAgZ2V0IHVzZXJTZWxlY3RlZCgpIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5fdXNlclNlbGVjdGVkO1xyXG4gICAgfVxyXG5cclxuICAgIEBPdXRwdXQoKVxyXG4gICAgZ2V0IHNlbGVjdGVkKCkge1xyXG4gICAgICAgIHJldHVybiB0aGlzLl9zZWxlY3RlZDtcclxuICAgIH1cclxuXHJcbiAgICBAT3V0cHV0KClcclxuICAgIGdldCByZXBvcnRlZCgpIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5fcmVwb3J0ZWQ7XHJcbiAgICB9XHJcblxyXG4gICAgQE91dHB1dCgpXHJcbiAgICBnZXQgdXB2b3RlZCgpIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5fdXB2b3RlZDtcclxuICAgIH1cclxuXHJcbiAgICBhdmF0YXJGb3JVc2VyKHVzZXIgOiBVc2VyKSB7XHJcbiAgICAgICAgaWYgKHVzZXIgJiYgdXNlci5hdmF0YXJVcmwpIHtcclxuICAgICAgICAgICAgbGV0IHVybCA9IHVzZXIuYXZhdGFyVXJsO1xyXG4gICAgICAgICAgICByZXR1cm4gYHVybCgke3VybH0pYDtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIHJldHVybiBudWxsO1xyXG4gICAgfVxyXG4gICAgXHJcbiAgICB1cHZvdGUoKSB7XHJcbiAgICAgICAgdGhpcy5fdXB2b3RlZC5uZXh0KCk7XHJcbiAgICB9XHJcblxyXG4gICAgcmVwb3J0KCkge1xyXG4gICAgICAgIHRoaXMuX3JlcG9ydGVkLm5leHQoKTtcclxuICAgIH1cclxuXHJcbiAgICBzZWxlY3QoKSB7XHJcbiAgICAgICAgdGhpcy5fc2VsZWN0ZWQubmV4dCgpO1xyXG4gICAgfVxyXG4gICAgXHJcbiAgICBzZWxlY3RVc2VyKCkge1xyXG4gICAgICAgIHRoaXMuX3VzZXJTZWxlY3RlZC5uZXh0KCk7XHJcbiAgICB9XHJcblxyXG59Il19
|
|
@@ -108,7 +108,7 @@ var ChatViewComponent = /** @class */ (function () {
|
|
|
108
108
|
};
|
|
109
109
|
ChatViewComponent.prototype.jumpTo = function (message) {
|
|
110
110
|
var element = this.elementRef.nativeElement;
|
|
111
|
-
var messageElement = element.querySelector("
|
|
111
|
+
var messageElement = element.querySelector("banta-chat-message[data-id=\"" + message.id + "\"]");
|
|
112
112
|
if (!messageElement) {
|
|
113
113
|
alert("could not find message " + message.id);
|
|
114
114
|
return;
|
|
@@ -186,13 +186,13 @@ var ChatViewComponent = /** @class */ (function () {
|
|
|
186
186
|
], ChatViewComponent.prototype, "maxMessages", void 0);
|
|
187
187
|
ChatViewComponent = __decorate([
|
|
188
188
|
Component({
|
|
189
|
-
selector: '
|
|
190
|
-
template: "<div class=\"message-container\" #messageContainer>\r\n <ng-content select=\"[data-before]\"></ng-content>\r\n <
|
|
191
|
-
styles: [":host{display:flex;flex-direction:column;flex-grow:1}.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}
|
|
189
|
+
selector: 'banta-chat-view',
|
|
190
|
+
template: "<div class=\"message-container\" #messageContainer>\r\n <ng-content select=\"[data-before]\"></ng-content>\r\n <banta-chat-message \r\n *ngFor=\"let message of messages\"\r\n [message]=\"message\"\r\n [class.highlight]=\"mentionsMe(message)\" \r\n [class.flash]=\"message.id === flashedMessageId\"\r\n (selected)=\"selectMessage(message)\"\r\n (upvoted)=\"upvoteMessage(message)\"\r\n (reported)=\"reportMessage(message)\"\r\n (userSelected)=\"selectMessageUser(message)\"\r\n [attr.data-id]=\"message.id\"\r\n >\r\n </banta-chat-message>\r\n <ng-content select=\":not([data-before])\"></ng-content>\r\n</div>",
|
|
191
|
+
styles: [":host{display:flex;flex-direction:column;flex-grow:1}.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}banta-chat-message.flash{-webkit-animation:2.5s flash;animation:2.5s flash}@-webkit-keyframes flash{0%{transform:scale(1);background:#425700}25%,75%{transform:scale(1.05)}100%,50%{transform:scale(1)}}@keyframes flash{0%{transform:scale(1);background:#425700}25%,75%{transform:scale(1.05)}100%,50%{transform:scale(1)}}"]
|
|
192
192
|
}),
|
|
193
193
|
__metadata("design:paramtypes", [ElementRef])
|
|
194
194
|
], ChatViewComponent);
|
|
195
195
|
return ChatViewComponent;
|
|
196
196
|
}());
|
|
197
197
|
export { ChatViewComponent };
|
|
198
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chat-view.component.js","sourceRoot":"ng://@banta/sdk/","sources":["lib/chat/chat-view/chat-view.component.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEhF,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAO/B;IACI,2BACY,UAAoC;QAApC,eAAU,GAAV,UAAU,CAA0B;QAKxC,gBAAW,GAAG,IAAI,OAAO,EAAE,CAAC;QAQ5B,cAAS,GAAG,IAAI,OAAO,EAAe,CAAC;QACvC,cAAS,GAAG,IAAI,OAAO,EAAe,CAAC;QACvC,aAAQ,GAAG,IAAI,OAAO,EAAe,CAAC;QACtC,kBAAa,GAAG,IAAI,OAAO,EAAe,CAAC;QA2DnD,aAAQ,GAAmB,EAAE,CAAC;QAO9B,gBAAW,GAAY,GAAG,CAAC;IA/E3B,CAAC;IAMD,sBAAI,qCAAM;aAAV;YACI,OAAO,IAAI,CAAC,OAAO,CAAC;QACxB,CAAC;aA2BD,UAAW,KAAK;YAAhB,iBAmCC;YAlCG,IAAI,IAAI,CAAC,WAAW,EAAE;gBAClB,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC;gBAC/B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;aAC3B;YAED,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YAErB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;YAEnB,IAAI,KAAK,EAAE;gBACP,IAAI,CAAC,WAAW,GAAG,IAAI,OAAO,EAAE,CAAC;gBACjC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;gBAEvC,OAAO,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;gBAC3B,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;gBAEnB,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC;gBAChC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAE3B,IAAI,CAAC,WAAW,CAAC,GAAG,CAChB,IAAI,CAAC,OAAO,CAAC,eAAe;qBACvB,SAAS,CAAC,UAAA,GAAG,IAAI,OAAA,KAAI,CAAC,eAAe,CAAC,GAAG,CAAC,EAAzB,CAAyB,CAAC,EAChD,IAAI,CAAC,OAAO,CAAC,WAAW;qBACnB,SAAS,CAAC,UAAA,GAAG,IAAI,OAAA,KAAI,CAAC,WAAW,CAAC,GAAG,CAAC,EAArB,CAAqB,CAAC,CAC/C,CAAC;gBAGF,IAAI,IAAI,CAAC,OAAO,CAAC,kBAAkB,EAAE;oBACjC,IAAI,CAAC,WAAW,CAAC,GAAG,CAChB,IAAI,CAAC,OAAO,CAAC,kBAAkB;yBAC1B,SAAS,CAAC,UAAA,IAAI,IAAI,OAAA,KAAI,CAAC,WAAW,GAAG,IAAI,EAAvB,CAAuB,CAAC,CAClD,CAAC;iBACL;aACJ;QACL,CAAC;;;OA9DA;IAQD,sBAAI,uCAAQ;aAAZ;YACI,OAAO,IAAI,CAAC,SAAS,CAAC;QAC1B,CAAC;;;OAAA;IAGD,sBAAI,2CAAY;aAAhB;YACI,OAAO,IAAI,CAAC,aAAa,CAAC;QAC9B,CAAC;;;OAAA;IAGD,sBAAI,uCAAQ;aAAZ;YACI,OAAO,IAAI,CAAC,SAAS,CAAC;QAC1B,CAAC;;;OAAA;IAGD,sBAAI,sCAAO;aAAX;YACI,OAAO,IAAI,CAAC,QAAQ,CAAC;QACzB,CAAC;;;OAAA;IAgDO,sCAAU,GAAlB,UAAmB,OAAqB;QACpC,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,WAAW,GAAG,CAAC,EAAE;YAC7C,OAAO,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,WAAW;gBAC1C,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;SAC7B;QAED,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAChC,CAAC;IAEO,2CAAe,GAAvB,UAAwB,OAAqB;QAA7C,iBAKC;QAJG,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;QAEzB,IAAI,IAAI,CAAC,kBAAkB,EAAE;YACzB,UAAU,CAAC,cAAM,OAAA,KAAI,CAAC,cAAc,EAAE,EAArB,CAAqB,CAAC,CAAC;IAChD,CAAC;IAED,8CAAkB,GAAlB;QACI,IAAI,CAAC,IAAI,CAAC,gBAAgB;YACtB,OAAO,KAAK,CAAC;QAEjB,IAAI,EAAE,GAAG,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC;QAC7C,IAAI,aAAa,GAAG,EAAE,CAAC,SAAS,CAAC;QACjC,IAAI,YAAY,GAAG,EAAE,CAAC,YAAY,GAAG,EAAE,CAAC,YAAY,CAAC;QAErD,OAAO,aAAa,GAAG,YAAY,GAAG,EAAE,CAAC;IAC7C,CAAC;IAEO,uCAAW,GAAnB,UAAoB,OAAqB;QAAzC,iBAOC;QANG,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;QAEzB,IAAI,CAAC,IAAI,CAAC,gBAAgB;YACtB,OAAO;QAEX,UAAU,CAAC,cAAM,OAAA,KAAI,CAAC,cAAc,EAAE,EAArB,CAAqB,CAAC,CAAC;IAC5C,CAAC;IAED,0CAAc,GAAd;QACI,IAAI,CAAC,IAAI,CAAC,gBAAgB;YACtB,OAAO;QAEX,IAAI,EAAE,GAAG,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC;QAC7C,EAAE,CAAC,SAAS,GAAG,EAAE,CAAC,YAAY,CAAC;IACnC,CAAC;IAED,kCAAM,GAAN,UAAO,OAAqB;QACxB,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;QAC5C,IAAI,cAAc,GAAG,OAAO,CAAC,aAAa,CAAC,mCAAgC,OAAO,CAAC,EAAE,QAAI,CAAC,CAAA;QAE1F,IAAI,CAAC,cAAc,EAAE;YACjB,KAAK,CAAC,4BAA0B,OAAO,CAAC,EAAI,CAAC,CAAC;YAC9C,OAAO;SACV;QAED,cAAc,CAAC,cAAc,CAAC,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;QAEtD,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;IAC/B,CAAC;IAED,wCAAY,GAAZ,UAAa,OAAqB;QAC9B,IAAI,CAAC,OAAO;YACR,OAAO;QAEX,IAAI,CAAC,gBAAgB,GAAG,OAAO,CAAC,EAAE,CAAC;QACnC,sDAAsD;IAC1D,CAAC;IAKD,sCAAU,GAAV,UAAW,OAAqB;QAC5B,IAAI,CAAC,IAAI,CAAC,WAAW;YACjB,OAAO,KAAK,CAAC;QAEjB,IAAI,OAAO,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAI,IAAI,CAAC,WAAW,CAAC,QAAU,CAAC;YACzD,OAAO,IAAI,CAAC;QAEhB,OAAO,KAAK,CAAC;IACjB,CAAC;IAED,yCAAa,GAAb,UAAc,OAAqB;QAC/B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAChC,CAAC;IAED,yCAAa,GAAb,UAAc,OAAqB;QAC/B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACjC,CAAC;IAED,yCAAa,GAAb,UAAc,OAAqB;QAC/B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACjC,CAAC;IAED,6CAAiB,GAAjB,UAAkB,OAAqB;QACnC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACrC,CAAC;IAED,yCAAa,GAAb,UAAc,IAAW;QACrB,IAAI,IAAI,IAAI,IAAI,CAAC,SAAS,EAAE;YACxB,IAAI,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC;YACzB,OAAO,SAAO,GAAG,MAAG,CAAC;SACxB;QAED,OAAO,IAAI,CAAC;IAChB,CAAC;;gBA1LwB,UAAU;;IASnC;QADC,KAAK,EAAE;;;mDAGP;IAQD;QADC,MAAM,EAAE;;;qDAGR;IAGD;QADC,MAAM,EAAE;;;yDAGR;IAGD;QADC,MAAM,EAAE;;;qDAGR;IAGD;QADC,MAAM,EAAE;;;oDAGR;IA2CD;QADC,SAAS,CAAC,kBAAkB,CAAC;kCACX,UAAU;+DAAc;IAG3C;QADC,KAAK,EAAE;;0DACmB;IApFlB,iBAAiB;QAL7B,SAAS,CAAC;YACP,QAAQ,EAAE,kBAAkB;YAC5B,qsBAAyC;;SAE5C,CAAC;yCAG2B,UAAU;OAF1B,iBAAiB,CA6L7B;IAAD,wBAAC;CAAA,AA7LD,IA6LC;SA7LY,iBAAiB","sourcesContent":["import { Component, Input, ViewChild, ElementRef, Output } from \"@angular/core\";\r\nimport { ChatSource, User, ChatMessage } from '@banta/common';\r\nimport { SubSink } from 'subsink';\r\nimport { Subject } from 'rxjs';\r\n\r\n@Component({\r\n    selector: 'engage-chat-view',\r\n    templateUrl: './chat-view.component.html',\r\n    styleUrls: ['./chat-view.component.scss']\r\n})\r\nexport class ChatViewComponent {\r\n    constructor(\r\n        private elementRef : ElementRef<HTMLElement>\r\n    ) {\r\n\r\n    }\r\n\r\n    private _sourceSubs = new SubSink();\r\n    private _source : ChatSource;\r\n\r\n    @Input()\r\n    get source() {\r\n        return this._source;\r\n    }\r\n\r\n    private _selected = new Subject<ChatMessage>();\r\n    private _reported = new Subject<ChatMessage>();\r\n    private _upvoted = new Subject<ChatMessage>();\r\n    private _userSelected = new Subject<ChatMessage>();\r\n\r\n    @Output()\r\n    get selected() {\r\n        return this._selected;\r\n    }\r\n\r\n    @Output()\r\n    get 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    set source(value) {\r\n        if (this._sourceSubs) {\r\n            this._sourceSubs.unsubscribe();\r\n            this._sourceSubs = null;\r\n        }\r\n\r\n        this._source = value;\r\n\r\n        this.messages = [];\r\n\r\n        if (value) {\r\n            this._sourceSubs = new SubSink();\r\n            this.messages = value.messages.slice();\r\n\r\n            console.log(`Source set:`);\r\n            console.dir(value);\r\n\r\n            console.log(`Messages loaded:`);\r\n            console.dir(this.messages); \r\n            \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\r\n                        .subscribe(user => this.currentUser = user)\r\n                );\r\n            }\r\n        }\r\n    }\r\n\r\n    messages : ChatMessage[] = [];\r\n    currentUser : User;\r\n\r\n    @ViewChild('messageContainer')\r\n    messageContainer : ElementRef<HTMLElement>;\r\n\r\n    @Input()\r\n    maxMessages : number = 200;\r\n\r\n    private addMessage(message : ChatMessage) {\r\n        if (this.messages.length > this.maxMessages + 1) {\r\n            while (this.messages.length > this.maxMessages)\r\n                this.messages.shift();\r\n        }\r\n\r\n        this.messages.push(message);\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        setTimeout(() => 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    jumpTo(message : ChatMessage) {\r\n        let element = this.elementRef.nativeElement;\r\n        let messageElement = element.querySelector(`engage-chat-message[data-id=\"${message.id}\"]`)\r\n\r\n        if (!messageElement) {\r\n            alert(`could not find message ${message.id}`);\r\n            return;\r\n        }\r\n\r\n        messageElement.scrollIntoView({ behavior: 'smooth' });\r\n\r\n        this.flashMessage(message);\r\n    }\r\n\r\n    flashMessage(message : ChatMessage) {\r\n        if (!message)\r\n            return;\r\n        \r\n        this.flashedMessageId = message.id;\r\n        //setTimeout(() => this.flashedMessageId = null, 250);\r\n    }\r\n\r\n    flashedMessageId : string;\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    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    avatarForUser(user : User) {\r\n        if (user && user.avatarUrl) {\r\n            let url = user.avatarUrl;\r\n            return `url(${url})`;\r\n        }\r\n\r\n        return null;\r\n    }\r\n}"]}
|
|
198
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chat-view.component.js","sourceRoot":"ng://@banta/sdk/","sources":["lib/chat/chat-view/chat-view.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ViewChild, ElementRef, Output } from \"@angular/core\";\r\nimport { ChatSource, User, ChatMessage } from '@banta/common';\r\nimport { SubSink } from 'subsink';\r\nimport { Subject } from 'rxjs';\r\n\r\n@Component({\r\n    selector: 'banta-chat-view',\r\n    templateUrl: './chat-view.component.html',\r\n    styleUrls: ['./chat-view.component.scss']\r\n})\r\nexport class ChatViewComponent {\r\n    constructor(\r\n        private elementRef : ElementRef<HTMLElement>\r\n    ) {\r\n\r\n    }\r\n\r\n    private _sourceSubs = new SubSink();\r\n    private _source : ChatSource;\r\n\r\n    @Input()\r\n    get source() {\r\n        return this._source;\r\n    }\r\n\r\n    private _selected = new Subject<ChatMessage>();\r\n    private _reported = new Subject<ChatMessage>();\r\n    private _upvoted = new Subject<ChatMessage>();\r\n    private _userSelected = new Subject<ChatMessage>();\r\n\r\n    @Output()\r\n    get selected() {\r\n        return this._selected;\r\n    }\r\n\r\n    @Output()\r\n    get 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    set source(value) {\r\n        if (this._sourceSubs) {\r\n            this._sourceSubs.unsubscribe();\r\n            this._sourceSubs = null;\r\n        }\r\n\r\n        this._source = value;\r\n\r\n        this.messages = [];\r\n\r\n        if (value) {\r\n            this._sourceSubs = new SubSink();\r\n            this.messages = value.messages.slice();\r\n\r\n            console.log(`Source set:`);\r\n            console.dir(value);\r\n\r\n            console.log(`Messages loaded:`);\r\n            console.dir(this.messages); \r\n            \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\r\n                        .subscribe(user => this.currentUser = user)\r\n                );\r\n            }\r\n        }\r\n    }\r\n\r\n    messages : ChatMessage[] = [];\r\n    currentUser : User;\r\n\r\n    @ViewChild('messageContainer')\r\n    messageContainer : ElementRef<HTMLElement>;\r\n\r\n    @Input()\r\n    maxMessages : number = 200;\r\n\r\n    private addMessage(message : ChatMessage) {\r\n        if (this.messages.length > this.maxMessages + 1) {\r\n            while (this.messages.length > this.maxMessages)\r\n                this.messages.shift();\r\n        }\r\n\r\n        this.messages.push(message);\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        setTimeout(() => 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    jumpTo(message : ChatMessage) {\r\n        let element = this.elementRef.nativeElement;\r\n        let messageElement = element.querySelector(`banta-chat-message[data-id=\"${message.id}\"]`)\r\n\r\n        if (!messageElement) {\r\n            alert(`could not find message ${message.id}`);\r\n            return;\r\n        }\r\n\r\n        messageElement.scrollIntoView({ behavior: 'smooth' });\r\n\r\n        this.flashMessage(message);\r\n    }\r\n\r\n    flashMessage(message : ChatMessage) {\r\n        if (!message)\r\n            return;\r\n        \r\n        this.flashedMessageId = message.id;\r\n        //setTimeout(() => this.flashedMessageId = null, 250);\r\n    }\r\n\r\n    flashedMessageId : string;\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    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    avatarForUser(user : User) {\r\n        if (user && user.avatarUrl) {\r\n            let url = user.avatarUrl;\r\n            return `url(${url})`;\r\n        }\r\n\r\n        return null;\r\n    }\r\n}"]}
|
|
@@ -2,7 +2,7 @@ import { __decorate } from "tslib";
|
|
|
2
2
|
import { NgModule } from "@angular/core";
|
|
3
3
|
import { ChatMessageComponent } from './chat-message/chat-message.component';
|
|
4
4
|
import { ChatViewComponent } from './chat-view/chat-view.component';
|
|
5
|
-
import {
|
|
5
|
+
import { BantaChatComponent } from './banta-chat/banta-chat.component';
|
|
6
6
|
import { CommonModule } from '@angular/common';
|
|
7
7
|
import { FormsModule } from '@angular/forms';
|
|
8
8
|
import { EmojiModule } from '../emoji';
|
|
@@ -13,7 +13,7 @@ var COMPONENTS = [
|
|
|
13
13
|
ChatMessageComponent,
|
|
14
14
|
LiveChatMessageComponent,
|
|
15
15
|
ChatViewComponent,
|
|
16
|
-
|
|
16
|
+
BantaChatComponent
|
|
17
17
|
];
|
|
18
18
|
var ChatModule = /** @class */ (function () {
|
|
19
19
|
function ChatModule() {
|
|
@@ -34,4 +34,4 @@ var ChatModule = /** @class */ (function () {
|
|
|
34
34
|
return ChatModule;
|
|
35
35
|
}());
|
|
36
36
|
export { ChatModule };
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhdC5tb2R1bGUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AYmFudGEvc2RrLyIsInNvdXJjZXMiOlsibGliL2NoYXQvY2hhdC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDN0UsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDcEUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDdkUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQ3ZDLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ3pFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFdkQsSUFBTSxVQUFVLEdBQUc7SUFDZixvQkFBb0I7SUFDcEIsd0JBQXdCO0lBQ3hCLGlCQUFpQjtJQUNqQixrQkFBa0I7Q0FDckIsQ0FBQztBQWFGO0lBQUE7SUFDQSxDQUFDO0lBRFksVUFBVTtRQVh0QixRQUFRLENBQUM7WUFDTixZQUFZLEVBQUUsVUFBVTtZQUN4QixPQUFPLEVBQUU7Z0JBQ0wsWUFBWTtnQkFDWixXQUFXO2dCQUNYLGFBQWE7Z0JBQ2IsZUFBZTtnQkFDZixXQUFXO2FBQ2Q7WUFDRCxPQUFPLEVBQUUsVUFBVTtTQUN0QixDQUFDO09BQ1csVUFBVSxDQUN0QjtJQUFELGlCQUFDO0NBQUEsQUFERCxJQUNDO1NBRFksVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgQ2hhdE1lc3NhZ2VDb21wb25lbnQgfSBmcm9tICcuL2NoYXQtbWVzc2FnZS9jaGF0LW1lc3NhZ2UuY29tcG9uZW50JztcclxuaW1wb3J0IHsgQ2hhdFZpZXdDb21wb25lbnQgfSBmcm9tICcuL2NoYXQtdmlldy9jaGF0LXZpZXcuY29tcG9uZW50JztcclxuaW1wb3J0IHsgQmFudGFDaGF0Q29tcG9uZW50IH0gZnJvbSAnLi9iYW50YS1jaGF0L2JhbnRhLWNoYXQuY29tcG9uZW50JztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IEVtb2ppTW9kdWxlIH0gZnJvbSAnLi4vZW1vamknO1xyXG5pbXBvcnQgeyBMaXZlQ2hhdE1lc3NhZ2VDb21wb25lbnQgfSBmcm9tICcuL2xpdmUtY2hhdC1tZXNzYWdlLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XHJcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcclxuXHJcbmNvbnN0IENPTVBPTkVOVFMgPSBbXHJcbiAgICBDaGF0TWVzc2FnZUNvbXBvbmVudCxcclxuICAgIExpdmVDaGF0TWVzc2FnZUNvbXBvbmVudCxcclxuICAgIENoYXRWaWV3Q29tcG9uZW50LFxyXG4gICAgQmFudGFDaGF0Q29tcG9uZW50XHJcbl07XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgZGVjbGFyYXRpb25zOiBDT01QT05FTlRTLFxyXG4gICAgaW1wb3J0czogW1xyXG4gICAgICAgIENvbW1vbk1vZHVsZSxcclxuICAgICAgICBGb3Jtc01vZHVsZSxcclxuICAgICAgICBNYXRJY29uTW9kdWxlLFxyXG4gICAgICAgIE1hdEJ1dHRvbk1vZHVsZSxcclxuICAgICAgICBFbW9qaU1vZHVsZVxyXG4gICAgXSxcclxuICAgIGV4cG9ydHM6IENPTVBPTkVOVFNcclxufSlcclxuZXhwb3J0IGNsYXNzIENoYXRNb2R1bGUge1xyXG59Il19
|
package/esm5/lib/chat/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
export * from './chat-message/chat-message.component';
|
|
2
2
|
export * from './live-chat-message.component';
|
|
3
3
|
export * from './chat-view/chat-view.component';
|
|
4
|
-
export * from './
|
|
4
|
+
export * from './banta-chat/banta-chat.component';
|
|
5
5
|
export * from './chat.module';
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AYmFudGEvc2RrLyIsInNvdXJjZXMiOlsibGliL2NoYXQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyxtQ0FBbUMsQ0FBQztBQUVsRCxjQUFjLGVBQWUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY2hhdC1tZXNzYWdlL2NoYXQtbWVzc2FnZS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpdmUtY2hhdC1tZXNzYWdlLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY2hhdC12aWV3L2NoYXQtdmlldy5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2JhbnRhLWNoYXQvYmFudGEtY2hhdC5jb21wb25lbnQnO1xyXG5cclxuZXhwb3J0ICogZnJvbSAnLi9jaGF0Lm1vZHVsZSc7Il19
|
|
@@ -86,8 +86,8 @@ var LiveChatMessageComponent = /** @class */ (function () {
|
|
|
86
86
|
], LiveChatMessageComponent.prototype, "message", null);
|
|
87
87
|
LiveChatMessageComponent = __decorate([
|
|
88
88
|
Component({
|
|
89
|
-
selector: '
|
|
90
|
-
template: "\n <
|
|
89
|
+
selector: 'banta-live-chat-message',
|
|
90
|
+
template: "\n <banta-chat-message \n *ngIf=\"message\"\n [message]=\"message\"\n (upvoted)=\"upvote()\"\n (reported)=\"report()\"\n (selected)=\"select()\"\n ></banta-chat-message>\n ",
|
|
91
91
|
styles: [""]
|
|
92
92
|
}),
|
|
93
93
|
__metadata("design:paramtypes", [ChatBackendService])
|
|
@@ -95,4 +95,4 @@ var LiveChatMessageComponent = /** @class */ (function () {
|
|
|
95
95
|
return LiveChatMessageComponent;
|
|
96
96
|
}());
|
|
97
97
|
export { LiveChatMessageComponent };
|
|
98
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGl2ZS1jaGF0LW1lc3NhZ2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vQGJhbnRhL3Nkay8iLCJzb3VyY2VzIjpbImxpYi9jaGF0L2xpdmUtY2hhdC1tZXNzYWdlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpELE9BQU8sRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzNDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBZTdEO0lBQ0ksa0NBQ1ksT0FBNEI7UUFBNUIsWUFBTyxHQUFQLE9BQU8sQ0FBcUI7UUFNaEMsYUFBUSxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFDL0IsY0FBUyxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7UUFDaEMsY0FBUyxHQUFHLElBQUksT0FBTyxFQUFRLENBQUM7SUFMeEMsQ0FBQztJQVFELHNCQUFJLDZDQUFPO2FBQVg7WUFDSSxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUM7UUFDekIsQ0FBQzs7O09BQUE7SUFHRCxzQkFBSSw4Q0FBUTthQUFaO1lBQ0ksT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO1FBQzFCLENBQUM7OztPQUFBO0lBR0Qsc0JBQUksOENBQVE7YUFBWjtZQUNJLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQztRQUMxQixDQUFDOzs7T0FBQTtJQUdELHNCQUFJLDZDQUFPO2FBQVg7WUFDSSxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUM7UUFDekIsQ0FBQzthQUlELFVBQVksS0FBSztZQUFqQixpQkFpQkM7WUFoQkcsSUFBSSxVQUFVLEdBQUcsSUFBSSxDQUFDO1lBQ3RCLElBQUksSUFBSSxDQUFDLFFBQVE7Z0JBQ2IsVUFBVSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDO1lBRWxDLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDO1lBRXRCLElBQUksS0FBSyxJQUFJLFVBQVUsS0FBSyxLQUFLLENBQUMsRUFBRSxFQUFFO2dCQUNsQyxPQUFPO2FBQ1Y7WUFFRCxJQUFJLElBQUksQ0FBQyxXQUFXO2dCQUNoQixJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7WUFFdkIsSUFBSSxLQUFLLEVBQUU7Z0JBQ1AsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLFlBQVksQ0FBQyxLQUFLLEVBQUUsVUFBQSxPQUFPLElBQUksT0FBQSxLQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sRUFBdEIsQ0FBc0IsQ0FBQyxDQUFDO2FBQzFGO1FBQ0wsQ0FBQzs7O09BckJBO0lBdUJELHlDQUFNLEdBQU47UUFDSSxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQzFCLENBQUM7SUFFRCx5Q0FBTSxHQUFOO1FBQ0ksSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUN6QixDQUFDO0lBRUQseUNBQU0sR0FBTjtRQUNJLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDMUIsQ0FBQzs7Z0JBN0RxQixrQkFBa0I7O0lBV3hDO1FBREMsTUFBTSxFQUFFO2tDQUNPLFVBQVU7OzJEQUV6QjtJQUdEO1FBREMsTUFBTSxFQUFFO2tDQUNRLFVBQVU7OzREQUUxQjtJQUdEO1FBREMsTUFBTSxFQUFFO2tDQUNRLFVBQVU7OzREQUUxQjtJQUdEO1FBREMsS0FBSyxFQUFFOzs7MkRBR1A7SUE5QlEsd0JBQXdCO1FBYnBDLFNBQVMsQ0FBQztZQUNQLFFBQVEsRUFBRSx5QkFBeUI7WUFDbkMsUUFBUSxFQUFFLDBQQVFUO3FCQUNRLEVBQUU7U0FDZCxDQUFDO3lDQUd3QixrQkFBa0I7T0FGL0Isd0JBQXdCLENBZ0VwQztJQUFELCtCQUFDO0NBQUEsQUFoRUQsSUFnRUM7U0FoRVksd0JBQXdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENoYXRNZXNzYWdlIH0gZnJvbSAnQGJhbnRhL2NvbW1vbic7XHJcbmltcG9ydCB7IFN1YmplY3QsIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgQ2hhdEJhY2tlbmRTZXJ2aWNlIH0gZnJvbSAnLi4vY2hhdC1iYWNrZW5kLnNlcnZpY2UnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2JhbnRhLWxpdmUtY2hhdC1tZXNzYWdlJyxcclxuICAgIHRlbXBsYXRlOiBgXHJcbiAgICAgICAgPGJhbnRhLWNoYXQtbWVzc2FnZSBcclxuICAgICAgICAgICAgKm5nSWY9XCJtZXNzYWdlXCJcclxuICAgICAgICAgICAgW21lc3NhZ2VdPVwibWVzc2FnZVwiXHJcbiAgICAgICAgICAgICh1cHZvdGVkKT1cInVwdm90ZSgpXCJcclxuICAgICAgICAgICAgKHJlcG9ydGVkKT1cInJlcG9ydCgpXCJcclxuICAgICAgICAgICAgKHNlbGVjdGVkKT1cInNlbGVjdCgpXCJcclxuICAgICAgICAgICAgPjwvYmFudGEtY2hhdC1tZXNzYWdlPlxyXG4gICAgYCxcclxuICAgIHN0eWxlczogW2BgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgTGl2ZUNoYXRNZXNzYWdlQ29tcG9uZW50IHtcclxuICAgIGNvbnN0cnVjdG9yKFxyXG4gICAgICAgIHByaXZhdGUgYmFja2VuZCA6IENoYXRCYWNrZW5kU2VydmljZVxyXG4gICAgKSB7XHJcblxyXG4gICAgfVxyXG5cclxuICAgIHByaXZhdGUgX21lc3NhZ2UgOiBDaGF0TWVzc2FnZTtcclxuICAgIHByaXZhdGUgX3Vwdm90ZWQgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xyXG4gICAgcHJpdmF0ZSBfcmVwb3J0ZWQgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xyXG4gICAgcHJpdmF0ZSBfc2VsZWN0ZWQgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xyXG5cclxuICAgIEBPdXRwdXQoKVxyXG4gICAgZ2V0IHVwdm90ZWQoKSA6IE9ic2VydmFibGU8dm9pZD4ge1xyXG4gICAgICAgIHJldHVybiB0aGlzLl91cHZvdGVkO1xyXG4gICAgfVxyXG4gICAgXHJcbiAgICBAT3V0cHV0KClcclxuICAgIGdldCByZXBvcnRlZCgpIDogT2JzZXJ2YWJsZTx2b2lkPiB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuX3JlcG9ydGVkO1xyXG4gICAgfVxyXG5cclxuICAgIEBPdXRwdXQoKVxyXG4gICAgZ2V0IHNlbGVjdGVkKCkgOiBPYnNlcnZhYmxlPHZvaWQ+IHtcclxuICAgICAgICByZXR1cm4gdGhpcy5fc2VsZWN0ZWQ7XHJcbiAgICB9XHJcbiAgICBcclxuICAgIEBJbnB1dCgpXHJcbiAgICBnZXQgbWVzc2FnZSgpIDogQ2hhdE1lc3NhZ2Uge1xyXG4gICAgICAgIHJldHVybiB0aGlzLl9tZXNzYWdlO1xyXG4gICAgfVxyXG5cclxuICAgIHByaXZhdGUgdW5zdWJzY3JpYmUgOiBGdW5jdGlvbjtcclxuXHJcbiAgICBzZXQgbWVzc2FnZSh2YWx1ZSkge1xyXG4gICAgICAgIGxldCBvcmlnaW5hbElkID0gbnVsbDtcclxuICAgICAgICBpZiAodGhpcy5fbWVzc2FnZSlcclxuICAgICAgICAgICAgb3JpZ2luYWxJZCA9IHRoaXMuX21lc3NhZ2UuaWQ7XHJcbiAgICAgICAgXHJcbiAgICAgICAgdGhpcy5fbWVzc2FnZSA9IHZhbHVlO1xyXG5cclxuICAgICAgICBpZiAodmFsdWUgJiYgb3JpZ2luYWxJZCA9PT0gdmFsdWUuaWQpIHtcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgaWYgKHRoaXMudW5zdWJzY3JpYmUpXHJcbiAgICAgICAgICAgIHRoaXMudW5zdWJzY3JpYmUoKTtcclxuICAgICAgICBcclxuICAgICAgICBpZiAodmFsdWUpIHtcclxuICAgICAgICAgICAgdGhpcy51bnN1YnNjcmliZSA9IHRoaXMuYmFja2VuZC53YXRjaE1lc3NhZ2UodmFsdWUsIG1lc3NhZ2UgPT4gdGhpcy5tZXNzYWdlID0gbWVzc2FnZSk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG5cclxuICAgIHJlcG9ydCgpIHtcclxuICAgICAgICB0aGlzLl9yZXBvcnRlZC5uZXh0KCk7XHJcbiAgICB9XHJcbiAgICBcclxuICAgIHVwdm90ZSgpIHtcclxuICAgICAgICB0aGlzLl91cHZvdGVkLm5leHQoKTtcclxuICAgIH1cclxuXHJcbiAgICBzZWxlY3QoKSB7XHJcbiAgICAgICAgdGhpcy5fc2VsZWN0ZWQubmV4dCgpO1xyXG4gICAgfVxyXG59Il19
|