@sebgroup/green-angular 1.0.0-beta.1 → 1.0.0-beta.2

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 (41) hide show
  1. package/esm2020/index.mjs +10 -0
  2. package/esm2020/lib/dropdown/dropdown.component.mjs +111 -0
  3. package/esm2020/lib/dropdown/dropdown.module.mjs +42 -0
  4. package/esm2020/lib/dropdown/popover-element.directive.mjs +218 -0
  5. package/esm2020/lib/dropdown/popover-option.directive.mjs +58 -0
  6. package/esm2020/lib/dropdown/popover-trigger.directive.mjs +80 -0
  7. package/esm2020/lib/dropdown/popover.directive.mjs +46 -0
  8. package/esm2020/lib/green-angular.module.mjs +19 -0
  9. package/esm2020/lib/segmented-control/segmented-control.component.mjs +40 -0
  10. package/esm2020/lib/segmented-control/segmented-control.module.mjs +19 -0
  11. package/esm2020/sebgroup-green-angular.mjs +5 -0
  12. package/fesm2015/{sebgroup-green-angular.js → sebgroup-green-angular.mjs} +54 -45
  13. package/fesm2015/sebgroup-green-angular.mjs.map +1 -0
  14. package/fesm2020/sebgroup-green-angular.mjs +599 -0
  15. package/fesm2020/sebgroup-green-angular.mjs.map +1 -0
  16. package/package.json +26 -13
  17. package/bundles/sebgroup-green-angular.umd.js +0 -610
  18. package/bundles/sebgroup-green-angular.umd.js.map +0 -1
  19. package/esm2015/index.js +0 -10
  20. package/esm2015/index.js.map +0 -1
  21. package/esm2015/lib/dropdown/dropdown.component.js +0 -111
  22. package/esm2015/lib/dropdown/dropdown.component.js.map +0 -1
  23. package/esm2015/lib/dropdown/dropdown.module.js +0 -42
  24. package/esm2015/lib/dropdown/dropdown.module.js.map +0 -1
  25. package/esm2015/lib/dropdown/popover-element.directive.js +0 -220
  26. package/esm2015/lib/dropdown/popover-element.directive.js.map +0 -1
  27. package/esm2015/lib/dropdown/popover-option.directive.js +0 -59
  28. package/esm2015/lib/dropdown/popover-option.directive.js.map +0 -1
  29. package/esm2015/lib/dropdown/popover-trigger.directive.js +0 -80
  30. package/esm2015/lib/dropdown/popover-trigger.directive.js.map +0 -1
  31. package/esm2015/lib/dropdown/popover.directive.js +0 -46
  32. package/esm2015/lib/dropdown/popover.directive.js.map +0 -1
  33. package/esm2015/lib/green-angular.module.js +0 -19
  34. package/esm2015/lib/green-angular.module.js.map +0 -1
  35. package/esm2015/lib/segmented-control/segmented-control.component.js +0 -40
  36. package/esm2015/lib/segmented-control/segmented-control.component.js.map +0 -1
  37. package/esm2015/lib/segmented-control/segmented-control.module.js +0 -19
  38. package/esm2015/lib/segmented-control/segmented-control.module.js.map +0 -1
  39. package/esm2015/sebgroup-green-angular.js +0 -5
  40. package/esm2015/sebgroup-green-angular.js.map +0 -1
  41. package/fesm2015/sebgroup-green-angular.js.map +0 -1
@@ -0,0 +1,10 @@
1
+ export * from './lib/green-angular.module';
2
+ export * from './lib/dropdown/dropdown.module';
3
+ export * from './lib/dropdown/dropdown.component';
4
+ export * from './lib/dropdown/popover.directive';
5
+ export * from './lib/dropdown/popover-element.directive';
6
+ export * from './lib/dropdown/popover-option.directive';
7
+ export * from './lib/dropdown/popover-trigger.directive';
8
+ export * from './lib/segmented-control/segmented-control.module';
9
+ export * from './lib/segmented-control/segmented-control.component';
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsNEJBQTRCLENBQUE7QUFDMUMsY0FBYyxnQ0FBZ0MsQ0FBQTtBQUM5QyxjQUFjLG1DQUFtQyxDQUFBO0FBQ2pELGNBQWMsa0NBQWtDLENBQUE7QUFDaEQsY0FBYywwQ0FBMEMsQ0FBQTtBQUN4RCxjQUFjLHlDQUF5QyxDQUFBO0FBQ3ZELGNBQWMsMENBQTBDLENBQUE7QUFDeEQsY0FBYyxrREFBa0QsQ0FBQTtBQUNoRSxjQUFjLHFEQUFxRCxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvZ3JlZW4tYW5ndWxhci5tb2R1bGUnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kcm9wZG93bi9kcm9wZG93bi5tb2R1bGUnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kcm9wZG93bi9kcm9wZG93bi5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kcm9wZG93bi9wb3BvdmVyLmRpcmVjdGl2ZSdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Ryb3Bkb3duL3BvcG92ZXItZWxlbWVudC5kaXJlY3RpdmUnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kcm9wZG93bi9wb3BvdmVyLW9wdGlvbi5kaXJlY3RpdmUnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kcm9wZG93bi9wb3BvdmVyLXRyaWdnZXIuZGlyZWN0aXZlJ1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VnbWVudGVkLWNvbnRyb2wvc2VnbWVudGVkLWNvbnRyb2wubW9kdWxlJ1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VnbWVudGVkLWNvbnRyb2wvc2VnbWVudGVkLWNvbnRyb2wuY29tcG9uZW50J1xuIl19
@@ -0,0 +1,111 @@
1
+ import { Component, Input } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "./popover.directive";
5
+ import * as i2 from "./popover-trigger.directive";
6
+ import * as i3 from "./popover-element.directive";
7
+ import * as i4 from "@angular/common";
8
+ import * as i5 from "./popover-option.directive";
9
+ export class NggDropdownComponent {
10
+ constructor() {
11
+ this._options = [];
12
+ this._config = {};
13
+ }
14
+ get options() {
15
+ return this._options;
16
+ }
17
+ set options(value) {
18
+ this._options = value;
19
+ }
20
+ get config() {
21
+ return this._config;
22
+ }
23
+ set config(value) {
24
+ this._config = value;
25
+ }
26
+ writeValue(obj) {
27
+ this.value = obj;
28
+ }
29
+ registerOnChange(fn) {
30
+ this.onChangeFn = fn;
31
+ }
32
+ registerOnTouched(fn) {
33
+ this.onTouchedFn = fn;
34
+ }
35
+ select(value) {
36
+ this.onChangeFn(value);
37
+ this.value = value;
38
+ }
39
+ }
40
+ NggDropdownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: NggDropdownComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
41
+ NggDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.2", type: NggDropdownComponent, selector: "ngg-dropdown", inputs: { options: "options", config: "config" }, providers: [
42
+ {
43
+ provide: NG_VALUE_ACCESSOR,
44
+ useExisting: NggDropdownComponent,
45
+ multi: true,
46
+ },
47
+ ], ngImport: i0, template: `
48
+ <div nggPopover [config]="config">
49
+ <button type="button" nggPopoverTrigger>
50
+ {{ value }}
51
+ </button>
52
+ <div nggPopoverElement tabindex="-1" autofocus>
53
+ <button class="close m-4 m-sm-2 d-block d-sm-none ">
54
+ <span class="sr-only">Close</span>
55
+ </button>
56
+ <ul role="listbox">
57
+ <li
58
+ *ngFor="let option of options; let i = index"
59
+ [nggPopoverOption]="option.value"
60
+ [index]="i"
61
+ [selected]="value === option.value"
62
+ (selectedChanged)="select($event)"
63
+ >
64
+ {{ option.key }}
65
+ </li>
66
+ </ul>
67
+ </div>
68
+ </div>
69
+ `, isInline: true, directives: [{ type: i1.NggPopoverDirective, selector: "[nggPopover]", inputs: ["config"] }, { type: i2.NggPopoverTriggerDirective, selector: "[nggPopoverTrigger]" }, { type: i3.NggPopoverElementDirective, selector: "[nggPopoverElement]" }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i5.NggPopoverOptionDirective, selector: "[nggPopoverOption]", inputs: ["nggPopoverOption", "index", "selected"], outputs: ["selectedChanged"] }] });
70
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: NggDropdownComponent, decorators: [{
71
+ type: Component,
72
+ args: [{
73
+ selector: 'ngg-dropdown',
74
+ template: `
75
+ <div nggPopover [config]="config">
76
+ <button type="button" nggPopoverTrigger>
77
+ {{ value }}
78
+ </button>
79
+ <div nggPopoverElement tabindex="-1" autofocus>
80
+ <button class="close m-4 m-sm-2 d-block d-sm-none ">
81
+ <span class="sr-only">Close</span>
82
+ </button>
83
+ <ul role="listbox">
84
+ <li
85
+ *ngFor="let option of options; let i = index"
86
+ [nggPopoverOption]="option.value"
87
+ [index]="i"
88
+ [selected]="value === option.value"
89
+ (selectedChanged)="select($event)"
90
+ >
91
+ {{ option.key }}
92
+ </li>
93
+ </ul>
94
+ </div>
95
+ </div>
96
+ `,
97
+ providers: [
98
+ {
99
+ provide: NG_VALUE_ACCESSOR,
100
+ useExisting: NggDropdownComponent,
101
+ multi: true,
102
+ },
103
+ ],
104
+ //changeDetection: ChangeDetectionStrategy.OnPush
105
+ }]
106
+ }], propDecorators: { options: [{
107
+ type: Input
108
+ }], config: [{
109
+ type: Input
110
+ }] } });
111
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL3NyYy9saWIvZHJvcGRvd24vZHJvcGRvd24uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBQ2hELE9BQU8sRUFBd0IsaUJBQWlCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQTs7Ozs7OztBQW9DeEUsTUFBTSxPQUFPLG9CQUFvQjtJQWxDakM7UUFxRFUsYUFBUSxHQUFlLEVBQUUsQ0FBQTtRQUV6QixZQUFPLEdBQVMsRUFBRSxDQUFBO0tBa0IzQjtJQXRDQyxJQUFJLE9BQU87UUFDVCxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUE7SUFDdEIsQ0FBQztJQUVELElBQWEsT0FBTyxDQUFDLEtBQWlCO1FBQ3BDLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFBO0lBQ3ZCLENBQUM7SUFDRCxJQUFJLE1BQU07UUFDUixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUE7SUFDckIsQ0FBQztJQUNELElBQWEsTUFBTSxDQUFDLEtBQVU7UUFDNUIsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUE7SUFDdEIsQ0FBQztJQVVELFVBQVUsQ0FBQyxHQUFRO1FBQ2pCLElBQUksQ0FBQyxLQUFLLEdBQUcsR0FBRyxDQUFBO0lBQ2xCLENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxFQUFPO1FBQ3RCLElBQUksQ0FBQyxVQUFVLEdBQUcsRUFBRSxDQUFBO0lBQ3RCLENBQUM7SUFFRCxpQkFBaUIsQ0FBQyxFQUFPO1FBQ3ZCLElBQUksQ0FBQyxXQUFXLEdBQUcsRUFBRSxDQUFBO0lBQ3ZCLENBQUM7SUFFRCxNQUFNLENBQUMsS0FBVTtRQUNmLElBQUksQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLENBQUE7UUFDdEIsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUE7SUFDcEIsQ0FBQzs7aUhBdENVLG9CQUFvQjtxR0FBcEIsb0JBQW9CLHlGQVRwQjtRQUNUO1lBQ0UsT0FBTyxFQUFFLGlCQUFpQjtZQUMxQixXQUFXLEVBQUUsb0JBQW9CO1lBQ2pDLEtBQUssRUFBRSxJQUFJO1NBQ1o7S0FDRiwwQkE3QlM7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FzQlQ7MkZBVVUsb0JBQW9CO2tCQWxDaEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsY0FBYztvQkFDeEIsUUFBUSxFQUFFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBc0JUO29CQUNELFNBQVMsRUFBRTt3QkFDVDs0QkFDRSxPQUFPLEVBQUUsaUJBQWlCOzRCQUMxQixXQUFXLHNCQUFzQjs0QkFDakMsS0FBSyxFQUFFLElBQUk7eUJBQ1o7cUJBQ0Y7b0JBQ0QsaURBQWlEO2lCQUNsRDs4QkFNYyxPQUFPO3NCQUFuQixLQUFLO2dCQU1PLE1BQU07c0JBQWxCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcbmltcG9ydCB7IENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBOR19WQUxVRV9BQ0NFU1NPUiB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJ1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICduZ2ctZHJvcGRvd24nLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxkaXYgbmdnUG9wb3ZlciBbY29uZmlnXT1cImNvbmZpZ1wiPlxuICAgICAgPGJ1dHRvbiB0eXBlPVwiYnV0dG9uXCIgbmdnUG9wb3ZlclRyaWdnZXI+XG4gICAgICAgIHt7IHZhbHVlIH19XG4gICAgICA8L2J1dHRvbj5cbiAgICAgIDxkaXYgbmdnUG9wb3ZlckVsZW1lbnQgdGFiaW5kZXg9XCItMVwiIGF1dG9mb2N1cz5cbiAgICAgICAgPGJ1dHRvbiBjbGFzcz1cImNsb3NlIG0tNCBtLXNtLTIgZC1ibG9jayBkLXNtLW5vbmUgXCI+XG4gICAgICAgICAgPHNwYW4gY2xhc3M9XCJzci1vbmx5XCI+Q2xvc2U8L3NwYW4+XG4gICAgICAgIDwvYnV0dG9uPlxuICAgICAgICA8dWwgcm9sZT1cImxpc3Rib3hcIj5cbiAgICAgICAgICA8bGlcbiAgICAgICAgICAgICpuZ0Zvcj1cImxldCBvcHRpb24gb2Ygb3B0aW9uczsgbGV0IGkgPSBpbmRleFwiXG4gICAgICAgICAgICBbbmdnUG9wb3Zlck9wdGlvbl09XCJvcHRpb24udmFsdWVcIlxuICAgICAgICAgICAgW2luZGV4XT1cImlcIlxuICAgICAgICAgICAgW3NlbGVjdGVkXT1cInZhbHVlID09PSBvcHRpb24udmFsdWVcIlxuICAgICAgICAgICAgKHNlbGVjdGVkQ2hhbmdlZCk9XCJzZWxlY3QoJGV2ZW50KVwiXG4gICAgICAgICAgPlxuICAgICAgICAgICAge3sgb3B0aW9uLmtleSB9fVxuICAgICAgICAgIDwvbGk+XG4gICAgICAgIDwvdWw+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgYCxcbiAgcHJvdmlkZXJzOiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXG4gICAgICB1c2VFeGlzdGluZzogTmdnRHJvcGRvd25Db21wb25lbnQsXG4gICAgICBtdWx0aTogdHJ1ZSxcbiAgICB9LFxuICBdLFxuICAvL2NoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIE5nZ0Ryb3Bkb3duQ29tcG9uZW50IGltcGxlbWVudHMgQ29udHJvbFZhbHVlQWNjZXNzb3Ige1xuICBnZXQgb3B0aW9ucygpOiBBcnJheTxhbnk+IHtcbiAgICByZXR1cm4gdGhpcy5fb3B0aW9uc1xuICB9XG5cbiAgQElucHV0KCkgc2V0IG9wdGlvbnModmFsdWU6IEFycmF5PGFueT4pIHtcbiAgICB0aGlzLl9vcHRpb25zID0gdmFsdWVcbiAgfVxuICBnZXQgY29uZmlnKCk6IGFueSB7XG4gICAgcmV0dXJuIHRoaXMuX2NvbmZpZ1xuICB9XG4gIEBJbnB1dCgpIHNldCBjb25maWcodmFsdWU6IGFueSkge1xuICAgIHRoaXMuX2NvbmZpZyA9IHZhbHVlXG4gIH1cblxuICB2YWx1ZTogYW55XG4gIG9uQ2hhbmdlRm46IGFueVxuICBvblRvdWNoZWRGbjogYW55XG5cbiAgcHJpdmF0ZSBfb3B0aW9uczogQXJyYXk8YW55PiA9IFtdXG5cbiAgcHJpdmF0ZSBfY29uZmlnPzogYW55ID0ge31cblxuICB3cml0ZVZhbHVlKG9iajogYW55KTogdm9pZCB7XG4gICAgdGhpcy52YWx1ZSA9IG9ialxuICB9XG5cbiAgcmVnaXN0ZXJPbkNoYW5nZShmbjogYW55KTogdm9pZCB7XG4gICAgdGhpcy5vbkNoYW5nZUZuID0gZm5cbiAgfVxuXG4gIHJlZ2lzdGVyT25Ub3VjaGVkKGZuOiBhbnkpOiB2b2lkIHtcbiAgICB0aGlzLm9uVG91Y2hlZEZuID0gZm5cbiAgfVxuXG4gIHNlbGVjdCh2YWx1ZTogYW55KSB7XG4gICAgdGhpcy5vbkNoYW5nZUZuKHZhbHVlKVxuICAgIHRoaXMudmFsdWUgPSB2YWx1ZVxuICB9XG59XG4iXX0=
@@ -0,0 +1,42 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { NggDropdownComponent } from './dropdown.component';
4
+ import { NggPopoverElementDirective } from './popover-element.directive';
5
+ import { NggPopoverOptionDirective } from './popover-option.directive';
6
+ import { NggPopoverTriggerDirective } from './popover-trigger.directive';
7
+ import { NggPopoverDirective } from './popover.directive';
8
+ import * as i0 from "@angular/core";
9
+ export class NggDropdownModule {
10
+ }
11
+ NggDropdownModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: NggDropdownModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
12
+ NggDropdownModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: NggDropdownModule, declarations: [NggPopoverDirective,
13
+ NggPopoverOptionDirective,
14
+ NggPopoverElementDirective,
15
+ NggPopoverTriggerDirective,
16
+ NggDropdownComponent], imports: [CommonModule], exports: [NggPopoverDirective,
17
+ NggPopoverOptionDirective,
18
+ NggPopoverElementDirective,
19
+ NggPopoverTriggerDirective,
20
+ NggDropdownComponent] });
21
+ NggDropdownModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: NggDropdownModule, imports: [[CommonModule]] });
22
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: NggDropdownModule, decorators: [{
23
+ type: NgModule,
24
+ args: [{
25
+ declarations: [
26
+ NggPopoverDirective,
27
+ NggPopoverOptionDirective,
28
+ NggPopoverElementDirective,
29
+ NggPopoverTriggerDirective,
30
+ NggDropdownComponent,
31
+ ],
32
+ imports: [CommonModule],
33
+ exports: [
34
+ NggPopoverDirective,
35
+ NggPopoverOptionDirective,
36
+ NggPopoverElementDirective,
37
+ NggPopoverTriggerDirective,
38
+ NggDropdownComponent,
39
+ ],
40
+ }]
41
+ }] });
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL3NyYy9saWIvZHJvcGRvd24vZHJvcGRvd24ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFDeEMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFBO0FBQzlDLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHNCQUFzQixDQUFBO0FBQzNELE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLDZCQUE2QixDQUFBO0FBQ3hFLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLDRCQUE0QixDQUFBO0FBQ3RFLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLDZCQUE2QixDQUFBO0FBQ3hFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHFCQUFxQixDQUFBOztBQW1CekQsTUFBTSxPQUFPLGlCQUFpQjs7OEdBQWpCLGlCQUFpQjsrR0FBakIsaUJBQWlCLGlCQWYxQixtQkFBbUI7UUFDbkIseUJBQXlCO1FBQ3pCLDBCQUEwQjtRQUMxQiwwQkFBMEI7UUFDMUIsb0JBQW9CLGFBRVosWUFBWSxhQUVwQixtQkFBbUI7UUFDbkIseUJBQXlCO1FBQ3pCLDBCQUEwQjtRQUMxQiwwQkFBMEI7UUFDMUIsb0JBQW9COytHQUdYLGlCQUFpQixZQVRuQixDQUFDLFlBQVksQ0FBQzsyRkFTWixpQkFBaUI7a0JBakI3QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWixtQkFBbUI7d0JBQ25CLHlCQUF5Qjt3QkFDekIsMEJBQTBCO3dCQUMxQiwwQkFBMEI7d0JBQzFCLG9CQUFvQjtxQkFDckI7b0JBQ0QsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixPQUFPLEVBQUU7d0JBQ1AsbUJBQW1CO3dCQUNuQix5QkFBeUI7d0JBQ3pCLDBCQUEwQjt3QkFDMUIsMEJBQTBCO3dCQUMxQixvQkFBb0I7cUJBQ3JCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJ1xuaW1wb3J0IHsgTmdnRHJvcGRvd25Db21wb25lbnQgfSBmcm9tICcuL2Ryb3Bkb3duLmNvbXBvbmVudCdcbmltcG9ydCB7IE5nZ1BvcG92ZXJFbGVtZW50RGlyZWN0aXZlIH0gZnJvbSAnLi9wb3BvdmVyLWVsZW1lbnQuZGlyZWN0aXZlJ1xuaW1wb3J0IHsgTmdnUG9wb3Zlck9wdGlvbkRpcmVjdGl2ZSB9IGZyb20gJy4vcG9wb3Zlci1vcHRpb24uZGlyZWN0aXZlJ1xuaW1wb3J0IHsgTmdnUG9wb3ZlclRyaWdnZXJEaXJlY3RpdmUgfSBmcm9tICcuL3BvcG92ZXItdHJpZ2dlci5kaXJlY3RpdmUnXG5pbXBvcnQgeyBOZ2dQb3BvdmVyRGlyZWN0aXZlIH0gZnJvbSAnLi9wb3BvdmVyLmRpcmVjdGl2ZSdcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgTmdnUG9wb3ZlckRpcmVjdGl2ZSxcbiAgICBOZ2dQb3BvdmVyT3B0aW9uRGlyZWN0aXZlLFxuICAgIE5nZ1BvcG92ZXJFbGVtZW50RGlyZWN0aXZlLFxuICAgIE5nZ1BvcG92ZXJUcmlnZ2VyRGlyZWN0aXZlLFxuICAgIE5nZ0Ryb3Bkb3duQ29tcG9uZW50LFxuICBdLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgZXhwb3J0czogW1xuICAgIE5nZ1BvcG92ZXJEaXJlY3RpdmUsXG4gICAgTmdnUG9wb3Zlck9wdGlvbkRpcmVjdGl2ZSxcbiAgICBOZ2dQb3BvdmVyRWxlbWVudERpcmVjdGl2ZSxcbiAgICBOZ2dQb3BvdmVyVHJpZ2dlckRpcmVjdGl2ZSxcbiAgICBOZ2dEcm9wZG93bkNvbXBvbmVudCxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgTmdnRHJvcGRvd25Nb2R1bGUge31cbiJdfQ==
@@ -0,0 +1,218 @@
1
+ import { ChangeDetectorRef, ContentChildren, Directive, ElementRef, forwardRef, HostBinding, HostListener, Inject, Renderer2, } from '@angular/core';
2
+ import { filter, skip, switchMap, takeUntil, tap } from 'rxjs/operators';
3
+ import { EMPTY, fromEvent, merge, Subject } from 'rxjs';
4
+ import { NggPopoverOptionDirective } from './popover-option.directive';
5
+ import { NggPopoverDirective } from './popover.directive';
6
+ import { createPopper } from '@popperjs/core';
7
+ import { disableBodyScroll, enableBodyScroll } from 'body-scroll-lock';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "./popover.directive";
10
+ export class NggPopoverElementDirective {
11
+ constructor(popover, _elRef, _renderer, _cdr) {
12
+ this.popover = popover;
13
+ this._elRef = _elRef;
14
+ this._renderer = _renderer;
15
+ this._cdr = _cdr;
16
+ this.$unsubscribe = new Subject();
17
+ this.sm = window.innerWidth <= 576;
18
+ this.class = true;
19
+ this.role = 'listbox';
20
+ this.id = null;
21
+ this.show = this.popover.state.$isOpen.value;
22
+ this.activeDescendant = null;
23
+ }
24
+ // TODO: refactor and move to general size/device service
25
+ onResize(event) {
26
+ // determine if small screen size i.e less than or equal to 576 pixels which is the breakpoint for small screens
27
+ this.sm = event.target.innerWidth <= 576;
28
+ if (this.sm) {
29
+ // remove popper
30
+ this.removePopper();
31
+ }
32
+ else if (!this._popper) {
33
+ // add popper
34
+ this.addPopper();
35
+ }
36
+ }
37
+ handleClickEvent(event) {
38
+ // if click inside popover element...
39
+ if (this._elRef.nativeElement.contains(event.target)) {
40
+ this.popover.close();
41
+ }
42
+ else if (this.popover.state.$isOpen.value) {
43
+ // else if click outside popover element...
44
+ this.popover.close();
45
+ }
46
+ }
47
+ handleKeydownEvent(event) {
48
+ if (event.key === 'Escape') {
49
+ this.popover.close();
50
+ return;
51
+ }
52
+ let next = 0; // Used for home key
53
+ const currentSelection = this.options?.find((option) => !!option.selected)?.index || 0;
54
+ if (event.key === 'End') {
55
+ // set next to last option
56
+ next = (this.options?.length || 1) - 1;
57
+ }
58
+ else if (event.key === 'ArrowUp') {
59
+ // next can't be less than zero
60
+ next = Math.max(0, currentSelection - 1);
61
+ // prevent container from scrolling
62
+ event.preventDefault();
63
+ }
64
+ else if (event.key === 'ArrowDown') {
65
+ // next can't be greater than number of options
66
+ next = Math.min((this.options?.length || 1) - 1, currentSelection + 1);
67
+ // prevent container from scrolling
68
+ event.preventDefault();
69
+ }
70
+ // select next option
71
+ this.options?.get(next)?.select(event);
72
+ }
73
+ ngOnInit() {
74
+ this.id = /^ngg_dropdownTrigger/.test(this.popover.triggerElement?.nativeElement.id)
75
+ ? this.popover.triggerElement?.nativeElement.id.replace(/dropdownTrigger/, 'popover')
76
+ : this.popover.triggerElement?.nativeElement.id + '_popover';
77
+ this.popover.state.$isOpen
78
+ .pipe(skip(1), // skip initial value
79
+ tap((isOpen) => {
80
+ this.show = isOpen; // toggle visibility
81
+ if (isOpen) {
82
+ this.activeDescendant =
83
+ this.options?.find((option) => !!option.selected)?.id || null;
84
+ // if use body scroll lock
85
+ if (this.popover.config.useBodyScrollLock) {
86
+ this.disableBodyScrollLock();
87
+ }
88
+ // if popover is configured to use a container...
89
+ if (this.popover.config.container !== '') {
90
+ // ...add container
91
+ this.addContainer();
92
+ }
93
+ // if popover is configured to use popper.js...
94
+ if (this.popover.config.usePopper) {
95
+ this.addPopper();
96
+ }
97
+ }
98
+ else {
99
+ this.activeDescendant = null;
100
+ if (this.popover.config.useBodyScrollLock) {
101
+ this.enableBodyScrollLock();
102
+ }
103
+ this.removeContainer();
104
+ this.removePopper();
105
+ }
106
+ }), switchMap((isOpen) => isOpen
107
+ ? merge(
108
+ // listen to click events
109
+ fromEvent(document, 'click').pipe(tap((event) => this.handleClickEvent(event))),
110
+ // listen to keydown events
111
+ fromEvent(document, 'keydown').pipe(
112
+ // filter keys
113
+ filter((event) => ['ArrowDown', 'ArrowUp', 'Escape', 'Home', 'End'].indexOf(event.key) !== -1), tap((event) => this.handleKeydownEvent(event))))
114
+ : EMPTY), takeUntil(this.$unsubscribe))
115
+ .subscribe();
116
+ }
117
+ ngOnDestroy() {
118
+ this.removePopper();
119
+ // enable scroll if body scroll lock is used
120
+ if (this.popover.config.useBodyScrollLock) {
121
+ this.enableBodyScrollLock();
122
+ }
123
+ // remove container if declared
124
+ if (this._container) {
125
+ this.removeContainer();
126
+ }
127
+ this.$unsubscribe.next();
128
+ this.$unsubscribe.complete();
129
+ }
130
+ enableBodyScrollLock() {
131
+ enableBodyScroll(this._elRef.nativeElement);
132
+ }
133
+ disableBodyScrollLock() {
134
+ disableBodyScroll(this._elRef.nativeElement);
135
+ }
136
+ addPopper() {
137
+ if (this.sm) {
138
+ return;
139
+ }
140
+ if (!this._popper) {
141
+ // ...create popper instance for anchoring popover with trigger element
142
+ this._popper = createPopper(this.popover.triggerElement?.nativeElement, this._elRef.nativeElement, {
143
+ placement: 'bottom-start',
144
+ modifiers: [
145
+ {
146
+ name: 'offset',
147
+ options: {
148
+ offset: [0, 4],
149
+ },
150
+ },
151
+ ],
152
+ });
153
+ // detect changes once element and popper is initiated to update initial position
154
+ this._cdr.detectChanges();
155
+ }
156
+ else {
157
+ this._popper.state.elements.reference =
158
+ this.popover.triggerElement?.nativeElement;
159
+ this._popper.update().then((_) => this._cdr.detectChanges());
160
+ }
161
+ }
162
+ removePopper() {
163
+ // destroy popper if declared
164
+ if (this._popper) {
165
+ this._popper?.destroy();
166
+ this._popper = null;
167
+ }
168
+ }
169
+ addContainer() {
170
+ // create global container for popover if not already present
171
+ if (!this._container) {
172
+ this._container = this._renderer.createElement('div');
173
+ }
174
+ this._renderer.appendChild(this._container, this._elRef.nativeElement);
175
+ this._renderer.appendChild(document.body, this._container);
176
+ }
177
+ removeContainer() {
178
+ if (this._container) {
179
+ // remove container from DOM tree
180
+ this._renderer.removeChild(document.body, this._container);
181
+ // clear container
182
+ this._container = null;
183
+ }
184
+ }
185
+ }
186
+ NggPopoverElementDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: NggPopoverElementDirective, deps: [{ token: forwardRef(() => NggPopoverDirective) }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
187
+ NggPopoverElementDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.0.2", type: NggPopoverElementDirective, selector: "[nggPopoverElement]", host: { listeners: { "window:resize": "onResize($event)" }, properties: { "class.popover": "this.class", "attr.role": "this.role", "attr.id": "this.id", "class.active": "this.show", "attr.aria-activedescendant": "this.activeDescendant" } }, queries: [{ propertyName: "options", predicate: NggPopoverOptionDirective, descendants: true }], ngImport: i0 });
188
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: NggPopoverElementDirective, decorators: [{
189
+ type: Directive,
190
+ args: [{
191
+ selector: '[nggPopoverElement]',
192
+ }]
193
+ }], ctorParameters: function () { return [{ type: i1.NggPopoverDirective, decorators: [{
194
+ type: Inject,
195
+ args: [forwardRef(() => NggPopoverDirective)]
196
+ }] }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { options: [{
197
+ type: ContentChildren,
198
+ args: [NggPopoverOptionDirective, { descendants: true }]
199
+ }], class: [{
200
+ type: HostBinding,
201
+ args: ['class.popover']
202
+ }], role: [{
203
+ type: HostBinding,
204
+ args: ['attr.role']
205
+ }], id: [{
206
+ type: HostBinding,
207
+ args: ['attr.id']
208
+ }], show: [{
209
+ type: HostBinding,
210
+ args: ['class.active']
211
+ }], activeDescendant: [{
212
+ type: HostBinding,
213
+ args: ['attr.aria-activedescendant']
214
+ }], onResize: [{
215
+ type: HostListener,
216
+ args: ['window:resize', ['$event']]
217
+ }] } });
218
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover-element.directive.js","sourceRoot":"","sources":["../../../../../../libs/angular/src/lib/dropdown/popover-element.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  ContentChildren,\n  Directive,\n  ElementRef,\n  forwardRef,\n  HostBinding,\n  HostListener,\n  Inject,\n  OnDestroy,\n  OnInit,\n  QueryList,\n  Renderer2,\n} from '@angular/core'\nimport { filter, skip, switchMap, takeUntil, tap } from 'rxjs/operators'\nimport { Instance } from '@popperjs/core/lib/types'\nimport { EMPTY, fromEvent, merge, Subject } from 'rxjs'\nimport { NggPopoverOptionDirective } from './popover-option.directive'\nimport { NggPopoverDirective } from './popover.directive'\nimport { createPopper } from '@popperjs/core'\nimport { disableBodyScroll, enableBodyScroll } from 'body-scroll-lock'\n\n@Directive({\n  selector: '[nggPopoverElement]',\n})\nexport class NggPopoverElementDirective implements OnInit, OnDestroy {\n  _popper?: Instance | null\n  _container?: ElementRef | null\n  $unsubscribe = new Subject()\n  sm = window.innerWidth <= 576\n  @ContentChildren(NggPopoverOptionDirective, { descendants: true }) options:\n    | QueryList<NggPopoverOptionDirective>\n    | undefined\n\n  @HostBinding('class.popover') class = true\n  @HostBinding('attr.role') role = 'listbox'\n  @HostBinding('attr.id') id = null\n  @HostBinding('class.active') show = this.popover.state.$isOpen.value\n  @HostBinding('attr.aria-activedescendant') activeDescendant: string | null =\n    null\n  // TODO: refactor and move to general size/device service\n  @HostListener('window:resize', ['$event']) onResize(event: UIEvent) {\n    // determine if small screen size i.e less than or equal to 576 pixels which is the breakpoint for small screens\n    this.sm = (event.target as Window).innerWidth <= 576\n    if (this.sm) {\n      // remove popper\n      this.removePopper()\n    } else if (!this._popper) {\n      // add popper\n      this.addPopper()\n    }\n  }\n\n  handleClickEvent(event: Event) {\n    // if click inside popover element...\n    if (this._elRef.nativeElement.contains(event.target)) {\n      this.popover.close()\n    } else if (this.popover.state.$isOpen.value) {\n      // else if click outside popover element...\n      this.popover.close()\n    }\n  }\n  handleKeydownEvent(event: KeyboardEvent) {\n    if (event.key === 'Escape') {\n      this.popover.close()\n      return\n    }\n    let next = 0 // Used for home key\n    const currentSelection =\n      this.options?.find((option) => !!option.selected)?.index || 0\n    if (event.key === 'End') {\n      // set next to last option\n      next = (this.options?.length || 1) - 1\n    } else if (event.key === 'ArrowUp') {\n      // next can't be less than zero\n      next = Math.max(0, currentSelection - 1)\n\n      // prevent container from scrolling\n      event.preventDefault()\n    } else if (event.key === 'ArrowDown') {\n      // next can't be greater than number of options\n      next = Math.min((this.options?.length || 1) - 1, currentSelection + 1)\n\n      // prevent container from scrolling\n      event.preventDefault()\n    }\n    // select next option\n    this.options?.get(next)?.select(event)\n  }\n\n  constructor(\n    @Inject(forwardRef(() => NggPopoverDirective))\n    public popover: NggPopoverDirective,\n    private _elRef: ElementRef,\n    private _renderer: Renderer2,\n    private _cdr: ChangeDetectorRef\n  ) {}\n  ngOnInit() {\n    this.id = /^ngg_dropdownTrigger/.test(\n      this.popover.triggerElement?.nativeElement.id\n    )\n      ? this.popover.triggerElement?.nativeElement.id.replace(\n          /dropdownTrigger/,\n          'popover'\n        )\n      : this.popover.triggerElement?.nativeElement.id + '_popover'\n    this.popover.state.$isOpen\n      .pipe(\n        skip(1), // skip initial value\n        tap((isOpen) => {\n          this.show = isOpen // toggle visibility\n\n          if (isOpen) {\n            this.activeDescendant =\n              this.options?.find((option) => !!option.selected)?.id || null\n\n            // if use body scroll lock\n            if (this.popover.config.useBodyScrollLock) {\n              this.disableBodyScrollLock()\n            }\n            // if popover is configured to use a container...\n            if (this.popover.config.container !== '') {\n              // ...add container\n              this.addContainer()\n            }\n            // if popover is configured to use popper.js...\n            if (this.popover.config.usePopper) {\n              this.addPopper()\n            }\n          } else {\n            this.activeDescendant = null\n            if (this.popover.config.useBodyScrollLock) {\n              this.enableBodyScrollLock()\n            }\n            this.removeContainer()\n            this.removePopper()\n          }\n        }),\n        switchMap((isOpen) =>\n          isOpen\n            ? merge(\n                // listen to click events\n                fromEvent(document, 'click').pipe(\n                  tap((event) => this.handleClickEvent(event))\n                ),\n                // listen to keydown events\n                fromEvent(document, 'keydown').pipe(\n                  // filter keys\n                  filter(\n                    (event) =>\n                      ['ArrowDown', 'ArrowUp', 'Escape', 'Home', 'End'].indexOf(\n                        (event as KeyboardEvent).key\n                      ) !== -1\n                  ),\n                  tap((event) =>\n                    this.handleKeydownEvent(event as KeyboardEvent)\n                  )\n                )\n              )\n            : EMPTY\n        ),\n        takeUntil(this.$unsubscribe)\n      )\n      .subscribe()\n  }\n\n  ngOnDestroy() {\n    this.removePopper()\n\n    // enable scroll if body scroll lock is used\n    if (this.popover.config.useBodyScrollLock) {\n      this.enableBodyScrollLock()\n    }\n\n    // remove container if declared\n    if (this._container) {\n      this.removeContainer()\n    }\n    this.$unsubscribe.next()\n    this.$unsubscribe.complete()\n  }\n\n  enableBodyScrollLock() {\n    enableBodyScroll(this._elRef.nativeElement)\n  }\n\n  disableBodyScrollLock() {\n    disableBodyScroll(this._elRef.nativeElement)\n  }\n\n  addPopper() {\n    if (this.sm) {\n      return\n    }\n    if (!this._popper) {\n      // ...create popper instance for anchoring popover with trigger element\n      this._popper = createPopper(\n        this.popover.triggerElement?.nativeElement,\n        this._elRef.nativeElement,\n        {\n          placement: 'bottom-start',\n          modifiers: [\n            {\n              name: 'offset',\n              options: {\n                offset: [0, 4],\n              },\n            },\n          ],\n        }\n      )\n      // detect changes once element and popper is initiated to update initial position\n      this._cdr.detectChanges()\n    } else {\n      this._popper.state.elements.reference =\n        this.popover.triggerElement?.nativeElement\n      this._popper.update().then((_) => this._cdr.detectChanges())\n    }\n  }\n  removePopper() {\n    // destroy popper if declared\n    if (this._popper) {\n      this._popper?.destroy()\n      this._popper = null\n    }\n  }\n  addContainer() {\n    // create global container for popover if not already present\n    if (!this._container) {\n      this._container = this._renderer.createElement('div')\n    }\n    this._renderer.appendChild(this._container, this._elRef.nativeElement)\n    this._renderer.appendChild(document.body, this._container)\n  }\n\n  removeContainer() {\n    if (this._container) {\n      // remove container from DOM tree\n      this._renderer.removeChild(document.body, this._container)\n\n      // clear container\n      this._container = null\n    }\n  }\n}\n"]}
@@ -0,0 +1,58 @@
1
+ import { Directive, ElementRef, EventEmitter, forwardRef, HostBinding, HostListener, Inject, Input, Output, } from '@angular/core';
2
+ import { NggPopoverDirective } from './popover.directive';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "./popover.directive";
5
+ export class NggPopoverOptionDirective {
6
+ constructor(popover, elRef) {
7
+ this.popover = popover;
8
+ this.elRef = elRef;
9
+ this.selected = false;
10
+ this.selectedChanged = new EventEmitter();
11
+ this.role = 'option';
12
+ this.id = '';
13
+ this.clickHandler = (event) => {
14
+ this.select(event);
15
+ };
16
+ this.select = (event) => {
17
+ this.selectedChanged.emit(this.nggPopoverOption);
18
+ };
19
+ }
20
+ get ariaSelected() {
21
+ return this.selected || null;
22
+ }
23
+ ngOnInit() {
24
+ this.id = `${this.popover.triggerElement?.nativeElement.id}_dropdownOption_${this.index}`;
25
+ }
26
+ }
27
+ NggPopoverOptionDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: NggPopoverOptionDirective, deps: [{ token: forwardRef(() => NggPopoverDirective) }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
28
+ NggPopoverOptionDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.0.2", type: NggPopoverOptionDirective, selector: "[nggPopoverOption]", inputs: { nggPopoverOption: "nggPopoverOption", index: "index", selected: "selected" }, outputs: { selectedChanged: "selectedChanged" }, host: { listeners: { "click": "clickHandler()" }, properties: { "attr.role": "this.role", "attr.aria-selected": "this.ariaSelected", "attr.id": "this.id" } }, ngImport: i0 });
29
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: NggPopoverOptionDirective, decorators: [{
30
+ type: Directive,
31
+ args: [{
32
+ selector: '[nggPopoverOption]',
33
+ }]
34
+ }], ctorParameters: function () { return [{ type: i1.NggPopoverDirective, decorators: [{
35
+ type: Inject,
36
+ args: [forwardRef(() => NggPopoverDirective)]
37
+ }] }, { type: i0.ElementRef }]; }, propDecorators: { nggPopoverOption: [{
38
+ type: Input
39
+ }], index: [{
40
+ type: Input
41
+ }], selected: [{
42
+ type: Input
43
+ }], selectedChanged: [{
44
+ type: Output
45
+ }], role: [{
46
+ type: HostBinding,
47
+ args: ['attr.role']
48
+ }], ariaSelected: [{
49
+ type: HostBinding,
50
+ args: ['attr.aria-selected']
51
+ }], id: [{
52
+ type: HostBinding,
53
+ args: ['attr.id']
54
+ }], clickHandler: [{
55
+ type: HostListener,
56
+ args: ['click']
57
+ }] } });
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci1vcHRpb24uZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL3NyYy9saWIvZHJvcGRvd24vcG9wb3Zlci1vcHRpb24uZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxTQUFTLEVBQ1QsVUFBVSxFQUNWLFlBQVksRUFDWixVQUFVLEVBQ1YsV0FBVyxFQUNYLFlBQVksRUFDWixNQUFNLEVBQ04sS0FBSyxFQUVMLE1BQU0sR0FDUCxNQUFNLGVBQWUsQ0FBQTtBQUN0QixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQTs7O0FBS3pELE1BQU0sT0FBTyx5QkFBeUI7SUFlcEMsWUFFUyxPQUE0QixFQUM1QixLQUFpQjtRQURqQixZQUFPLEdBQVAsT0FBTyxDQUFxQjtRQUM1QixVQUFLLEdBQUwsS0FBSyxDQUFZO1FBZmpCLGFBQVEsR0FBRyxLQUFLLENBQUE7UUFDZixvQkFBZSxHQUFHLElBQUksWUFBWSxFQUFFLENBQUE7UUFDcEIsU0FBSSxHQUFHLFFBQVEsQ0FBQTtRQUtqQixPQUFFLEdBQUcsRUFBRSxDQUFBO1FBQ1IsaUJBQVksR0FBRyxDQUFDLEtBQVksRUFBRSxFQUFFO1lBQ3JELElBQUksQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUE7UUFDcEIsQ0FBQyxDQUFBO1FBWUQsV0FBTSxHQUFHLENBQUMsS0FBWSxFQUFFLEVBQUU7WUFDeEIsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLENBQUE7UUFDbEQsQ0FBQyxDQUFBO0lBUkUsQ0FBQztJQWJKLElBQ1csWUFBWTtRQUNyQixPQUFPLElBQUksQ0FBQyxRQUFRLElBQUksSUFBSSxDQUFBO0lBQzlCLENBQUM7SUFZRCxRQUFRO1FBQ04sSUFBSSxDQUFDLEVBQUUsR0FBRyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsY0FBYyxFQUFFLGFBQWEsQ0FBQyxFQUFFLG1CQUFtQixJQUFJLENBQUMsS0FBSyxFQUFFLENBQUE7SUFDM0YsQ0FBQzs7c0hBdkJVLHlCQUF5QixrQkFnQjFCLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxtQkFBbUIsQ0FBQzswR0FoQnBDLHlCQUF5QjsyRkFBekIseUJBQXlCO2tCQUhyQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxvQkFBb0I7aUJBQy9COzswQkFpQkksTUFBTTsyQkFBQyxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsbUJBQW1CLENBQUM7cUVBZnRDLGdCQUFnQjtzQkFBeEIsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDSSxlQUFlO3NCQUF4QixNQUFNO2dCQUNtQixJQUFJO3NCQUE3QixXQUFXO3VCQUFDLFdBQVc7Z0JBRWIsWUFBWTtzQkFEdEIsV0FBVzt1QkFBQyxvQkFBb0I7Z0JBSVQsRUFBRTtzQkFBekIsV0FBVzt1QkFBQyxTQUFTO2dCQUNDLFlBQVk7c0JBQWxDLFlBQVk7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIERpcmVjdGl2ZSxcbiAgRWxlbWVudFJlZixcbiAgRXZlbnRFbWl0dGVyLFxuICBmb3J3YXJkUmVmLFxuICBIb3N0QmluZGluZyxcbiAgSG9zdExpc3RlbmVyLFxuICBJbmplY3QsXG4gIElucHV0LFxuICBPbkluaXQsXG4gIE91dHB1dCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcbmltcG9ydCB7IE5nZ1BvcG92ZXJEaXJlY3RpdmUgfSBmcm9tICcuL3BvcG92ZXIuZGlyZWN0aXZlJ1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbbmdnUG9wb3Zlck9wdGlvbl0nLFxufSlcbmV4cG9ydCBjbGFzcyBOZ2dQb3BvdmVyT3B0aW9uRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KCkgbmdnUG9wb3Zlck9wdGlvbjogYW55XG4gIEBJbnB1dCgpIGluZGV4OiBudW1iZXIgfCB1bmRlZmluZWRcbiAgQElucHV0KCkgc2VsZWN0ZWQgPSBmYWxzZVxuICBAT3V0cHV0KCkgc2VsZWN0ZWRDaGFuZ2VkID0gbmV3IEV2ZW50RW1pdHRlcigpXG4gIEBIb3N0QmluZGluZygnYXR0ci5yb2xlJykgcm9sZSA9ICdvcHRpb24nXG4gIEBIb3N0QmluZGluZygnYXR0ci5hcmlhLXNlbGVjdGVkJylcbiAgcHVibGljIGdldCBhcmlhU2VsZWN0ZWQoKTogbnVsbCB8IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLnNlbGVjdGVkIHx8IG51bGxcbiAgfVxuICBASG9zdEJpbmRpbmcoJ2F0dHIuaWQnKSBpZCA9ICcnXG4gIEBIb3N0TGlzdGVuZXIoJ2NsaWNrJykgY2xpY2tIYW5kbGVyID0gKGV2ZW50OiBFdmVudCkgPT4ge1xuICAgIHRoaXMuc2VsZWN0KGV2ZW50KVxuICB9XG5cbiAgY29uc3RydWN0b3IoXG4gICAgQEluamVjdChmb3J3YXJkUmVmKCgpID0+IE5nZ1BvcG92ZXJEaXJlY3RpdmUpKVxuICAgIHB1YmxpYyBwb3BvdmVyOiBOZ2dQb3BvdmVyRGlyZWN0aXZlLFxuICAgIHB1YmxpYyBlbFJlZjogRWxlbWVudFJlZlxuICApIHt9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgdGhpcy5pZCA9IGAke3RoaXMucG9wb3Zlci50cmlnZ2VyRWxlbWVudD8ubmF0aXZlRWxlbWVudC5pZH1fZHJvcGRvd25PcHRpb25fJHt0aGlzLmluZGV4fWBcbiAgfVxuXG4gIHNlbGVjdCA9IChldmVudDogRXZlbnQpID0+IHtcbiAgICB0aGlzLnNlbGVjdGVkQ2hhbmdlZC5lbWl0KHRoaXMubmdnUG9wb3Zlck9wdGlvbilcbiAgfVxufVxuIl19
@@ -0,0 +1,80 @@
1
+ import { Directive, ElementRef, forwardRef, HostBinding, HostListener, Inject, } from '@angular/core';
2
+ import { Subject } from 'rxjs';
3
+ import { takeUntil, tap } from 'rxjs/operators';
4
+ import { NggPopoverDirective } from './popover.directive';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "./popover.directive";
7
+ export class NggPopoverTriggerDirective {
8
+ constructor(popover, _elRef) {
9
+ this.popover = popover;
10
+ this._elRef = _elRef;
11
+ this.$unsubscribe = new Subject();
12
+ this.class = 'dropdown-toggle';
13
+ this.haspopup = 'listbox';
14
+ this.owns = null;
15
+ this.expanded = this.popover.state.$isOpen.value;
16
+ this.toggle = (event) => {
17
+ if ('key' in event && event.key === 'ArrowDown') {
18
+ // open popover on arrow down by not stopping event propagation
19
+ if (this.popover.state.$isOpen.value) {
20
+ return;
21
+ }
22
+ else {
23
+ // prevent container from scrolling
24
+ event.preventDefault();
25
+ }
26
+ }
27
+ event.stopPropagation();
28
+ this.popover.toggle();
29
+ };
30
+ }
31
+ ngOnInit() {
32
+ // if trigger element does not have an id...
33
+ if (!this._elRef.nativeElement.id) {
34
+ // ...add a unique id
35
+ this._elRef.nativeElement.id = `ngg_dropdownTrigger_${new Date().getTime()}`;
36
+ this.owns = this._elRef.nativeElement.id.replace(/dropdownTrigger/, 'popover');
37
+ }
38
+ else {
39
+ this.owns = this._elRef.nativeElement.id + '_popover';
40
+ }
41
+ this.popover.triggerElement = this._elRef;
42
+ this.popover.state.$isOpen
43
+ .pipe(tap((isOpen) => (this.expanded = isOpen)), takeUntil(this.$unsubscribe))
44
+ .subscribe();
45
+ }
46
+ ngOnDestroy() {
47
+ this.$unsubscribe.next();
48
+ this.$unsubscribe.complete();
49
+ }
50
+ }
51
+ NggPopoverTriggerDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: NggPopoverTriggerDirective, deps: [{ token: forwardRef(() => NggPopoverDirective) }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
52
+ NggPopoverTriggerDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.0.2", type: NggPopoverTriggerDirective, selector: "[nggPopoverTrigger]", host: { listeners: { "keydown.arrowdown": "toggle($event)", "click": "toggle($event)" }, properties: { "class": "this.class", "attr.aria-haspopup": "this.haspopup", "attr.aria-owns": "this.owns", "attr.aria-expanded": "this.expanded" } }, ngImport: i0 });
53
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: NggPopoverTriggerDirective, decorators: [{
54
+ type: Directive,
55
+ args: [{
56
+ selector: '[nggPopoverTrigger]',
57
+ }]
58
+ }], ctorParameters: function () { return [{ type: i1.NggPopoverDirective, decorators: [{
59
+ type: Inject,
60
+ args: [forwardRef(() => NggPopoverDirective)]
61
+ }] }, { type: i0.ElementRef }]; }, propDecorators: { class: [{
62
+ type: HostBinding,
63
+ args: ['class']
64
+ }], haspopup: [{
65
+ type: HostBinding,
66
+ args: ['attr.aria-haspopup']
67
+ }], owns: [{
68
+ type: HostBinding,
69
+ args: ['attr.aria-owns']
70
+ }], expanded: [{
71
+ type: HostBinding,
72
+ args: ['attr.aria-expanded']
73
+ }], toggle: [{
74
+ type: HostListener,
75
+ args: ['keydown.arrowdown', ['$event']]
76
+ }, {
77
+ type: HostListener,
78
+ args: ['click', ['$event']]
79
+ }] } });
80
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci10cmlnZ2VyLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9zcmMvbGliL2Ryb3Bkb3duL3BvcG92ZXItdHJpZ2dlci5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCxVQUFVLEVBQ1YsVUFBVSxFQUNWLFdBQVcsRUFDWCxZQUFZLEVBQ1osTUFBTSxHQUdQLE1BQU0sZUFBZSxDQUFBO0FBQ3RCLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUE7QUFDOUIsT0FBTyxFQUFFLFNBQVMsRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQTtBQUMvQyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQTs7O0FBS3pELE1BQU0sT0FBTywwQkFBMEI7SUF1QnJDLFlBRVMsT0FBNEIsRUFDM0IsTUFBa0I7UUFEbkIsWUFBTyxHQUFQLE9BQU8sQ0FBcUI7UUFDM0IsV0FBTSxHQUFOLE1BQU0sQ0FBWTtRQXpCNUIsaUJBQVksR0FBRyxJQUFJLE9BQU8sRUFBRSxDQUFBO1FBRU4sVUFBSyxHQUFHLGlCQUFpQixDQUFBO1FBQ1osYUFBUSxHQUFHLFNBQVMsQ0FBQTtRQUN4QixTQUFJLEdBQWtCLElBQUksQ0FBQTtRQUN0QixhQUFRLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQTtRQUk5RSxXQUFNLEdBQUcsQ0FBQyxLQUE0QixFQUFFLEVBQUU7WUFDeEMsSUFBSSxLQUFLLElBQUksS0FBSyxJQUFJLEtBQUssQ0FBQyxHQUFHLEtBQUssV0FBVyxFQUFFO2dCQUMvQywrREFBK0Q7Z0JBQy9ELElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLEtBQUssRUFBRTtvQkFDcEMsT0FBTTtpQkFDUDtxQkFBTTtvQkFDTCxtQ0FBbUM7b0JBQ25DLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQTtpQkFDdkI7YUFDRjtZQUNELEtBQUssQ0FBQyxlQUFlLEVBQUUsQ0FBQTtZQUN2QixJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRSxDQUFBO1FBQ3ZCLENBQUMsQ0FBQTtJQUtFLENBQUM7SUFFSixRQUFRO1FBQ04sNENBQTRDO1FBQzVDLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLGFBQWEsQ0FBQyxFQUFFLEVBQUU7WUFDakMscUJBQXFCO1lBQ3JCLElBQUksQ0FBQyxNQUFNLENBQUMsYUFBYSxDQUFDLEVBQUUsR0FBRyx1QkFBdUIsSUFBSSxJQUFJLEVBQUUsQ0FBQyxPQUFPLEVBQUUsRUFBRSxDQUFBO1lBQzVFLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxhQUFhLENBQUMsRUFBRSxDQUFDLE9BQU8sQ0FDOUMsaUJBQWlCLEVBQ2pCLFNBQVMsQ0FDVixDQUFBO1NBQ0Y7YUFBTTtZQUNMLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxhQUFhLENBQUMsRUFBRSxHQUFHLFVBQVUsQ0FBQTtTQUN0RDtRQUVELElBQUksQ0FBQyxPQUFPLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUE7UUFFekMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsT0FBTzthQUN2QixJQUFJLENBQ0gsR0FBRyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxRQUFRLEdBQUcsTUFBTSxDQUFDLENBQUMsRUFDekMsU0FBUyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FDN0I7YUFDQSxTQUFTLEVBQUUsQ0FBQTtJQUNoQixDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxFQUFFLENBQUE7UUFDeEIsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLEVBQUUsQ0FBQTtJQUM5QixDQUFDOzt1SEF2RFUsMEJBQTBCLGtCQXdCM0IsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLG1CQUFtQixDQUFDOzJHQXhCcEMsMEJBQTBCOzJGQUExQiwwQkFBMEI7a0JBSHRDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHFCQUFxQjtpQkFDaEM7OzBCQXlCSSxNQUFNOzJCQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxtQkFBbUIsQ0FBQztxRUFyQnpCLEtBQUs7c0JBQTFCLFdBQVc7dUJBQUMsT0FBTztnQkFDZSxRQUFRO3NCQUExQyxXQUFXO3VCQUFDLG9CQUFvQjtnQkFDRixJQUFJO3NCQUFsQyxXQUFXO3VCQUFDLGdCQUFnQjtnQkFDTSxRQUFRO3NCQUExQyxXQUFXO3VCQUFDLG9CQUFvQjtnQkFJakMsTUFBTTtzQkFGTCxZQUFZO3VCQUFDLG1CQUFtQixFQUFFLENBQUMsUUFBUSxDQUFDOztzQkFDNUMsWUFBWTt1QkFBQyxPQUFPLEVBQUUsQ0FBQyxRQUFRLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBEaXJlY3RpdmUsXG4gIEVsZW1lbnRSZWYsXG4gIGZvcndhcmRSZWYsXG4gIEhvc3RCaW5kaW5nLFxuICBIb3N0TGlzdGVuZXIsXG4gIEluamVjdCxcbiAgT25EZXN0cm95LFxuICBPbkluaXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcydcbmltcG9ydCB7IHRha2VVbnRpbCwgdGFwIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnXG5pbXBvcnQgeyBOZ2dQb3BvdmVyRGlyZWN0aXZlIH0gZnJvbSAnLi9wb3BvdmVyLmRpcmVjdGl2ZSdcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW25nZ1BvcG92ZXJUcmlnZ2VyXScsXG59KVxuZXhwb3J0IGNsYXNzIE5nZ1BvcG92ZXJUcmlnZ2VyRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xuICAkdW5zdWJzY3JpYmUgPSBuZXcgU3ViamVjdCgpXG5cbiAgQEhvc3RCaW5kaW5nKCdjbGFzcycpIGNsYXNzID0gJ2Ryb3Bkb3duLXRvZ2dsZSdcbiAgQEhvc3RCaW5kaW5nKCdhdHRyLmFyaWEtaGFzcG9wdXAnKSBoYXNwb3B1cCA9ICdsaXN0Ym94J1xuICBASG9zdEJpbmRpbmcoJ2F0dHIuYXJpYS1vd25zJykgb3duczogc3RyaW5nIHwgbnVsbCA9IG51bGxcbiAgQEhvc3RCaW5kaW5nKCdhdHRyLmFyaWEtZXhwYW5kZWQnKSBleHBhbmRlZCA9IHRoaXMucG9wb3Zlci5zdGF0ZS4kaXNPcGVuLnZhbHVlXG5cbiAgQEhvc3RMaXN0ZW5lcigna2V5ZG93bi5hcnJvd2Rvd24nLCBbJyRldmVudCddKVxuICBASG9zdExpc3RlbmVyKCdjbGljaycsIFsnJGV2ZW50J10pXG4gIHRvZ2dsZSA9IChldmVudDogRXZlbnQgfCBLZXlib2FyZEV2ZW50KSA9PiB7XG4gICAgaWYgKCdrZXknIGluIGV2ZW50ICYmIGV2ZW50LmtleSA9PT0gJ0Fycm93RG93bicpIHtcbiAgICAgIC8vIG9wZW4gcG9wb3ZlciBvbiBhcnJvdyBkb3duIGJ5IG5vdCBzdG9wcGluZyBldmVudCBwcm9wYWdhdGlvblxuICAgICAgaWYgKHRoaXMucG9wb3Zlci5zdGF0ZS4kaXNPcGVuLnZhbHVlKSB7XG4gICAgICAgIHJldHVyblxuICAgICAgfSBlbHNlIHtcbiAgICAgICAgLy8gcHJldmVudCBjb250YWluZXIgZnJvbSBzY3JvbGxpbmdcbiAgICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKVxuICAgICAgfVxuICAgIH1cbiAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKVxuICAgIHRoaXMucG9wb3Zlci50b2dnbGUoKVxuICB9XG4gIGNvbnN0cnVjdG9yKFxuICAgIEBJbmplY3QoZm9yd2FyZFJlZigoKSA9PiBOZ2dQb3BvdmVyRGlyZWN0aXZlKSlcbiAgICBwdWJsaWMgcG9wb3ZlcjogTmdnUG9wb3ZlckRpcmVjdGl2ZSxcbiAgICBwcml2YXRlIF9lbFJlZjogRWxlbWVudFJlZlxuICApIHt9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgLy8gaWYgdHJpZ2dlciBlbGVtZW50IGRvZXMgbm90IGhhdmUgYW4gaWQuLi5cbiAgICBpZiAoIXRoaXMuX2VsUmVmLm5hdGl2ZUVsZW1lbnQuaWQpIHtcbiAgICAgIC8vIC4uLmFkZCBhIHVuaXF1ZSBpZFxuICAgICAgdGhpcy5fZWxSZWYubmF0aXZlRWxlbWVudC5pZCA9IGBuZ2dfZHJvcGRvd25UcmlnZ2VyXyR7bmV3IERhdGUoKS5nZXRUaW1lKCl9YFxuICAgICAgdGhpcy5vd25zID0gdGhpcy5fZWxSZWYubmF0aXZlRWxlbWVudC5pZC5yZXBsYWNlKFxuICAgICAgICAvZHJvcGRvd25UcmlnZ2VyLyxcbiAgICAgICAgJ3BvcG92ZXInXG4gICAgICApXG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMub3ducyA9IHRoaXMuX2VsUmVmLm5hdGl2ZUVsZW1lbnQuaWQgKyAnX3BvcG92ZXInXG4gICAgfVxuXG4gICAgdGhpcy5wb3BvdmVyLnRyaWdnZXJFbGVtZW50ID0gdGhpcy5fZWxSZWZcblxuICAgIHRoaXMucG9wb3Zlci5zdGF0ZS4kaXNPcGVuXG4gICAgICAucGlwZShcbiAgICAgICAgdGFwKChpc09wZW4pID0+ICh0aGlzLmV4cGFuZGVkID0gaXNPcGVuKSksXG4gICAgICAgIHRha2VVbnRpbCh0aGlzLiR1bnN1YnNjcmliZSlcbiAgICAgIClcbiAgICAgIC5zdWJzY3JpYmUoKVxuICB9XG5cbiAgbmdPbkRlc3Ryb3koKSB7XG4gICAgdGhpcy4kdW5zdWJzY3JpYmUubmV4dCgpXG4gICAgdGhpcy4kdW5zdWJzY3JpYmUuY29tcGxldGUoKVxuICB9XG59XG4iXX0=
@@ -0,0 +1,46 @@
1
+ import { Directive, Input } from '@angular/core';
2
+ import { BehaviorSubject } from 'rxjs';
3
+ import * as i0 from "@angular/core";
4
+ export class NggPopoverDirective {
5
+ constructor() {
6
+ this._config = {
7
+ usePopper: true,
8
+ container: '',
9
+ useBodyScrollLock: true,
10
+ };
11
+ this.state = {
12
+ $isOpen: new BehaviorSubject(false),
13
+ };
14
+ }
15
+ get config() {
16
+ return this._config;
17
+ }
18
+ set config(config) {
19
+ this._config = { ...this.config, ...config };
20
+ }
21
+ close() {
22
+ this.state.$isOpen.next(false);
23
+ }
24
+ open() {
25
+ this.state.$isOpen.next(true);
26
+ }
27
+ toggle() {
28
+ if (this.state.$isOpen.value) {
29
+ this.close();
30
+ }
31
+ else {
32
+ this.open();
33
+ }
34
+ }
35
+ }
36
+ NggPopoverDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: NggPopoverDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
37
+ NggPopoverDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.0.2", type: NggPopoverDirective, selector: "[nggPopover]", inputs: { config: "config" }, ngImport: i0 });
38
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: NggPopoverDirective, decorators: [{
39
+ type: Directive,
40
+ args: [{
41
+ selector: '[nggPopover]',
42
+ }]
43
+ }], propDecorators: { config: [{
44
+ type: Input
45
+ }] } });
46
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvc3JjL2xpYi9kcm9wZG93bi9wb3BvdmVyLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUM1RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sTUFBTSxDQUFBOztBQWN0QyxNQUFNLE9BQU8sbUJBQW1CO0lBSGhDO1FBWVUsWUFBTyxHQUFrQjtZQUMvQixTQUFTLEVBQUUsSUFBSTtZQUNmLFNBQVMsRUFBRSxFQUFFO1lBQ2IsaUJBQWlCLEVBQUUsSUFBSTtTQUN4QixDQUFBO1FBQ0QsVUFBSyxHQUFpQjtZQUNwQixPQUFPLEVBQUUsSUFBSSxlQUFlLENBQVUsS0FBSyxDQUFDO1NBQzdDLENBQUE7S0FlRjtJQTlCQyxJQUFJLE1BQU07UUFDUixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUE7SUFDckIsQ0FBQztJQUVELElBQWEsTUFBTSxDQUFDLE1BQXFCO1FBQ3ZDLElBQUksQ0FBQyxPQUFPLEdBQUcsRUFBRSxHQUFHLElBQUksQ0FBQyxNQUFNLEVBQUUsR0FBRyxNQUFNLEVBQUUsQ0FBQTtJQUM5QyxDQUFDO0lBV0QsS0FBSztRQUNILElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQTtJQUNoQyxDQUFDO0lBQ0QsSUFBSTtRQUNGLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQTtJQUMvQixDQUFDO0lBQ0QsTUFBTTtRQUNKLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFO1lBQzVCLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQTtTQUNiO2FBQU07WUFDTCxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUE7U0FDWjtJQUNILENBQUM7O2dIQTlCVSxtQkFBbUI7b0dBQW5CLG1CQUFtQjsyRkFBbkIsbUJBQW1CO2tCQUgvQixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxjQUFjO2lCQUN6Qjs4QkFNYyxNQUFNO3NCQUFsQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnXG5pbXBvcnQgeyBCZWhhdmlvclN1YmplY3QgfSBmcm9tICdyeGpzJ1xuaW50ZXJmYWNlIFBvcG92ZXJDb25maWcge1xuICB1c2VQb3BwZXI/OiBib29sZWFuXG4gIGNvbnRhaW5lcj86ICcnIHwgJ2JvZHknXG4gIHVzZUJvZHlTY3JvbGxMb2NrPzogYm9vbGVhblxufVxuXG5pbnRlcmZhY2UgUG9wb3ZlclN0YXRlIHtcbiAgJGlzT3BlbjogQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+XG59XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ1tuZ2dQb3BvdmVyXScsXG59KVxuZXhwb3J0IGNsYXNzIE5nZ1BvcG92ZXJEaXJlY3RpdmUge1xuICBnZXQgY29uZmlnKCk6IFBvcG92ZXJDb25maWcge1xuICAgIHJldHVybiB0aGlzLl9jb25maWdcbiAgfVxuXG4gIEBJbnB1dCgpIHNldCBjb25maWcoY29uZmlnOiBQb3BvdmVyQ29uZmlnKSB7XG4gICAgdGhpcy5fY29uZmlnID0geyAuLi50aGlzLmNvbmZpZywgLi4uY29uZmlnIH1cbiAgfVxuICB0cmlnZ2VyRWxlbWVudD86IEVsZW1lbnRSZWZcbiAgcHJpdmF0ZSBfY29uZmlnOiBQb3BvdmVyQ29uZmlnID0ge1xuICAgIHVzZVBvcHBlcjogdHJ1ZSxcbiAgICBjb250YWluZXI6ICcnLFxuICAgIHVzZUJvZHlTY3JvbGxMb2NrOiB0cnVlLFxuICB9XG4gIHN0YXRlOiBQb3BvdmVyU3RhdGUgPSB7XG4gICAgJGlzT3BlbjogbmV3IEJlaGF2aW9yU3ViamVjdDxib29sZWFuPihmYWxzZSksXG4gIH1cblxuICBjbG9zZSgpIHtcbiAgICB0aGlzLnN0YXRlLiRpc09wZW4ubmV4dChmYWxzZSlcbiAgfVxuICBvcGVuKCkge1xuICAgIHRoaXMuc3RhdGUuJGlzT3Blbi5uZXh0KHRydWUpXG4gIH1cbiAgdG9nZ2xlKCkge1xuICAgIGlmICh0aGlzLnN0YXRlLiRpc09wZW4udmFsdWUpIHtcbiAgICAgIHRoaXMuY2xvc2UoKVxuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLm9wZW4oKVxuICAgIH1cbiAgfVxufVxuIl19