adb-shared 6.0.2 → 6.0.3
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/esm2022/adb-shared.mjs +4 -4
- package/esm2022/lib/components/adb-artportalen-nav/adb-artportalen-footer.component.mjs +48 -48
- package/esm2022/lib/components/adb-artportalen-nav/adb-artportalen-nav.component.mjs +112 -112
- package/esm2022/lib/components/adb-artportalen-nav/adb-artportalen-nav.module.mjs +58 -66
- package/esm2022/lib/components/adb-artportalen-nav/environment.service.mjs +16 -16
- package/esm2022/lib/components/adb-artportalen-nav/navigation.model.mjs +1 -1
- package/esm2022/lib/components/adb-buttons/adb-buttons.module.mjs +19 -19
- package/esm2022/lib/components/adb-buttons/help-button.component.mjs +35 -35
- package/esm2022/lib/components/adb-confirm-modal/adb-confirm-modal.mjs +29 -29
- package/esm2022/lib/components/adb-confirm-modal/adb-modal.module.mjs +23 -23
- package/esm2022/lib/components/adb-confirm-modal/adb-modal.service.mjs +46 -46
- package/esm2022/lib/components/adb-dropdown/adb-dropdown.directive.mjs +100 -100
- package/esm2022/lib/components/adb-dropdown/adb-dropdown.module.mjs +24 -24
- package/esm2022/lib/components/adb-dropdown/adb-dropdown.service.mjs +10 -10
- package/esm2022/lib/components/adb-dropdown/adb-dropdown2.directive.mjs +119 -119
- package/esm2022/lib/components/adb-header/adb-header.module.mjs +49 -57
- package/esm2022/lib/components/adb-header/adb-nav.component.mjs +115 -115
- package/esm2022/lib/components/adb-header/environment.service.mjs +16 -16
- package/esm2022/lib/components/adb-header/navigation.model.mjs +1 -1
- package/esm2022/lib/components/adb-rich-editor/adb-rich-editor.component.mjs +84 -65
- package/esm2022/lib/components/adb-rich-editor/adb-rich-editor.module.mjs +19 -19
- package/esm2022/lib/components/adb-toast/adb-toast.mjs +25 -25
- package/esm2022/lib/components/adb-toast/adb-toast.module.mjs +23 -23
- package/esm2022/lib/components/adb-toast/adb-toast.service.mjs +55 -55
- package/esm2022/lib/components/date-picker/adb-date-picker.component.mjs +177 -177
- package/esm2022/lib/components/date-picker/adb-date-picker.directive.mjs +220 -220
- package/esm2022/lib/components/date-picker/adb-date-picker.module.mjs +25 -25
- package/esm2022/lib/components/date-picker/adb-date-picker.service.mjs +10 -10
- package/esm2022/lib/components/pagers/infinite-scroll.component.mjs +47 -47
- package/esm2022/lib/components/pagers/pager-base.directive.mjs +57 -57
- package/esm2022/lib/components/pagers/pager-inline.mjs +49 -49
- package/esm2022/lib/components/pagers/pager.mjs +53 -53
- package/esm2022/lib/components/pagers/pagers.module.mjs +26 -26
- package/esm2022/lib/directives/click-outside.directive.mjs +28 -28
- package/esm2022/lib/directives/directives.module.mjs +21 -21
- package/esm2022/lib/directives/file-upload.directive.mjs +36 -36
- package/esm2022/lib/directives/focus.directive.mjs +34 -34
- package/esm2022/lib/directives/redlist-badge-class.directive.mjs +44 -44
- package/esm2022/lib/directives/risk-class.directive.mjs +37 -37
- package/esm2022/lib/pipes/date.pipe.mjs +22 -22
- package/esm2022/lib/pipes/emptyValue.pipe.mjs +22 -22
- package/esm2022/lib/pipes/highlight-html.pipe.mjs +46 -46
- package/esm2022/lib/pipes/highlight.pipe.mjs +46 -46
- package/esm2022/lib/pipes/number-spacing.pipe.mjs +21 -21
- package/esm2022/lib/pipes/pipes.module.mjs +22 -22
- package/esm2022/lib/pipes/rich.pipe.mjs +36 -36
- package/esm2022/public-api.mjs +41 -41
- package/fesm2022/adb-shared.mjs +1817 -1815
- package/fesm2022/adb-shared.mjs.map +1 -1
- package/index.d.ts +5 -5
- package/lib/components/adb-artportalen-nav/adb-artportalen-footer.component.d.ts +23 -23
- package/lib/components/adb-artportalen-nav/adb-artportalen-nav.component.d.ts +41 -41
- package/lib/components/adb-artportalen-nav/adb-artportalen-nav.module.d.ts +16 -17
- package/lib/components/adb-artportalen-nav/environment.service.d.ts +7 -7
- package/lib/components/adb-artportalen-nav/navigation.model.d.ts +18 -18
- package/lib/components/adb-buttons/adb-buttons.module.d.ts +9 -9
- package/lib/components/adb-buttons/help-button.component.d.ts +13 -13
- package/lib/components/adb-confirm-modal/adb-confirm-modal.d.ts +20 -20
- package/lib/components/adb-confirm-modal/adb-modal.module.d.ts +10 -10
- package/lib/components/adb-confirm-modal/adb-modal.service.d.ts +18 -18
- package/lib/components/adb-dropdown/adb-dropdown.directive.d.ts +21 -21
- package/lib/components/adb-dropdown/adb-dropdown.module.d.ts +11 -11
- package/lib/components/adb-dropdown/adb-dropdown.service.d.ts +7 -7
- package/lib/components/adb-dropdown/adb-dropdown2.directive.d.ts +23 -23
- package/lib/components/adb-header/adb-header.module.d.ts +15 -16
- package/lib/components/adb-header/adb-nav.component.d.ts +41 -41
- package/lib/components/adb-header/environment.service.d.ts +7 -7
- package/lib/components/adb-header/navigation.model.d.ts +29 -29
- package/lib/components/adb-rich-editor/adb-rich-editor.component.d.ts +24 -22
- package/lib/components/adb-rich-editor/adb-rich-editor.module.d.ts +9 -9
- package/lib/components/adb-toast/adb-toast.d.ts +11 -11
- package/lib/components/adb-toast/adb-toast.module.d.ts +10 -10
- package/lib/components/adb-toast/adb-toast.service.d.ts +36 -36
- package/lib/components/date-picker/adb-date-picker.component.d.ts +64 -64
- package/lib/components/date-picker/adb-date-picker.directive.d.ts +47 -47
- package/lib/components/date-picker/adb-date-picker.module.d.ts +12 -12
- package/lib/components/date-picker/adb-date-picker.service.d.ts +8 -8
- package/lib/components/pagers/infinite-scroll.component.d.ts +15 -15
- package/lib/components/pagers/pager-base.directive.d.ts +16 -16
- package/lib/components/pagers/pager-inline.d.ts +16 -16
- package/lib/components/pagers/pager.d.ts +22 -22
- package/lib/components/pagers/pagers.module.d.ts +11 -11
- package/lib/directives/click-outside.directive.d.ts +10 -10
- package/lib/directives/directives.module.d.ts +11 -11
- package/lib/directives/file-upload.directive.d.ts +12 -12
- package/lib/directives/focus.directive.d.ts +11 -11
- package/lib/directives/redlist-badge-class.directive.d.ts +7 -7
- package/lib/directives/risk-class.directive.d.ts +7 -7
- package/lib/pipes/date.pipe.d.ts +10 -10
- package/lib/pipes/emptyValue.pipe.d.ts +7 -7
- package/lib/pipes/highlight-html.pipe.d.ts +10 -10
- package/lib/pipes/highlight.pipe.d.ts +9 -9
- package/lib/pipes/number-spacing.pipe.d.ts +7 -7
- package/lib/pipes/pipes.module.d.ts +12 -12
- package/lib/pipes/rich.pipe.d.ts +11 -11
- package/package.json +5 -5
- package/public-api.d.ts +38 -38
|
@@ -1,100 +1,100 @@
|
|
|
1
|
-
import { Directive, EventEmitter, HostBinding, HostListener, Input, Output } from "@angular/core";
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "./adb-dropdown.service";
|
|
4
|
-
export class AdbDropdownDirective {
|
|
5
|
-
constructor(elementRef, adbDropdownService) {
|
|
6
|
-
this.elementRef = elementRef;
|
|
7
|
-
this.adbDropdownService = adbDropdownService;
|
|
8
|
-
this.adbDropdown = new EventEmitter();
|
|
9
|
-
this.insideClick = false;
|
|
10
|
-
this.dataToggle = "dropdown";
|
|
11
|
-
this.haspPopup = true;
|
|
12
|
-
this.expanded = false;
|
|
13
|
-
this.id = this.getId();
|
|
14
|
-
this.dropId = this.getId();
|
|
15
|
-
}
|
|
16
|
-
onClick() {
|
|
17
|
-
this.adbDropdownService.currentMenuId = this.id;
|
|
18
|
-
const node = this.elementRef.nativeElement.parentNode;
|
|
19
|
-
const toggleButton = node.querySelector('.dropdown-toggle');
|
|
20
|
-
let style = `transform:translate3d(0px, ${toggleButton?.clientHeight + 1}px, 0px);`;
|
|
21
|
-
const menu = node.querySelector('.dropdown-menu');
|
|
22
|
-
if (menu) {
|
|
23
|
-
this.adbDropdownService.currentMenu = this.elementRef.nativeElement;
|
|
24
|
-
if (menu.classList?.contains('dropdown-menu-end')) {
|
|
25
|
-
style = style + 'inset: 0px 0px auto auto;';
|
|
26
|
-
}
|
|
27
|
-
menu.setAttribute('style', style);
|
|
28
|
-
menu.setAttribute('id', this.dropId);
|
|
29
|
-
if (menu.classList.contains('show')) {
|
|
30
|
-
menu.classList.remove('show');
|
|
31
|
-
this.expanded = false;
|
|
32
|
-
}
|
|
33
|
-
else {
|
|
34
|
-
this.adbDropdown.emit();
|
|
35
|
-
menu.classList.add('show');
|
|
36
|
-
this.expanded = true;
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
onCheckOutSideClick(target) {
|
|
41
|
-
if (this.adbDropdownService.currentMenuId === this.id) {
|
|
42
|
-
const parent = this.insideClick ? this.elementRef.nativeElement.parentNode : this.elementRef.nativeElement;
|
|
43
|
-
const clickedInside = parent.contains(target);
|
|
44
|
-
if (!clickedInside) {
|
|
45
|
-
const parent = this.elementRef.nativeElement.parentNode.querySelector('.dropdown-menu');
|
|
46
|
-
parent?.classList.remove('show');
|
|
47
|
-
this.expanded = false;
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
else {
|
|
51
|
-
const parent = this.elementRef.nativeElement.parentNode.querySelector('.dropdown-menu');
|
|
52
|
-
parent?.classList.remove('show');
|
|
53
|
-
this.expanded = false;
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
close() {
|
|
57
|
-
const node = this.elementRef.nativeElement.parentNode;
|
|
58
|
-
const menu = node.querySelector('.dropdown-menu');
|
|
59
|
-
menu.classList.remove('show');
|
|
60
|
-
this.expanded = false;
|
|
61
|
-
}
|
|
62
|
-
getId() {
|
|
63
|
-
return '' + Math.floor(Math.random() * Date.now());
|
|
64
|
-
}
|
|
65
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
66
|
-
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "
|
|
67
|
-
}
|
|
68
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
69
|
-
type: Directive,
|
|
70
|
-
args: [{
|
|
71
|
-
selector: '[adbDropdown]',
|
|
72
|
-
exportAs: 'adbDropdown'
|
|
73
|
-
}]
|
|
74
|
-
}], ctorParameters:
|
|
75
|
-
type: Output
|
|
76
|
-
}], insideClick: [{
|
|
77
|
-
type: Input
|
|
78
|
-
}], id: [{
|
|
79
|
-
type: HostBinding,
|
|
80
|
-
args: ['id']
|
|
81
|
-
}], dataToggle: [{
|
|
82
|
-
type: HostBinding,
|
|
83
|
-
args: ['attr.data-toggle']
|
|
84
|
-
}], haspPopup: [{
|
|
85
|
-
type: HostBinding,
|
|
86
|
-
args: ['attr.aria-haspopup']
|
|
87
|
-
}], expanded: [{
|
|
88
|
-
type: HostBinding,
|
|
89
|
-
args: ['attr.aria-expanded']
|
|
90
|
-
}], dropId: [{
|
|
91
|
-
type: HostBinding,
|
|
92
|
-
args: ['attr.aria-controls']
|
|
93
|
-
}], onClick: [{
|
|
94
|
-
type: HostListener,
|
|
95
|
-
args: ['click']
|
|
96
|
-
}], onCheckOutSideClick: [{
|
|
97
|
-
type: HostListener,
|
|
98
|
-
args: ['document:click', ['$event.target']]
|
|
99
|
-
}] } });
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { Directive, EventEmitter, HostBinding, HostListener, Input, Output } from "@angular/core";
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "./adb-dropdown.service";
|
|
4
|
+
export class AdbDropdownDirective {
|
|
5
|
+
constructor(elementRef, adbDropdownService) {
|
|
6
|
+
this.elementRef = elementRef;
|
|
7
|
+
this.adbDropdownService = adbDropdownService;
|
|
8
|
+
this.adbDropdown = new EventEmitter();
|
|
9
|
+
this.insideClick = false;
|
|
10
|
+
this.dataToggle = "dropdown";
|
|
11
|
+
this.haspPopup = true;
|
|
12
|
+
this.expanded = false;
|
|
13
|
+
this.id = this.getId();
|
|
14
|
+
this.dropId = this.getId();
|
|
15
|
+
}
|
|
16
|
+
onClick() {
|
|
17
|
+
this.adbDropdownService.currentMenuId = this.id;
|
|
18
|
+
const node = this.elementRef.nativeElement.parentNode;
|
|
19
|
+
const toggleButton = node.querySelector('.dropdown-toggle');
|
|
20
|
+
let style = `transform:translate3d(0px, ${toggleButton?.clientHeight + 1}px, 0px);`;
|
|
21
|
+
const menu = node.querySelector('.dropdown-menu');
|
|
22
|
+
if (menu) {
|
|
23
|
+
this.adbDropdownService.currentMenu = this.elementRef.nativeElement;
|
|
24
|
+
if (menu.classList?.contains('dropdown-menu-end')) {
|
|
25
|
+
style = style + 'inset: 0px 0px auto auto;';
|
|
26
|
+
}
|
|
27
|
+
menu.setAttribute('style', style);
|
|
28
|
+
menu.setAttribute('id', this.dropId);
|
|
29
|
+
if (menu.classList.contains('show')) {
|
|
30
|
+
menu.classList.remove('show');
|
|
31
|
+
this.expanded = false;
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
34
|
+
this.adbDropdown.emit();
|
|
35
|
+
menu.classList.add('show');
|
|
36
|
+
this.expanded = true;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
onCheckOutSideClick(target) {
|
|
41
|
+
if (this.adbDropdownService.currentMenuId === this.id) {
|
|
42
|
+
const parent = this.insideClick ? this.elementRef.nativeElement.parentNode : this.elementRef.nativeElement;
|
|
43
|
+
const clickedInside = parent.contains(target);
|
|
44
|
+
if (!clickedInside) {
|
|
45
|
+
const parent = this.elementRef.nativeElement.parentNode.querySelector('.dropdown-menu');
|
|
46
|
+
parent?.classList.remove('show');
|
|
47
|
+
this.expanded = false;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
const parent = this.elementRef.nativeElement.parentNode.querySelector('.dropdown-menu');
|
|
52
|
+
parent?.classList.remove('show');
|
|
53
|
+
this.expanded = false;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
close() {
|
|
57
|
+
const node = this.elementRef.nativeElement.parentNode;
|
|
58
|
+
const menu = node.querySelector('.dropdown-menu');
|
|
59
|
+
menu.classList.remove('show');
|
|
60
|
+
this.expanded = false;
|
|
61
|
+
}
|
|
62
|
+
getId() {
|
|
63
|
+
return '' + Math.floor(Math.random() * Date.now());
|
|
64
|
+
}
|
|
65
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: AdbDropdownDirective, deps: [{ token: i0.ElementRef }, { token: i1.AdbDropdownService }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
66
|
+
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.8", type: AdbDropdownDirective, selector: "[adbDropdown]", inputs: { insideClick: "insideClick" }, outputs: { adbDropdown: "adbDropdown" }, host: { listeners: { "click": "onClick()", "document:click": "onCheckOutSideClick($event.target)" }, properties: { "id": "this.id", "attr.data-toggle": "this.dataToggle", "attr.aria-haspopup": "this.haspPopup", "attr.aria-expanded": "this.expanded", "attr.aria-controls": "this.dropId" } }, exportAs: ["adbDropdown"], ngImport: i0 }); }
|
|
67
|
+
}
|
|
68
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: AdbDropdownDirective, decorators: [{
|
|
69
|
+
type: Directive,
|
|
70
|
+
args: [{
|
|
71
|
+
selector: '[adbDropdown]',
|
|
72
|
+
exportAs: 'adbDropdown'
|
|
73
|
+
}]
|
|
74
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.AdbDropdownService }], propDecorators: { adbDropdown: [{
|
|
75
|
+
type: Output
|
|
76
|
+
}], insideClick: [{
|
|
77
|
+
type: Input
|
|
78
|
+
}], id: [{
|
|
79
|
+
type: HostBinding,
|
|
80
|
+
args: ['id']
|
|
81
|
+
}], dataToggle: [{
|
|
82
|
+
type: HostBinding,
|
|
83
|
+
args: ['attr.data-toggle']
|
|
84
|
+
}], haspPopup: [{
|
|
85
|
+
type: HostBinding,
|
|
86
|
+
args: ['attr.aria-haspopup']
|
|
87
|
+
}], expanded: [{
|
|
88
|
+
type: HostBinding,
|
|
89
|
+
args: ['attr.aria-expanded']
|
|
90
|
+
}], dropId: [{
|
|
91
|
+
type: HostBinding,
|
|
92
|
+
args: ['attr.aria-controls']
|
|
93
|
+
}], onClick: [{
|
|
94
|
+
type: HostListener,
|
|
95
|
+
args: ['click']
|
|
96
|
+
}], onCheckOutSideClick: [{
|
|
97
|
+
type: HostListener,
|
|
98
|
+
args: ['document:click', ['$event.target']]
|
|
99
|
+
}] } });
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adb-dropdown.directive.js","sourceRoot":"","sources":["../../../../../../projects/artdata-shared/src/lib/components/adb-dropdown/adb-dropdown.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAc,YAAY,EAAE,WAAW,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;;;AAO9G,MAAM,OAAO,oBAAoB;IAE7B,YACY,UAAsB,EACtB,kBAAsC;QADtC,eAAU,GAAV,UAAU,CAAY;QACtB,uBAAkB,GAAlB,kBAAkB,CAAoB;QAKxC,gBAAW,GAAG,IAAI,YAAY,EAAE,CAAC;QAClC,gBAAW,GAAG,KAAK,CAAC;QAM7B,eAAU,GAAG,UAAU,CAAC;QAGxB,cAAS,GAAG,IAAI,CAAC;QAGjB,aAAQ,GAAG,KAAK,CAAC;QAjBb,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;QACvB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;IAC/B,CAAC;IAqBD,OAAO;QACH,IAAI,CAAC,kBAAkB,CAAC,aAAa,GAAG,IAAI,CAAC,EAAE,CAAC;QAChD,MAAM,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,UAAU,CAAC;QACtD,MAAM,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,kBAAkB,CAAC,CAAC;QAC5D,IAAI,KAAK,GAAG,8BAA8B,YAAY,EAAE,YAAY,GAAG,CAAC,WAAW,CAAC;QACpF,MAAM,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC;QAClD,IAAI,IAAI,EAAE,CAAC;YACP,IAAI,CAAC,kBAAkB,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;YACpE,IAAI,IAAI,CAAC,SAAS,EAAE,QAAQ,CAAC,mBAAmB,CAAC,EAAE,CAAC;gBAChD,KAAK,GAAG,KAAK,GAAG,2BAA2B,CAAC;YAChD,CAAC;YACD,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;YAClC,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;YACrC,IAAI,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;gBAClC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;gBAC9B,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;YAC1B,CAAC;iBAAM,CAAC;gBACJ,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;gBACxB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;gBAC3B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;YACzB,CAAC;QACL,CAAC;IACL,CAAC;IAGD,mBAAmB,CAAC,MAAW;QAC3B,IAAI,IAAI,CAAC,kBAAkB,CAAC,aAAa,KAAK,IAAI,CAAC,EAAE,EAAE,CAAC;YACpD,MAAM,MAAM,GAAG,IAAI,CAAC,WAAW,CAAA,CAAC,CAAA,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,UAAU,CAAA,CAAC,CAAA,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;YACvG,MAAM,aAAa,GAAG,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;YAC9C,IAAI,CAAC,aAAa,EAAE,CAAC;gBACjB,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,UAAU,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC;gBACxF,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;gBACjC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;YAC1B,CAAC;QACL,CAAC;aAAM,CAAC;YACJ,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,UAAU,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC;YACxF,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;YACjC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QAC1B,CAAC;IACL,CAAC;IAED,KAAK;QACD,MAAM,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,UAAU,CAAC;QACtD,MAAM,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC;QAClD,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAC9B,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;IAC1B,CAAC;IAEO,KAAK;QACT,OAAO,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,CAAA;IACtD,CAAC;iIA9EQ,oBAAoB;qHAApB,oBAAoB;;2FAApB,oBAAoB;kBAJhC,SAAS;mBAAC;oBACP,QAAQ,EAAE,eAAe;oBACzB,QAAQ,EAAE,aAAa;iBAC1B;gHAUa,WAAW;sBAApB,MAAM;gBACE,WAAW;sBAAnB,KAAK;gBAGN,EAAE;sBADD,WAAW;uBAAC,IAAI;gBAIjB,UAAU;sBADT,WAAW;uBAAC,kBAAkB;gBAI/B,SAAS;sBADR,WAAW;uBAAC,oBAAoB;gBAIjC,QAAQ;sBADP,WAAW;uBAAC,oBAAoB;gBAIjC,MAAM;sBADL,WAAW;uBAAC,oBAAoB;gBAIjC,OAAO;sBADN,YAAY;uBAAC,OAAO;gBA0BrB,mBAAmB;sBADlB,YAAY;uBAAC,gBAAgB,EAAE,CAAC,eAAe,CAAC","sourcesContent":["import { Directive, ElementRef, EventEmitter, HostBinding, HostListener, Input, Output } from \"@angular/core\";\r\nimport { AdbDropdownService } from \"./adb-dropdown.service\";\r\n\r\n@Directive({\r\n    selector: '[adbDropdown]',\r\n    exportAs: 'adbDropdown'\r\n})\r\nexport class AdbDropdownDirective {\r\n\r\n    constructor(\r\n        private elementRef: ElementRef,\r\n        private adbDropdownService: AdbDropdownService) {\r\n        this.id = this.getId();\r\n        this.dropId = this.getId();\r\n    }\r\n\r\n    @Output() adbDropdown = new EventEmitter();\r\n    @Input() insideClick = false;\r\n\r\n    @HostBinding('id')\r\n    id: string;\r\n\r\n    @HostBinding('attr.data-toggle')\r\n    dataToggle = \"dropdown\";\r\n\r\n    @HostBinding('attr.aria-haspopup')\r\n    haspPopup = true;\r\n\r\n    @HostBinding('attr.aria-expanded')\r\n    expanded = false;\r\n\r\n    @HostBinding('attr.aria-controls')\r\n    dropId:string;\r\n\r\n    @HostListener('click')\r\n    onClick(): void {\r\n        this.adbDropdownService.currentMenuId = this.id;\r\n        const node = this.elementRef.nativeElement.parentNode;\r\n        const toggleButton = node.querySelector('.dropdown-toggle');\r\n        let style = `transform:translate3d(0px, ${toggleButton?.clientHeight + 1}px, 0px);`;\r\n        const menu = node.querySelector('.dropdown-menu');\r\n        if (menu) {\r\n            this.adbDropdownService.currentMenu = this.elementRef.nativeElement;\r\n            if (menu.classList?.contains('dropdown-menu-end')) {\r\n                style = style + 'inset: 0px 0px auto auto;';\r\n            }\r\n            menu.setAttribute('style', style);\r\n            menu.setAttribute('id', this.dropId);\r\n            if (menu.classList.contains('show')) {\r\n                menu.classList.remove('show');\r\n                this.expanded = false;\r\n            } else {\r\n                this.adbDropdown.emit();\r\n                menu.classList.add('show');\r\n                this.expanded = true;\r\n            }\r\n        }\r\n    }\r\n\r\n    @HostListener('document:click', ['$event.target'])\r\n    onCheckOutSideClick(target: any): void {\r\n        if (this.adbDropdownService.currentMenuId === this.id) {\r\n            const parent = this.insideClick?this.elementRef.nativeElement.parentNode:this.elementRef.nativeElement;\r\n            const clickedInside = parent.contains(target);\r\n            if (!clickedInside) {\r\n                const parent = this.elementRef.nativeElement.parentNode.querySelector('.dropdown-menu');\r\n                parent?.classList.remove('show');\r\n                this.expanded = false;\r\n            }\r\n        } else {\r\n            const parent = this.elementRef.nativeElement.parentNode.querySelector('.dropdown-menu');\r\n            parent?.classList.remove('show');\r\n            this.expanded = false;\r\n        }\r\n    }\r\n\r\n    close(): void {\r\n        const node = this.elementRef.nativeElement.parentNode;\r\n        const menu = node.querySelector('.dropdown-menu');\r\n        menu.classList.remove('show');\r\n        this.expanded = false;\r\n    }\r\n\r\n    private getId(): string {\r\n        return '' + Math.floor(Math.random() * Date.now())\r\n    }\r\n}"]}
|
|
@@ -1,24 +1,24 @@
|
|
|
1
|
-
import { CommonModule } from "@angular/common";
|
|
2
|
-
import { NgModule } from "@angular/core";
|
|
3
|
-
import { TranslateModule } from "@ngx-translate/core";
|
|
4
|
-
import { AdbDirectivesModule } from "../../directives/directives.module";
|
|
5
|
-
import { AdbDropdownDirective } from "./adb-dropdown.directive";
|
|
6
|
-
import { AdbDropdownService } from "./adb-dropdown.service";
|
|
7
|
-
import { AdbDropdown2Directive } from "./adb-dropdown2.directive";
|
|
8
|
-
import * as i0 from "@angular/core";
|
|
9
|
-
import * as i1 from "@ngx-translate/core";
|
|
10
|
-
export class AdbDropdownModule {
|
|
11
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
12
|
-
/** @nocollapse */ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "
|
|
13
|
-
/** @nocollapse */ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "
|
|
14
|
-
}
|
|
15
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
16
|
-
type: NgModule,
|
|
17
|
-
args: [{
|
|
18
|
-
imports: [CommonModule, TranslateModule.forChild(), AdbDirectivesModule],
|
|
19
|
-
declarations: [AdbDropdownDirective, AdbDropdown2Directive],
|
|
20
|
-
exports: [AdbDropdownDirective, AdbDropdown2Directive],
|
|
21
|
-
providers: [AdbDropdownService]
|
|
22
|
-
}]
|
|
23
|
-
}] });
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { CommonModule } from "@angular/common";
|
|
2
|
+
import { NgModule } from "@angular/core";
|
|
3
|
+
import { TranslateModule } from "@ngx-translate/core";
|
|
4
|
+
import { AdbDirectivesModule } from "../../directives/directives.module";
|
|
5
|
+
import { AdbDropdownDirective } from "./adb-dropdown.directive";
|
|
6
|
+
import { AdbDropdownService } from "./adb-dropdown.service";
|
|
7
|
+
import { AdbDropdown2Directive } from "./adb-dropdown2.directive";
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "@ngx-translate/core";
|
|
10
|
+
export class AdbDropdownModule {
|
|
11
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: AdbDropdownModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
12
|
+
/** @nocollapse */ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.8", ngImport: i0, type: AdbDropdownModule, declarations: [AdbDropdownDirective, AdbDropdown2Directive], imports: [CommonModule, i1.TranslateModule, AdbDirectivesModule], exports: [AdbDropdownDirective, AdbDropdown2Directive] }); }
|
|
13
|
+
/** @nocollapse */ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: AdbDropdownModule, providers: [AdbDropdownService], imports: [CommonModule, TranslateModule.forChild(), AdbDirectivesModule] }); }
|
|
14
|
+
}
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: AdbDropdownModule, decorators: [{
|
|
16
|
+
type: NgModule,
|
|
17
|
+
args: [{
|
|
18
|
+
imports: [CommonModule, TranslateModule.forChild(), AdbDirectivesModule],
|
|
19
|
+
declarations: [AdbDropdownDirective, AdbDropdown2Directive],
|
|
20
|
+
exports: [AdbDropdownDirective, AdbDropdown2Directive],
|
|
21
|
+
providers: [AdbDropdownService]
|
|
22
|
+
}]
|
|
23
|
+
}] });
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRiLWRyb3Bkb3duLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FydGRhdGEtc2hhcmVkL3NyYy9saWIvY29tcG9uZW50cy9hZGItZHJvcGRvd24vYWRiLWRyb3Bkb3duLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDdEQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDekUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDaEUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDNUQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7OztBQVFsRSxNQUFNLE9BQU8saUJBQWlCO2lJQUFqQixpQkFBaUI7a0lBQWpCLGlCQUFpQixpQkFKWCxvQkFBb0IsRUFBRSxxQkFBcUIsYUFEaEQsWUFBWSxzQkFBOEIsbUJBQW1CLGFBRTdELG9CQUFvQixFQUFFLHFCQUFxQjtrSUFHNUMsaUJBQWlCLGFBRmYsQ0FBQyxrQkFBa0IsQ0FBQyxZQUhyQixZQUFZLEVBQUUsZUFBZSxDQUFDLFFBQVEsRUFBRSxFQUFFLG1CQUFtQjs7MkZBSzlELGlCQUFpQjtrQkFON0IsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsZUFBZSxDQUFDLFFBQVEsRUFBRSxFQUFFLG1CQUFtQixDQUFDO29CQUN4RSxZQUFZLEVBQUUsQ0FBQyxvQkFBb0IsRUFBRSxxQkFBcUIsQ0FBQztvQkFDM0QsT0FBTyxFQUFFLENBQUMsb0JBQW9CLEVBQUUscUJBQXFCLENBQUM7b0JBQ3RELFNBQVMsRUFBRSxDQUFDLGtCQUFrQixDQUFDO2lCQUNsQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBUcmFuc2xhdGVNb2R1bGUgfSBmcm9tIFwiQG5neC10cmFuc2xhdGUvY29yZVwiO1xyXG5pbXBvcnQgeyBBZGJEaXJlY3RpdmVzTW9kdWxlIH0gZnJvbSBcIi4uLy4uL2RpcmVjdGl2ZXMvZGlyZWN0aXZlcy5tb2R1bGVcIjtcclxuaW1wb3J0IHsgQWRiRHJvcGRvd25EaXJlY3RpdmUgfSBmcm9tIFwiLi9hZGItZHJvcGRvd24uZGlyZWN0aXZlXCI7XHJcbmltcG9ydCB7IEFkYkRyb3Bkb3duU2VydmljZSB9IGZyb20gXCIuL2FkYi1kcm9wZG93bi5zZXJ2aWNlXCI7XHJcbmltcG9ydCB7IEFkYkRyb3Bkb3duMkRpcmVjdGl2ZSB9IGZyb20gXCIuL2FkYi1kcm9wZG93bjIuZGlyZWN0aXZlXCI7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgVHJhbnNsYXRlTW9kdWxlLmZvckNoaWxkKCksIEFkYkRpcmVjdGl2ZXNNb2R1bGVdLFxyXG4gICAgZGVjbGFyYXRpb25zOiBbQWRiRHJvcGRvd25EaXJlY3RpdmUsIEFkYkRyb3Bkb3duMkRpcmVjdGl2ZV0sXHJcbiAgICBleHBvcnRzOiBbQWRiRHJvcGRvd25EaXJlY3RpdmUsIEFkYkRyb3Bkb3duMkRpcmVjdGl2ZV0sXHJcbiAgICBwcm92aWRlcnM6IFtBZGJEcm9wZG93blNlcnZpY2VdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBZGJEcm9wZG93bk1vZHVsZSB7IH0iXX0=
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import { Injectable } from "@angular/core";
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
export class AdbDropdownService {
|
|
4
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
5
|
-
/** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "
|
|
6
|
-
}
|
|
7
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
8
|
-
type: Injectable
|
|
9
|
-
}] });
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
import { Injectable } from "@angular/core";
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class AdbDropdownService {
|
|
4
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: AdbDropdownService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
5
|
+
/** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: AdbDropdownService }); }
|
|
6
|
+
}
|
|
7
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: AdbDropdownService, decorators: [{
|
|
8
|
+
type: Injectable
|
|
9
|
+
}] });
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRiLWRyb3Bkb3duLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hcnRkYXRhLXNoYXJlZC9zcmMvbGliL2NvbXBvbmVudHMvYWRiLWRyb3Bkb3duL2FkYi1kcm9wZG93bi5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBYyxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBR3ZELE1BQU0sT0FBTyxrQkFBa0I7aUlBQWxCLGtCQUFrQjtxSUFBbEIsa0JBQWtCOzsyRkFBbEIsa0JBQWtCO2tCQUQ5QixVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRWxlbWVudFJlZiwgSW5qZWN0YWJsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcblxyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBBZGJEcm9wZG93blNlcnZpY2Uge1xyXG4gICAgY3VycmVudE1lbnU6IGFueTtcclxuICAgIGN1cnJlbnRNZW51SWQ6IHN0cmluZztcclxufSJdfQ==
|
|
@@ -1,119 +1,119 @@
|
|
|
1
|
-
import { Directive, EventEmitter, HostBinding, HostListener, Input, Output } from "@angular/core";
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "./adb-dropdown.service";
|
|
4
|
-
export class AdbDropdown2Directive {
|
|
5
|
-
constructor(elementRef, adbDropdownService) {
|
|
6
|
-
this.elementRef = elementRef;
|
|
7
|
-
this.adbDropdownService = adbDropdownService;
|
|
8
|
-
this.adbDropdown = new EventEmitter();
|
|
9
|
-
this.insideClick = false;
|
|
10
|
-
this.dataToggle = "dropdown";
|
|
11
|
-
this.haspPopup = true;
|
|
12
|
-
this.expanded = false;
|
|
13
|
-
this.id = this.getId();
|
|
14
|
-
this.dropId = this.getId();
|
|
15
|
-
}
|
|
16
|
-
onClick() {
|
|
17
|
-
this.adbDropdownService.currentMenuId = this.id;
|
|
18
|
-
const node = this.elementRef.nativeElement.parentNode;
|
|
19
|
-
const menu = node.querySelector('.dropdown-menu');
|
|
20
|
-
if (menu) {
|
|
21
|
-
this.adbDropdownService.currentMenu = this.elementRef.nativeElement;
|
|
22
|
-
this.setMenuPosition(node, menu);
|
|
23
|
-
menu.setAttribute('id', this.dropId);
|
|
24
|
-
if (menu.classList.contains('show')) {
|
|
25
|
-
menu.classList.remove('show');
|
|
26
|
-
this.expanded = false;
|
|
27
|
-
}
|
|
28
|
-
else {
|
|
29
|
-
this.adbDropdown.emit();
|
|
30
|
-
menu.classList.add('show');
|
|
31
|
-
this.expanded = true;
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
onCheckOutSideClick(target) {
|
|
36
|
-
if (this.adbDropdownService.currentMenuId === this.id) {
|
|
37
|
-
const parent = this.insideClick ? this.elementRef.nativeElement.parentNode : this.elementRef.nativeElement;
|
|
38
|
-
const clickedInside = parent.contains(target);
|
|
39
|
-
if (!clickedInside) {
|
|
40
|
-
const parent = this.elementRef.nativeElement.parentNode.querySelector('.dropdown-menu');
|
|
41
|
-
parent?.classList.remove('show');
|
|
42
|
-
this.expanded = false;
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
else {
|
|
46
|
-
const parent = this.elementRef.nativeElement.parentNode.querySelector('.dropdown-menu');
|
|
47
|
-
parent?.classList.remove('show');
|
|
48
|
-
this.expanded = false;
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
onWindowScroll() {
|
|
52
|
-
const node = this.elementRef.nativeElement.parentNode;
|
|
53
|
-
const menu = node.querySelector('.dropdown-menu');
|
|
54
|
-
if (menu.classList?.contains('show')) {
|
|
55
|
-
this.setMenuPosition(node, menu);
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
setMenuPosition(dropdownNode, menu) {
|
|
59
|
-
const toggleButton = dropdownNode.querySelector('.dropdown-toggle');
|
|
60
|
-
menu.setAttribute('style', 'visibility:hidden');
|
|
61
|
-
menu.setAttribute('style', 'display:block');
|
|
62
|
-
const menuWidth = menu.offsetWidth;
|
|
63
|
-
menu.setAttribute('style', 'visibility:visible');
|
|
64
|
-
menu.setAttribute('style', 'display:none');
|
|
65
|
-
const buttonRect = toggleButton.getBoundingClientRect();
|
|
66
|
-
let menuPosition = `top:${buttonRect.bottom}px;left:${buttonRect.left}px;position:fixed;`;
|
|
67
|
-
if (menu.classList?.contains('dropdown-menu-end')) {
|
|
68
|
-
menuPosition = `top:${buttonRect.bottom}px;left:${buttonRect.right - menuWidth}px;position:fixed;`;
|
|
69
|
-
}
|
|
70
|
-
menu.setAttribute('style', menuPosition);
|
|
71
|
-
}
|
|
72
|
-
close() {
|
|
73
|
-
const node = this.elementRef.nativeElement.parentNode;
|
|
74
|
-
const menu = node.querySelector('.dropdown-menu');
|
|
75
|
-
menu.classList.remove('show');
|
|
76
|
-
this.expanded = false;
|
|
77
|
-
}
|
|
78
|
-
getId() {
|
|
79
|
-
return '' + Math.floor(Math.random() * Date.now());
|
|
80
|
-
}
|
|
81
|
-
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
82
|
-
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "
|
|
83
|
-
}
|
|
84
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
85
|
-
type: Directive,
|
|
86
|
-
args: [{
|
|
87
|
-
selector: '[adbDropdown2]',
|
|
88
|
-
exportAs: 'adbDropdown'
|
|
89
|
-
}]
|
|
90
|
-
}], ctorParameters:
|
|
91
|
-
type: Output
|
|
92
|
-
}], insideClick: [{
|
|
93
|
-
type: Input
|
|
94
|
-
}], id: [{
|
|
95
|
-
type: HostBinding,
|
|
96
|
-
args: ['id']
|
|
97
|
-
}], dataToggle: [{
|
|
98
|
-
type: HostBinding,
|
|
99
|
-
args: ['attr.data-toggle']
|
|
100
|
-
}], haspPopup: [{
|
|
101
|
-
type: HostBinding,
|
|
102
|
-
args: ['attr.aria-haspopup']
|
|
103
|
-
}], expanded: [{
|
|
104
|
-
type: HostBinding,
|
|
105
|
-
args: ['attr.aria-expanded']
|
|
106
|
-
}], dropId: [{
|
|
107
|
-
type: HostBinding,
|
|
108
|
-
args: ['attr.aria-controls']
|
|
109
|
-
}], onClick: [{
|
|
110
|
-
type: HostListener,
|
|
111
|
-
args: ['click']
|
|
112
|
-
}], onCheckOutSideClick: [{
|
|
113
|
-
type: HostListener,
|
|
114
|
-
args: ['document:click', ['$event.target']]
|
|
115
|
-
}], onWindowScroll: [{
|
|
116
|
-
type: HostListener,
|
|
117
|
-
args: ['window:scroll']
|
|
118
|
-
}] } });
|
|
119
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adb-dropdown2.directive.js","sourceRoot":"","sources":["../../../../../../projects/artdata-shared/src/lib/components/adb-dropdown/adb-dropdown2.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, EventEmitter, HostBinding, HostListener, Input, Output } from \"@angular/core\";\r\nimport { AdbDropdownService } from \"./adb-dropdown.service\";\r\n\r\n@Directive({\r\n    selector: '[adbDropdown2]',\r\n    exportAs: 'adbDropdown'\r\n})\r\nexport class AdbDropdown2Directive {\r\n\r\n    constructor(\r\n        private elementRef: ElementRef,\r\n        private adbDropdownService: AdbDropdownService) {\r\n        this.id = this.getId();\r\n        this.dropId = this.getId();\r\n    }\r\n\r\n    @Output() adbDropdown = new EventEmitter();\r\n    @Input() insideClick = false;\r\n\r\n    @HostBinding('id')\r\n    id: string;\r\n\r\n    @HostBinding('attr.data-toggle')\r\n    dataToggle = \"dropdown\";\r\n\r\n    @HostBinding('attr.aria-haspopup')\r\n    haspPopup = true;\r\n\r\n    @HostBinding('attr.aria-expanded')\r\n    expanded = false;\r\n\r\n    @HostBinding('attr.aria-controls')\r\n    dropId: string;\r\n\r\n    @HostListener('click')\r\n    onClick(): void {\r\n        this.adbDropdownService.currentMenuId = this.id;\r\n        const node = this.elementRef.nativeElement.parentNode;\r\n        const menu = node.querySelector('.dropdown-menu');\r\n        if (menu) {\r\n            this.adbDropdownService.currentMenu = this.elementRef.nativeElement;\r\n            this.setMenuPosition(node, menu);\r\n            menu.setAttribute('id', this.dropId);\r\n            if (menu.classList.contains('show')) {\r\n                menu.classList.remove('show');\r\n                this.expanded = false;\r\n            } else {\r\n                this.adbDropdown.emit();\r\n                menu.classList.add('show');\r\n                this.expanded = true;\r\n            }\r\n        }\r\n    }\r\n\r\n    @HostListener('document:click', ['$event.target'])\r\n    onCheckOutSideClick(target: any): void {\r\n        if (this.adbDropdownService.currentMenuId === this.id) {\r\n            const parent = this.insideClick ? this.elementRef.nativeElement.parentNode : this.elementRef.nativeElement;\r\n            const clickedInside = parent.contains(target);\r\n            if (!clickedInside) {\r\n                const parent = this.elementRef.nativeElement.parentNode.querySelector('.dropdown-menu');\r\n                parent?.classList.remove('show');\r\n                this.expanded = false;\r\n            }\r\n        } else {\r\n            const parent = this.elementRef.nativeElement.parentNode.querySelector('.dropdown-menu');\r\n            parent?.classList.remove('show');\r\n            this.expanded = false;\r\n        }\r\n    }\r\n\r\n    @HostListener('window:scroll')\r\n    onWindowScroll(): void {\r\n        const node = this.elementRef.nativeElement.parentNode;\r\n        const menu = node.querySelector('.dropdown-menu');\r\n        if (menu.classList?.contains('show')) {\r\n            this.setMenuPosition(node, menu);\r\n        }\r\n    }\r\n\r\n    private setMenuPosition(dropdownNode: any, menu: any): void {\r\n        const toggleButton = dropdownNode.querySelector('.dropdown-toggle');\r\n        menu.setAttribute('style', 'visibility:hidden');\r\n        menu.setAttribute('style', 'display:block');\r\n        const menuWidth = menu.offsetWidth;\r\n        menu.setAttribute('style', 'visibility:visible');\r\n        menu.setAttribute('style', 'display:none');\r\n        const buttonRect = toggleButton.getBoundingClientRect();\r\n        let menuPosition = `top:${buttonRect.bottom}px;left:${buttonRect.left}px;position:fixed;`;\r\n        if (menu.classList?.contains('dropdown-menu-end')) {\r\n            menuPosition = `top:${buttonRect.bottom}px;left:${buttonRect.right-menuWidth}px;position:fixed;`;\r\n        }\r\n        menu.setAttribute('style', menuPosition);\r\n    }\r\n\r\n    close(): void {\r\n        const node = this.elementRef.nativeElement.parentNode;\r\n        const menu = node.querySelector('.dropdown-menu');\r\n        menu.classList.remove('show');\r\n        this.expanded = false;\r\n    }\r\n\r\n    private getId(): string {\r\n        return '' + Math.floor(Math.random() * Date.now())\r\n    }\r\n}"]}
|
|
1
|
+
import { Directive, EventEmitter, HostBinding, HostListener, Input, Output } from "@angular/core";
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "./adb-dropdown.service";
|
|
4
|
+
export class AdbDropdown2Directive {
|
|
5
|
+
constructor(elementRef, adbDropdownService) {
|
|
6
|
+
this.elementRef = elementRef;
|
|
7
|
+
this.adbDropdownService = adbDropdownService;
|
|
8
|
+
this.adbDropdown = new EventEmitter();
|
|
9
|
+
this.insideClick = false;
|
|
10
|
+
this.dataToggle = "dropdown";
|
|
11
|
+
this.haspPopup = true;
|
|
12
|
+
this.expanded = false;
|
|
13
|
+
this.id = this.getId();
|
|
14
|
+
this.dropId = this.getId();
|
|
15
|
+
}
|
|
16
|
+
onClick() {
|
|
17
|
+
this.adbDropdownService.currentMenuId = this.id;
|
|
18
|
+
const node = this.elementRef.nativeElement.parentNode;
|
|
19
|
+
const menu = node.querySelector('.dropdown-menu');
|
|
20
|
+
if (menu) {
|
|
21
|
+
this.adbDropdownService.currentMenu = this.elementRef.nativeElement;
|
|
22
|
+
this.setMenuPosition(node, menu);
|
|
23
|
+
menu.setAttribute('id', this.dropId);
|
|
24
|
+
if (menu.classList.contains('show')) {
|
|
25
|
+
menu.classList.remove('show');
|
|
26
|
+
this.expanded = false;
|
|
27
|
+
}
|
|
28
|
+
else {
|
|
29
|
+
this.adbDropdown.emit();
|
|
30
|
+
menu.classList.add('show');
|
|
31
|
+
this.expanded = true;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
onCheckOutSideClick(target) {
|
|
36
|
+
if (this.adbDropdownService.currentMenuId === this.id) {
|
|
37
|
+
const parent = this.insideClick ? this.elementRef.nativeElement.parentNode : this.elementRef.nativeElement;
|
|
38
|
+
const clickedInside = parent.contains(target);
|
|
39
|
+
if (!clickedInside) {
|
|
40
|
+
const parent = this.elementRef.nativeElement.parentNode.querySelector('.dropdown-menu');
|
|
41
|
+
parent?.classList.remove('show');
|
|
42
|
+
this.expanded = false;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
const parent = this.elementRef.nativeElement.parentNode.querySelector('.dropdown-menu');
|
|
47
|
+
parent?.classList.remove('show');
|
|
48
|
+
this.expanded = false;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
onWindowScroll() {
|
|
52
|
+
const node = this.elementRef.nativeElement.parentNode;
|
|
53
|
+
const menu = node.querySelector('.dropdown-menu');
|
|
54
|
+
if (menu.classList?.contains('show')) {
|
|
55
|
+
this.setMenuPosition(node, menu);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
setMenuPosition(dropdownNode, menu) {
|
|
59
|
+
const toggleButton = dropdownNode.querySelector('.dropdown-toggle');
|
|
60
|
+
menu.setAttribute('style', 'visibility:hidden');
|
|
61
|
+
menu.setAttribute('style', 'display:block');
|
|
62
|
+
const menuWidth = menu.offsetWidth;
|
|
63
|
+
menu.setAttribute('style', 'visibility:visible');
|
|
64
|
+
menu.setAttribute('style', 'display:none');
|
|
65
|
+
const buttonRect = toggleButton.getBoundingClientRect();
|
|
66
|
+
let menuPosition = `top:${buttonRect.bottom}px;left:${buttonRect.left}px;position:fixed;`;
|
|
67
|
+
if (menu.classList?.contains('dropdown-menu-end')) {
|
|
68
|
+
menuPosition = `top:${buttonRect.bottom}px;left:${buttonRect.right - menuWidth}px;position:fixed;`;
|
|
69
|
+
}
|
|
70
|
+
menu.setAttribute('style', menuPosition);
|
|
71
|
+
}
|
|
72
|
+
close() {
|
|
73
|
+
const node = this.elementRef.nativeElement.parentNode;
|
|
74
|
+
const menu = node.querySelector('.dropdown-menu');
|
|
75
|
+
menu.classList.remove('show');
|
|
76
|
+
this.expanded = false;
|
|
77
|
+
}
|
|
78
|
+
getId() {
|
|
79
|
+
return '' + Math.floor(Math.random() * Date.now());
|
|
80
|
+
}
|
|
81
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: AdbDropdown2Directive, deps: [{ token: i0.ElementRef }, { token: i1.AdbDropdownService }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
82
|
+
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.8", type: AdbDropdown2Directive, selector: "[adbDropdown2]", inputs: { insideClick: "insideClick" }, outputs: { adbDropdown: "adbDropdown" }, host: { listeners: { "click": "onClick()", "document:click": "onCheckOutSideClick($event.target)", "window:scroll": "onWindowScroll()" }, properties: { "id": "this.id", "attr.data-toggle": "this.dataToggle", "attr.aria-haspopup": "this.haspPopup", "attr.aria-expanded": "this.expanded", "attr.aria-controls": "this.dropId" } }, exportAs: ["adbDropdown"], ngImport: i0 }); }
|
|
83
|
+
}
|
|
84
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: AdbDropdown2Directive, decorators: [{
|
|
85
|
+
type: Directive,
|
|
86
|
+
args: [{
|
|
87
|
+
selector: '[adbDropdown2]',
|
|
88
|
+
exportAs: 'adbDropdown'
|
|
89
|
+
}]
|
|
90
|
+
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.AdbDropdownService }], propDecorators: { adbDropdown: [{
|
|
91
|
+
type: Output
|
|
92
|
+
}], insideClick: [{
|
|
93
|
+
type: Input
|
|
94
|
+
}], id: [{
|
|
95
|
+
type: HostBinding,
|
|
96
|
+
args: ['id']
|
|
97
|
+
}], dataToggle: [{
|
|
98
|
+
type: HostBinding,
|
|
99
|
+
args: ['attr.data-toggle']
|
|
100
|
+
}], haspPopup: [{
|
|
101
|
+
type: HostBinding,
|
|
102
|
+
args: ['attr.aria-haspopup']
|
|
103
|
+
}], expanded: [{
|
|
104
|
+
type: HostBinding,
|
|
105
|
+
args: ['attr.aria-expanded']
|
|
106
|
+
}], dropId: [{
|
|
107
|
+
type: HostBinding,
|
|
108
|
+
args: ['attr.aria-controls']
|
|
109
|
+
}], onClick: [{
|
|
110
|
+
type: HostListener,
|
|
111
|
+
args: ['click']
|
|
112
|
+
}], onCheckOutSideClick: [{
|
|
113
|
+
type: HostListener,
|
|
114
|
+
args: ['document:click', ['$event.target']]
|
|
115
|
+
}], onWindowScroll: [{
|
|
116
|
+
type: HostListener,
|
|
117
|
+
args: ['window:scroll']
|
|
118
|
+
}] } });
|
|
119
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adb-dropdown2.directive.js","sourceRoot":"","sources":["../../../../../../projects/artdata-shared/src/lib/components/adb-dropdown/adb-dropdown2.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, EventEmitter, HostBinding, HostListener, Input, Output } from \"@angular/core\";\r\nimport { AdbDropdownService } from \"./adb-dropdown.service\";\r\n\r\n@Directive({\r\n    selector: '[adbDropdown2]',\r\n    exportAs: 'adbDropdown'\r\n})\r\nexport class AdbDropdown2Directive {\r\n\r\n    constructor(\r\n        private elementRef: ElementRef,\r\n        private adbDropdownService: AdbDropdownService) {\r\n        this.id = this.getId();\r\n        this.dropId = this.getId();\r\n    }\r\n\r\n    @Output() adbDropdown = new EventEmitter();\r\n    @Input() insideClick = false;\r\n\r\n    @HostBinding('id')\r\n    id: string;\r\n\r\n    @HostBinding('attr.data-toggle')\r\n    dataToggle = \"dropdown\";\r\n\r\n    @HostBinding('attr.aria-haspopup')\r\n    haspPopup = true;\r\n\r\n    @HostBinding('attr.aria-expanded')\r\n    expanded = false;\r\n\r\n    @HostBinding('attr.aria-controls')\r\n    dropId: string;\r\n\r\n    @HostListener('click')\r\n    onClick(): void {\r\n        this.adbDropdownService.currentMenuId = this.id;\r\n        const node = this.elementRef.nativeElement.parentNode;\r\n        const menu = node.querySelector('.dropdown-menu');\r\n        if (menu) {\r\n            this.adbDropdownService.currentMenu = this.elementRef.nativeElement;\r\n            this.setMenuPosition(node, menu);\r\n            menu.setAttribute('id', this.dropId);\r\n            if (menu.classList.contains('show')) {\r\n                menu.classList.remove('show');\r\n                this.expanded = false;\r\n            } else {\r\n                this.adbDropdown.emit();\r\n                menu.classList.add('show');\r\n                this.expanded = true;\r\n            }\r\n        }\r\n    }\r\n\r\n    @HostListener('document:click', ['$event.target'])\r\n    onCheckOutSideClick(target: any): void {\r\n        if (this.adbDropdownService.currentMenuId === this.id) {\r\n            const parent = this.insideClick ? this.elementRef.nativeElement.parentNode : this.elementRef.nativeElement;\r\n            const clickedInside = parent.contains(target);\r\n            if (!clickedInside) {\r\n                const parent = this.elementRef.nativeElement.parentNode.querySelector('.dropdown-menu');\r\n                parent?.classList.remove('show');\r\n                this.expanded = false;\r\n            }\r\n        } else {\r\n            const parent = this.elementRef.nativeElement.parentNode.querySelector('.dropdown-menu');\r\n            parent?.classList.remove('show');\r\n            this.expanded = false;\r\n        }\r\n    }\r\n\r\n    @HostListener('window:scroll')\r\n    onWindowScroll(): void {\r\n        const node = this.elementRef.nativeElement.parentNode;\r\n        const menu = node.querySelector('.dropdown-menu');\r\n        if (menu.classList?.contains('show')) {\r\n            this.setMenuPosition(node, menu);\r\n        }\r\n    }\r\n\r\n    private setMenuPosition(dropdownNode: any, menu: any): void {\r\n        const toggleButton = dropdownNode.querySelector('.dropdown-toggle');\r\n        menu.setAttribute('style', 'visibility:hidden');\r\n        menu.setAttribute('style', 'display:block');\r\n        const menuWidth = menu.offsetWidth;\r\n        menu.setAttribute('style', 'visibility:visible');\r\n        menu.setAttribute('style', 'display:none');\r\n        const buttonRect = toggleButton.getBoundingClientRect();\r\n        let menuPosition = `top:${buttonRect.bottom}px;left:${buttonRect.left}px;position:fixed;`;\r\n        if (menu.classList?.contains('dropdown-menu-end')) {\r\n            menuPosition = `top:${buttonRect.bottom}px;left:${buttonRect.right-menuWidth}px;position:fixed;`;\r\n        }\r\n        menu.setAttribute('style', menuPosition);\r\n    }\r\n\r\n    close(): void {\r\n        const node = this.elementRef.nativeElement.parentNode;\r\n        const menu = node.querySelector('.dropdown-menu');\r\n        menu.classList.remove('show');\r\n        this.expanded = false;\r\n    }\r\n\r\n    private getId(): string {\r\n        return '' + Math.floor(Math.random() * Date.now())\r\n    }\r\n}"]}
|