@ifsworld/granite-components 13.2.6 → 13.2.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/core/core.module.mjs +5 -2
- package/esm2022/lib/core/overlay-base.mjs +18 -0
- package/esm2022/lib/core/overlay-position-config.mjs +2 -0
- package/esm2022/lib/core/overlay-trigger-for-base.directive.mjs +121 -0
- package/esm2022/lib/core/overlay.service.mjs +90 -0
- package/esm2022/lib/input-field/input-field.component.mjs +4 -9
- package/esm2022/lib/progress-bar/progress-bar-legend/progress-bar-legend.component.mjs +2 -2
- package/esm2022/lib/progress-bar/progress-bar-legend-base.mjs +10 -13
- package/esm2022/lib/progress-bar/progress-bar-legend-trigger-for.directive.mjs +30 -167
- package/fesm2022/ifsworld-granite-components.mjs +238 -160
- package/fesm2022/ifsworld-granite-components.mjs.map +1 -1
- package/lib/core/core.module.d.ts +2 -1
- package/lib/core/overlay-base.d.ts +16 -0
- package/lib/core/overlay-position-config.d.ts +12 -0
- package/lib/core/overlay-trigger-for-base.directive.d.ts +32 -0
- package/lib/core/overlay.service.d.ts +21 -0
- package/lib/input-field/input-field.component.d.ts +0 -1
- package/lib/progress-bar/progress-bar-legend-base.d.ts +3 -12
- package/lib/progress-bar/progress-bar-legend-trigger-for.directive.d.ts +14 -37
- package/package.json +1 -1
|
@@ -1,163 +1,38 @@
|
|
|
1
|
-
import { Directive,
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import { GRANITE_CLIENT_INPUT, GRANITE_CLIENT_OUTPUT, } from '../core/client-environment';
|
|
5
|
-
import { Directionality } from '@angular/cdk/bidi';
|
|
6
|
-
import { FocusMonitor } from '@angular/cdk/a11y';
|
|
7
|
-
import { GraniteProgressBarLegendComponent } from './progress-bar-legend/progress-bar-legend.component';
|
|
1
|
+
import { Directive, Input } from '@angular/core';
|
|
2
|
+
import { GraniteOverlayTriggerForBaseDirective } from '../core/overlay-trigger-for-base.directive';
|
|
3
|
+
import { OverlayBaseComponent } from '../core/overlay-base';
|
|
8
4
|
import * as i0 from "@angular/core";
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
_clientInput,
|
|
16
|
-
/** Client output device information */
|
|
17
|
-
_clientOutput, _dir, _focusMonitor) {
|
|
18
|
-
this._overlay = _overlay;
|
|
19
|
-
this._element = _element;
|
|
20
|
-
this._viewContainerRef = _viewContainerRef;
|
|
21
|
-
this._outsideClickDispatcher = _outsideClickDispatcher;
|
|
22
|
-
this._clientInput = _clientInput;
|
|
23
|
-
this._clientOutput = _clientOutput;
|
|
24
|
-
this._dir = _dir;
|
|
25
|
-
this._focusMonitor = _focusMonitor;
|
|
26
|
-
this._isLegendOpen = false;
|
|
27
|
-
this._portal = null;
|
|
28
|
-
this._overlayRef = null;
|
|
5
|
+
export class GraniteProgressBarLegendTriggerForDirective extends GraniteOverlayTriggerForBaseDirective {
|
|
6
|
+
constructor() {
|
|
7
|
+
super(...arguments);
|
|
8
|
+
this.isLegendOpen = false;
|
|
9
|
+
this.selector = '.granite-progress-bar-legend';
|
|
10
|
+
this.offsetY = 4;
|
|
29
11
|
}
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
this._overlayRef.dispose();
|
|
33
|
-
this._overlayRef = null;
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
openLegend() {
|
|
37
|
-
if (this._isLegendOpen) {
|
|
38
|
-
return;
|
|
39
|
-
}
|
|
40
|
-
this.legend.direction = this._dir.value === 'rtl' ? 'rtl' : 'ltr';
|
|
41
|
-
this.legend.clientInput = this._clientInput;
|
|
42
|
-
this.legend.clientOutput = this._clientOutput;
|
|
43
|
-
const panelClass = [];
|
|
44
|
-
if (this._clientOutput?.device === 'touch') {
|
|
45
|
-
panelClass.push('granite-overlay-pane-center');
|
|
46
|
-
}
|
|
47
|
-
const scrollStrategy = this._clientOutput?.device !== 'touch'
|
|
48
|
-
? this._overlay.scrollStrategies.reposition()
|
|
49
|
-
: this._overlay.scrollStrategies.block();
|
|
50
|
-
const hasBackdrop = this._clientOutput?.device === 'touch';
|
|
51
|
-
if (!this._overlayRef) {
|
|
52
|
-
const config = new OverlayConfig({
|
|
53
|
-
positionStrategy: this._positionStrategy(),
|
|
54
|
-
backdropClass: 'granite-overlay-dark-glass-backdrop',
|
|
55
|
-
scrollStrategy,
|
|
56
|
-
direction: this._dir,
|
|
57
|
-
panelClass,
|
|
58
|
-
hasBackdrop,
|
|
59
|
-
});
|
|
60
|
-
this._overlayRef = this._overlay.create(config);
|
|
61
|
-
}
|
|
62
|
-
if (!this._portal || this._portal.templateRef !== this.legend.templateRef) {
|
|
63
|
-
this._portal = new TemplatePortal(this.legend.templateRef, this._viewContainerRef);
|
|
64
|
-
}
|
|
65
|
-
this._overlayRef.attach(this._portal);
|
|
66
|
-
this._outsideClickDispatcher.add(this._overlayRef);
|
|
67
|
-
this._overlayRef.outsidePointerEvents().subscribe((event) => {
|
|
68
|
-
event.stopPropagation();
|
|
69
|
-
this.closeLegend();
|
|
70
|
-
});
|
|
71
|
-
this._isLegendOpen = true;
|
|
72
|
-
}
|
|
73
|
-
toggleLegend() {
|
|
74
|
-
if (this._isLegendOpen) {
|
|
75
|
-
this.closeLegend();
|
|
76
|
-
}
|
|
77
|
-
else {
|
|
78
|
-
this.openLegend();
|
|
79
|
-
}
|
|
12
|
+
get legend() {
|
|
13
|
+
return this.componentRef;
|
|
80
14
|
}
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
return;
|
|
84
|
-
}
|
|
85
|
-
this._outsideClickDispatcher.remove(this._overlayRef);
|
|
86
|
-
this._overlayRef.detach();
|
|
87
|
-
this._restoreFocus();
|
|
88
|
-
this._isLegendOpen = false;
|
|
15
|
+
set legend(value) {
|
|
16
|
+
this.componentRef = value;
|
|
89
17
|
}
|
|
90
|
-
|
|
18
|
+
handleKeydown(event) {
|
|
91
19
|
if (event.key === 'Enter') {
|
|
92
20
|
event.preventDefault();
|
|
93
|
-
this.
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
_handleClick() {
|
|
97
|
-
this.toggleLegend();
|
|
98
|
-
}
|
|
99
|
-
_restoreFocus(origin = 'program', options) {
|
|
100
|
-
if (this._focusMonitor) {
|
|
101
|
-
this._focusMonitor.focusVia(this._element, origin, options);
|
|
102
|
-
}
|
|
103
|
-
else {
|
|
104
|
-
this._element.nativeElement.focus(options);
|
|
21
|
+
this.isLegendOpen = this.toggleOverlay(this.isLegendOpen);
|
|
105
22
|
}
|
|
106
23
|
}
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
.position()
|
|
110
|
-
.flexibleConnectedTo(this._element)
|
|
111
|
-
.withLockedPosition()
|
|
112
|
-
.withTransformOriginOn('.granite-progress-bar-legend')
|
|
113
|
-
.withPush(false);
|
|
114
|
-
this._setPosition(positionStrategy);
|
|
115
|
-
return positionStrategy;
|
|
24
|
+
handleClick() {
|
|
25
|
+
this.isLegendOpen = this.toggleOverlay(this.isLegendOpen);
|
|
116
26
|
}
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
let [originY, originFallbackY] = [overlayY, overlayFallbackY];
|
|
121
|
-
const [overlayX, overlayFallbackX] = [originX, originFallbackX];
|
|
122
|
-
const offsetY = 4;
|
|
123
|
-
originY = overlayY === 'top' ? 'bottom' : 'top';
|
|
124
|
-
originFallbackY = overlayFallbackY === 'top' ? 'bottom' : 'top';
|
|
125
|
-
positionStrategy.withPositions([
|
|
126
|
-
{ originX, originY, overlayX, overlayY, offsetY },
|
|
127
|
-
{
|
|
128
|
-
originX: originFallbackX,
|
|
129
|
-
originY,
|
|
130
|
-
overlayX: overlayFallbackX,
|
|
131
|
-
overlayY,
|
|
132
|
-
offsetY,
|
|
133
|
-
},
|
|
134
|
-
{
|
|
135
|
-
originX,
|
|
136
|
-
originY: originFallbackY,
|
|
137
|
-
overlayX,
|
|
138
|
-
overlayY: overlayFallbackY,
|
|
139
|
-
offsetY: -offsetY,
|
|
140
|
-
},
|
|
141
|
-
{
|
|
142
|
-
originX: originFallbackX,
|
|
143
|
-
originY: originFallbackY,
|
|
144
|
-
overlayX: overlayFallbackX,
|
|
145
|
-
overlayY: overlayFallbackY,
|
|
146
|
-
offsetY: -offsetY,
|
|
147
|
-
},
|
|
148
|
-
]);
|
|
149
|
-
}
|
|
150
|
-
_positionStrategy() {
|
|
151
|
-
if (this._clientOutput?.device !== 'touch') {
|
|
152
|
-
return this._desktopPositionStrategy();
|
|
153
|
-
}
|
|
154
|
-
return this._touchPositionStrategy();
|
|
27
|
+
onOutsideClick() {
|
|
28
|
+
super.onOutsideClick();
|
|
29
|
+
this.isLegendOpen = false;
|
|
155
30
|
}
|
|
156
|
-
|
|
157
|
-
return this.
|
|
31
|
+
getScrollStrategy() {
|
|
32
|
+
return this.setScrollStrategy('reposition');
|
|
158
33
|
}
|
|
159
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GraniteProgressBarLegendTriggerForDirective, deps:
|
|
160
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.4", type: GraniteProgressBarLegendTriggerForDirective, selector: "[graniteProgressBarLegendTriggerFor]", inputs: { legend: ["graniteProgressBarLegendTriggerFor", "legend"] }, host: { attributes: { "aria-haspopup": "true" }, listeners: { "keydown": "
|
|
34
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GraniteProgressBarLegendTriggerForDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
35
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.4", type: GraniteProgressBarLegendTriggerForDirective, selector: "[graniteProgressBarLegendTriggerFor]", inputs: { legend: ["graniteProgressBarLegendTriggerFor", "legend"] }, host: { attributes: { "aria-haspopup": "true" }, listeners: { "keydown": "handleKeydown($event)", "click": "handleClick($event)" }, properties: { "attr.aria-expanded": "isLegendOpen || null", "attr.aria-controls": "isLegendOpen ? legend.panelId : null" }, classAttribute: "granite-progress-bar-legend-trigger" }, usesInheritance: true, ngImport: i0 }); }
|
|
161
36
|
}
|
|
162
37
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImport: i0, type: GraniteProgressBarLegendTriggerForDirective, decorators: [{
|
|
163
38
|
type: Directive,
|
|
@@ -166,26 +41,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.4", ngImpor
|
|
|
166
41
|
host: {
|
|
167
42
|
class: 'granite-progress-bar-legend-trigger',
|
|
168
43
|
'aria-haspopup': 'true',
|
|
169
|
-
'[attr.aria-expanded]': '
|
|
170
|
-
'[attr.aria-controls]': '
|
|
171
|
-
'(keydown)': '
|
|
172
|
-
'(click)': '
|
|
44
|
+
'[attr.aria-expanded]': 'isLegendOpen || null',
|
|
45
|
+
'[attr.aria-controls]': 'isLegendOpen ? legend.panelId : null',
|
|
46
|
+
'(keydown)': 'handleKeydown($event)',
|
|
47
|
+
'(click)': 'handleClick($event)',
|
|
173
48
|
},
|
|
174
49
|
}]
|
|
175
|
-
}],
|
|
176
|
-
type: Inject,
|
|
177
|
-
args: [GRANITE_CLIENT_INPUT]
|
|
178
|
-
}, {
|
|
179
|
-
type: Optional
|
|
180
|
-
}] }, { type: undefined, decorators: [{
|
|
181
|
-
type: Inject,
|
|
182
|
-
args: [GRANITE_CLIENT_OUTPUT]
|
|
183
|
-
}, {
|
|
184
|
-
type: Optional
|
|
185
|
-
}] }, { type: i2.Directionality, decorators: [{
|
|
186
|
-
type: Optional
|
|
187
|
-
}] }, { type: i3.FocusMonitor }], propDecorators: { legend: [{
|
|
50
|
+
}], propDecorators: { legend: [{
|
|
188
51
|
type: Input,
|
|
189
52
|
args: ['graniteProgressBarLegendTriggerFor']
|
|
190
53
|
}] } });
|
|
191
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"progress-bar-legend-trigger-for.directive.js","sourceRoot":"","sources":["../../../../../../libs/granite-components/src/lib/progress-bar/progress-bar-legend-trigger-for.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,UAAU,EACV,MAAM,EACN,KAAK,EAEL,QAAQ,EACR,gBAAgB,GACjB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AACrD,OAAO,EAGL,OAAO,EACP,aAAa,EACb,6BAA6B,GAI9B,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAGL,oBAAoB,EACpB,qBAAqB,GACtB,MAAM,4BAA4B,CAAC;AACpC,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAAE,YAAY,EAAe,MAAM,mBAAmB,CAAC;AAC9D,OAAO,EAAE,iCAAiC,EAAE,MAAM,qDAAqD,CAAC;;;;;AAaxG,MAAM,OAAO,2CAA2C;IAStD,YACU,QAAiB,EACjB,QAAiC,EACjC,iBAAmC,EACnC,uBAAsD;IAE9D,sCAAsC;IAG/B,YAAkC;IAEzC,uCAAuC;IAGhC,aAAoC,EAGnC,IAAoB,EAEpB,aAA2B;QAlB3B,aAAQ,GAAR,QAAQ,CAAS;QACjB,aAAQ,GAAR,QAAQ,CAAyB;QACjC,sBAAiB,GAAjB,iBAAiB,CAAkB;QACnC,4BAAuB,GAAvB,uBAAuB,CAA+B;QAKvD,iBAAY,GAAZ,YAAY,CAAsB;QAKlC,kBAAa,GAAb,aAAa,CAAuB;QAGnC,SAAI,GAAJ,IAAI,CAAgB;QAEpB,kBAAa,GAAb,aAAa,CAAc;QAxBrC,kBAAa,GAAY,KAAK,CAAC;QAEvB,YAAO,GAA0B,IAAI,CAAC;QACtC,gBAAW,GAAsB,IAAI,CAAC;IAsB3C,CAAC;IAEJ,WAAW;QACT,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;YAC3B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QAC1B,CAAC;IACH,CAAC;IAED,UAAU;QACR,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB,OAAO;QACT,CAAC;QAED,IAAI,CAAC,MAAM,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC;QAClE,IAAI,CAAC,MAAM,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC;QAC5C,IAAI,CAAC,MAAM,CAAC,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC;QAE9C,MAAM,UAAU,GAAa,EAAE,CAAC;QAChC,IAAI,IAAI,CAAC,aAAa,EAAE,MAAM,KAAK,OAAO,EAAE,CAAC;YAC3C,UAAU,CAAC,IAAI,CAAC,6BAA6B,CAAC,CAAC;QACjD,CAAC;QAED,MAAM,cAAc,GAClB,IAAI,CAAC,aAAa,EAAE,MAAM,KAAK,OAAO;YACpC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,UAAU,EAAE;YAC7C,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;QAE7C,MAAM,WAAW,GAAG,IAAI,CAAC,aAAa,EAAE,MAAM,KAAK,OAAO,CAAC;QAE3D,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACtB,MAAM,MAAM,GAAG,IAAI,aAAa,CAAC;gBAC/B,gBAAgB,EAAE,IAAI,CAAC,iBAAiB,EAAE;gBAC1C,aAAa,EAAE,qCAAqC;gBACpD,cAAc;gBACd,SAAS,EAAE,IAAI,CAAC,IAAI;gBACpB,UAAU;gBACV,WAAW;aACZ,CAAC,CAAC;YAEH,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAClD,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,KAAK,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC;YAC1E,IAAI,CAAC,OAAO,GAAG,IAAI,cAAc,CAC/B,IAAI,CAAC,MAAM,CAAC,WAAW,EACvB,IAAI,CAAC,iBAAiB,CACvB,CAAC;QACJ,CAAC;QAED,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACtC,IAAI,CAAC,uBAAuB,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACnD,IAAI,CAAC,WAAW,CAAC,oBAAoB,EAAE,CAAC,SAAS,CAAC,CAAC,KAAiB,EAAE,EAAE;YACtE,KAAK,CAAC,eAAe,EAAE,CAAC;YACxB,IAAI,CAAC,WAAW,EAAE,CAAC;QACrB,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;IAC5B,CAAC;IAED,YAAY;QACV,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB,IAAI,CAAC,WAAW,EAAE,CAAC;QACrB,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,CAAC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;YAC7C,OAAO;QACT,CAAC;QAED,IAAI,CAAC,uBAAuB,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACtD,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;QAE1B,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;IAC7B,CAAC;IAED,cAAc,CAAC,KAAoB;QACjC,IAAI,KAAK,CAAC,GAAG,KAAK,OAAO,EAAE,CAAC;YAC1B,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,IAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC;IACH,CAAC;IAED,YAAY;QACV,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,aAAa,CAAC,SAAsB,SAAS,EAAE,OAAsB;QACnE,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;QAC9D,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QAC7C,CAAC;IACH,CAAC;IAEO,wBAAwB;QAC9B,MAAM,gBAAgB,GAAsC,IAAI,CAAC,QAAQ;aACtE,QAAQ,EAAE;aACV,mBAAmB,CAAC,IAAI,CAAC,QAAQ,CAAC;aAClC,kBAAkB,EAAE;aACpB,qBAAqB,CAAC,8BAA8B,CAAC;aACrD,QAAQ,CAAC,KAAK,CAAC,CAAC;QAEnB,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,CAAC;QACpC,OAAO,gBAAgB,CAAC;IAC1B,CAAC;IAEO,YAAY,CAAC,gBAAmD;QACtE,MAAM,CAAC,OAAO,EAAE,eAAe,CAAC,GAC9B,IAAI,CAAC,MAAM,CAAC,SAAS,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;QAE3E,MAAM,CAAC,QAAQ,EAAE,gBAAgB,CAAC,GAChC,IAAI,CAAC,MAAM,CAAC,SAAS,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;QAE5E,IAAI,CAAC,OAAO,EAAE,eAAe,CAAC,GAAG,CAAC,QAAQ,EAAE,gBAAgB,CAAC,CAAC;QAC9D,MAAM,CAAC,QAAQ,EAAE,gBAAgB,CAAC,GAAG,CAAC,OAAO,EAAE,eAAe,CAAC,CAAC;QAChE,MAAM,OAAO,GAAG,CAAC,CAAC;QAElB,OAAO,GAAG,QAAQ,KAAK,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC;QAChD,eAAe,GAAG,gBAAgB,KAAK,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC;QAEhE,gBAAgB,CAAC,aAAa,CAAC;YAC7B,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,OAAO,EAAE;YACjD;gBACE,OAAO,EAAE,eAAe;gBACxB,OAAO;gBACP,QAAQ,EAAE,gBAAgB;gBAC1B,QAAQ;gBACR,OAAO;aACR;YACD;gBACE,OAAO;gBACP,OAAO,EAAE,eAAe;gBACxB,QAAQ;gBACR,QAAQ,EAAE,gBAAgB;gBAC1B,OAAO,EAAE,CAAC,OAAO;aAClB;YACD;gBACE,OAAO,EAAE,eAAe;gBACxB,OAAO,EAAE,eAAe;gBACxB,QAAQ,EAAE,gBAAgB;gBAC1B,QAAQ,EAAE,gBAAgB;gBAC1B,OAAO,EAAE,CAAC,OAAO;aAClB;SACF,CAAC,CAAC;IACL,CAAC;IAEO,iBAAiB;QACvB,IAAI,IAAI,CAAC,aAAa,EAAE,MAAM,KAAK,OAAO,EAAE,CAAC;YAC3C,OAAO,IAAI,CAAC,wBAAwB,EAAE,CAAC;QACzC,CAAC;QACD,OAAO,IAAI,CAAC,sBAAsB,EAAE,CAAC;IACvC,CAAC;IAEO,sBAAsB;QAC5B,OAAO,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,MAAM,EAAE,CAAC;IAC3C,CAAC;8GA7LU,2CAA2C,gJAgB5C,oBAAoB,6BAKpB,qBAAqB;kGArBpB,2CAA2C;;2FAA3C,2CAA2C;kBAXvD,SAAS;mBAAC;oBACT,QAAQ,EAAE,sCAAsC;oBAChD,IAAI,EAAE;wBACJ,KAAK,EAAE,qCAAqC;wBAC5C,eAAe,EAAE,MAAM;wBACvB,sBAAsB,EAAE,uBAAuB;wBAC/C,sBAAsB,EAAE,uCAAuC;wBAC/D,WAAW,EAAE,wBAAwB;wBACrC,SAAS,EAAE,sBAAsB;qBAClC;iBACF;;0BAiBI,MAAM;2BAAC,oBAAoB;;0BAC3B,QAAQ;;0BAIR,MAAM;2BAAC,qBAAqB;;0BAC5B,QAAQ;;0BAGR,QAAQ;oEAvBX,MAAM;sBADL,KAAK;uBAAC,oCAAoC","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  Inject,\n  Input,\n  OnDestroy,\n  Optional,\n  ViewContainerRef,\n} from '@angular/core';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport {\n  FlexibleConnectedPositionStrategy,\n  HorizontalConnectionPos,\n  Overlay,\n  OverlayConfig,\n  OverlayOutsideClickDispatcher,\n  OverlayRef,\n  PositionStrategy,\n  VerticalConnectionPos,\n} from '@angular/cdk/overlay';\nimport {\n  ClientInputInterface,\n  ClientOutputInterface,\n  GRANITE_CLIENT_INPUT,\n  GRANITE_CLIENT_OUTPUT,\n} from '../core/client-environment';\nimport { Directionality } from '@angular/cdk/bidi';\nimport { FocusMonitor, FocusOrigin } from '@angular/cdk/a11y';\nimport { GraniteProgressBarLegendComponent } from './progress-bar-legend/progress-bar-legend.component';\n\n@Directive({\n  selector: '[graniteProgressBarLegendTriggerFor]',\n  host: {\n    class: 'granite-progress-bar-legend-trigger',\n    'aria-haspopup': 'true',\n    '[attr.aria-expanded]': '_isLegendOpen || null',\n    '[attr.aria-controls]': '_isLegendOpen ? legend.panelId : null',\n    '(keydown)': '_handleKeydown($event)',\n    '(click)': '_handleClick($event)',\n  },\n})\nexport class GraniteProgressBarLegendTriggerForDirective implements OnDestroy {\n  @Input('graniteProgressBarLegendTriggerFor')\n  legend: GraniteProgressBarLegendComponent;\n\n  _isLegendOpen: boolean = false;\n\n  private _portal: TemplatePortal | null = null;\n  private _overlayRef: OverlayRef | null = null;\n\n  constructor(\n    private _overlay: Overlay,\n    private _element: ElementRef<HTMLElement>,\n    private _viewContainerRef: ViewContainerRef,\n    private _outsideClickDispatcher: OverlayOutsideClickDispatcher,\n\n    /** Client input device information */\n    @Inject(GRANITE_CLIENT_INPUT)\n    @Optional()\n    public _clientInput: ClientInputInterface,\n\n    /** Client output device information */\n    @Inject(GRANITE_CLIENT_OUTPUT)\n    @Optional()\n    public _clientOutput: ClientOutputInterface,\n\n    @Optional()\n    private _dir: Directionality,\n\n    private _focusMonitor: FocusMonitor\n  ) {}\n\n  ngOnDestroy(): void {\n    if (this._overlayRef) {\n      this._overlayRef.dispose();\n      this._overlayRef = null;\n    }\n  }\n\n  openLegend(): void {\n    if (this._isLegendOpen) {\n      return;\n    }\n\n    this.legend.direction = this._dir.value === 'rtl' ? 'rtl' : 'ltr';\n    this.legend.clientInput = this._clientInput;\n    this.legend.clientOutput = this._clientOutput;\n\n    const panelClass: string[] = [];\n    if (this._clientOutput?.device === 'touch') {\n      panelClass.push('granite-overlay-pane-center');\n    }\n\n    const scrollStrategy =\n      this._clientOutput?.device !== 'touch'\n        ? this._overlay.scrollStrategies.reposition()\n        : this._overlay.scrollStrategies.block();\n\n    const hasBackdrop = this._clientOutput?.device === 'touch';\n\n    if (!this._overlayRef) {\n      const config = new OverlayConfig({\n        positionStrategy: this._positionStrategy(),\n        backdropClass: 'granite-overlay-dark-glass-backdrop',\n        scrollStrategy,\n        direction: this._dir,\n        panelClass,\n        hasBackdrop,\n      });\n\n      this._overlayRef = this._overlay.create(config);\n    }\n\n    if (!this._portal || this._portal.templateRef !== this.legend.templateRef) {\n      this._portal = new TemplatePortal(\n        this.legend.templateRef,\n        this._viewContainerRef\n      );\n    }\n\n    this._overlayRef.attach(this._portal);\n    this._outsideClickDispatcher.add(this._overlayRef);\n    this._overlayRef.outsidePointerEvents().subscribe((event: MouseEvent) => {\n      event.stopPropagation();\n      this.closeLegend();\n    });\n\n    this._isLegendOpen = true;\n  }\n\n  toggleLegend(): void {\n    if (this._isLegendOpen) {\n      this.closeLegend();\n    } else {\n      this.openLegend();\n    }\n  }\n\n  closeLegend(): void {\n    if (!this._overlayRef || !this._isLegendOpen) {\n      return;\n    }\n\n    this._outsideClickDispatcher.remove(this._overlayRef);\n    this._overlayRef.detach();\n\n    this._restoreFocus();\n    this._isLegendOpen = false;\n  }\n\n  _handleKeydown(event: KeyboardEvent): void {\n    if (event.key === 'Enter') {\n      event.preventDefault();\n      this.toggleLegend();\n    }\n  }\n\n  _handleClick(): void {\n    this.toggleLegend();\n  }\n\n  _restoreFocus(origin: FocusOrigin = 'program', options?: FocusOptions): void {\n    if (this._focusMonitor) {\n      this._focusMonitor.focusVia(this._element, origin, options);\n    } else {\n      this._element.nativeElement.focus(options);\n    }\n  }\n\n  private _desktopPositionStrategy(): PositionStrategy {\n    const positionStrategy: FlexibleConnectedPositionStrategy = this._overlay\n      .position()\n      .flexibleConnectedTo(this._element)\n      .withLockedPosition()\n      .withTransformOriginOn('.granite-progress-bar-legend')\n      .withPush(false);\n\n    this._setPosition(positionStrategy);\n    return positionStrategy;\n  }\n\n  private _setPosition(positionStrategy: FlexibleConnectedPositionStrategy) {\n    const [originX, originFallbackX]: HorizontalConnectionPos[] =\n      this.legend.xPosition === 'before' ? ['end', 'start'] : ['start', 'end'];\n\n    const [overlayY, overlayFallbackY]: VerticalConnectionPos[] =\n      this.legend.yPosition === 'above' ? ['bottom', 'top'] : ['top', 'bottom'];\n\n    let [originY, originFallbackY] = [overlayY, overlayFallbackY];\n    const [overlayX, overlayFallbackX] = [originX, originFallbackX];\n    const offsetY = 4;\n\n    originY = overlayY === 'top' ? 'bottom' : 'top';\n    originFallbackY = overlayFallbackY === 'top' ? 'bottom' : 'top';\n\n    positionStrategy.withPositions([\n      { originX, originY, overlayX, overlayY, offsetY },\n      {\n        originX: originFallbackX,\n        originY,\n        overlayX: overlayFallbackX,\n        overlayY,\n        offsetY,\n      },\n      {\n        originX,\n        originY: originFallbackY,\n        overlayX,\n        overlayY: overlayFallbackY,\n        offsetY: -offsetY,\n      },\n      {\n        originX: originFallbackX,\n        originY: originFallbackY,\n        overlayX: overlayFallbackX,\n        overlayY: overlayFallbackY,\n        offsetY: -offsetY,\n      },\n    ]);\n  }\n\n  private _positionStrategy(): PositionStrategy {\n    if (this._clientOutput?.device !== 'touch') {\n      return this._desktopPositionStrategy();\n    }\n    return this._touchPositionStrategy();\n  }\n\n  private _touchPositionStrategy(): PositionStrategy {\n    return this._overlay.position().global();\n  }\n}\n"]}
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZ3Jlc3MtYmFyLWxlZ2VuZC10cmlnZ2VyLWZvci5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2dyYW5pdGUtY29tcG9uZW50cy9zcmMvbGliL3Byb2dyZXNzLWJhci9wcm9ncmVzcy1iYXItbGVnZW5kLXRyaWdnZXItZm9yLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVqRCxPQUFPLEVBQUUscUNBQXFDLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQztBQUNuRyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7QUFrQjVELE1BQU0sT0FBTywyQ0FBNEMsU0FBUSxxQ0FBcUM7SUFYdEc7O1FBcUJFLGlCQUFZLEdBQVksS0FBSyxDQUFDO1FBRVgsYUFBUSxHQUFXLDhCQUE4QixDQUFDO1FBQ2xELFlBQU8sR0FBVyxDQUFDLENBQUM7S0F3QnhDO0lBcENDLElBQ0ksTUFBTTtRQUNSLE9BQU8sSUFBSSxDQUFDLFlBQVksQ0FBQztJQUMzQixDQUFDO0lBRUQsSUFBSSxNQUFNLENBQUMsS0FBd0M7UUFDakQsSUFBSSxDQUFDLFlBQVksR0FBRyxLQUFLLENBQUM7SUFDNUIsQ0FBQztJQU9ELGFBQWEsQ0FBQyxLQUFvQjtRQUNoQyxJQUFJLEtBQUssQ0FBQyxHQUFHLEtBQUssT0FBTyxFQUFFLENBQUM7WUFDMUIsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO1lBQ3ZCLElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDNUQsQ0FBQztJQUNILENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUM1RCxDQUFDO0lBRUQsY0FBYztRQUNaLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUN2QixJQUFJLENBQUMsWUFBWSxHQUFHLEtBQUssQ0FBQztJQUM1QixDQUFDO0lBRVEsaUJBQWlCO1FBSXhCLE9BQU8sSUFBSSxDQUFDLGlCQUFpQixDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQzlDLENBQUM7OEdBcENVLDJDQUEyQztrR0FBM0MsMkNBQTJDOzsyRkFBM0MsMkNBQTJDO2tCQVh2RCxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxzQ0FBc0M7b0JBQ2hELElBQUksRUFBRTt3QkFDSixLQUFLLEVBQUUscUNBQXFDO3dCQUM1QyxlQUFlLEVBQUUsTUFBTTt3QkFDdkIsc0JBQXNCLEVBQUUsc0JBQXNCO3dCQUM5QyxzQkFBc0IsRUFBRSxzQ0FBc0M7d0JBQzlELFdBQVcsRUFBRSx1QkFBdUI7d0JBQ3BDLFNBQVMsRUFBRSxxQkFBcUI7cUJBQ2pDO2lCQUNGOzhCQUdLLE1BQU07c0JBRFQsS0FBSzt1QkFBQyxvQ0FBb0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBHcmFuaXRlUHJvZ3Jlc3NCYXJMZWdlbmRDb21wb25lbnQgfSBmcm9tICcuL3Byb2dyZXNzLWJhci1sZWdlbmQvcHJvZ3Jlc3MtYmFyLWxlZ2VuZC5jb21wb25lbnQnO1xuaW1wb3J0IHsgR3Jhbml0ZU92ZXJsYXlUcmlnZ2VyRm9yQmFzZURpcmVjdGl2ZSB9IGZyb20gJy4uL2NvcmUvb3ZlcmxheS10cmlnZ2VyLWZvci1iYXNlLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBPdmVybGF5QmFzZUNvbXBvbmVudCB9IGZyb20gJy4uL2NvcmUvb3ZlcmxheS1iYXNlJztcbmltcG9ydCB7XG4gIEJsb2NrU2Nyb2xsU3RyYXRlZ3ksXG4gIENsb3NlU2Nyb2xsU3RyYXRlZ3ksXG4gIFJlcG9zaXRpb25TY3JvbGxTdHJhdGVneSxcbn0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbZ3Jhbml0ZVByb2dyZXNzQmFyTGVnZW5kVHJpZ2dlckZvcl0nLFxuICBob3N0OiB7XG4gICAgY2xhc3M6ICdncmFuaXRlLXByb2dyZXNzLWJhci1sZWdlbmQtdHJpZ2dlcicsXG4gICAgJ2FyaWEtaGFzcG9wdXAnOiAndHJ1ZScsXG4gICAgJ1thdHRyLmFyaWEtZXhwYW5kZWRdJzogJ2lzTGVnZW5kT3BlbiB8fCBudWxsJyxcbiAgICAnW2F0dHIuYXJpYS1jb250cm9sc10nOiAnaXNMZWdlbmRPcGVuID8gbGVnZW5kLnBhbmVsSWQgOiBudWxsJyxcbiAgICAnKGtleWRvd24pJzogJ2hhbmRsZUtleWRvd24oJGV2ZW50KScsXG4gICAgJyhjbGljayknOiAnaGFuZGxlQ2xpY2soJGV2ZW50KScsXG4gIH0sXG59KVxuZXhwb3J0IGNsYXNzIEdyYW5pdGVQcm9ncmVzc0JhckxlZ2VuZFRyaWdnZXJGb3JEaXJlY3RpdmUgZXh0ZW5kcyBHcmFuaXRlT3ZlcmxheVRyaWdnZXJGb3JCYXNlRGlyZWN0aXZlIHtcbiAgQElucHV0KCdncmFuaXRlUHJvZ3Jlc3NCYXJMZWdlbmRUcmlnZ2VyRm9yJylcbiAgZ2V0IGxlZ2VuZCgpOiBPdmVybGF5QmFzZUNvbXBvbmVudCB7XG4gICAgcmV0dXJuIHRoaXMuY29tcG9uZW50UmVmO1xuICB9XG5cbiAgc2V0IGxlZ2VuZCh2YWx1ZTogR3Jhbml0ZVByb2dyZXNzQmFyTGVnZW5kQ29tcG9uZW50KSB7XG4gICAgdGhpcy5jb21wb25lbnRSZWYgPSB2YWx1ZTtcbiAgfVxuXG4gIGlzTGVnZW5kT3BlbjogYm9vbGVhbiA9IGZhbHNlO1xuXG4gIHByb3RlY3RlZCBvdmVycmlkZSBzZWxlY3Rvcjogc3RyaW5nID0gJy5ncmFuaXRlLXByb2dyZXNzLWJhci1sZWdlbmQnO1xuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgb2Zmc2V0WTogbnVtYmVyID0gNDtcblxuICBoYW5kbGVLZXlkb3duKGV2ZW50OiBLZXlib2FyZEV2ZW50KTogdm9pZCB7XG4gICAgaWYgKGV2ZW50LmtleSA9PT0gJ0VudGVyJykge1xuICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbiAgICAgIHRoaXMuaXNMZWdlbmRPcGVuID0gdGhpcy50b2dnbGVPdmVybGF5KHRoaXMuaXNMZWdlbmRPcGVuKTtcbiAgICB9XG4gIH1cblxuICBoYW5kbGVDbGljaygpOiB2b2lkIHtcbiAgICB0aGlzLmlzTGVnZW5kT3BlbiA9IHRoaXMudG9nZ2xlT3ZlcmxheSh0aGlzLmlzTGVnZW5kT3Blbik7XG4gIH1cblxuICBvbk91dHNpZGVDbGljaygpOiB2b2lkIHtcbiAgICBzdXBlci5vbk91dHNpZGVDbGljaygpO1xuICAgIHRoaXMuaXNMZWdlbmRPcGVuID0gZmFsc2U7XG4gIH1cblxuICBvdmVycmlkZSBnZXRTY3JvbGxTdHJhdGVneSgpOlxuICAgIHwgUmVwb3NpdGlvblNjcm9sbFN0cmF0ZWd5XG4gICAgfCBCbG9ja1Njcm9sbFN0cmF0ZWd5XG4gICAgfCBDbG9zZVNjcm9sbFN0cmF0ZWd5IHtcbiAgICByZXR1cm4gdGhpcy5zZXRTY3JvbGxTdHJhdGVneSgncmVwb3NpdGlvbicpO1xuICB9XG59XG4iXX0=
|