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.
Files changed (97) hide show
  1. package/esm2022/adb-shared.mjs +4 -4
  2. package/esm2022/lib/components/adb-artportalen-nav/adb-artportalen-footer.component.mjs +48 -48
  3. package/esm2022/lib/components/adb-artportalen-nav/adb-artportalen-nav.component.mjs +112 -112
  4. package/esm2022/lib/components/adb-artportalen-nav/adb-artportalen-nav.module.mjs +58 -66
  5. package/esm2022/lib/components/adb-artportalen-nav/environment.service.mjs +16 -16
  6. package/esm2022/lib/components/adb-artportalen-nav/navigation.model.mjs +1 -1
  7. package/esm2022/lib/components/adb-buttons/adb-buttons.module.mjs +19 -19
  8. package/esm2022/lib/components/adb-buttons/help-button.component.mjs +35 -35
  9. package/esm2022/lib/components/adb-confirm-modal/adb-confirm-modal.mjs +29 -29
  10. package/esm2022/lib/components/adb-confirm-modal/adb-modal.module.mjs +23 -23
  11. package/esm2022/lib/components/adb-confirm-modal/adb-modal.service.mjs +46 -46
  12. package/esm2022/lib/components/adb-dropdown/adb-dropdown.directive.mjs +100 -100
  13. package/esm2022/lib/components/adb-dropdown/adb-dropdown.module.mjs +24 -24
  14. package/esm2022/lib/components/adb-dropdown/adb-dropdown.service.mjs +10 -10
  15. package/esm2022/lib/components/adb-dropdown/adb-dropdown2.directive.mjs +119 -119
  16. package/esm2022/lib/components/adb-header/adb-header.module.mjs +49 -57
  17. package/esm2022/lib/components/adb-header/adb-nav.component.mjs +115 -115
  18. package/esm2022/lib/components/adb-header/environment.service.mjs +16 -16
  19. package/esm2022/lib/components/adb-header/navigation.model.mjs +1 -1
  20. package/esm2022/lib/components/adb-rich-editor/adb-rich-editor.component.mjs +84 -65
  21. package/esm2022/lib/components/adb-rich-editor/adb-rich-editor.module.mjs +19 -19
  22. package/esm2022/lib/components/adb-toast/adb-toast.mjs +25 -25
  23. package/esm2022/lib/components/adb-toast/adb-toast.module.mjs +23 -23
  24. package/esm2022/lib/components/adb-toast/adb-toast.service.mjs +55 -55
  25. package/esm2022/lib/components/date-picker/adb-date-picker.component.mjs +177 -177
  26. package/esm2022/lib/components/date-picker/adb-date-picker.directive.mjs +220 -220
  27. package/esm2022/lib/components/date-picker/adb-date-picker.module.mjs +25 -25
  28. package/esm2022/lib/components/date-picker/adb-date-picker.service.mjs +10 -10
  29. package/esm2022/lib/components/pagers/infinite-scroll.component.mjs +47 -47
  30. package/esm2022/lib/components/pagers/pager-base.directive.mjs +57 -57
  31. package/esm2022/lib/components/pagers/pager-inline.mjs +49 -49
  32. package/esm2022/lib/components/pagers/pager.mjs +53 -53
  33. package/esm2022/lib/components/pagers/pagers.module.mjs +26 -26
  34. package/esm2022/lib/directives/click-outside.directive.mjs +28 -28
  35. package/esm2022/lib/directives/directives.module.mjs +21 -21
  36. package/esm2022/lib/directives/file-upload.directive.mjs +36 -36
  37. package/esm2022/lib/directives/focus.directive.mjs +34 -34
  38. package/esm2022/lib/directives/redlist-badge-class.directive.mjs +44 -44
  39. package/esm2022/lib/directives/risk-class.directive.mjs +37 -37
  40. package/esm2022/lib/pipes/date.pipe.mjs +22 -22
  41. package/esm2022/lib/pipes/emptyValue.pipe.mjs +22 -22
  42. package/esm2022/lib/pipes/highlight-html.pipe.mjs +46 -46
  43. package/esm2022/lib/pipes/highlight.pipe.mjs +46 -46
  44. package/esm2022/lib/pipes/number-spacing.pipe.mjs +21 -21
  45. package/esm2022/lib/pipes/pipes.module.mjs +22 -22
  46. package/esm2022/lib/pipes/rich.pipe.mjs +36 -36
  47. package/esm2022/public-api.mjs +41 -41
  48. package/fesm2022/adb-shared.mjs +1817 -1815
  49. package/fesm2022/adb-shared.mjs.map +1 -1
  50. package/index.d.ts +5 -5
  51. package/lib/components/adb-artportalen-nav/adb-artportalen-footer.component.d.ts +23 -23
  52. package/lib/components/adb-artportalen-nav/adb-artportalen-nav.component.d.ts +41 -41
  53. package/lib/components/adb-artportalen-nav/adb-artportalen-nav.module.d.ts +16 -17
  54. package/lib/components/adb-artportalen-nav/environment.service.d.ts +7 -7
  55. package/lib/components/adb-artportalen-nav/navigation.model.d.ts +18 -18
  56. package/lib/components/adb-buttons/adb-buttons.module.d.ts +9 -9
  57. package/lib/components/adb-buttons/help-button.component.d.ts +13 -13
  58. package/lib/components/adb-confirm-modal/adb-confirm-modal.d.ts +20 -20
  59. package/lib/components/adb-confirm-modal/adb-modal.module.d.ts +10 -10
  60. package/lib/components/adb-confirm-modal/adb-modal.service.d.ts +18 -18
  61. package/lib/components/adb-dropdown/adb-dropdown.directive.d.ts +21 -21
  62. package/lib/components/adb-dropdown/adb-dropdown.module.d.ts +11 -11
  63. package/lib/components/adb-dropdown/adb-dropdown.service.d.ts +7 -7
  64. package/lib/components/adb-dropdown/adb-dropdown2.directive.d.ts +23 -23
  65. package/lib/components/adb-header/adb-header.module.d.ts +15 -16
  66. package/lib/components/adb-header/adb-nav.component.d.ts +41 -41
  67. package/lib/components/adb-header/environment.service.d.ts +7 -7
  68. package/lib/components/adb-header/navigation.model.d.ts +29 -29
  69. package/lib/components/adb-rich-editor/adb-rich-editor.component.d.ts +24 -22
  70. package/lib/components/adb-rich-editor/adb-rich-editor.module.d.ts +9 -9
  71. package/lib/components/adb-toast/adb-toast.d.ts +11 -11
  72. package/lib/components/adb-toast/adb-toast.module.d.ts +10 -10
  73. package/lib/components/adb-toast/adb-toast.service.d.ts +36 -36
  74. package/lib/components/date-picker/adb-date-picker.component.d.ts +64 -64
  75. package/lib/components/date-picker/adb-date-picker.directive.d.ts +47 -47
  76. package/lib/components/date-picker/adb-date-picker.module.d.ts +12 -12
  77. package/lib/components/date-picker/adb-date-picker.service.d.ts +8 -8
  78. package/lib/components/pagers/infinite-scroll.component.d.ts +15 -15
  79. package/lib/components/pagers/pager-base.directive.d.ts +16 -16
  80. package/lib/components/pagers/pager-inline.d.ts +16 -16
  81. package/lib/components/pagers/pager.d.ts +22 -22
  82. package/lib/components/pagers/pagers.module.d.ts +11 -11
  83. package/lib/directives/click-outside.directive.d.ts +10 -10
  84. package/lib/directives/directives.module.d.ts +11 -11
  85. package/lib/directives/file-upload.directive.d.ts +12 -12
  86. package/lib/directives/focus.directive.d.ts +11 -11
  87. package/lib/directives/redlist-badge-class.directive.d.ts +7 -7
  88. package/lib/directives/risk-class.directive.d.ts +7 -7
  89. package/lib/pipes/date.pipe.d.ts +10 -10
  90. package/lib/pipes/emptyValue.pipe.d.ts +7 -7
  91. package/lib/pipes/highlight-html.pipe.d.ts +10 -10
  92. package/lib/pipes/highlight.pipe.d.ts +9 -9
  93. package/lib/pipes/number-spacing.pipe.d.ts +7 -7
  94. package/lib/pipes/pipes.module.d.ts +12 -12
  95. package/lib/pipes/rich.pipe.d.ts +11 -11
  96. package/package.json +5 -5
  97. 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: "16.2.12", 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: "16.2.12", 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: "16.2.12", ngImport: i0, type: AdbDropdownDirective, decorators: [{
69
- type: Directive,
70
- args: [{
71
- selector: '[adbDropdown]',
72
- exportAs: 'adbDropdown'
73
- }]
74
- }], ctorParameters: function () { return [{ 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":"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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: '[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
+ 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":"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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: '[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: "16.2.12", ngImport: i0, type: AdbDropdownModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
12
- /** @nocollapse */ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", 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: "16.2.12", ngImport: i0, type: AdbDropdownModule, providers: [AdbDropdownService], imports: [CommonModule, TranslateModule.forChild(), AdbDirectivesModule] }); }
14
- }
15
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", 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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRiLWRyb3Bkb3duLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FydGRhdGEtc2hhcmVkL3NyYy9saWIvY29tcG9uZW50cy9hZGItZHJvcGRvd24vYWRiLWRyb3Bkb3duLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDdEQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sb0NBQW9DLENBQUM7QUFDekUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDaEUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDNUQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7OztBQVFsRSxNQUFNLE9BQU8saUJBQWlCO2tJQUFqQixpQkFBaUI7bUlBQWpCLGlCQUFpQixpQkFKWCxvQkFBb0IsRUFBRSxxQkFBcUIsYUFEaEQsWUFBWSxzQkFBOEIsbUJBQW1CLGFBRTdELG9CQUFvQixFQUFFLHFCQUFxQjttSUFHNUMsaUJBQWlCLGFBRmYsQ0FBQyxrQkFBa0IsQ0FBQyxZQUhyQixZQUFZLEVBQUUsZUFBZSxDQUFDLFFBQVEsRUFBRSxFQUFFLG1CQUFtQjs7NEZBSzlELGlCQUFpQjtrQkFON0IsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsZUFBZSxDQUFDLFFBQVEsRUFBRSxFQUFFLG1CQUFtQixDQUFDO29CQUN4RSxZQUFZLEVBQUUsQ0FBQyxvQkFBb0IsRUFBRSxxQkFBcUIsQ0FBQztvQkFDM0QsT0FBTyxFQUFFLENBQUMsb0JBQW9CLEVBQUUscUJBQXFCLENBQUM7b0JBQ3RELFNBQVMsRUFBRSxDQUFDLGtCQUFrQixDQUFDO2lCQUNsQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBUcmFuc2xhdGVNb2R1bGUgfSBmcm9tIFwiQG5neC10cmFuc2xhdGUvY29yZVwiO1xyXG5pbXBvcnQgeyBBZGJEaXJlY3RpdmVzTW9kdWxlIH0gZnJvbSBcIi4uLy4uL2RpcmVjdGl2ZXMvZGlyZWN0aXZlcy5tb2R1bGVcIjtcclxuaW1wb3J0IHsgQWRiRHJvcGRvd25EaXJlY3RpdmUgfSBmcm9tIFwiLi9hZGItZHJvcGRvd24uZGlyZWN0aXZlXCI7XHJcbmltcG9ydCB7IEFkYkRyb3Bkb3duU2VydmljZSB9IGZyb20gXCIuL2FkYi1kcm9wZG93bi5zZXJ2aWNlXCI7XHJcbmltcG9ydCB7IEFkYkRyb3Bkb3duMkRpcmVjdGl2ZSB9IGZyb20gXCIuL2FkYi1kcm9wZG93bjIuZGlyZWN0aXZlXCI7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgVHJhbnNsYXRlTW9kdWxlLmZvckNoaWxkKCksIEFkYkRpcmVjdGl2ZXNNb2R1bGVdLFxyXG4gICAgZGVjbGFyYXRpb25zOiBbQWRiRHJvcGRvd25EaXJlY3RpdmUsIEFkYkRyb3Bkb3duMkRpcmVjdGl2ZV0sXHJcbiAgICBleHBvcnRzOiBbQWRiRHJvcGRvd25EaXJlY3RpdmUsIEFkYkRyb3Bkb3duMkRpcmVjdGl2ZV0sXHJcbiAgICBwcm92aWRlcnM6IFtBZGJEcm9wZG93blNlcnZpY2VdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBZGJEcm9wZG93bk1vZHVsZSB7IH0iXX0=
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: "16.2.12", ngImport: i0, type: AdbDropdownService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
5
- /** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AdbDropdownService }); }
6
- }
7
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AdbDropdownService, decorators: [{
8
- type: Injectable
9
- }] });
10
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRiLWRyb3Bkb3duLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hcnRkYXRhLXNoYXJlZC9zcmMvbGliL2NvbXBvbmVudHMvYWRiLWRyb3Bkb3duL2FkYi1kcm9wZG93bi5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBYyxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBR3ZELE1BQU0sT0FBTyxrQkFBa0I7a0lBQWxCLGtCQUFrQjtzSUFBbEIsa0JBQWtCOzs0RkFBbEIsa0JBQWtCO2tCQUQ5QixVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRWxlbWVudFJlZiwgSW5qZWN0YWJsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcblxyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBBZGJEcm9wZG93blNlcnZpY2Uge1xyXG4gICAgY3VycmVudE1lbnU6IGFueTtcclxuICAgIGN1cnJlbnRNZW51SWQ6IHN0cmluZztcclxufSJdfQ==
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: "16.2.12", 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: "16.2.12", 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: "16.2.12", ngImport: i0, type: AdbDropdown2Directive, decorators: [{
85
- type: Directive,
86
- args: [{
87
- selector: '[adbDropdown2]',
88
- exportAs: 'adbDropdown'
89
- }]
90
- }], ctorParameters: function () { return [{ 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}"]}
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}"]}