@banta/sdk 4.0.13 → 4.0.14

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.
@@ -13,7 +13,13 @@ export class EmojiSelectorButtonComponent {
13
13
  this.panelElement.nativeElement.remove();
14
14
  }
15
15
  ngAfterViewInit() {
16
- let root = document.body.querySelector('[ng-version]') || document.body;
16
+ this.putPanelAtRoot();
17
+ }
18
+ putPanelAtRoot() {
19
+ // If we are in full-screen, placing the panel outside of the full-screen element will result in it
20
+ // always being behind said full-screen element, so we need to ensure we never place it further up the
21
+ // stack.
22
+ let root = document.fullscreenElement || document.body.querySelector('[ng-version]') || document.body;
17
23
  root.appendChild(this.panelElement.nativeElement);
18
24
  }
19
25
  removeListener() {
@@ -21,6 +27,7 @@ export class EmojiSelectorButtonComponent {
21
27
  window.removeEventListener('resize', this.resizeListener);
22
28
  }
23
29
  place() {
30
+ this.putPanelAtRoot();
24
31
  let pos = this.buttonElement.nativeElement.getBoundingClientRect();
25
32
  let size = this.panelElement.nativeElement.getBoundingClientRect();
26
33
  let left = window.scrollX + pos.left + pos.width - size.width;
@@ -126,4 +133,4 @@ EmojiSelectorButtonComponent.propDecorators = {
126
133
  panelElement: [{ type: ViewChild, args: ['panel', { read: ElementRef },] }],
127
134
  buttonElement: [{ type: ViewChild, args: ['button', { read: ElementRef },] }]
128
135
  };
129
- //# 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":["import { Component, ElementRef, 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            /* bottom: 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        /* :host.bottom-left emoji-selector-panel {\r\n            right: auto;\r\n            left: 0;\r\n        }\r\n\r\n        :host.top-right emoji-selector-panel {\r\n            top: 2.4em;\r\n            bottom: auto;\r\n        }\r\n\r\n        :host.top-left emoji-selector-panel {\r\n            top: 2.4em;\r\n            bottom: auto;\r\n            left: 0;\r\n            right: auto;\r\n        } */\r\n    `]\r\n})\r\nexport class EmojiSelectorButtonComponent {\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    ngAfterViewInit() {\r\n        let root = 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        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\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            this.resizeListener = () => {\r\n                if (!this.showEmojiPanel)\r\n                    return;\r\n                this.place();\r\n            };\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}"]}
136
+ //# 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":["import { Component, ElementRef, 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            /* bottom: 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        /* :host.bottom-left emoji-selector-panel {\r\n            right: auto;\r\n            left: 0;\r\n        }\r\n\r\n        :host.top-right emoji-selector-panel {\r\n            top: 2.4em;\r\n            bottom: auto;\r\n        }\r\n\r\n        :host.top-left emoji-selector-panel {\r\n            top: 2.4em;\r\n            bottom: auto;\r\n            left: 0;\r\n            right: auto;\r\n        } */\r\n    `]\r\n})\r\nexport class EmojiSelectorButtonComponent {\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    ngAfterViewInit() {\r\n        this.putPanelAtRoot();\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        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\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            this.resizeListener = () => {\r\n                if (!this.showEmojiPanel)\r\n                    return;\r\n                this.place();\r\n            };\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}"]}
@@ -6784,7 +6784,13 @@ class EmojiSelectorButtonComponent {
6784
6784
  this.panelElement.nativeElement.remove();
6785
6785
  }
6786
6786
  ngAfterViewInit() {
6787
- let root = document.body.querySelector('[ng-version]') || document.body;
6787
+ this.putPanelAtRoot();
6788
+ }
6789
+ putPanelAtRoot() {
6790
+ // If we are in full-screen, placing the panel outside of the full-screen element will result in it
6791
+ // always being behind said full-screen element, so we need to ensure we never place it further up the
6792
+ // stack.
6793
+ let root = document.fullscreenElement || document.body.querySelector('[ng-version]') || document.body;
6788
6794
  root.appendChild(this.panelElement.nativeElement);
6789
6795
  }
6790
6796
  removeListener() {
@@ -6792,6 +6798,7 @@ class EmojiSelectorButtonComponent {
6792
6798
  window.removeEventListener('resize', this.resizeListener);
6793
6799
  }
6794
6800
  place() {
6801
+ this.putPanelAtRoot();
6795
6802
  let pos = this.buttonElement.nativeElement.getBoundingClientRect();
6796
6803
  let size = this.panelElement.nativeElement.getBoundingClientRect();
6797
6804
  let left = window.scrollX + pos.left + pos.width - size.width;