@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.
Files changed (32) hide show
  1. package/bundles/banta-sdk.umd.js +574 -117
  2. package/bundles/banta-sdk.umd.js.map +1 -1
  3. package/bundles/banta-sdk.umd.min.js +1 -1
  4. package/bundles/banta-sdk.umd.min.js.map +1 -1
  5. package/esm2015/lib/attachment-scraper.js +87 -0
  6. package/esm2015/lib/banta-sdk.module.js +6 -2
  7. package/esm2015/lib/chat-backend-base.js +20 -1
  8. package/esm2015/lib/chat-backend.js +19 -1
  9. package/esm2015/lib/comments/banta-comments/banta-comments.component.js +1 -1
  10. package/esm2015/lib/comments/comment/comment.component.js +9 -12
  11. package/esm2015/lib/comments/comment-field/comment-field.component.js +89 -7
  12. package/esm2015/lib/comments/comments.module.js +6 -2
  13. package/esm2015/lib/common/attachment/attachment.component.js +55 -0
  14. package/esm2015/lib/common/attachments/attachments.component.js +47 -0
  15. package/esm2015/lib/common/common.module.js +13 -3
  16. package/esm2015/lib/common/index.js +4 -1
  17. package/esm2015/lib/common/trust-resource-url.pipe.js +21 -0
  18. package/esm2015/lib/emoji/emoji-selector-button.component.js +56 -105
  19. package/esm2015/lib/emoji/emoji.module.js +6 -2
  20. package/fesm2015/banta-sdk.js +404 -127
  21. package/fesm2015/banta-sdk.js.map +1 -1
  22. package/lib/attachment-scraper.d.ts +30 -0
  23. package/lib/chat-backend-base.d.ts +9 -0
  24. package/lib/chat-backend.d.ts +2 -1
  25. package/lib/comments/comment/comment.component.d.ts +2 -4
  26. package/lib/comments/comment-field/comment-field.component.d.ts +11 -2
  27. package/lib/common/attachment/attachment.component.d.ts +18 -0
  28. package/lib/common/attachments/attachments.component.d.ts +15 -0
  29. package/lib/common/index.d.ts +3 -0
  30. package/lib/common/trust-resource-url.pipe.d.ts +7 -0
  31. package/lib/emoji/emoji-selector-button.component.d.ts +13 -14
  32. package/package.json +1 -1
@@ -1,101 +1,66 @@
1
1
  /// <reference types="@types/resize-observer-browser" />
2
- import { Component, ElementRef, HostBinding, Output, ViewChild } from '@angular/core';
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
- ngOnDestroy() {
14
- this.removeListener();
15
- this.panelElement.nativeElement.remove();
16
+ get isOpen() {
17
+ return this.overlayRef;
16
18
  }
17
- get widthConstrained() { return this.width < 700; }
18
- ngAfterViewInit() {
19
- }
20
- putPanelAtRoot() {
21
- // If we are in full-screen, placing the panel outside of the full-screen element will result in it
22
- // always being behind said full-screen element, so we need to ensure we never place it further up the
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
- place() {
32
- // Not currently used as it can't be easily done handling all
33
- // scrolling corner cases.
34
- this.putPanelAtRoot();
35
- let pos = this.buttonElement.nativeElement.getBoundingClientRect();
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.showEmojiPanel) {
50
- this.showEmojiPanel = false;
51
- return;
34
+ if (this.isOpen) {
35
+ this.close();
52
36
  }
53
- this.showEmojiPanel = true;
54
- //this.place();
55
- setTimeout(() => {
56
- let onResize = () => {
57
- if (!this.showEmojiPanel)
58
- return;
59
- this.width = window.innerWidth;
60
- this.height = window.innerHeight;
61
- let edgeOffset = 0;
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
- if (isInDialog)
89
- return;
90
- this.showEmojiPanel = false;
91
- this.removeListener();
92
- };
93
- document.addEventListener('click', this.clickListener);
94
- window.addEventListener('resize', this.resizeListener);
47
+ ])
48
+ .withFlexibleDimensions(true),
49
+ hasBackdrop: true,
50
+ disposeOnNavigation: true,
51
+ scrollStrategy: this.overlay.scrollStrategies.reposition({
52
+ autoClose: true
53
+ })
95
54
  });
96
- }
97
- insert(str) {
98
- this._selected.next(str);
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
- <emoji-selector-panel
109
- #panel
110
- (selected)="insert($event)"
111
- [class.visible]="showEmojiPanel"
112
- ></emoji-selector-panel>
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
- selected: [{ type: Output }],
145
- panelElement: [{ type: ViewChild, args: ['panel', { read: ElementRef },] }],
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1vamkubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2RrL3NyYy9saWIvZW1vamkvZW1vamkubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sdURBQXVELENBQUM7QUFDcEcsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ2pGLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUU3QyxNQUFNLFVBQVUsR0FBRztJQUNmLDJCQUEyQjtJQUMzQiw0QkFBNEI7Q0FDL0IsQ0FBQztBQWNGLE1BQU0sT0FBTyxXQUFXOzs7WUFadkIsUUFBUSxTQUFDO2dCQUNOLFlBQVksRUFBRSxVQUFVO2dCQUN4QixPQUFPLEVBQUU7b0JBQ0wsWUFBWTtvQkFDWixXQUFXO29CQUNYLGFBQWE7b0JBQ2IsZUFBZTtvQkFDZixrQkFBa0I7b0JBQ2xCLGNBQWM7aUJBQ2pCO2dCQUNELE9BQU8sRUFBRSxVQUFVO2FBQ3RCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRW1vamlTZWxlY3RvclBhbmVsQ29tcG9uZW50IH0gZnJvbSAnLi9lbW9qaS1zZWxlY3Rvci1wYW5lbC9lbW9qaS1zZWxlY3Rvci1wYW5lbC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBFbW9qaVNlbGVjdG9yQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi9lbW9qaS1zZWxlY3Rvci1idXR0b24uY29tcG9uZW50JztcclxuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xyXG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xyXG5pbXBvcnQgeyBNYXRGb3JtRmllbGRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9mb3JtLWZpZWxkJztcclxuaW1wb3J0IHsgTWF0SW5wdXRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pbnB1dCc7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5cclxuY29uc3QgQ09NUE9ORU5UUyA9IFtcclxuICAgIEVtb2ppU2VsZWN0b3JQYW5lbENvbXBvbmVudCxcclxuICAgIEVtb2ppU2VsZWN0b3JCdXR0b25Db21wb25lbnRcclxuXTtcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgICBkZWNsYXJhdGlvbnM6IENPTVBPTkVOVFMsXHJcbiAgICBpbXBvcnRzOiBbXHJcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgICAgIEZvcm1zTW9kdWxlLFxyXG4gICAgICAgIE1hdEljb25Nb2R1bGUsXHJcbiAgICAgICAgTWF0QnV0dG9uTW9kdWxlLFxyXG4gICAgICAgIE1hdEZvcm1GaWVsZE1vZHVsZSxcclxuICAgICAgICBNYXRJbnB1dE1vZHVsZVxyXG4gICAgXSxcclxuICAgIGV4cG9ydHM6IENPTVBPTkVOVFNcclxufSlcclxuZXhwb3J0IGNsYXNzIEVtb2ppTW9kdWxlIHtcclxuXHJcbn0iXX0=
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1vamkubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvc2RrL3NyYy9saWIvZW1vamkvZW1vamkubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sdURBQXVELENBQUM7QUFDcEcsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ2pGLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDckQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRW5ELE1BQU0sVUFBVSxHQUFHO0lBQ2YsMkJBQTJCO0lBQzNCLDRCQUE0QjtDQUMvQixDQUFDO0FBZ0JGLE1BQU0sT0FBTyxXQUFXOzs7WUFkdkIsUUFBUSxTQUFDO2dCQUNOLFlBQVksRUFBRSxVQUFVO2dCQUN4QixPQUFPLEVBQUU7b0JBQ0wsWUFBWTtvQkFDWixXQUFXO29CQUNYLGFBQWE7b0JBQ2IsZUFBZTtvQkFDZixrQkFBa0I7b0JBQ2xCLGNBQWM7b0JBQ2QsYUFBYTtvQkFDYixZQUFZO2lCQUNmO2dCQUNELE9BQU8sRUFBRSxVQUFVO2FBQ3RCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRW1vamlTZWxlY3RvclBhbmVsQ29tcG9uZW50IH0gZnJvbSAnLi9lbW9qaS1zZWxlY3Rvci1wYW5lbC9lbW9qaS1zZWxlY3Rvci1wYW5lbC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBFbW9qaVNlbGVjdG9yQnV0dG9uQ29tcG9uZW50IH0gZnJvbSAnLi9lbW9qaS1zZWxlY3Rvci1idXR0b24uY29tcG9uZW50JztcclxuaW1wb3J0IHsgTWF0SWNvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2ljb24nO1xyXG5pbXBvcnQgeyBNYXRCdXR0b25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9idXR0b24nO1xyXG5pbXBvcnQgeyBNYXRGb3JtRmllbGRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9mb3JtLWZpZWxkJztcclxuaW1wb3J0IHsgTWF0SW5wdXRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pbnB1dCc7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBPdmVybGF5TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xyXG5pbXBvcnQgeyBQb3J0YWxNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvcG9ydGFsJztcclxuXHJcbmNvbnN0IENPTVBPTkVOVFMgPSBbXHJcbiAgICBFbW9qaVNlbGVjdG9yUGFuZWxDb21wb25lbnQsXHJcbiAgICBFbW9qaVNlbGVjdG9yQnV0dG9uQ29tcG9uZW50XHJcbl07XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgZGVjbGFyYXRpb25zOiBDT01QT05FTlRTLFxyXG4gICAgaW1wb3J0czogW1xyXG4gICAgICAgIENvbW1vbk1vZHVsZSxcclxuICAgICAgICBGb3Jtc01vZHVsZSxcclxuICAgICAgICBNYXRJY29uTW9kdWxlLFxyXG4gICAgICAgIE1hdEJ1dHRvbk1vZHVsZSxcclxuICAgICAgICBNYXRGb3JtRmllbGRNb2R1bGUsXHJcbiAgICAgICAgTWF0SW5wdXRNb2R1bGUsXHJcbiAgICAgICAgT3ZlcmxheU1vZHVsZSxcclxuICAgICAgICBQb3J0YWxNb2R1bGVcclxuICAgIF0sXHJcbiAgICBleHBvcnRzOiBDT01QT05FTlRTXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBFbW9qaU1vZHVsZSB7XHJcblxyXG59Il19