wacom 16.0.8 → 16.0.9

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.
@@ -1,189 +1,30 @@
1
- import { Directive, EventEmitter, Inject, Injectable, Input, Output, PLATFORM_ID, } from '@angular/core';
2
- import { isPlatformBrowser } from '@angular/common';
1
+ import { Directive, EventEmitter, Output, HostListener } from '@angular/core';
3
2
  import * as i0 from "@angular/core";
4
- import * as i1 from "../services/core.service";
5
3
  class ClickOutsideDirective {
6
- platformId;
7
- _el;
8
- _ngZone;
9
- core;
10
- clickOutsideEnabled = true;
11
- attachOutsideOnClick = false;
12
- delayClickOutsideInit = false;
13
- emitOnBlur = false;
14
- exclude = '';
15
- excludeBeforeClick = false;
16
- clickOutsideEvents = '';
4
+ elementRef;
17
5
  clickOutside = new EventEmitter();
18
- _nodesExcluded = [];
19
- _events = ['click'];
20
- constructor(platformId, _el, _ngZone, core) {
21
- this.platformId = platformId;
22
- this._el = _el;
23
- this._ngZone = _ngZone;
24
- this.core = core;
25
- this._initOnClickBody = this._initOnClickBody.bind(this);
26
- this._onClickBody = this._onClickBody.bind(this);
27
- this._onWindowBlur = this._onWindowBlur.bind(this);
6
+ constructor(elementRef) {
7
+ this.elementRef = elementRef;
28
8
  }
29
- ngOnInit() {
30
- if (!isPlatformBrowser(this.platformId)) {
31
- return;
9
+ onClick(event) {
10
+ const clickedInside = this.elementRef.nativeElement.contains(event.target);
11
+ if (!clickedInside) {
12
+ this.clickOutside.emit(event);
32
13
  }
33
- this._init();
34
14
  }
35
- ngOnDestroy() {
36
- if (!isPlatformBrowser(this.platformId)) {
37
- return;
38
- }
39
- this._removeClickOutsideListener();
40
- this._removeAttachOutsideOnClickListener();
41
- this._removeWindowBlurListener();
42
- }
43
- ngOnChanges(changes) {
44
- if (!isPlatformBrowser(this.platformId)) {
45
- return;
46
- }
47
- if (changes['attachOutsideOnClick'] || changes['exclude'] || changes['emitOnBlur']) {
48
- this._init();
49
- }
50
- }
51
- _init() {
52
- if (this.clickOutsideEvents !== '') {
53
- this._events = this.clickOutsideEvents.split(',').map(e => e.trim());
54
- }
55
- this._excludeCheck();
56
- if (this.attachOutsideOnClick) {
57
- this._initAttachOutsideOnClickListener();
58
- }
59
- else {
60
- this._initOnClickBody();
61
- }
62
- if (this.emitOnBlur) {
63
- this._initWindowBlurListener();
64
- }
65
- }
66
- _initOnClickBody() {
67
- if (this.delayClickOutsideInit) {
68
- setTimeout(this._initClickOutsideListener.bind(this));
69
- }
70
- else {
71
- this._initClickOutsideListener();
72
- }
73
- }
74
- _excludeCheck() {
75
- if (this.exclude) {
76
- try {
77
- const nodes = Array.from(this.core.document.querySelectorAll(this.exclude));
78
- if (nodes) {
79
- this._nodesExcluded = nodes;
80
- }
81
- }
82
- catch (err) {
83
- console.error('[ng-click-outside] Check your exclude selector syntax.', err);
84
- }
85
- }
86
- }
87
- _onClickBody(ev) {
88
- if (!this.clickOutsideEnabled) {
89
- return;
90
- }
91
- if (this.excludeBeforeClick) {
92
- this._excludeCheck();
93
- }
94
- if (!this._el.nativeElement.contains(ev.target) && !this._shouldExclude(ev.target)) {
95
- this._emit(ev);
96
- if (this.attachOutsideOnClick) {
97
- this._removeClickOutsideListener();
98
- }
99
- }
100
- }
101
- /**
102
- * Resolves problem with outside click on iframe
103
- * @see https://github.com/arkon/ng-click-outside/issues/32
104
- */
105
- _onWindowBlur(ev) {
106
- setTimeout(() => {
107
- if (!this.core.document.hidden) {
108
- this._emit(ev);
109
- }
110
- });
111
- }
112
- _emit(ev) {
113
- if (!this.clickOutsideEnabled) {
114
- return;
115
- }
116
- this._ngZone.run(() => this.clickOutside.emit(ev));
117
- }
118
- _shouldExclude(target) {
119
- for (let excludedNode of this._nodesExcluded) {
120
- if (excludedNode.contains(target)) {
121
- return true;
122
- }
123
- }
124
- return false;
125
- }
126
- _initClickOutsideListener() {
127
- this._ngZone.runOutsideAngular(() => {
128
- this._events.forEach(e => this.core.document.addEventListener(e, this._onClickBody));
129
- });
130
- }
131
- _removeClickOutsideListener() {
132
- this._ngZone.runOutsideAngular(() => {
133
- this._events.forEach(e => this.core.document.removeEventListener(e, this._onClickBody));
134
- });
135
- }
136
- _initAttachOutsideOnClickListener() {
137
- this._ngZone.runOutsideAngular(() => {
138
- this._events.forEach(e => this._el.nativeElement.addEventListener(e, this._initOnClickBody));
139
- });
140
- }
141
- _removeAttachOutsideOnClickListener() {
142
- this._ngZone.runOutsideAngular(() => {
143
- this._events.forEach(e => this._el.nativeElement.removeEventListener(e, this._initOnClickBody));
144
- });
145
- }
146
- _initWindowBlurListener() {
147
- this._ngZone.runOutsideAngular(() => {
148
- this.core.window.addEventListener('blur', this._onWindowBlur);
149
- });
150
- }
151
- _removeWindowBlurListener() {
152
- this._ngZone.runOutsideAngular(() => {
153
- this.core.window.removeEventListener('blur', this._onWindowBlur);
154
- });
155
- }
156
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: ClickOutsideDirective, deps: [{ token: PLATFORM_ID }, { token: i0.ElementRef }, { token: i0.NgZone }, { token: i1.CoreService }], target: i0.ɵɵFactoryTarget.Directive });
157
- static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.2", type: ClickOutsideDirective, selector: "[clickOutside]", inputs: { clickOutsideEnabled: "clickOutsideEnabled", attachOutsideOnClick: "attachOutsideOnClick", delayClickOutsideInit: "delayClickOutsideInit", emitOnBlur: "emitOnBlur", exclude: "exclude", excludeBeforeClick: "excludeBeforeClick", clickOutsideEvents: "clickOutsideEvents" }, outputs: { clickOutside: "clickOutside" }, exportAs: ["clickOutside"], usesOnChanges: true, ngImport: i0 });
158
- static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: ClickOutsideDirective });
15
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: ClickOutsideDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
16
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.2", type: ClickOutsideDirective, selector: "[clickOutside]", outputs: { clickOutside: "clickOutside" }, host: { listeners: { "document:click": "onClick($event)" } }, ngImport: i0 });
159
17
  }
160
18
  export { ClickOutsideDirective };
161
19
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: ClickOutsideDirective, decorators: [{
162
- type: Injectable
163
- }, {
164
20
  type: Directive,
165
21
  args: [{
166
- selector: '[clickOutside]',
167
- exportAs: 'clickOutside'
22
+ selector: '[clickOutside]'
168
23
  }]
169
- }], ctorParameters: function () { return [{ type: Object, decorators: [{
170
- type: Inject,
171
- args: [PLATFORM_ID]
172
- }] }, { type: i0.ElementRef }, { type: i0.NgZone }, { type: i1.CoreService }]; }, propDecorators: { clickOutsideEnabled: [{
173
- type: Input
174
- }], attachOutsideOnClick: [{
175
- type: Input
176
- }], delayClickOutsideInit: [{
177
- type: Input
178
- }], emitOnBlur: [{
179
- type: Input
180
- }], exclude: [{
181
- type: Input
182
- }], excludeBeforeClick: [{
183
- type: Input
184
- }], clickOutsideEvents: [{
185
- type: Input
186
- }], clickOutside: [{
24
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { clickOutside: [{
187
25
  type: Output
26
+ }], onClick: [{
27
+ type: HostListener,
28
+ args: ['document:click', ['$event']]
188
29
  }] } });
189
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"click-outside.directive.js","sourceRoot":"","sources":["../../../../../projects/wacom/src/lib/directives/click-outside.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tDirective,\n\tElementRef,\n\tEventEmitter,\n\tInject,\n\tInjectable,\n\tInput,\n\tOnChanges,\n\tOnDestroy,\n\tOnInit,\n\tOutput,\n\tPLATFORM_ID,\n\tSimpleChanges,\n\tNgZone,\n} from '@angular/core';\nimport { isPlatformBrowser } from '@angular/common';\nimport { CoreService } from '../services/core.service';\n\n@Injectable()\n@Directive({\n\tselector: '[clickOutside]',\n\texportAs: 'clickOutside'\n})\nexport class ClickOutsideDirective implements OnInit, OnChanges, OnDestroy {\n\t@Input() clickOutsideEnabled = true;\n\t@Input() attachOutsideOnClick = false;\n\t@Input() delayClickOutsideInit = false;\n\t@Input() emitOnBlur = false;\n\t@Input() exclude = '';\n\t@Input() excludeBeforeClick = false;\n\t@Input() clickOutsideEvents = '';\n\t@Output() clickOutside: EventEmitter<Event> = new EventEmitter<Event>();\n\n\tprivate _nodesExcluded: Array<HTMLElement> = [];\n\tprivate _events: Array<string> = ['click'];\n\n\tconstructor(\n\t\t@Inject(PLATFORM_ID) private platformId: Object,\n\t\tprivate _el: ElementRef,\n\t\tprivate _ngZone: NgZone,\n\t\tpublic core: CoreService\n\t) {\n\t\tthis._initOnClickBody = this._initOnClickBody.bind(this);\n\t\tthis._onClickBody = this._onClickBody.bind(this);\n\t\tthis._onWindowBlur = this._onWindowBlur.bind(this);\n\t}\n\n\tngOnInit() {\n\t\tif (!isPlatformBrowser(this.platformId)) { return; }\n\n\t\tthis._init();\n\t}\n\n\tngOnDestroy() {\n\t\tif (!isPlatformBrowser(this.platformId)) { return; }\n\n\t\tthis._removeClickOutsideListener();\n\t\tthis._removeAttachOutsideOnClickListener();\n\t\tthis._removeWindowBlurListener();\n\t}\n\n\tngOnChanges(changes: SimpleChanges) {\n\t\tif (!isPlatformBrowser(this.platformId)) { return; }\n\n\t\tif (changes['attachOutsideOnClick'] || changes['exclude'] || changes['emitOnBlur']) {\n\t\t\tthis._init();\n\t\t}\n\t}\n\n\tprivate _init() {\n\t\tif (this.clickOutsideEvents !== '') {\n\t\t\tthis._events = this.clickOutsideEvents.split(',').map(e => e.trim());\n\t\t}\n\n\t\tthis._excludeCheck();\n\n\t\tif (this.attachOutsideOnClick) {\n\t\t\tthis._initAttachOutsideOnClickListener();\n\t\t} else {\n\t\t\tthis._initOnClickBody();\n\t\t}\n\n\t\tif (this.emitOnBlur) {\n\t\t\tthis._initWindowBlurListener();\n\t\t}\n\t}\n\n\tprivate _initOnClickBody() {\n\t\tif (this.delayClickOutsideInit) {\n\t\t\tsetTimeout(this._initClickOutsideListener.bind(this));\n\t\t} else {\n\t\t\tthis._initClickOutsideListener();\n\t\t}\n\t}\n\n\tprivate _excludeCheck() {\n\t\tif (this.exclude) {\n\t\t\ttry {\n\t\t\t\tconst nodes = Array.from(this.core.document.querySelectorAll(this.exclude)) as Array<HTMLElement>;\n\t\t\t\tif (nodes) {\n\t\t\t\t\tthis._nodesExcluded = nodes;\n\t\t\t\t}\n\t\t\t} catch (err) {\n\t\t\t\tconsole.error('[ng-click-outside] Check your exclude selector syntax.', err);\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate _onClickBody(ev: Event) {\n\t\tif (!this.clickOutsideEnabled) { return; }\n\n\t\tif (this.excludeBeforeClick) {\n\t\t\tthis._excludeCheck();\n\t\t}\n\n\t\tif (!this._el.nativeElement.contains(ev.target) && !this._shouldExclude(ev.target)) {\n\t\t\tthis._emit(ev);\n\n\t\t\tif (this.attachOutsideOnClick) {\n\t\t\t\tthis._removeClickOutsideListener();\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Resolves problem with outside click on iframe\n\t * @see https://github.com/arkon/ng-click-outside/issues/32\n\t */\n\tprivate _onWindowBlur(ev: Event) {\n\t\tsetTimeout(() => {\n\t\t\tif (!this.core.document.hidden) {\n\t\t\t\tthis._emit(ev);\n\t\t\t}\n\t\t});\n\t}\n\n\tprivate _emit(ev: Event) {\n\t\tif (!this.clickOutsideEnabled) { return; }\n\n\t\tthis._ngZone.run(() => this.clickOutside.emit(ev));\n\t}\n\n\tprivate _shouldExclude(target: any): boolean {\n\t\tfor (let excludedNode of this._nodesExcluded) {\n\t\t\tif (excludedNode.contains(target)) {\n\t\t\t\treturn true;\n\t\t\t}\n\t\t}\n\n\t\treturn false;\n\t}\n\n\tprivate _initClickOutsideListener() {\n\t\tthis._ngZone.runOutsideAngular(() => {\n\t\t\tthis._events.forEach(e => this.core.document.addEventListener(e, this._onClickBody));\n\t\t});\n\t}\n\n\tprivate _removeClickOutsideListener() {\n\t\tthis._ngZone.runOutsideAngular(() => {\n\t\t\tthis._events.forEach(e => this.core.document.removeEventListener(e, this._onClickBody));\n\t\t});\n\t}\n\n\tprivate _initAttachOutsideOnClickListener() {\n\t\tthis._ngZone.runOutsideAngular(() => {\n\t\t\tthis._events.forEach(e => this._el.nativeElement.addEventListener(e, this._initOnClickBody));\n\t\t});\n\t}\n\n\tprivate _removeAttachOutsideOnClickListener() {\n\t\tthis._ngZone.runOutsideAngular(() => {\n\t\t\tthis._events.forEach(e => this._el.nativeElement.removeEventListener(e, this._initOnClickBody));\n\t\t});\n\t}\n\n\tprivate _initWindowBlurListener() {\n\t\tthis._ngZone.runOutsideAngular(() => {\n\t\t\tthis.core.window.addEventListener('blur', this._onWindowBlur);\n\t\t});\n\t}\n\n\tprivate _removeWindowBlurListener() {\n\t\tthis._ngZone.runOutsideAngular(() => {\n\t\t\tthis.core.window.removeEventListener('blur', this._onWindowBlur);\n\t\t});\n\t}\n\n}\n"]}
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpY2stb3V0c2lkZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy93YWNvbS9zcmMvbGliL2RpcmVjdGl2ZXMvY2xpY2stb3V0c2lkZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBYyxZQUFZLEVBQUUsTUFBTSxFQUFFLFlBQVksRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFFMUYsTUFHYSxxQkFBcUI7SUFHYjtJQUZWLFlBQVksR0FBd0IsSUFBSSxZQUFZLEVBQVMsQ0FBQztJQUV4RSxZQUFvQixVQUFzQjtRQUF0QixlQUFVLEdBQVYsVUFBVSxDQUFZO0lBQUksQ0FBQztJQUcvQyxPQUFPLENBQUMsS0FBWTtRQUNuQixNQUFNLGFBQWEsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQzNFLElBQUksQ0FBQyxhQUFhLEVBQUU7WUFDbkIsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDOUI7SUFDRixDQUFDO3VHQVhXLHFCQUFxQjsyRkFBckIscUJBQXFCOztTQUFyQixxQkFBcUI7MkZBQXJCLHFCQUFxQjtrQkFIakMsU0FBUzttQkFBQztvQkFDVixRQUFRLEVBQUUsZ0JBQWdCO2lCQUMxQjtpR0FFVSxZQUFZO3NCQUFyQixNQUFNO2dCQUtQLE9BQU87c0JBRE4sWUFBWTt1QkFBQyxnQkFBZ0IsRUFBRSxDQUFDLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgRXZlbnRFbWl0dGVyLCBPdXRwdXQsIEhvc3RMaXN0ZW5lciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5ARGlyZWN0aXZlKHtcblx0c2VsZWN0b3I6ICdbY2xpY2tPdXRzaWRlXSdcbn0pXG5leHBvcnQgY2xhc3MgQ2xpY2tPdXRzaWRlRGlyZWN0aXZlIHtcblx0QE91dHB1dCgpIGNsaWNrT3V0c2lkZTogRXZlbnRFbWl0dGVyPEV2ZW50PiA9IG5ldyBFdmVudEVtaXR0ZXI8RXZlbnQ+KCk7XG5cblx0Y29uc3RydWN0b3IocHJpdmF0ZSBlbGVtZW50UmVmOiBFbGVtZW50UmVmKSB7IH1cblxuXHRASG9zdExpc3RlbmVyKCdkb2N1bWVudDpjbGljaycsIFsnJGV2ZW50J10pXG5cdG9uQ2xpY2soZXZlbnQ6IEV2ZW50KTogdm9pZCB7XG5cdFx0Y29uc3QgY2xpY2tlZEluc2lkZSA9IHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LmNvbnRhaW5zKGV2ZW50LnRhcmdldCk7XG5cdFx0aWYgKCFjbGlja2VkSW5zaWRlKSB7XG5cdFx0XHR0aGlzLmNsaWNrT3V0c2lkZS5lbWl0KGV2ZW50KTtcblx0XHR9XG5cdH1cbn1cbiJdfQ==
@@ -1,9 +1,9 @@
1
1
  import * as i0 from '@angular/core';
2
- import { InjectionToken, PLATFORM_ID, Injectable, Inject, Optional, Component, ViewChild, EventEmitter, Directive, Input, Output, Pipe, NgModule } from '@angular/core';
2
+ import { InjectionToken, PLATFORM_ID, Injectable, Inject, Optional, Component, ViewChild, EventEmitter, Directive, Output, HostListener, Pipe, NgModule } from '@angular/core';
3
3
  import * as i1 from '@angular/router';
4
4
  import * as i2 from '@angular/platform-browser';
5
5
  import * as i2$1 from '@angular/common';
6
- import { isPlatformServer, isPlatformBrowser, CommonModule } from '@angular/common';
6
+ import { isPlatformServer, CommonModule } from '@angular/common';
7
7
  import * as i2$2 from '@angular/common/http';
8
8
  import { HttpHeaders, HttpClientModule } from '@angular/common/http';
9
9
  import { Subject } from 'rxjs';
@@ -634,187 +634,30 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImpor
634
634
  }] } });
635
635
 
636
636
  class ClickOutsideDirective {
637
- platformId;
638
- _el;
639
- _ngZone;
640
- core;
641
- clickOutsideEnabled = true;
642
- attachOutsideOnClick = false;
643
- delayClickOutsideInit = false;
644
- emitOnBlur = false;
645
- exclude = '';
646
- excludeBeforeClick = false;
647
- clickOutsideEvents = '';
637
+ elementRef;
648
638
  clickOutside = new EventEmitter();
649
- _nodesExcluded = [];
650
- _events = ['click'];
651
- constructor(platformId, _el, _ngZone, core) {
652
- this.platformId = platformId;
653
- this._el = _el;
654
- this._ngZone = _ngZone;
655
- this.core = core;
656
- this._initOnClickBody = this._initOnClickBody.bind(this);
657
- this._onClickBody = this._onClickBody.bind(this);
658
- this._onWindowBlur = this._onWindowBlur.bind(this);
659
- }
660
- ngOnInit() {
661
- if (!isPlatformBrowser(this.platformId)) {
662
- return;
663
- }
664
- this._init();
665
- }
666
- ngOnDestroy() {
667
- if (!isPlatformBrowser(this.platformId)) {
668
- return;
669
- }
670
- this._removeClickOutsideListener();
671
- this._removeAttachOutsideOnClickListener();
672
- this._removeWindowBlurListener();
673
- }
674
- ngOnChanges(changes) {
675
- if (!isPlatformBrowser(this.platformId)) {
676
- return;
677
- }
678
- if (changes['attachOutsideOnClick'] || changes['exclude'] || changes['emitOnBlur']) {
679
- this._init();
680
- }
681
- }
682
- _init() {
683
- if (this.clickOutsideEvents !== '') {
684
- this._events = this.clickOutsideEvents.split(',').map(e => e.trim());
685
- }
686
- this._excludeCheck();
687
- if (this.attachOutsideOnClick) {
688
- this._initAttachOutsideOnClickListener();
689
- }
690
- else {
691
- this._initOnClickBody();
692
- }
693
- if (this.emitOnBlur) {
694
- this._initWindowBlurListener();
695
- }
696
- }
697
- _initOnClickBody() {
698
- if (this.delayClickOutsideInit) {
699
- setTimeout(this._initClickOutsideListener.bind(this));
700
- }
701
- else {
702
- this._initClickOutsideListener();
703
- }
704
- }
705
- _excludeCheck() {
706
- if (this.exclude) {
707
- try {
708
- const nodes = Array.from(this.core.document.querySelectorAll(this.exclude));
709
- if (nodes) {
710
- this._nodesExcluded = nodes;
711
- }
712
- }
713
- catch (err) {
714
- console.error('[ng-click-outside] Check your exclude selector syntax.', err);
715
- }
716
- }
717
- }
718
- _onClickBody(ev) {
719
- if (!this.clickOutsideEnabled) {
720
- return;
721
- }
722
- if (this.excludeBeforeClick) {
723
- this._excludeCheck();
724
- }
725
- if (!this._el.nativeElement.contains(ev.target) && !this._shouldExclude(ev.target)) {
726
- this._emit(ev);
727
- if (this.attachOutsideOnClick) {
728
- this._removeClickOutsideListener();
729
- }
730
- }
731
- }
732
- /**
733
- * Resolves problem with outside click on iframe
734
- * @see https://github.com/arkon/ng-click-outside/issues/32
735
- */
736
- _onWindowBlur(ev) {
737
- setTimeout(() => {
738
- if (!this.core.document.hidden) {
739
- this._emit(ev);
740
- }
741
- });
742
- }
743
- _emit(ev) {
744
- if (!this.clickOutsideEnabled) {
745
- return;
746
- }
747
- this._ngZone.run(() => this.clickOutside.emit(ev));
639
+ constructor(elementRef) {
640
+ this.elementRef = elementRef;
748
641
  }
749
- _shouldExclude(target) {
750
- for (let excludedNode of this._nodesExcluded) {
751
- if (excludedNode.contains(target)) {
752
- return true;
753
- }
642
+ onClick(event) {
643
+ const clickedInside = this.elementRef.nativeElement.contains(event.target);
644
+ if (!clickedInside) {
645
+ this.clickOutside.emit(event);
754
646
  }
755
- return false;
756
647
  }
757
- _initClickOutsideListener() {
758
- this._ngZone.runOutsideAngular(() => {
759
- this._events.forEach(e => this.core.document.addEventListener(e, this._onClickBody));
760
- });
761
- }
762
- _removeClickOutsideListener() {
763
- this._ngZone.runOutsideAngular(() => {
764
- this._events.forEach(e => this.core.document.removeEventListener(e, this._onClickBody));
765
- });
766
- }
767
- _initAttachOutsideOnClickListener() {
768
- this._ngZone.runOutsideAngular(() => {
769
- this._events.forEach(e => this._el.nativeElement.addEventListener(e, this._initOnClickBody));
770
- });
771
- }
772
- _removeAttachOutsideOnClickListener() {
773
- this._ngZone.runOutsideAngular(() => {
774
- this._events.forEach(e => this._el.nativeElement.removeEventListener(e, this._initOnClickBody));
775
- });
776
- }
777
- _initWindowBlurListener() {
778
- this._ngZone.runOutsideAngular(() => {
779
- this.core.window.addEventListener('blur', this._onWindowBlur);
780
- });
781
- }
782
- _removeWindowBlurListener() {
783
- this._ngZone.runOutsideAngular(() => {
784
- this.core.window.removeEventListener('blur', this._onWindowBlur);
785
- });
786
- }
787
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: ClickOutsideDirective, deps: [{ token: PLATFORM_ID }, { token: i0.ElementRef }, { token: i0.NgZone }, { token: CoreService }], target: i0.ɵɵFactoryTarget.Directive });
788
- static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.2", type: ClickOutsideDirective, selector: "[clickOutside]", inputs: { clickOutsideEnabled: "clickOutsideEnabled", attachOutsideOnClick: "attachOutsideOnClick", delayClickOutsideInit: "delayClickOutsideInit", emitOnBlur: "emitOnBlur", exclude: "exclude", excludeBeforeClick: "excludeBeforeClick", clickOutsideEvents: "clickOutsideEvents" }, outputs: { clickOutside: "clickOutside" }, exportAs: ["clickOutside"], usesOnChanges: true, ngImport: i0 });
789
- static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: ClickOutsideDirective });
648
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: ClickOutsideDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
649
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.2", type: ClickOutsideDirective, selector: "[clickOutside]", outputs: { clickOutside: "clickOutside" }, host: { listeners: { "document:click": "onClick($event)" } }, ngImport: i0 });
790
650
  }
791
651
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.2", ngImport: i0, type: ClickOutsideDirective, decorators: [{
792
- type: Injectable
793
- }, {
794
652
  type: Directive,
795
653
  args: [{
796
- selector: '[clickOutside]',
797
- exportAs: 'clickOutside'
654
+ selector: '[clickOutside]'
798
655
  }]
799
- }], ctorParameters: function () { return [{ type: Object, decorators: [{
800
- type: Inject,
801
- args: [PLATFORM_ID]
802
- }] }, { type: i0.ElementRef }, { type: i0.NgZone }, { type: CoreService }]; }, propDecorators: { clickOutsideEnabled: [{
803
- type: Input
804
- }], attachOutsideOnClick: [{
805
- type: Input
806
- }], delayClickOutsideInit: [{
807
- type: Input
808
- }], emitOnBlur: [{
809
- type: Input
810
- }], exclude: [{
811
- type: Input
812
- }], excludeBeforeClick: [{
813
- type: Input
814
- }], clickOutsideEvents: [{
815
- type: Input
816
- }], clickOutside: [{
656
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { clickOutside: [{
817
657
  type: Output
658
+ }], onClick: [{
659
+ type: HostListener,
660
+ args: ['document:click', ['$event']]
818
661
  }] } });
819
662
 
820
663
  class ArrPipe {