@banta/sdk 4.3.2 → 4.4.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/bundles/banta-sdk.umd.js +574 -117
- package/bundles/banta-sdk.umd.js.map +1 -1
- package/bundles/banta-sdk.umd.min.js +1 -1
- package/bundles/banta-sdk.umd.min.js.map +1 -1
- package/esm2015/lib/attachment-scraper.js +87 -0
- package/esm2015/lib/banta-sdk.module.js +6 -2
- package/esm2015/lib/chat-backend-base.js +20 -1
- package/esm2015/lib/chat-backend.js +19 -1
- package/esm2015/lib/comments/banta-comments/banta-comments.component.js +1 -1
- package/esm2015/lib/comments/comment/comment.component.js +9 -12
- package/esm2015/lib/comments/comment-field/comment-field.component.js +89 -7
- package/esm2015/lib/comments/comments.module.js +6 -2
- package/esm2015/lib/common/attachment/attachment.component.js +55 -0
- package/esm2015/lib/common/attachments/attachments.component.js +47 -0
- package/esm2015/lib/common/common.module.js +13 -3
- package/esm2015/lib/common/index.js +4 -1
- package/esm2015/lib/common/trust-resource-url.pipe.js +21 -0
- package/esm2015/lib/emoji/emoji-selector-button.component.js +56 -105
- package/esm2015/lib/emoji/emoji.module.js +6 -2
- package/fesm2015/banta-sdk.js +404 -127
- package/fesm2015/banta-sdk.js.map +1 -1
- package/lib/attachment-scraper.d.ts +30 -0
- package/lib/chat-backend-base.d.ts +9 -0
- package/lib/chat-backend.d.ts +2 -1
- package/lib/comments/comment/comment.component.d.ts +2 -4
- package/lib/comments/comment-field/comment-field.component.d.ts +11 -2
- package/lib/common/attachment/attachment.component.d.ts +18 -0
- package/lib/common/attachments/attachments.component.d.ts +15 -0
- package/lib/common/index.d.ts +3 -0
- package/lib/common/trust-resource-url.pipe.d.ts +7 -0
- package/lib/emoji/emoji-selector-button.component.d.ts +13 -14
- package/package.json +1 -1
|
@@ -1,101 +1,66 @@
|
|
|
1
1
|
/// <reference types="@types/resize-observer-browser" />
|
|
2
|
-
import {
|
|
2
|
+
import { Overlay } from '@angular/cdk/overlay';
|
|
3
|
+
import { TemplatePortal } from '@angular/cdk/portal';
|
|
4
|
+
import { Component, ElementRef, Output, ViewChild } from '@angular/core';
|
|
3
5
|
import { Subject, Observable } from 'rxjs';
|
|
4
6
|
export class EmojiSelectorButtonComponent {
|
|
5
|
-
constructor(elementRef) {
|
|
7
|
+
constructor(elementRef, overlay) {
|
|
6
8
|
this.elementRef = elementRef;
|
|
9
|
+
this.overlay = overlay;
|
|
7
10
|
this._selected = new Subject();
|
|
8
11
|
this.showEmojiPanel = false;
|
|
9
12
|
}
|
|
10
13
|
get selected() {
|
|
11
14
|
return this._selected;
|
|
12
15
|
}
|
|
13
|
-
|
|
14
|
-
this.
|
|
15
|
-
this.panelElement.nativeElement.remove();
|
|
16
|
+
get isOpen() {
|
|
17
|
+
return this.overlayRef;
|
|
16
18
|
}
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
// stack.
|
|
24
|
-
let root = document.fullscreenElement || document.body.querySelector('[ng-version]') || document.body;
|
|
25
|
-
root.appendChild(this.panelElement.nativeElement);
|
|
26
|
-
}
|
|
27
|
-
removeListener() {
|
|
28
|
-
document.removeEventListener('click', this.clickListener);
|
|
29
|
-
window.removeEventListener('resize', this.resizeListener);
|
|
19
|
+
/**
|
|
20
|
+
* Insert the given emoji.
|
|
21
|
+
* @param str
|
|
22
|
+
*/
|
|
23
|
+
insert(str) {
|
|
24
|
+
this._selected.next(str);
|
|
30
25
|
}
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
let size = this.panelElement.nativeElement.getBoundingClientRect();
|
|
37
|
-
let left = window.scrollX + pos.left + pos.width - size.width;
|
|
38
|
-
if (left < 0)
|
|
39
|
-
left = (window.scrollX + window.innerWidth) / 2 - size.width / 2;
|
|
40
|
-
let scrollY = window.scrollY;
|
|
41
|
-
if (document.fullscreenElement) {
|
|
26
|
+
close() {
|
|
27
|
+
if (this.overlayRef) {
|
|
28
|
+
this.overlayRef.dispose();
|
|
29
|
+
this.overlayRef = null;
|
|
30
|
+
return;
|
|
42
31
|
}
|
|
43
|
-
Object.assign(this.panelElement.nativeElement.style, {
|
|
44
|
-
top: `${window.scrollY + pos.top + pos.height}px`,
|
|
45
|
-
left: `${Math.max(0, left)}px`
|
|
46
|
-
});
|
|
47
32
|
}
|
|
48
33
|
show() {
|
|
49
|
-
if (this.
|
|
50
|
-
this.
|
|
51
|
-
return;
|
|
34
|
+
if (this.isOpen) {
|
|
35
|
+
this.close();
|
|
52
36
|
}
|
|
53
|
-
this.
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
let commentField = this.elementRef.nativeElement.closest(`banta-comment-field`);
|
|
63
|
-
if (commentField) {
|
|
64
|
-
let size = commentField.getBoundingClientRect();
|
|
65
|
-
this.width = size.width;
|
|
66
|
-
edgeOffset = window.innerWidth - size.right;
|
|
67
|
-
}
|
|
68
|
-
let buttonRect = this.buttonElement.nativeElement.getBoundingClientRect();
|
|
69
|
-
let buttonRight = window.innerWidth - buttonRect.right - edgeOffset - 10;
|
|
70
|
-
if (this.width < 700) {
|
|
71
|
-
this.panelElement.nativeElement.style.right = `${-buttonRight}px`;
|
|
72
|
-
}
|
|
73
|
-
else {
|
|
74
|
-
this.panelElement.nativeElement.style.right = '';
|
|
75
|
-
}
|
|
76
|
-
this.panelElement.nativeElement.style.maxWidth = `${this.width - 15}px`;
|
|
77
|
-
};
|
|
78
|
-
this.resizeListener = onResize;
|
|
79
|
-
onResize();
|
|
80
|
-
this.clickListener = (ev) => {
|
|
81
|
-
let parent = ev.target;
|
|
82
|
-
let isInDialog = false;
|
|
83
|
-
while (parent) {
|
|
84
|
-
if (parent.matches('emoji-selector-panel'))
|
|
85
|
-
isInDialog = true;
|
|
86
|
-
parent = parent.parentElement;
|
|
37
|
+
this.overlayRef = this.overlay.create({
|
|
38
|
+
positionStrategy: this.overlay.position()
|
|
39
|
+
.flexibleConnectedTo(this.elementRef)
|
|
40
|
+
.withPositions([
|
|
41
|
+
{
|
|
42
|
+
originX: 'end',
|
|
43
|
+
originY: 'bottom',
|
|
44
|
+
overlayX: 'end',
|
|
45
|
+
overlayY: 'top'
|
|
87
46
|
}
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
47
|
+
])
|
|
48
|
+
.withFlexibleDimensions(true),
|
|
49
|
+
hasBackdrop: true,
|
|
50
|
+
disposeOnNavigation: true,
|
|
51
|
+
scrollStrategy: this.overlay.scrollStrategies.reposition({
|
|
52
|
+
autoClose: true
|
|
53
|
+
})
|
|
95
54
|
});
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
55
|
+
this.overlayRef.backdropClick().subscribe(() => {
|
|
56
|
+
this.close();
|
|
57
|
+
});
|
|
58
|
+
this.overlayRef.keydownEvents().subscribe(event => {
|
|
59
|
+
if (event.key === 'Escape') {
|
|
60
|
+
this.close();
|
|
61
|
+
}
|
|
62
|
+
});
|
|
63
|
+
this.overlayRef.attach(this.selectorPanelTemplate);
|
|
99
64
|
}
|
|
100
65
|
}
|
|
101
66
|
EmojiSelectorButtonComponent.decorators = [
|
|
@@ -105,11 +70,12 @@ EmojiSelectorButtonComponent.decorators = [
|
|
|
105
70
|
<button #button type="button" mat-icon-button (click)="show()">
|
|
106
71
|
<mat-icon>emoji_emotions</mat-icon>
|
|
107
72
|
</button>
|
|
108
|
-
<
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
73
|
+
<ng-template cdkPortal #selectorPanelTemplate="cdkPortal">
|
|
74
|
+
<emoji-selector-panel
|
|
75
|
+
#panel
|
|
76
|
+
(selected)="insert($event)"
|
|
77
|
+
></emoji-selector-panel>
|
|
78
|
+
</ng-template>
|
|
113
79
|
`,
|
|
114
80
|
styles: [`
|
|
115
81
|
:host {
|
|
@@ -117,20 +83,6 @@ EmojiSelectorButtonComponent.decorators = [
|
|
|
117
83
|
position: relative;
|
|
118
84
|
}
|
|
119
85
|
|
|
120
|
-
emoji-selector-panel {
|
|
121
|
-
position: absolute;
|
|
122
|
-
top: 2.5em;
|
|
123
|
-
right: 0;
|
|
124
|
-
opacity: 0;
|
|
125
|
-
pointer-events: none;
|
|
126
|
-
z-index: 10;
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
emoji-selector-panel.visible {
|
|
130
|
-
pointer-events: initial;
|
|
131
|
-
opacity: 1;
|
|
132
|
-
}
|
|
133
|
-
|
|
134
86
|
button {
|
|
135
87
|
color: #666
|
|
136
88
|
}
|
|
@@ -138,12 +90,11 @@ EmojiSelectorButtonComponent.decorators = [
|
|
|
138
90
|
},] }
|
|
139
91
|
];
|
|
140
92
|
EmojiSelectorButtonComponent.ctorParameters = () => [
|
|
141
|
-
{ type: ElementRef }
|
|
93
|
+
{ type: ElementRef },
|
|
94
|
+
{ type: Overlay }
|
|
142
95
|
];
|
|
143
96
|
EmojiSelectorButtonComponent.propDecorators = {
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
buttonElement: [{ type: ViewChild, args: ['button', { read: ElementRef },] }],
|
|
147
|
-
widthConstrained: [{ type: HostBinding, args: ['class.width-constrained',] }]
|
|
97
|
+
selectorPanelTemplate: [{ type: ViewChild, args: ['selectorPanelTemplate',] }],
|
|
98
|
+
selected: [{ type: Output }]
|
|
148
99
|
};
|
|
149
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"emoji-selector-button.component.js","sourceRoot":"","sources":["../../../../../projects/sdk/src/lib/emoji/emoji-selector-button.component.ts"],"names":[],"mappings":"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","sourcesContent":["/// <reference types=\"@types/resize-observer-browser\" />\r\n\r\nimport { Component, ElementRef, HostBinding, Output, ViewChild } from '@angular/core';\r\nimport { Subject, Observable } from 'rxjs';\r\n\r\n@Component({\r\n    selector: 'emoji-selector-button',\r\n    template: `\r\n        <button #button type=\"button\" mat-icon-button (click)=\"show()\">\r\n            <mat-icon>emoji_emotions</mat-icon>\r\n        </button>\r\n        <emoji-selector-panel \r\n            #panel\r\n            (selected)=\"insert($event)\"\r\n            [class.visible]=\"showEmojiPanel\"\r\n            ></emoji-selector-panel>\r\n    `,\r\n    styles: [`\r\n        :host {\r\n            display: block;\r\n            position: relative;\r\n        }\r\n\r\n        emoji-selector-panel {\r\n            position: absolute;\r\n            top: 2.5em;\r\n            right: 0;\r\n            opacity: 0;\r\n            pointer-events: none;\r\n            z-index: 10;\r\n        }\r\n\r\n        emoji-selector-panel.visible {\r\n            pointer-events: initial;\r\n            opacity: 1;\r\n        }\r\n\r\n        button {\r\n            color: #666\r\n        }\r\n    `]\r\n})\r\nexport class EmojiSelectorButtonComponent {\r\n    constructor(private elementRef: ElementRef<HTMLElement>) {\r\n\r\n    }\r\n\r\n    private _selected = new Subject<string>();\r\n    private clickListener : any;\r\n    private resizeListener : any;\r\n    showEmojiPanel = false;\r\n\r\n    @Output()\r\n    get selected() : Observable<string> {\r\n        return this._selected;\r\n    }\r\n\r\n    @ViewChild('panel', { read: ElementRef })\r\n    panelElement : ElementRef<HTMLElement>;\r\n\r\n    @ViewChild('button', { read: ElementRef })\r\n    buttonElement : ElementRef<HTMLElement>;\r\n\r\n    ngOnDestroy() {\r\n        this.removeListener();\r\n        this.panelElement.nativeElement.remove();\r\n    }\r\n\r\n    private width: number;\r\n    private height: number;\r\n\r\n    @HostBinding('class.width-constrained')\r\n    get widthConstrained() { return this.width < 700; }\r\n\r\n    ngAfterViewInit() {\r\n    }\r\n\r\n    private putPanelAtRoot() {\r\n        // If we are in full-screen, placing the panel outside of the full-screen element will result in it \r\n        // always being behind said full-screen element, so we need to ensure we never place it further up the \r\n        // stack.\r\n        \r\n        let root = document.fullscreenElement || document.body.querySelector('[ng-version]') || document.body;\r\n        root.appendChild(this.panelElement.nativeElement);\r\n    }\r\n\r\n    private removeListener() {\r\n        document.removeEventListener('click', this.clickListener);\r\n        window.removeEventListener('resize', this.resizeListener);\r\n    }\r\n\r\n    place() {\r\n        // Not currently used as it can't be easily done handling all \r\n        // scrolling corner cases.\r\n\r\n        this.putPanelAtRoot();\r\n        let pos = this.buttonElement.nativeElement.getBoundingClientRect();\r\n        let size = this.panelElement.nativeElement.getBoundingClientRect();\r\n        let left = window.scrollX + pos.left + pos.width - size.width;\r\n        if (left < 0)\r\n            left = (window.scrollX + window.innerWidth) / 2 - size.width / 2;\r\n        let scrollY = window.scrollY;\r\n        if (document.fullscreenElement) {\r\n            \r\n        }\r\n\r\n        Object.assign(\r\n            this.panelElement.nativeElement.style,\r\n            {\r\n                top: `${window.scrollY + pos.top + pos.height}px`,\r\n                left: `${Math.max(0, left)}px`\r\n            }\r\n        );\r\n    }\r\n\r\n    show() {\r\n        if (this.showEmojiPanel) {\r\n            this.showEmojiPanel = false;\r\n            return;\r\n        }\r\n\r\n        this.showEmojiPanel = true;\r\n        //this.place();\r\n\r\n        setTimeout(() => {\r\n            let onResize = () => {\r\n                if (!this.showEmojiPanel)\r\n                    return;\r\n                this.width = window.innerWidth;\r\n                this.height = window.innerHeight;\r\n\r\n                let edgeOffset = 0;\r\n                let commentField = this.elementRef.nativeElement.closest(`banta-comment-field`);\r\n                if (commentField) {\r\n                    let size = commentField.getBoundingClientRect();\r\n                    this.width = size.width;\r\n                    edgeOffset = window.innerWidth - size.right;\r\n                }\r\n\r\n                let buttonRect = this.buttonElement.nativeElement.getBoundingClientRect();\r\n                let buttonRight = window.innerWidth - buttonRect.right - edgeOffset - 10;\r\n\r\n                if (this.width < 700) {\r\n                    this.panelElement.nativeElement.style.right = `${-buttonRight}px`;\r\n                } else {\r\n                    this.panelElement.nativeElement.style.right = '';\r\n                }\r\n\r\n                this.panelElement.nativeElement.style.maxWidth = `${this.width - 15}px`;\r\n            };\r\n\r\n            this.resizeListener = onResize;\r\n            onResize();\r\n\r\n            this.clickListener = (ev : MouseEvent) => {\r\n\r\n                let parent = <HTMLElement> ev.target;\r\n                let isInDialog = false;\r\n                \r\n                while (parent) {\r\n                    if (parent.matches('emoji-selector-panel'))\r\n                        isInDialog = true;\r\n\r\n                    parent = parent.parentElement;\r\n                }\r\n\r\n                if (isInDialog)\r\n                    return;\r\n\r\n                this.showEmojiPanel = false;\r\n                this.removeListener();\r\n            };\r\n    \r\n            document.addEventListener('click', this.clickListener);\r\n            window.addEventListener('resize', this.resizeListener);\r\n        });\r\n    }\r\n\r\n    insert(str) {\r\n        this._selected.next(str);\r\n    }\r\n}"]}
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1vamktc2VsZWN0b3ItYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Nkay9zcmMvbGliL2Vtb2ppL2Vtb2ppLXNlbGVjdG9yLWJ1dHRvbi5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsd0RBQXdEO0FBRXhELE9BQU8sRUFBcUMsT0FBTyxFQUFjLE1BQU0sc0JBQXNCLENBQUM7QUFDOUYsT0FBTyxFQUFtQixjQUFjLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN0RSxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBZSxNQUFNLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3RGLE9BQU8sRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBMkIzQyxNQUFNLE9BQU8sNEJBQTRCO0lBQ3JDLFlBQ1ksVUFBbUMsRUFDbkMsT0FBZ0I7UUFEaEIsZUFBVSxHQUFWLFVBQVUsQ0FBeUI7UUFDbkMsWUFBTyxHQUFQLE9BQU8sQ0FBUztRQU1wQixjQUFTLEdBQUcsSUFBSSxPQUFPLEVBQVUsQ0FBQztRQUMxQyxtQkFBYyxHQUFHLEtBQUssQ0FBQztJQUx2QixDQUFDO0lBT0QsSUFDSSxRQUFRO1FBQ1IsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQzFCLENBQUM7SUFJRCxJQUFJLE1BQU07UUFDTixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUM7SUFDM0IsQ0FBQztJQUVEOzs7T0FHRztJQUNILE1BQU0sQ0FBQyxHQUFHO1FBQ04sSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDN0IsQ0FBQztJQUVELEtBQUs7UUFDRCxJQUFJLElBQUksQ0FBQyxVQUFVLEVBQUU7WUFDakIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUMxQixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQztZQUN2QixPQUFPO1NBQ1Y7SUFDTCxDQUFDO0lBRUQsSUFBSTtRQUNBLElBQUksSUFBSSxDQUFDLE1BQU0sRUFBRTtZQUNiLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztTQUNoQjtRQUVELElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUM7WUFDbEMsZ0JBQWdCLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLEVBQUU7aUJBQ3BDLG1CQUFtQixDQUFDLElBQUksQ0FBQyxVQUFVLENBQUM7aUJBQ3BDLGFBQWEsQ0FBQztnQkFDWDtvQkFDSSxPQUFPLEVBQUUsS0FBSztvQkFDZCxPQUFPLEVBQUUsUUFBUTtvQkFDakIsUUFBUSxFQUFFLEtBQUs7b0JBQ2YsUUFBUSxFQUFFLEtBQUs7aUJBQ2xCO2FBQ0osQ0FBQztpQkFDRCxzQkFBc0IsQ0FBQyxJQUFJLENBQUM7WUFDakMsV0FBVyxFQUFFLElBQUk7WUFDakIsbUJBQW1CLEVBQUUsSUFBSTtZQUN6QixjQUFjLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxVQUFVLENBQUM7Z0JBQ3JELFNBQVMsRUFBRSxJQUFJO2FBQ2xCLENBQUM7U0FDTCxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsRUFBRSxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDM0MsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ2pCLENBQUMsQ0FBQyxDQUFBO1FBRUYsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLEVBQUUsQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDOUMsSUFBSSxLQUFLLENBQUMsR0FBRyxLQUFLLFFBQVEsRUFBRTtnQkFDeEIsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDO2FBQ2hCO1FBQ0wsQ0FBQyxDQUFDLENBQUM7UUFDSCxJQUFJLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMscUJBQXFCLENBQUMsQ0FBQztJQUN2RCxDQUFDOzs7WUFqR0osU0FBUyxTQUFDO2dCQUNQLFFBQVEsRUFBRSx1QkFBdUI7Z0JBQ2pDLFFBQVEsRUFBRTs7Ozs7Ozs7OztLQVVUO3lCQUNROzs7Ozs7Ozs7S0FTUjthQUNKOzs7WUEzQm1CLFVBQVU7WUFGYyxPQUFPOzs7b0NBcUM5QyxTQUFTLFNBQUMsdUJBQXVCO3VCQUtqQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiLy8vIDxyZWZlcmVuY2UgdHlwZXM9XCJAdHlwZXMvcmVzaXplLW9ic2VydmVyLWJyb3dzZXJcIiAvPlxyXG5cclxuaW1wb3J0IHsgRmxleGlibGVDb25uZWN0ZWRQb3NpdGlvblN0cmF0ZWd5LCBPdmVybGF5LCBPdmVybGF5UmVmIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xyXG5pbXBvcnQgeyBDb21wb25lbnRQb3J0YWwsIFRlbXBsYXRlUG9ydGFsIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL3BvcnRhbCc7XHJcbmltcG9ydCB7IENvbXBvbmVudCwgRWxlbWVudFJlZiwgSG9zdEJpbmRpbmcsIE91dHB1dCwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IFN1YmplY3QsIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgRW1vamlTZWxlY3RvclBhbmVsQ29tcG9uZW50IH0gZnJvbSAnLi9lbW9qaS1zZWxlY3Rvci1wYW5lbC9lbW9qaS1zZWxlY3Rvci1wYW5lbC5jb21wb25lbnQnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2Vtb2ppLXNlbGVjdG9yLWJ1dHRvbicsXHJcbiAgICB0ZW1wbGF0ZTogYFxyXG4gICAgICAgIDxidXR0b24gI2J1dHRvbiB0eXBlPVwiYnV0dG9uXCIgbWF0LWljb24tYnV0dG9uIChjbGljayk9XCJzaG93KClcIj5cclxuICAgICAgICAgICAgPG1hdC1pY29uPmVtb2ppX2Vtb3Rpb25zPC9tYXQtaWNvbj5cclxuICAgICAgICA8L2J1dHRvbj5cclxuICAgICAgICA8bmctdGVtcGxhdGUgY2RrUG9ydGFsICNzZWxlY3RvclBhbmVsVGVtcGxhdGU9XCJjZGtQb3J0YWxcIj5cclxuICAgICAgICAgICAgPGVtb2ppLXNlbGVjdG9yLXBhbmVsIFxyXG4gICAgICAgICAgICAgICAgI3BhbmVsXHJcbiAgICAgICAgICAgICAgICAoc2VsZWN0ZWQpPVwiaW5zZXJ0KCRldmVudClcIlxyXG4gICAgICAgICAgICAgICAgPjwvZW1vamktc2VsZWN0b3ItcGFuZWw+XHJcbiAgICAgICAgPC9uZy10ZW1wbGF0ZT5cclxuICAgIGAsXHJcbiAgICBzdHlsZXM6IFtgXHJcbiAgICAgICAgOmhvc3Qge1xyXG4gICAgICAgICAgICBkaXNwbGF5OiBibG9jaztcclxuICAgICAgICAgICAgcG9zaXRpb246IHJlbGF0aXZlO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgYnV0dG9uIHtcclxuICAgICAgICAgICAgY29sb3I6ICM2NjZcclxuICAgICAgICB9XHJcbiAgICBgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgRW1vamlTZWxlY3RvckJ1dHRvbkNvbXBvbmVudCB7XHJcbiAgICBjb25zdHJ1Y3RvcihcclxuICAgICAgICBwcml2YXRlIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+LFxyXG4gICAgICAgIHByaXZhdGUgb3ZlcmxheTogT3ZlcmxheVxyXG4gICAgKSB7XHJcbiAgICB9XHJcblxyXG4gICAgQFZpZXdDaGlsZCgnc2VsZWN0b3JQYW5lbFRlbXBsYXRlJykgc2VsZWN0b3JQYW5lbFRlbXBsYXRlOiBUZW1wbGF0ZVBvcnRhbDxhbnk+O1xyXG5cclxuICAgIHByaXZhdGUgX3NlbGVjdGVkID0gbmV3IFN1YmplY3Q8c3RyaW5nPigpO1xyXG4gICAgc2hvd0Vtb2ppUGFuZWwgPSBmYWxzZTtcclxuXHJcbiAgICBAT3V0cHV0KClcclxuICAgIGdldCBzZWxlY3RlZCgpIDogT2JzZXJ2YWJsZTxzdHJpbmc+IHtcclxuICAgICAgICByZXR1cm4gdGhpcy5fc2VsZWN0ZWQ7XHJcbiAgICB9XHJcblxyXG4gICAgcHJpdmF0ZSBvdmVybGF5UmVmOiBPdmVybGF5UmVmO1xyXG5cclxuICAgIGdldCBpc09wZW4oKSB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMub3ZlcmxheVJlZjtcclxuICAgIH1cclxuXHJcbiAgICAvKipcclxuICAgICAqIEluc2VydCB0aGUgZ2l2ZW4gZW1vamkuXHJcbiAgICAgKiBAcGFyYW0gc3RyIFxyXG4gICAgICovXHJcbiAgICBpbnNlcnQoc3RyKSB7XHJcbiAgICAgICAgdGhpcy5fc2VsZWN0ZWQubmV4dChzdHIpO1xyXG4gICAgfVxyXG5cclxuICAgIGNsb3NlKCkge1xyXG4gICAgICAgIGlmICh0aGlzLm92ZXJsYXlSZWYpIHtcclxuICAgICAgICAgICAgdGhpcy5vdmVybGF5UmVmLmRpc3Bvc2UoKTtcclxuICAgICAgICAgICAgdGhpcy5vdmVybGF5UmVmID0gbnVsbDtcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICBzaG93KCkge1xyXG4gICAgICAgIGlmICh0aGlzLmlzT3Blbikge1xyXG4gICAgICAgICAgICB0aGlzLmNsb3NlKCk7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICB0aGlzLm92ZXJsYXlSZWYgPSB0aGlzLm92ZXJsYXkuY3JlYXRlKHtcclxuICAgICAgICAgICAgcG9zaXRpb25TdHJhdGVneTogdGhpcy5vdmVybGF5LnBvc2l0aW9uKClcclxuICAgICAgICAgICAgICAgIC5mbGV4aWJsZUNvbm5lY3RlZFRvKHRoaXMuZWxlbWVudFJlZilcclxuICAgICAgICAgICAgICAgIC53aXRoUG9zaXRpb25zKFtcclxuICAgICAgICAgICAgICAgICAgICB7IFxyXG4gICAgICAgICAgICAgICAgICAgICAgICBvcmlnaW5YOiAnZW5kJywgXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIG9yaWdpblk6ICdib3R0b20nLFxyXG4gICAgICAgICAgICAgICAgICAgICAgICBvdmVybGF5WDogJ2VuZCcsXHJcbiAgICAgICAgICAgICAgICAgICAgICAgIG92ZXJsYXlZOiAndG9wJ1xyXG4gICAgICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICAgIF0pXHJcbiAgICAgICAgICAgICAgICAud2l0aEZsZXhpYmxlRGltZW5zaW9ucyh0cnVlKSxcclxuICAgICAgICAgICAgaGFzQmFja2Ryb3A6IHRydWUsXHJcbiAgICAgICAgICAgIGRpc3Bvc2VPbk5hdmlnYXRpb246IHRydWUsXHJcbiAgICAgICAgICAgIHNjcm9sbFN0cmF0ZWd5OiB0aGlzLm92ZXJsYXkuc2Nyb2xsU3RyYXRlZ2llcy5yZXBvc2l0aW9uKHtcclxuICAgICAgICAgICAgICAgIGF1dG9DbG9zZTogdHJ1ZVxyXG4gICAgICAgICAgICB9KVxyXG4gICAgICAgIH0pO1xyXG5cclxuICAgICAgICB0aGlzLm92ZXJsYXlSZWYuYmFja2Ryb3BDbGljaygpLnN1YnNjcmliZSgoKSA9PiB7XHJcbiAgICAgICAgICAgIHRoaXMuY2xvc2UoKTtcclxuICAgICAgICB9KVxyXG5cclxuICAgICAgICB0aGlzLm92ZXJsYXlSZWYua2V5ZG93bkV2ZW50cygpLnN1YnNjcmliZShldmVudCA9PiB7XHJcbiAgICAgICAgICAgIGlmIChldmVudC5rZXkgPT09ICdFc2NhcGUnKSB7XHJcbiAgICAgICAgICAgICAgICB0aGlzLmNsb3NlKCk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9KTtcclxuICAgICAgICB0aGlzLm92ZXJsYXlSZWYuYXR0YWNoKHRoaXMuc2VsZWN0b3JQYW5lbFRlbXBsYXRlKTtcclxuICAgIH1cclxufSJdfQ==
|
|
@@ -7,6 +7,8 @@ import { MatButtonModule } from '@angular/material/button';
|
|
|
7
7
|
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
8
8
|
import { MatInputModule } from '@angular/material/input';
|
|
9
9
|
import { FormsModule } from '@angular/forms';
|
|
10
|
+
import { OverlayModule } from '@angular/cdk/overlay';
|
|
11
|
+
import { PortalModule } from '@angular/cdk/portal';
|
|
10
12
|
const COMPONENTS = [
|
|
11
13
|
EmojiSelectorPanelComponent,
|
|
12
14
|
EmojiSelectorButtonComponent
|
|
@@ -22,9 +24,11 @@ EmojiModule.decorators = [
|
|
|
22
24
|
MatIconModule,
|
|
23
25
|
MatButtonModule,
|
|
24
26
|
MatFormFieldModule,
|
|
25
|
-
MatInputModule
|
|
27
|
+
MatInputModule,
|
|
28
|
+
OverlayModule,
|
|
29
|
+
PortalModule
|
|
26
30
|
],
|
|
27
31
|
exports: COMPONENTS
|
|
28
32
|
},] }
|
|
29
33
|
];
|
|
30
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1vamkubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2RrL3NyYy9saWIvZW1vamkvZW1vamkubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sdURBQXVELENBQUM7QUFDcEcsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ2pGLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDckQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRW5ELE1BQU0sVUFBVSxHQUFHO0lBQ2YsMkJBQTJCO0lBQzNCLDRCQUE0QjtDQUMvQixDQUFDO0FBZ0JGLE1BQU0sT0FBTyxXQUFXOzs7WUFkdkIsUUFBUSxTQUFDO2dCQUNOLFlBQVksRUFBRSxVQUFVO2dCQUN4QixPQUFPLEVBQUU7b0JBQ0wsWUFBWTtvQkFDWixXQUFXO29CQUNYLGFBQWE7b0JBQ2IsZUFBZTtvQkFDZixrQkFBa0I7b0JBQ2xCLGNBQWM7b0JBQ2QsYUFBYTtvQkFDYixZQUFZO2lCQUNmO2dCQUNELE9BQU8sRUFBRSxVQUFVO2FBQ3RCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRW1vamlTZWxlY3RvclBhbmVsQ29tcG9uZW50IH0gZnJvbSAnLi9lbW9qaS1zZWxlY3Rvci1wYW5lbC9lbW9qaS1zZWxlY3Rvci1wYW5lbC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBFbW9qaVNlbGVjdG9yQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi9lbW9qaS1zZWxlY3Rvci1idXR0b24uY29tcG9uZW50JztcclxuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xyXG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xyXG5pbXBvcnQgeyBNYXRGb3JtRmllbGRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9mb3JtLWZpZWxkJztcclxuaW1wb3J0IHsgTWF0SW5wdXRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pbnB1dCc7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBPdmVybGF5TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xyXG5pbXBvcnQgeyBQb3J0YWxNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvcG9ydGFsJztcclxuXHJcbmNvbnN0IENPTVBPTkVOVFMgPSBbXHJcbiAgICBFbW9qaVNlbGVjdG9yUGFuZWxDb21wb25lbnQsXHJcbiAgICBFbW9qaVNlbGVjdG9yQnV0dG9uQ29tcG9uZW50XHJcbl07XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgZGVjbGFyYXRpb25zOiBDT01QT05FTlRTLFxyXG4gICAgaW1wb3J0czogW1xyXG4gICAgICAgIENvbW1vbk1vZHVsZSxcclxuICAgICAgICBGb3Jtc01vZHVsZSxcclxuICAgICAgICBNYXRJY29uTW9kdWxlLFxyXG4gICAgICAgIE1hdEJ1dHRvbk1vZHVsZSxcclxuICAgICAgICBNYXRGb3JtRmllbGRNb2R1bGUsXHJcbiAgICAgICAgTWF0SW5wdXRNb2R1bGUsXHJcbiAgICAgICAgT3ZlcmxheU1vZHVsZSxcclxuICAgICAgICBQb3J0YWxNb2R1bGVcclxuICAgIF0sXHJcbiAgICBleHBvcnRzOiBDT01QT05FTlRTXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBFbW9qaU1vZHVsZSB7XHJcblxyXG59Il19
|