@sebgroup/green-angular 6.2.1 → 6.3.0
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/src/v-angular/dropdown/dropdown-list/dropdown-list.component.mjs +34 -20
- package/esm2022/src/v-angular/dropdown/dropdown.component.mjs +126 -25
- package/esm2022/src/v-angular/dropdown/typeahead/typeahead-dropdown-list/typeahead-dropdown-list.component.mjs +3 -3
- package/esm2022/v-angular/dropdown/dropdown-list/dropdown-list.component.mjs +34 -20
- package/esm2022/v-angular/dropdown/dropdown.component.mjs +126 -25
- package/esm2022/v-angular/dropdown/typeahead/typeahead-dropdown-list/typeahead-dropdown-list.component.mjs +3 -3
- package/fesm2022/sebgroup-green-angular-src-v-angular-dropdown.mjs +155 -41
- package/fesm2022/sebgroup-green-angular-src-v-angular-dropdown.mjs.map +1 -1
- package/fesm2022/sebgroup-green-angular-v-angular.mjs +153 -39
- package/fesm2022/sebgroup-green-angular-v-angular.mjs.map +1 -1
- package/package.json +20 -20
- package/src/v-angular/dropdown/dropdown-list/dropdown-list.component.d.ts +24 -5
- package/src/v-angular/dropdown/dropdown.component.d.ts +40 -5
- package/v-angular/dropdown/dropdown-list/dropdown-list.component.d.ts +24 -5
- package/v-angular/dropdown/dropdown.component.d.ts +40 -5
|
@@ -1,17 +1,20 @@
|
|
|
1
1
|
import '@sebgroup/green-core/components/icon/icons/triangle-exclamation.js';
|
|
2
|
-
import {
|
|
2
|
+
import { Overlay } from '@angular/cdk/overlay';
|
|
3
|
+
import { TemplatePortal } from '@angular/cdk/portal';
|
|
4
|
+
import { ChangeDetectorRef, Component, ContentChild, ElementRef, EventEmitter, HostBinding, HostListener, Inject, Input, Optional, Output, Self, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';
|
|
3
5
|
import { NgControl } from '@angular/forms';
|
|
4
6
|
import { TRANSLOCO_SCOPE } from '@jsverse/transloco';
|
|
5
7
|
import { fromEvent } from 'rxjs';
|
|
6
8
|
import { NggvBaseControlValueAccessorComponent } from '@sebgroup/green-angular/src/v-angular/base-control-value-accessor';
|
|
7
|
-
import { DropdownUtils
|
|
9
|
+
import { DropdownUtils } from '@sebgroup/green-angular/src/v-angular/core';
|
|
8
10
|
import * as i0 from "@angular/core";
|
|
9
11
|
import * as i1 from "@angular/forms";
|
|
10
12
|
import * as i2 from "@sebgroup/green-angular/src/v-angular/core";
|
|
11
|
-
import * as i3 from "@angular/
|
|
12
|
-
import * as i4 from "@
|
|
13
|
-
import * as i5 from "@
|
|
14
|
-
import * as i6 from "
|
|
13
|
+
import * as i3 from "@angular/cdk/overlay";
|
|
14
|
+
import * as i4 from "@angular/common";
|
|
15
|
+
import * as i5 from "@sebgroup/green-angular/src/lib/shared";
|
|
16
|
+
import * as i6 from "@jsverse/transloco";
|
|
17
|
+
import * as i7 from "./dropdown-list/dropdown-list.component";
|
|
15
18
|
/**
|
|
16
19
|
* A dropdown allows the user to select an option from a list.
|
|
17
20
|
* Dropdowns enables users to make a quick selection of the available options for a specific entry.
|
|
@@ -58,12 +61,14 @@ export class NggvDropdownComponent extends NggvBaseControlValueAccessorComponent
|
|
|
58
61
|
get defaultNullishOption() {
|
|
59
62
|
return { key: null, label: this.placeholder ?? '\u00A0' };
|
|
60
63
|
}
|
|
61
|
-
constructor(ngControl, translocoScope, cdr, dropdownUtils) {
|
|
64
|
+
constructor(ngControl, translocoScope, cdr, dropdownUtils, overlay, vcr) {
|
|
62
65
|
super(ngControl, translocoScope, cdr);
|
|
63
66
|
this.ngControl = ngControl;
|
|
64
67
|
this.translocoScope = translocoScope;
|
|
65
68
|
this.cdr = cdr;
|
|
66
69
|
this.dropdownUtils = dropdownUtils;
|
|
70
|
+
this.overlay = overlay;
|
|
71
|
+
this.vcr = vcr;
|
|
67
72
|
/**
|
|
68
73
|
* Special property used for selecting DOM elements during automated UI testing.
|
|
69
74
|
*/
|
|
@@ -99,6 +104,11 @@ export class NggvDropdownComponent extends NggvBaseControlValueAccessorComponent
|
|
|
99
104
|
* Defaults to true.
|
|
100
105
|
*/
|
|
101
106
|
this.onlyHandleDistinctChanges = true;
|
|
107
|
+
/**
|
|
108
|
+
* If true (default), the dropdown list will close when any scrollable ancestor is scrolled.
|
|
109
|
+
* If false, the dropdown list will reposition itself instead of closing.
|
|
110
|
+
*/
|
|
111
|
+
this.closeDropdownListOnScroll = true;
|
|
102
112
|
/**
|
|
103
113
|
* Emits changes of the expanded state of the dropdown
|
|
104
114
|
*/
|
|
@@ -107,6 +117,11 @@ export class NggvDropdownComponent extends NggvBaseControlValueAccessorComponent
|
|
|
107
117
|
this.expanded = false;
|
|
108
118
|
/** The current option selected based on numeric index. */
|
|
109
119
|
this.activeIndex = -1;
|
|
120
|
+
/**
|
|
121
|
+
* Stores the bounding rectangle of the dropdown trigger element,
|
|
122
|
+
* used for positioning the dropdown list overlay.
|
|
123
|
+
*/
|
|
124
|
+
this.triggerRect = undefined;
|
|
110
125
|
this.keyEvent = {};
|
|
111
126
|
this._options = [];
|
|
112
127
|
}
|
|
@@ -130,6 +145,8 @@ export class NggvDropdownComponent extends NggvBaseControlValueAccessorComponent
|
|
|
130
145
|
ngOnDestroy() {
|
|
131
146
|
this.onClickSubscription?.unsubscribe();
|
|
132
147
|
this.onScrollSubscription?.unsubscribe();
|
|
148
|
+
this.resizeSubscription?.unsubscribe();
|
|
149
|
+
this.overlayDetachSubscription?.unsubscribe();
|
|
133
150
|
}
|
|
134
151
|
/** @internal override to correctly set state from form value */
|
|
135
152
|
writeValue(value) {
|
|
@@ -168,17 +185,6 @@ export class NggvDropdownComponent extends NggvBaseControlValueAccessorComponent
|
|
|
168
185
|
},
|
|
169
186
|
});
|
|
170
187
|
}
|
|
171
|
-
subscribeToOutsideScrollEvent() {
|
|
172
|
-
this.onScrollSubscription = fromEvent(document, 'scroll').subscribe({
|
|
173
|
-
next: (event) => {
|
|
174
|
-
if (this.expanded &&
|
|
175
|
-
!this.inputRef?.nativeElement.contains(event.target)) {
|
|
176
|
-
this.toggleDropdown();
|
|
177
|
-
this.onScrollSubscription?.unsubscribe();
|
|
178
|
-
}
|
|
179
|
-
},
|
|
180
|
-
});
|
|
181
|
-
}
|
|
182
188
|
// ----------------------------------------------------------------------------
|
|
183
189
|
// HELPERS
|
|
184
190
|
// ----------------------------------------------------------------------------
|
|
@@ -204,11 +210,98 @@ export class NggvDropdownComponent extends NggvBaseControlValueAccessorComponent
|
|
|
204
210
|
this.expanded = state;
|
|
205
211
|
this.expandedChange.emit(this.expanded);
|
|
206
212
|
if (this.expanded) {
|
|
213
|
+
this.openDropdownOverlay();
|
|
207
214
|
this.subscribeToOutsideClickEvent();
|
|
208
|
-
this.subscribeToOutsideScrollEvent();
|
|
209
215
|
}
|
|
210
|
-
|
|
216
|
+
else {
|
|
217
|
+
this.closeDropdownOverlay();
|
|
211
218
|
this.onTouched();
|
|
219
|
+
}
|
|
220
|
+
}
|
|
221
|
+
/**
|
|
222
|
+
* Opens the dropdown overlay by detaching any existing overlay reference,
|
|
223
|
+
* attaching a new overlay, updating its width, and setting up listeners for overlay detachments.
|
|
224
|
+
* This method ensures the dropdown overlay is properly initialized and displayed.
|
|
225
|
+
*/
|
|
226
|
+
openDropdownOverlay() {
|
|
227
|
+
this.detachOldOverlayRef();
|
|
228
|
+
this.attachNewOverlayRef();
|
|
229
|
+
this.updateOverlayWidth();
|
|
230
|
+
this.listenOverlayDetachments();
|
|
231
|
+
}
|
|
232
|
+
detachOldOverlayRef() {
|
|
233
|
+
if (this.overlayRef) {
|
|
234
|
+
this.overlayRef.detach();
|
|
235
|
+
}
|
|
236
|
+
}
|
|
237
|
+
attachNewOverlayRef() {
|
|
238
|
+
const positionStrategy = this.overlay
|
|
239
|
+
.position()
|
|
240
|
+
.flexibleConnectedTo(this.toggleButton)
|
|
241
|
+
.withPositions(this.getDropdownListPositionsArray())
|
|
242
|
+
.withPush(false); // Prevent overlay from overlapping the trigger
|
|
243
|
+
this.overlayRef = this.overlay.create({
|
|
244
|
+
positionStrategy,
|
|
245
|
+
scrollStrategy: this.getScrollStrategy(),
|
|
246
|
+
});
|
|
247
|
+
// Get trigger rect and pass to dropdown-list
|
|
248
|
+
this.triggerRect = this.toggleButton.nativeElement.getBoundingClientRect();
|
|
249
|
+
this.overlayRef.attach(new TemplatePortal(this.dropdownTemplate, this.vcr));
|
|
250
|
+
}
|
|
251
|
+
updateOverlayWidth() {
|
|
252
|
+
// sets initial width to match trigger element
|
|
253
|
+
this.setOverlayWidth();
|
|
254
|
+
// Listen for window resize and update overlay width
|
|
255
|
+
this.resizeSubscription = fromEvent(window, 'resize').subscribe(() => {
|
|
256
|
+
this.setOverlayWidth();
|
|
257
|
+
});
|
|
258
|
+
}
|
|
259
|
+
// used to catch when overlay is detached after scroll with list expanded
|
|
260
|
+
listenOverlayDetachments() {
|
|
261
|
+
if (this.overlayRef) {
|
|
262
|
+
this.overlayDetachSubscription = this.overlayRef
|
|
263
|
+
.detachments()
|
|
264
|
+
.subscribe(() => {
|
|
265
|
+
if (this.expanded) {
|
|
266
|
+
this.setExpanded(false);
|
|
267
|
+
}
|
|
268
|
+
});
|
|
269
|
+
}
|
|
270
|
+
}
|
|
271
|
+
getDropdownListPositionsArray() {
|
|
272
|
+
return [
|
|
273
|
+
{
|
|
274
|
+
originX: 'start',
|
|
275
|
+
originY: 'bottom',
|
|
276
|
+
overlayX: 'start',
|
|
277
|
+
overlayY: 'top',
|
|
278
|
+
offsetY: 8, // 0.5rem gap below the trigger
|
|
279
|
+
},
|
|
280
|
+
{
|
|
281
|
+
originX: 'start',
|
|
282
|
+
originY: 'top',
|
|
283
|
+
overlayX: 'start',
|
|
284
|
+
overlayY: 'bottom',
|
|
285
|
+
offsetY: -8, // 0.5rem gap above the trigger
|
|
286
|
+
},
|
|
287
|
+
];
|
|
288
|
+
}
|
|
289
|
+
getScrollStrategy() {
|
|
290
|
+
return this.closeDropdownListOnScroll
|
|
291
|
+
? this.overlay.scrollStrategies.close()
|
|
292
|
+
: this.overlay.scrollStrategies.reposition();
|
|
293
|
+
}
|
|
294
|
+
setOverlayWidth() {
|
|
295
|
+
if (this.overlayRef && this.toggleButton) {
|
|
296
|
+
const buttonWidth = this.toggleButton.nativeElement.offsetWidth;
|
|
297
|
+
const pane = this.overlayRef.overlayElement;
|
|
298
|
+
pane.style.width = `${buttonWidth}px`;
|
|
299
|
+
}
|
|
300
|
+
}
|
|
301
|
+
closeDropdownOverlay() {
|
|
302
|
+
this.overlayRef?.detach();
|
|
303
|
+
this.resizeSubscription?.unsubscribe();
|
|
304
|
+
this.overlayDetachSubscription?.unsubscribe();
|
|
212
305
|
}
|
|
213
306
|
/* TYPE CASTS */
|
|
214
307
|
/**
|
|
@@ -233,12 +326,12 @@ export class NggvDropdownComponent extends NggvBaseControlValueAccessorComponent
|
|
|
233
326
|
isOption(option) {
|
|
234
327
|
return !('options' in option);
|
|
235
328
|
}
|
|
236
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: NggvDropdownComponent, deps: [{ token: i1.NgControl, optional: true, self: true }, { token: TRANSLOCO_SCOPE, optional: true }, { token: i0.ChangeDetectorRef }, { token: i2.DropdownUtils }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
237
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: NggvDropdownComponent, selector: "nggv-dropdown", inputs: { thook: "thook", size: "size", placeholder: "placeholder", ariaLabel: "ariaLabel", options: "options", scrollOffset: "scrollOffset", allowControlNullishOption: "allowControlNullishOption", textToHighlight: "textToHighlight", selectOnSingleOption: "selectOnSingleOption", selectWithSpace: "selectWithSpace", onlyHandleDistinctChanges: "onlyHandleDistinctChanges" }, outputs: { expandedChange: "expandedChange" }, host: { listeners: { "keyup": "onKeyUp($event)" }, properties: { "attr.data-thook": "this.thook", "class.small": "this.isSmall", "class.large": "this.isLarge" } }, queries: [{ propertyName: "selectedContentTpl", first: true, predicate: ["selectedTpl"], descendants: true, read: TemplateRef }, { propertyName: "optionContentTpl", first: true, predicate: ["optionTpl"], descendants: true, read: TemplateRef }, { propertyName: "groupLabelTpl", first: true, predicate: ["groupLabelTpl"], descendants: true, read: TemplateRef }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<!-- LABEL -->\n<ng-container *transloco=\"let t; read: scope\">\n <label\n [id]=\"id + '-label'\"\n class=\"gds-field-label hide-if-empty\"\n [attr.for]=\"id + '-toggle'\"\n *ngIf=\"labelContentTpl || label\"\n >\n <ng-template\n *ngTemplateOutlet=\"labelContentTpl || basicLabelContentTpl\"\n ></ng-template>\n <ng-template #basicLabelContentTpl>\n <!-- to trigger css:empty if no label was added -->\n <ng-container *ngIf=\"label\">\n {{ label }}\n <span\n *ngIf=\"optional === true || (required !== true && optional !== false)\"\n class=\"gds-field-label--optional\"\n >\n ({{ t('label.optional') }})\n </span>\n </ng-container>\n </ng-template>\n </label>\n\n <!-- DESCRIPTION -->\n <div class=\"description\" *ngIf=\"description\">{{ description }}</div>\n\n <!-- LOCKED INPUT -->\n <ng-container *ngIf=\"locked\">\n <ng-template\n *ngTemplateOutlet=\"\n lockedTpl || defaultLockedTpl;\n context: { $implicit: state }\n \"\n ></ng-template>\n <ng-template #defaultLockedTpl>\n <div\n [id]=\"id + '-input'\"\n class=\"nggv-field--locked\"\n [attr.name]=\"name\"\n [attr.value]=\"state\"\n [attr.role]=\"role\"\n [attr.aria-labelledby]=\"id + '-label ' + id + '-input'\"\n >\n <span *ngIf=\"!state\" class=\"unset-state\">-</span>\n <ng-container *ngIf=\"state\">\n <ng-template\n *ngTemplateOutlet=\"\n selectedContentTpl || defaultSelectedContentTpl;\n context: { $implicit: state }\n \"\n >\n </ng-template>\n </ng-container>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- INPUT -->\n <ng-container *ngIf=\"!locked\">\n <div class=\"gds-input-wrapper dropdown-wrapper\">\n <div #input [id]=\"id + '-input'\" class=\"dropdown\">\n <button\n [id]=\"id + '-toggle'\"\n [disabled]=\"disabled\"\n type=\"button\"\n class=\"nggv-field-dropdown__label toggle\"\n [class.nggv-field--error]=\"invalid\"\n role=\"combobox\"\n aria-owns=\"listbox\"\n aria-haspopup=\"listbox\"\n aria-controls=\"listbox\"\n [attr.data-thook]=\"thook + '-toggle'\"\n [attr.aria-expanded]=\"expanded\"\n [attr.aria-labelledby]=\"\n ariaLabel ? null : id + '-label ' + id + '-toggle'\n \"\n [attr.aria-label]=\"ariaLabel || null\"\n (click)=\"toggleDropdown()\"\n >\n <span>\n <ng-template\n *ngTemplateOutlet=\"\n selectedContentTpl || defaultSelectedContentTpl;\n context: { $implicit: state }\n \"\n >\n </ng-template>\n </span>\n </button>\n <nggv-dropdown-list\n #dropDownList\n [options]=\"options\"\n [scrollOffset]=\"scrollOffset\"\n [state]=\"state\"\n [expanded]=\"expanded\"\n [optionContentTpl]=\"optionContentTpl\"\n [groupLabelTpl]=\"groupLabelTpl\"\n [textToHighlight]=\"textToHighlight\"\n [onlyEmitDistinctChanges]=\"onlyHandleDistinctChanges\"\n [selectWithSpace]=\"selectWithSpace\"\n [dynamicPosition]=\"true\"\n (closed)=\"setExpanded(false)\"\n (selectedValueChanged)=\"onSelectChange($event)\"\n >\n </nggv-dropdown-list>\n </div>\n <!-- ERRORS -->\n <div class=\"gds-form-item__footer error-wrapper\">\n <span\n class=\"form-info form-info--error\"\n [attr.for]=\"id + '-input'\"\n *ngIf=\"invalid && (error || ngControl?.invalid)\"\n >\n <span class=\"error-icon\">\n <gds-icon-triangle-exclamation\n width=\"16\"\n height=\"16\"\n [solid]=\"true\"\n *nggCoreElement\n ></gds-icon-triangle-exclamation>\n </span>\n <span\n *ngIf=\"error; else errorsRef\"\n [attr.data-thook]=\"thook + '-errorlabel'\"\n >{{ error }}</span\n >\n </span>\n <ng-template #errorsRef>\n <span\n *ngIf=\"firstError as error\"\n [attr.data-thook]=\"thook + '-errorlabel'\"\n >\n {{ t('error.field' + error?.code, error?.params) }}\n </span>\n </ng-template>\n </div>\n <!-- CHILDREN -->\n <ng-content></ng-content>\n </div>\n </ng-container>\n\n <ng-template #defaultSelectedContentTpl let-state>\n <!-- eslint-disable-next-line @angular-eslint/template/eqeqeq -->\n {{ state?.key != null && state?.label ? t(state.label) : placeholder }}\n </ng-template>\n</ng-container>\n", styles: [":host{--sg-border-radius: .25rem;--sg-border-width: 1px;--sg-border-color: #868686;--text-primary-color: #333;--sg-form-control-bg: #fff;--grey-000: hsl(0 0% 100%);--grey-100: hsl(0, 0%, 97%);--grey-200: hsl(0, 0%, 91%);--grey-300: hsl(0, 0%, 87%);--grey-400: hsl(0, 0%, 81%);--grey-500: hsl(0, 0%, 68%);--grey-600: hsl(0, 0%, 53%);--grey-700: hsl(0, 0%, 29%);--grey-800: hsl(0, 0%, 20%);--grey-900: hsl(0, 0%, 10%);--grey-1000: hsl(0 0% 0%);display:flex;flex-direction:column;max-width:100%;position:relative;width:100%;z-index:0;position:initial}:host label{display:block;font-weight:500;line-height:1.25rem;width:100%}:host label+.gds-input-wrapper,:host label+.nggv-field--locked{margin-top:.5rem}:host .description{font-size:.875rem;margin-bottom:.5rem;line-height:1.25rem;width:100%}:host:not(:last-child){margin-bottom:1.5rem}:host .gds-form-item__header{display:flex}:host .gds-form-item__header .form-info{font-weight:400}:host .gds-form-item__header button.icon.small{margin-top:-.5rem;margin-right:-.5rem}:host .gds-form-item__labels{flex:1;margin-bottom:.5rem}:host .gds-form-item__labels .form-info{margin-bottom:0}:host .gds-form-item__labels .form-info a:link:not(.button,[aria-disabled]){color:#0062bc}:host .gds-form-item__labels>*{width:100%;display:block}:host .gds-form-item__expandable-info{overflow:hidden;font-size:.875rem;line-height:1.25rem;transition:height .3s cubic-bezier(.23,1,.32,1)}:host .gds-form-item__expandable-info>div{padding-bottom:.5rem}:host .gds-form-item__backdrop{position:absolute;inset:0;background:var(--gds-sys-color-base-100);border-radius:2px;z-index:-1;margin:-1rem;opacity:0;transition:all .3s cubic-bezier(.23,1,.32,1);border:1px solid transparent}@media (prefers-reduced-motion: reduce){:host .gds-form-item__backdrop{transition:none}}:host:has([aria-expanded=true]) .gds-form-item__backdrop{opacity:1;border-radius:.25rem;border-color:var(--gds-sys-color-base-600)}:host .gds-form-item__footer:not(:empty){margin-top:.5rem;display:flex;column-gap:.5rem}:host .gds-form-item__footer:not(:empty)>span,:host .gds-form-item__footer:not(:empty)>.form-info{font-weight:500;line-height:1.125}:host:not(:last-child){margin-bottom:unset}:host .gds-field-label--optional{font-weight:400}:host button{background-color:transparent;border:0;cursor:pointer;font-family:inherit;padding:0;padding:.75rem 1rem;border-radius:var(--sg-border-radius);border:solid var(--sg-border-width) var(--sg-border-color);--border-color: var(--grey-600);--sg-border-color: var(--grey-600);background:var(--sg-form-control-bg);color:var(--text-primary-color);min-height:2.75rem;display:flex;flex-wrap:nowrap;justify-content:space-between;align-items:center;max-width:100%;font-size:1rem;font-weight:400;line-height:1.125;text-align:left;width:100%}:host button:focus{outline-color:var(--gds-sys-color-focus-outline);outline-style:solid;outline-width:.125rem;outline-offset:.125rem}@media (max-width: 35.98em){:host button{min-width:100%}}:host button>span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}:host button:after{margin-left:.5rem;margin-right:.5rem;border-bottom:solid 2px var(--text-primary-color);border-left:solid 2px var(--text-primary-color);content:\"\";display:block;height:.5rem;width:.5rem;position:relative;top:-.15rem;transform:translate(75%) rotate3d(0,0,1,-45deg) scaleZ(-1);transition:transform .3s ease-in;flex-shrink:0}:host button[aria-expanded=true]:after{transform:translate(75%,6px) rotate3d(0,0,1,-45deg) scale3d(-1,-1,1)}:host button:hover:after{border-color:currentColor}:host button:disabled{--background: var(--grey-500)}:host button span{width:100%;white-space:nowrap;display:block;text-overflow:ellipsis}:host button.small{font-size:.875rem}:host button:hover{background:#e7e7e7}:host button:active{background:inherit;color:inherit;border-color:inherit}:host button:disabled,:host button.disabled{--text-primary-color: var(--grey-600);background:var(--grey-300);color:var(--grey-600);cursor:not-allowed}:host button.nggv-field--error{border-bottom:2px solid #9f000a}:host .gds-form-item__footer .form-info{font-weight:500;font-size:.875rem}:host .gds-form-item__footer .form-info--error{display:flex;align-items:flex-start;gap:.5em;color:#9f000a}:host .gds-form-item__footer .form-info--error .error-icon{align-items:center}:host .dropdown-wrapper{position:relative}:host .dropdown{width:100%;position:relative}:host .dropdown nggv-dropdown-list{width:100%}:host.small label{line-height:1rem;font-size:.875rem}:host.small label+.gds-input-wrapper,:host.small label+.nggv-field--locked{margin-top:.25rem}:host.small .description{font-size:.875rem;line-height:1rem;margin-bottom:.25rem}:host.small button{font-size:.875rem;line-height:1rem;padding:.38rem .5rem;min-height:2rem}:host.small .gds-form-item__footer:not(:empty){margin-top:.25rem}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i4.NggCoreElementDirective, selector: "[nggCoreElement]" }, { kind: "directive", type: i5.TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }, { kind: "component", type: i6.NggvDropdownListComponent, selector: "nggv-dropdown-list", inputs: ["expanded", "state", "scrollOffset", "optionContentTpl", "groupLabelTpl", "id", "thook", "options", "textToHighlight", "onlyEmitDistinctChanges", "selectWithSpace", "dynamicPosition"], outputs: ["selectedValueChanged", "closed"] }] }); }
|
|
329
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: NggvDropdownComponent, deps: [{ token: i1.NgControl, optional: true, self: true }, { token: TRANSLOCO_SCOPE, optional: true }, { token: i0.ChangeDetectorRef }, { token: i2.DropdownUtils }, { token: i3.Overlay }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
330
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: NggvDropdownComponent, selector: "nggv-dropdown", inputs: { thook: "thook", size: "size", placeholder: "placeholder", ariaLabel: "ariaLabel", options: "options", scrollOffset: "scrollOffset", allowControlNullishOption: "allowControlNullishOption", textToHighlight: "textToHighlight", selectOnSingleOption: "selectOnSingleOption", selectWithSpace: "selectWithSpace", onlyHandleDistinctChanges: "onlyHandleDistinctChanges", closeDropdownListOnScroll: "closeDropdownListOnScroll" }, outputs: { expandedChange: "expandedChange" }, host: { listeners: { "keyup": "onKeyUp($event)" }, properties: { "attr.data-thook": "this.thook", "class.small": "this.isSmall", "class.large": "this.isLarge" } }, queries: [{ propertyName: "selectedContentTpl", first: true, predicate: ["selectedTpl"], descendants: true, read: TemplateRef }, { propertyName: "optionContentTpl", first: true, predicate: ["optionTpl"], descendants: true, read: TemplateRef }, { propertyName: "groupLabelTpl", first: true, predicate: ["groupLabelTpl"], descendants: true, read: TemplateRef }], viewQueries: [{ propertyName: "dropdownTemplate", first: true, predicate: ["dropdownTemplate"], descendants: true }, { propertyName: "toggleButton", first: true, predicate: ["toggleButton"], descendants: true, read: ElementRef }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<!-- LABEL -->\n<ng-container *transloco=\"let t; read: scope\">\n <label\n [id]=\"id + '-label'\"\n class=\"gds-field-label hide-if-empty\"\n [attr.for]=\"id + '-toggle'\"\n *ngIf=\"labelContentTpl || label\"\n >\n <ng-template\n *ngTemplateOutlet=\"labelContentTpl || basicLabelContentTpl\"\n ></ng-template>\n <ng-template #basicLabelContentTpl>\n <!-- to trigger css:empty if no label was added -->\n <ng-container *ngIf=\"label\">\n {{ label }}\n <span\n *ngIf=\"optional === true || (required !== true && optional !== false)\"\n class=\"gds-field-label--optional\"\n >\n ({{ t('label.optional') }})\n </span>\n </ng-container>\n </ng-template>\n </label>\n\n <!-- DESCRIPTION -->\n <div class=\"description\" *ngIf=\"description\">{{ description }}</div>\n\n <!-- LOCKED INPUT -->\n <ng-container *ngIf=\"locked\">\n <ng-template\n *ngTemplateOutlet=\"\n lockedTpl || defaultLockedTpl;\n context: { $implicit: state }\n \"\n ></ng-template>\n <ng-template #defaultLockedTpl>\n <div\n [id]=\"id + '-input'\"\n class=\"nggv-field--locked\"\n [attr.name]=\"name\"\n [attr.value]=\"state\"\n [attr.role]=\"role\"\n [attr.aria-labelledby]=\"id + '-label ' + id + '-input'\"\n >\n <span *ngIf=\"!state\" class=\"unset-state\">-</span>\n <ng-container *ngIf=\"state\">\n <ng-template\n *ngTemplateOutlet=\"\n selectedContentTpl || defaultSelectedContentTpl;\n context: { $implicit: state }\n \"\n >\n </ng-template>\n </ng-container>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- INPUT -->\n <ng-container *ngIf=\"!locked\">\n <div class=\"gds-input-wrapper dropdown-wrapper\">\n <div #input [id]=\"id + '-input'\" class=\"dropdown\">\n <button\n #toggleButton\n [id]=\"id + '-toggle'\"\n [disabled]=\"disabled\"\n type=\"button\"\n class=\"nggv-field-dropdown__label toggle\"\n [class.nggv-field--error]=\"invalid\"\n role=\"combobox\"\n aria-owns=\"listbox\"\n aria-haspopup=\"listbox\"\n aria-controls=\"listbox\"\n [attr.data-thook]=\"thook + '-toggle'\"\n [attr.aria-expanded]=\"expanded\"\n [attr.aria-labelledby]=\"\n ariaLabel ? null : id + '-label ' + id + '-toggle'\n \"\n [attr.aria-label]=\"ariaLabel || null\"\n (click)=\"toggleDropdown()\"\n >\n <span>\n <ng-template\n *ngTemplateOutlet=\"\n selectedContentTpl || defaultSelectedContentTpl;\n context: { $implicit: state }\n \"\n >\n </ng-template>\n </span>\n </button>\n <ng-template #dropdownTemplate>\n <nggv-dropdown-list\n #dropDownList\n [options]=\"options\"\n [scrollOffset]=\"scrollOffset\"\n [state]=\"state\"\n [expanded]=\"expanded\"\n [optionContentTpl]=\"optionContentTpl\"\n [groupLabelTpl]=\"groupLabelTpl\"\n [textToHighlight]=\"textToHighlight\"\n [onlyEmitDistinctChanges]=\"onlyHandleDistinctChanges\"\n [selectWithSpace]=\"selectWithSpace\"\n [triggerRect]=\"triggerRect\"\n [useMargin]=\"false\"\n (closed)=\"setExpanded(false)\"\n (selectedValueChanged)=\"onSelectChange($event)\"\n >\n </nggv-dropdown-list>\n </ng-template>\n </div>\n <!-- ERRORS -->\n <div class=\"gds-form-item__footer error-wrapper\">\n <span\n class=\"form-info form-info--error\"\n [attr.for]=\"id + '-input'\"\n *ngIf=\"invalid && (error || ngControl?.invalid)\"\n >\n <span class=\"error-icon\">\n <gds-icon-triangle-exclamation\n width=\"16\"\n height=\"16\"\n [solid]=\"true\"\n *nggCoreElement\n ></gds-icon-triangle-exclamation>\n </span>\n <span\n *ngIf=\"error; else errorsRef\"\n [attr.data-thook]=\"thook + '-errorlabel'\"\n >{{ error }}</span\n >\n </span>\n <ng-template #errorsRef>\n <span\n *ngIf=\"firstError as error\"\n [attr.data-thook]=\"thook + '-errorlabel'\"\n >\n {{ t('error.field' + error?.code, error?.params) }}\n </span>\n </ng-template>\n </div>\n <!-- CHILDREN -->\n <ng-content></ng-content>\n </div>\n </ng-container>\n\n <ng-template #defaultSelectedContentTpl let-state>\n <!-- eslint-disable-next-line @angular-eslint/template/eqeqeq -->\n {{ state?.key != null && state?.label ? t(state.label) : placeholder }}\n </ng-template>\n</ng-container>\n", styles: [":host{--sg-border-radius: .25rem;--sg-border-width: 1px;--sg-border-color: #868686;--text-primary-color: #333;--sg-form-control-bg: #fff;--grey-000: hsl(0 0% 100%);--grey-100: hsl(0, 0%, 97%);--grey-200: hsl(0, 0%, 91%);--grey-300: hsl(0, 0%, 87%);--grey-400: hsl(0, 0%, 81%);--grey-500: hsl(0, 0%, 68%);--grey-600: hsl(0, 0%, 53%);--grey-700: hsl(0, 0%, 29%);--grey-800: hsl(0, 0%, 20%);--grey-900: hsl(0, 0%, 10%);--grey-1000: hsl(0 0% 0%);display:flex;flex-direction:column;max-width:100%;position:relative;width:100%;z-index:0;position:initial}:host label{display:block;font-weight:500;line-height:1.25rem;width:100%}:host label+.gds-input-wrapper,:host label+.nggv-field--locked{margin-top:.5rem}:host .description{font-size:.875rem;margin-bottom:.5rem;line-height:1.25rem;width:100%}:host:not(:last-child){margin-bottom:1.5rem}:host .gds-form-item__header{display:flex}:host .gds-form-item__header .form-info{font-weight:400}:host .gds-form-item__header button.icon.small{margin-top:-.5rem;margin-right:-.5rem}:host .gds-form-item__labels{flex:1;margin-bottom:.5rem}:host .gds-form-item__labels .form-info{margin-bottom:0}:host .gds-form-item__labels .form-info a:link:not(.button,[aria-disabled]){color:#0062bc}:host .gds-form-item__labels>*{width:100%;display:block}:host .gds-form-item__expandable-info{overflow:hidden;font-size:.875rem;line-height:1.25rem;transition:height .3s cubic-bezier(.23,1,.32,1)}:host .gds-form-item__expandable-info>div{padding-bottom:.5rem}:host .gds-form-item__backdrop{position:absolute;inset:0;background:var(--gds-sys-color-base-100);border-radius:2px;z-index:-1;margin:-1rem;opacity:0;transition:all .3s cubic-bezier(.23,1,.32,1);border:1px solid transparent}@media (prefers-reduced-motion: reduce){:host .gds-form-item__backdrop{transition:none}}:host:has([aria-expanded=true]) .gds-form-item__backdrop{opacity:1;border-radius:.25rem;border-color:var(--gds-sys-color-base-600)}:host .gds-form-item__footer:not(:empty){margin-top:.5rem;display:flex;column-gap:.5rem}:host .gds-form-item__footer:not(:empty)>span,:host .gds-form-item__footer:not(:empty)>.form-info{font-weight:500;line-height:1.125}:host:not(:last-child){margin-bottom:unset}:host .gds-field-label--optional{font-weight:400}:host button{background-color:transparent;border:0;cursor:pointer;font-family:inherit;padding:0;padding:.75rem 1rem;border-radius:var(--sg-border-radius);border:solid var(--sg-border-width) var(--sg-border-color);--border-color: var(--grey-600);--sg-border-color: var(--grey-600);background:var(--sg-form-control-bg);color:var(--text-primary-color);min-height:2.75rem;display:flex;flex-wrap:nowrap;justify-content:space-between;align-items:center;max-width:100%;font-size:1rem;font-weight:400;line-height:1.125;text-align:left;width:100%}:host button:focus{outline-color:var(--gds-sys-color-focus-outline);outline-style:solid;outline-width:.125rem;outline-offset:.125rem}@media (max-width: 35.98em){:host button{min-width:100%}}:host button>span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}:host button:after{margin-left:.5rem;margin-right:.5rem;border-bottom:solid 2px var(--text-primary-color);border-left:solid 2px var(--text-primary-color);content:\"\";display:block;height:.5rem;width:.5rem;position:relative;top:-.15rem;transform:translate(75%) rotate3d(0,0,1,-45deg) scaleZ(-1);transition:transform .3s ease-in;flex-shrink:0}:host button[aria-expanded=true]:after{transform:translate(75%,6px) rotate3d(0,0,1,-45deg) scale3d(-1,-1,1)}:host button:hover:after{border-color:currentColor}:host button:disabled{--background: var(--grey-500)}:host button span{width:100%;white-space:nowrap;display:block;text-overflow:ellipsis}:host button.small{font-size:.875rem}:host button:hover{background:#e7e7e7}:host button:active{background:inherit;color:inherit;border-color:inherit}:host button:disabled,:host button.disabled{--text-primary-color: var(--grey-600);background:var(--grey-300);color:var(--grey-600);cursor:not-allowed}:host button.nggv-field--error{border-bottom:2px solid #9f000a}:host .gds-form-item__footer .form-info{font-weight:500;font-size:.875rem}:host .gds-form-item__footer .form-info--error{display:flex;align-items:flex-start;gap:.5em;color:#9f000a}:host .gds-form-item__footer .form-info--error .error-icon{align-items:center}:host .dropdown-wrapper{position:relative}:host .dropdown{width:100%;position:relative}:host .dropdown nggv-dropdown-list{width:100%}:host.small label{line-height:1rem;font-size:.875rem}:host.small label+.gds-input-wrapper,:host.small label+.nggv-field--locked{margin-top:.25rem}:host.small .description{font-size:.875rem;line-height:1rem;margin-bottom:.25rem}:host.small button{font-size:.875rem;line-height:1rem;padding:.38rem .5rem;min-height:2rem}:host.small .gds-form-item__footer:not(:empty){margin-top:.25rem}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i5.NggCoreElementDirective, selector: "[nggCoreElement]" }, { kind: "directive", type: i6.TranslocoDirective, selector: "[transloco]", inputs: ["transloco", "translocoParams", "translocoScope", "translocoRead", "translocoPrefix", "translocoLang", "translocoLoadingTpl"] }, { kind: "component", type: i7.NggvDropdownListComponent, selector: "nggv-dropdown-list", inputs: ["expanded", "state", "scrollOffset", "optionContentTpl", "groupLabelTpl", "id", "thook", "options", "textToHighlight", "onlyEmitDistinctChanges", "selectWithSpace", "dynamicPosition", "triggerRect", "useMargin"], outputs: ["selectedValueChanged", "closed"] }] }); }
|
|
238
331
|
}
|
|
239
332
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: NggvDropdownComponent, decorators: [{
|
|
240
333
|
type: Component,
|
|
241
|
-
args: [{ selector: 'nggv-dropdown', template: "<!-- LABEL -->\n<ng-container *transloco=\"let t; read: scope\">\n <label\n [id]=\"id + '-label'\"\n class=\"gds-field-label hide-if-empty\"\n [attr.for]=\"id + '-toggle'\"\n *ngIf=\"labelContentTpl || label\"\n >\n <ng-template\n *ngTemplateOutlet=\"labelContentTpl || basicLabelContentTpl\"\n ></ng-template>\n <ng-template #basicLabelContentTpl>\n <!-- to trigger css:empty if no label was added -->\n <ng-container *ngIf=\"label\">\n {{ label }}\n <span\n *ngIf=\"optional === true || (required !== true && optional !== false)\"\n class=\"gds-field-label--optional\"\n >\n ({{ t('label.optional') }})\n </span>\n </ng-container>\n </ng-template>\n </label>\n\n <!-- DESCRIPTION -->\n <div class=\"description\" *ngIf=\"description\">{{ description }}</div>\n\n <!-- LOCKED INPUT -->\n <ng-container *ngIf=\"locked\">\n <ng-template\n *ngTemplateOutlet=\"\n lockedTpl || defaultLockedTpl;\n context: { $implicit: state }\n \"\n ></ng-template>\n <ng-template #defaultLockedTpl>\n <div\n [id]=\"id + '-input'\"\n class=\"nggv-field--locked\"\n [attr.name]=\"name\"\n [attr.value]=\"state\"\n [attr.role]=\"role\"\n [attr.aria-labelledby]=\"id + '-label ' + id + '-input'\"\n >\n <span *ngIf=\"!state\" class=\"unset-state\">-</span>\n <ng-container *ngIf=\"state\">\n <ng-template\n *ngTemplateOutlet=\"\n selectedContentTpl || defaultSelectedContentTpl;\n context: { $implicit: state }\n \"\n >\n </ng-template>\n </ng-container>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- INPUT -->\n <ng-container *ngIf=\"!locked\">\n <div class=\"gds-input-wrapper dropdown-wrapper\">\n <div #input [id]=\"id + '-input'\" class=\"dropdown\">\n <button\n [id]=\"id + '-toggle'\"\n [disabled]=\"disabled\"\n type=\"button\"\n class=\"nggv-field-dropdown__label toggle\"\n [class.nggv-field--error]=\"invalid\"\n role=\"combobox\"\n aria-owns=\"listbox\"\n aria-haspopup=\"listbox\"\n aria-controls=\"listbox\"\n [attr.data-thook]=\"thook + '-toggle'\"\n [attr.aria-expanded]=\"expanded\"\n [attr.aria-labelledby]=\"\n ariaLabel ? null : id + '-label ' + id + '-toggle'\n \"\n [attr.aria-label]=\"ariaLabel || null\"\n (click)=\"toggleDropdown()\"\n >\n <span>\n <ng-template\n *ngTemplateOutlet=\"\n selectedContentTpl || defaultSelectedContentTpl;\n context: { $implicit: state }\n \"\n >\n </ng-template>\n </span>\n </button>\n <nggv-dropdown-list\n
|
|
334
|
+
args: [{ selector: 'nggv-dropdown', template: "<!-- LABEL -->\n<ng-container *transloco=\"let t; read: scope\">\n <label\n [id]=\"id + '-label'\"\n class=\"gds-field-label hide-if-empty\"\n [attr.for]=\"id + '-toggle'\"\n *ngIf=\"labelContentTpl || label\"\n >\n <ng-template\n *ngTemplateOutlet=\"labelContentTpl || basicLabelContentTpl\"\n ></ng-template>\n <ng-template #basicLabelContentTpl>\n <!-- to trigger css:empty if no label was added -->\n <ng-container *ngIf=\"label\">\n {{ label }}\n <span\n *ngIf=\"optional === true || (required !== true && optional !== false)\"\n class=\"gds-field-label--optional\"\n >\n ({{ t('label.optional') }})\n </span>\n </ng-container>\n </ng-template>\n </label>\n\n <!-- DESCRIPTION -->\n <div class=\"description\" *ngIf=\"description\">{{ description }}</div>\n\n <!-- LOCKED INPUT -->\n <ng-container *ngIf=\"locked\">\n <ng-template\n *ngTemplateOutlet=\"\n lockedTpl || defaultLockedTpl;\n context: { $implicit: state }\n \"\n ></ng-template>\n <ng-template #defaultLockedTpl>\n <div\n [id]=\"id + '-input'\"\n class=\"nggv-field--locked\"\n [attr.name]=\"name\"\n [attr.value]=\"state\"\n [attr.role]=\"role\"\n [attr.aria-labelledby]=\"id + '-label ' + id + '-input'\"\n >\n <span *ngIf=\"!state\" class=\"unset-state\">-</span>\n <ng-container *ngIf=\"state\">\n <ng-template\n *ngTemplateOutlet=\"\n selectedContentTpl || defaultSelectedContentTpl;\n context: { $implicit: state }\n \"\n >\n </ng-template>\n </ng-container>\n </div>\n </ng-template>\n </ng-container>\n\n <!-- INPUT -->\n <ng-container *ngIf=\"!locked\">\n <div class=\"gds-input-wrapper dropdown-wrapper\">\n <div #input [id]=\"id + '-input'\" class=\"dropdown\">\n <button\n #toggleButton\n [id]=\"id + '-toggle'\"\n [disabled]=\"disabled\"\n type=\"button\"\n class=\"nggv-field-dropdown__label toggle\"\n [class.nggv-field--error]=\"invalid\"\n role=\"combobox\"\n aria-owns=\"listbox\"\n aria-haspopup=\"listbox\"\n aria-controls=\"listbox\"\n [attr.data-thook]=\"thook + '-toggle'\"\n [attr.aria-expanded]=\"expanded\"\n [attr.aria-labelledby]=\"\n ariaLabel ? null : id + '-label ' + id + '-toggle'\n \"\n [attr.aria-label]=\"ariaLabel || null\"\n (click)=\"toggleDropdown()\"\n >\n <span>\n <ng-template\n *ngTemplateOutlet=\"\n selectedContentTpl || defaultSelectedContentTpl;\n context: { $implicit: state }\n \"\n >\n </ng-template>\n </span>\n </button>\n <ng-template #dropdownTemplate>\n <nggv-dropdown-list\n #dropDownList\n [options]=\"options\"\n [scrollOffset]=\"scrollOffset\"\n [state]=\"state\"\n [expanded]=\"expanded\"\n [optionContentTpl]=\"optionContentTpl\"\n [groupLabelTpl]=\"groupLabelTpl\"\n [textToHighlight]=\"textToHighlight\"\n [onlyEmitDistinctChanges]=\"onlyHandleDistinctChanges\"\n [selectWithSpace]=\"selectWithSpace\"\n [triggerRect]=\"triggerRect\"\n [useMargin]=\"false\"\n (closed)=\"setExpanded(false)\"\n (selectedValueChanged)=\"onSelectChange($event)\"\n >\n </nggv-dropdown-list>\n </ng-template>\n </div>\n <!-- ERRORS -->\n <div class=\"gds-form-item__footer error-wrapper\">\n <span\n class=\"form-info form-info--error\"\n [attr.for]=\"id + '-input'\"\n *ngIf=\"invalid && (error || ngControl?.invalid)\"\n >\n <span class=\"error-icon\">\n <gds-icon-triangle-exclamation\n width=\"16\"\n height=\"16\"\n [solid]=\"true\"\n *nggCoreElement\n ></gds-icon-triangle-exclamation>\n </span>\n <span\n *ngIf=\"error; else errorsRef\"\n [attr.data-thook]=\"thook + '-errorlabel'\"\n >{{ error }}</span\n >\n </span>\n <ng-template #errorsRef>\n <span\n *ngIf=\"firstError as error\"\n [attr.data-thook]=\"thook + '-errorlabel'\"\n >\n {{ t('error.field' + error?.code, error?.params) }}\n </span>\n </ng-template>\n </div>\n <!-- CHILDREN -->\n <ng-content></ng-content>\n </div>\n </ng-container>\n\n <ng-template #defaultSelectedContentTpl let-state>\n <!-- eslint-disable-next-line @angular-eslint/template/eqeqeq -->\n {{ state?.key != null && state?.label ? t(state.label) : placeholder }}\n </ng-template>\n</ng-container>\n", styles: [":host{--sg-border-radius: .25rem;--sg-border-width: 1px;--sg-border-color: #868686;--text-primary-color: #333;--sg-form-control-bg: #fff;--grey-000: hsl(0 0% 100%);--grey-100: hsl(0, 0%, 97%);--grey-200: hsl(0, 0%, 91%);--grey-300: hsl(0, 0%, 87%);--grey-400: hsl(0, 0%, 81%);--grey-500: hsl(0, 0%, 68%);--grey-600: hsl(0, 0%, 53%);--grey-700: hsl(0, 0%, 29%);--grey-800: hsl(0, 0%, 20%);--grey-900: hsl(0, 0%, 10%);--grey-1000: hsl(0 0% 0%);display:flex;flex-direction:column;max-width:100%;position:relative;width:100%;z-index:0;position:initial}:host label{display:block;font-weight:500;line-height:1.25rem;width:100%}:host label+.gds-input-wrapper,:host label+.nggv-field--locked{margin-top:.5rem}:host .description{font-size:.875rem;margin-bottom:.5rem;line-height:1.25rem;width:100%}:host:not(:last-child){margin-bottom:1.5rem}:host .gds-form-item__header{display:flex}:host .gds-form-item__header .form-info{font-weight:400}:host .gds-form-item__header button.icon.small{margin-top:-.5rem;margin-right:-.5rem}:host .gds-form-item__labels{flex:1;margin-bottom:.5rem}:host .gds-form-item__labels .form-info{margin-bottom:0}:host .gds-form-item__labels .form-info a:link:not(.button,[aria-disabled]){color:#0062bc}:host .gds-form-item__labels>*{width:100%;display:block}:host .gds-form-item__expandable-info{overflow:hidden;font-size:.875rem;line-height:1.25rem;transition:height .3s cubic-bezier(.23,1,.32,1)}:host .gds-form-item__expandable-info>div{padding-bottom:.5rem}:host .gds-form-item__backdrop{position:absolute;inset:0;background:var(--gds-sys-color-base-100);border-radius:2px;z-index:-1;margin:-1rem;opacity:0;transition:all .3s cubic-bezier(.23,1,.32,1);border:1px solid transparent}@media (prefers-reduced-motion: reduce){:host .gds-form-item__backdrop{transition:none}}:host:has([aria-expanded=true]) .gds-form-item__backdrop{opacity:1;border-radius:.25rem;border-color:var(--gds-sys-color-base-600)}:host .gds-form-item__footer:not(:empty){margin-top:.5rem;display:flex;column-gap:.5rem}:host .gds-form-item__footer:not(:empty)>span,:host .gds-form-item__footer:not(:empty)>.form-info{font-weight:500;line-height:1.125}:host:not(:last-child){margin-bottom:unset}:host .gds-field-label--optional{font-weight:400}:host button{background-color:transparent;border:0;cursor:pointer;font-family:inherit;padding:0;padding:.75rem 1rem;border-radius:var(--sg-border-radius);border:solid var(--sg-border-width) var(--sg-border-color);--border-color: var(--grey-600);--sg-border-color: var(--grey-600);background:var(--sg-form-control-bg);color:var(--text-primary-color);min-height:2.75rem;display:flex;flex-wrap:nowrap;justify-content:space-between;align-items:center;max-width:100%;font-size:1rem;font-weight:400;line-height:1.125;text-align:left;width:100%}:host button:focus{outline-color:var(--gds-sys-color-focus-outline);outline-style:solid;outline-width:.125rem;outline-offset:.125rem}@media (max-width: 35.98em){:host button{min-width:100%}}:host button>span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}:host button:after{margin-left:.5rem;margin-right:.5rem;border-bottom:solid 2px var(--text-primary-color);border-left:solid 2px var(--text-primary-color);content:\"\";display:block;height:.5rem;width:.5rem;position:relative;top:-.15rem;transform:translate(75%) rotate3d(0,0,1,-45deg) scaleZ(-1);transition:transform .3s ease-in;flex-shrink:0}:host button[aria-expanded=true]:after{transform:translate(75%,6px) rotate3d(0,0,1,-45deg) scale3d(-1,-1,1)}:host button:hover:after{border-color:currentColor}:host button:disabled{--background: var(--grey-500)}:host button span{width:100%;white-space:nowrap;display:block;text-overflow:ellipsis}:host button.small{font-size:.875rem}:host button:hover{background:#e7e7e7}:host button:active{background:inherit;color:inherit;border-color:inherit}:host button:disabled,:host button.disabled{--text-primary-color: var(--grey-600);background:var(--grey-300);color:var(--grey-600);cursor:not-allowed}:host button.nggv-field--error{border-bottom:2px solid #9f000a}:host .gds-form-item__footer .form-info{font-weight:500;font-size:.875rem}:host .gds-form-item__footer .form-info--error{display:flex;align-items:flex-start;gap:.5em;color:#9f000a}:host .gds-form-item__footer .form-info--error .error-icon{align-items:center}:host .dropdown-wrapper{position:relative}:host .dropdown{width:100%;position:relative}:host .dropdown nggv-dropdown-list{width:100%}:host.small label{line-height:1rem;font-size:.875rem}:host.small label+.gds-input-wrapper,:host.small label+.nggv-field--locked{margin-top:.25rem}:host.small .description{font-size:.875rem;line-height:1rem;margin-bottom:.25rem}:host.small button{font-size:.875rem;line-height:1rem;padding:.38rem .5rem;min-height:2rem}:host.small .gds-form-item__footer:not(:empty){margin-top:.25rem}\n"] }]
|
|
242
335
|
}], ctorParameters: () => [{ type: i1.NgControl, decorators: [{
|
|
243
336
|
type: Self
|
|
244
337
|
}, {
|
|
@@ -248,7 +341,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
248
341
|
}, {
|
|
249
342
|
type: Inject,
|
|
250
343
|
args: [TRANSLOCO_SCOPE]
|
|
251
|
-
}] }, { type: i0.ChangeDetectorRef }, { type: i2.DropdownUtils }], propDecorators: { selectedContentTpl: [{
|
|
344
|
+
}] }, { type: i0.ChangeDetectorRef }, { type: i2.DropdownUtils }, { type: i3.Overlay }, { type: i0.ViewContainerRef }], propDecorators: { selectedContentTpl: [{
|
|
252
345
|
type: ContentChild,
|
|
253
346
|
args: ['selectedTpl', { read: TemplateRef }]
|
|
254
347
|
}], optionContentTpl: [{
|
|
@@ -268,6 +361,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
268
361
|
}], isLarge: [{
|
|
269
362
|
type: HostBinding,
|
|
270
363
|
args: ['class.large']
|
|
364
|
+
}], dropdownTemplate: [{
|
|
365
|
+
type: ViewChild,
|
|
366
|
+
args: ['dropdownTemplate']
|
|
367
|
+
}], toggleButton: [{
|
|
368
|
+
type: ViewChild,
|
|
369
|
+
args: ['toggleButton', { read: ElementRef }]
|
|
271
370
|
}], size: [{
|
|
272
371
|
type: Input
|
|
273
372
|
}], placeholder: [{
|
|
@@ -288,10 +387,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
288
387
|
type: Input
|
|
289
388
|
}], onlyHandleDistinctChanges: [{
|
|
290
389
|
type: Input
|
|
390
|
+
}], closeDropdownListOnScroll: [{
|
|
391
|
+
type: Input
|
|
291
392
|
}], expandedChange: [{
|
|
292
393
|
type: Output
|
|
293
394
|
}], onKeyUp: [{
|
|
294
395
|
type: HostListener,
|
|
295
396
|
args: ['keyup', ['$event']]
|
|
296
397
|
}] } });
|
|
297
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular/src/v-angular/dropdown/dropdown.component.ts","../../../../../../../libs/angular/src/v-angular/dropdown/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import '@sebgroup/green-core/components/icon/icons/triangle-exclamation.js'\n\nimport {\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  EventEmitter,\n  HostBinding,\n  HostListener,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Optional,\n  Output,\n  Self,\n  SimpleChanges,\n  TemplateRef,\n} from '@angular/core'\nimport { NgControl } from '@angular/forms'\nimport { TRANSLOCO_SCOPE, TranslocoScope } from '@jsverse/transloco'\nimport { fromEvent, Subscription } from 'rxjs'\n\nimport { NggvBaseControlValueAccessorComponent } from '@sebgroup/green-angular/src/v-angular/base-control-value-accessor'\nimport {\n  DropdownUtils,\n  Option,\n  OptionBase,\n  OptionGroup,\n} from '@sebgroup/green-angular/src/v-angular/core'\n\n/**\n * A dropdown allows the user to select an option from a list.\n * Dropdowns enables users to make a quick selection of the available options for a specific entry.\n * https://designlibrary.sebgroup.com/components/component-dropdown\n */\n@Component({\n  selector: 'nggv-dropdown',\n  templateUrl: './dropdown.component.html',\n  styleUrls: ['./dropdown.component.scss'],\n})\nexport class NggvDropdownComponent<\n    K = string | null | undefined,\n    V = string | null | undefined,\n    T extends Option<K, V> = Option<K, V>,\n  >\n  extends NggvBaseControlValueAccessorComponent\n  implements OnDestroy, OnChanges\n{\n  /** Custom template for displaying options and groups. */\n  @ContentChild('selectedTpl', { read: TemplateRef }) selectedContentTpl:\n    | TemplateRef<OptionBase<T>>\n    | undefined\n  @ContentChild('optionTpl', { read: TemplateRef }) optionContentTpl:\n    | TemplateRef<OptionBase<any>>\n    | undefined\n  @ContentChild('groupLabelTpl', { read: TemplateRef }) groupLabelTpl:\n    | TemplateRef<OptionBase<any>>\n    | undefined\n\n  /**\n   * Special property used for selecting DOM elements during automated UI testing.\n   */\n  @HostBinding('attr.data-thook') @Input() thook: string | null | undefined =\n    'dropdown'\n\n  @HostBinding('class.small') get isSmall(): boolean {\n    return this.size === 'small'\n  }\n\n  @HostBinding('class.large') get isLarge(): boolean {\n    return this.size === 'large'\n  }\n\n  /**\n   * Sets the displayed size of the dropdown.\n   */\n  @Input() size: 'small' | 'large' = 'large'\n\n  /** Text shown before an option is selected. */\n  @Input() placeholder?: string\n  /** Specific value for aria-label. If not provided, label/labelTpl will be used. */\n  @Input() ariaLabel?: string\n  /** List of {@link Option} and {@link OptionGroup} listed when dropdown is expanded. */\n  @Input() set options(value: OptionBase<T>[]) {\n    // update options\n    this._options = value\n    // already has a null/undefined key\n    const nullishOption = this.dropdownUtils\n      .flattenOptions(value, false)\n      .find((option) => option.key == null)\n    // if the dropdown is optional, add a null value to deselect option\n    if (!this.required && !nullishOption && this.allowControlNullishOption) {\n      this._options = [this.defaultNullishOption].concat(this._options)\n    }\n\n    // set default value and emit if there is only one option\n    if (value.length === 1 && this.required && this.selectOnSingleOption) {\n      const onlyOption = this.dropdownUtils.flattenOptions(value, false)[0]\n      this.updateModel(onlyOption)\n      return\n    }\n\n    // don't update local state if we shouldn't control nullish value and we cant find the selected value amongst the options\n    const matchingOption = this.dropdownUtils\n      .flattenOptions(value, false)\n      .find((option) => option.key == this.ngControl?.value)\n    if (!this.allowControlNullishOption && !matchingOption) return\n\n    // Update local state\n    this.writeValue(this.ngControl?.value)\n  }\n\n  get options(): OptionBase<T>[] {\n    return this._options\n  }\n\n  /** The additional amount to show when option is scrolled into view. */\n  @Input() scrollOffset = 24\n\n  /**\n   * Allow this component to add/ remove nullish options based on wether the control is required or not\n   * Defaults to true.\n   */\n  @Input() allowControlNullishOption = true\n\n  /** Text to highlight in option */\n  @Input() textToHighlight?: string\n\n  /**\n   * If only one option exists in options[], default is to select it.\n   * This input can be used to alter that behaviour so it doesn't automatically\n   * select a value if it's the only one.\n   * Defaults to true.\n   */\n  @Input() selectOnSingleOption = true\n\n  /**\n   * Used to control if the dropdown list should select the current active element, when Space is pressed on the keyboard.\n   * Primary usage is for typeahead, where the should be able to write a filter query containing spaces,\n   * but not select the current active element with Space.\n   */\n  @Input() selectWithSpace = true\n\n  /**\n   * Used to determine which changes should be handled by the dropdown.\n   * If set to false, all changes will be handled by the dropdown.\n   * If set to true, only changes that are distinct from the current value will be handled.\n   * Defaults to true.\n   */\n  @Input() onlyHandleDistinctChanges = true\n\n  /**\n   * Emits changes of the expanded state of the dropdown\n   */\n  @Output() expandedChange = new EventEmitter<boolean>()\n\n  /** @internal nullish option. */\n  get defaultNullishOption(): OptionBase<any> {\n    return { key: null, label: this.placeholder ?? '\\u00A0' }\n  }\n\n  /** The current expanded state of the dropdown options. */\n  public expanded = false\n  /** The current option selected based on numeric index. */\n  public activeIndex = -1\n  /** Subscribe if dropdown expanded to listen to click outside to close dropdown. */\n  private onClickSubscription: Subscription | undefined\n  /** Subscribe if dropdown expanded to listen to scroll outside to close dropdown. */\n  private onScrollSubscription: Subscription | undefined\n\n  public keyEvent: KeyboardEvent = {} as KeyboardEvent\n  private _options: OptionBase<T>[] = []\n\n  constructor(\n    @Self() @Optional() public ngControl: NgControl,\n    @Optional()\n    @Inject(TRANSLOCO_SCOPE)\n    protected translocoScope: TranslocoScope,\n    protected cdr: ChangeDetectorRef,\n    protected dropdownUtils: DropdownUtils<K, V, T>,\n  ) {\n    super(ngControl, translocoScope, cdr)\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.required?.currentValue !== undefined) {\n      const isRequired = changes.required.currentValue\n      // remove nullish option\n      const hasNullishOption =\n        this.dropdownUtils.flattenOptions(this._options, false)[0]?.key == null\n      // if required, remove nullish option\n      if (isRequired && hasNullishOption && this.allowControlNullishOption) {\n        this._options = this._options.slice(1)\n        return\n      }\n      // if not required, add nullish option\n      if (!isRequired && !hasNullishOption && this.allowControlNullishOption) {\n        this._options = [this.defaultNullishOption].concat(this._options)\n        return\n      }\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.onClickSubscription?.unsubscribe()\n    this.onScrollSubscription?.unsubscribe()\n  }\n\n  /** @internal override to correctly set state from form value */\n  writeValue(value: any): void {\n    const options = this.dropdownUtils.flattenOptions(this._options, false)\n    this.state = options.find((option) => option.key === value)\n  }\n\n  // ----------------------------------------------------------------------------\n  // EVENTS\n  // ----------------------------------------------------------------------------\n\n  /** @internal */\n  onSelectChange(option: T) {\n    if (option.disabled) return\n    this.updateModel(option)\n    this.setExpanded(false)\n  }\n\n  // /**\n  //  * @internal\n  //  * Enter toggles the dropdown, home, end, and, arrows change the index.\n  //  * @param event fired containing which key was released.\n  //  */\n  @HostListener('keyup', ['$event'])\n  onKeyUp(event: KeyboardEvent) {\n    this.keyEvent = event\n  }\n\n  /**\n   * Closes the dropdown on click outside.\n   */\n  subscribeToOutsideClickEvent() {\n    this.onClickSubscription = fromEvent(document, 'click').subscribe({\n      next: (event: Event) => {\n        if (\n          this.expanded &&\n          !this.inputRef?.nativeElement.contains(event.target)\n        ) {\n          this.toggleDropdown()\n          this.onClickSubscription?.unsubscribe()\n        }\n      },\n    })\n  }\n  subscribeToOutsideScrollEvent() {\n    this.onScrollSubscription = fromEvent(document, 'scroll').subscribe({\n      next: (event: Event) => {\n        if (\n          this.expanded &&\n          !this.inputRef?.nativeElement.contains(event.target)\n        ) {\n          this.toggleDropdown()\n          this.onScrollSubscription?.unsubscribe()\n        }\n      },\n    })\n  }\n\n  // ----------------------------------------------------------------------------\n  // HELPERS\n  // ----------------------------------------------------------------------------\n\n  /**\n   * Set the dropdown value to given option.\n   * @param value the dropdown option to select.\n   */\n  private updateModel(value: T) {\n    this.state = value\n    this.onChange(value.key)\n  }\n\n  /** Toggle the expanded state of the dropdown options. */\n  toggleDropdown() {\n    this.setExpanded(!this.expanded)\n    this.cdr.detectChanges()\n  }\n\n  /**\n   * Set the expanded state of the dropdown options. If true the options are shown below the field.\n   * Activate on click event to be able to close dropdown on click outside.\n   * @param state the expanded state which to set.\n   */\n  setExpanded(state = true) {\n    this.expanded = state\n    this.expandedChange.emit(this.expanded)\n    if (this.expanded) {\n      this.subscribeToOutsideClickEvent()\n      this.subscribeToOutsideScrollEvent()\n    }\n    if (!this.expanded) this.onTouched()\n  }\n\n  /* TYPE CASTS */\n\n  /**\n   * Typecast anything to an {@link Option}.\n   * @param option the object to typecast.\n   */\n  castOption(option: any): T {\n    return option\n  }\n\n  /**\n   * Typecast anything to an {@link OptionGroup}.\n   * @param group the object to typecast.\n   */\n  castGroup(group: any): OptionGroup<T> {\n    return group\n  }\n\n  /* TYPE CHECKS */\n\n  /**\n   * Returns true if argument is an {@link Option}.\n   * @param option the object to check.\n   */\n  isOption(option: OptionBase<T>): option is OptionGroup<T> {\n    return !('options' in option)\n  }\n}\n","<!-- LABEL -->\n<ng-container *transloco=\"let t; read: scope\">\n  <label\n    [id]=\"id + '-label'\"\n    class=\"gds-field-label hide-if-empty\"\n    [attr.for]=\"id + '-toggle'\"\n    *ngIf=\"labelContentTpl || label\"\n  >\n    <ng-template\n      *ngTemplateOutlet=\"labelContentTpl || basicLabelContentTpl\"\n    ></ng-template>\n    <ng-template #basicLabelContentTpl>\n      <!-- to trigger css:empty if no label was added -->\n      <ng-container *ngIf=\"label\">\n        {{ label }}\n        <span\n          *ngIf=\"optional === true || (required !== true && optional !== false)\"\n          class=\"gds-field-label--optional\"\n        >\n          ({{ t('label.optional') }})\n        </span>\n      </ng-container>\n    </ng-template>\n  </label>\n\n  <!-- DESCRIPTION -->\n  <div class=\"description\" *ngIf=\"description\">{{ description }}</div>\n\n  <!-- LOCKED INPUT -->\n  <ng-container *ngIf=\"locked\">\n    <ng-template\n      *ngTemplateOutlet=\"\n        lockedTpl || defaultLockedTpl;\n        context: { $implicit: state }\n      \"\n    ></ng-template>\n    <ng-template #defaultLockedTpl>\n      <div\n        [id]=\"id + '-input'\"\n        class=\"nggv-field--locked\"\n        [attr.name]=\"name\"\n        [attr.value]=\"state\"\n        [attr.role]=\"role\"\n        [attr.aria-labelledby]=\"id + '-label ' + id + '-input'\"\n      >\n        <span *ngIf=\"!state\" class=\"unset-state\">-</span>\n        <ng-container *ngIf=\"state\">\n          <ng-template\n            *ngTemplateOutlet=\"\n              selectedContentTpl || defaultSelectedContentTpl;\n              context: { $implicit: state }\n            \"\n          >\n          </ng-template>\n        </ng-container>\n      </div>\n    </ng-template>\n  </ng-container>\n\n  <!-- INPUT -->\n  <ng-container *ngIf=\"!locked\">\n    <div class=\"gds-input-wrapper dropdown-wrapper\">\n      <div #input [id]=\"id + '-input'\" class=\"dropdown\">\n        <button\n          [id]=\"id + '-toggle'\"\n          [disabled]=\"disabled\"\n          type=\"button\"\n          class=\"nggv-field-dropdown__label toggle\"\n          [class.nggv-field--error]=\"invalid\"\n          role=\"combobox\"\n          aria-owns=\"listbox\"\n          aria-haspopup=\"listbox\"\n          aria-controls=\"listbox\"\n          [attr.data-thook]=\"thook + '-toggle'\"\n          [attr.aria-expanded]=\"expanded\"\n          [attr.aria-labelledby]=\"\n            ariaLabel ? null : id + '-label ' + id + '-toggle'\n          \"\n          [attr.aria-label]=\"ariaLabel || null\"\n          (click)=\"toggleDropdown()\"\n        >\n          <span>\n            <ng-template\n              *ngTemplateOutlet=\"\n                selectedContentTpl || defaultSelectedContentTpl;\n                context: { $implicit: state }\n              \"\n            >\n            </ng-template>\n          </span>\n        </button>\n        <nggv-dropdown-list\n          #dropDownList\n          [options]=\"options\"\n          [scrollOffset]=\"scrollOffset\"\n          [state]=\"state\"\n          [expanded]=\"expanded\"\n          [optionContentTpl]=\"optionContentTpl\"\n          [groupLabelTpl]=\"groupLabelTpl\"\n          [textToHighlight]=\"textToHighlight\"\n          [onlyEmitDistinctChanges]=\"onlyHandleDistinctChanges\"\n          [selectWithSpace]=\"selectWithSpace\"\n          [dynamicPosition]=\"true\"\n          (closed)=\"setExpanded(false)\"\n          (selectedValueChanged)=\"onSelectChange($event)\"\n        >\n        </nggv-dropdown-list>\n      </div>\n      <!-- ERRORS -->\n      <div class=\"gds-form-item__footer error-wrapper\">\n        <span\n          class=\"form-info form-info--error\"\n          [attr.for]=\"id + '-input'\"\n          *ngIf=\"invalid && (error || ngControl?.invalid)\"\n        >\n          <span class=\"error-icon\">\n            <gds-icon-triangle-exclamation\n              width=\"16\"\n              height=\"16\"\n              [solid]=\"true\"\n              *nggCoreElement\n            ></gds-icon-triangle-exclamation>\n          </span>\n          <span\n            *ngIf=\"error; else errorsRef\"\n            [attr.data-thook]=\"thook + '-errorlabel'\"\n            >{{ error }}</span\n          >\n        </span>\n        <ng-template #errorsRef>\n          <span\n            *ngIf=\"firstError as error\"\n            [attr.data-thook]=\"thook + '-errorlabel'\"\n          >\n            {{ t('error.field' + error?.code, error?.params) }}\n          </span>\n        </ng-template>\n      </div>\n      <!-- CHILDREN -->\n      <ng-content></ng-content>\n    </div>\n  </ng-container>\n\n  <ng-template #defaultSelectedContentTpl let-state>\n    <!-- eslint-disable-next-line @angular-eslint/template/eqeqeq -->\n    {{ state?.key != null && state?.label ? t(state.label) : placeholder }}\n  </ng-template>\n</ng-container>\n"]}
|
|
398
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../../libs/angular/src/v-angular/dropdown/dropdown.component.ts","../../../../../../../libs/angular/src/v-angular/dropdown/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["\n\n\nimport '@sebgroup/green-core/components/icon/icons/triangle-exclamation.js';\n\n\n\nimport { ConnectedPosition, Overlay, OverlayRef, ScrollStrategy } from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport { ChangeDetectorRef, Component, ContentChild, ElementRef, EventEmitter, HostBinding, HostListener, Inject, Input, OnChanges, OnDestroy, Optional, Output, Self, SimpleChanges, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';\nimport { NgControl } from '@angular/forms';\nimport { TRANSLOCO_SCOPE, TranslocoScope } from '@jsverse/transloco';\nimport { fromEvent, Subscription } from 'rxjs';\n\n\n\nimport { NggvBaseControlValueAccessorComponent } from '@sebgroup/green-angular/src/v-angular/base-control-value-accessor';\nimport { DropdownUtils, Option, OptionBase, OptionGroup } from '@sebgroup/green-angular/src/v-angular/core';\n\n\n\n\n\n/**\n * A dropdown allows the user to select an option from a list.\n * Dropdowns enables users to make a quick selection of the available options for a specific entry.\n * https://designlibrary.sebgroup.com/components/component-dropdown\n */\n@Component({\n  selector: 'nggv-dropdown',\n  templateUrl: './dropdown.component.html',\n  styleUrls: ['./dropdown.component.scss'],\n})\nexport class NggvDropdownComponent<\n    K = string | null | undefined,\n    V = string | null | undefined,\n    T extends Option<K, V> = Option<K, V>,\n  >\n  extends NggvBaseControlValueAccessorComponent\n  implements OnDestroy, OnChanges\n{\n  /** Custom template for displaying options and groups. */\n  @ContentChild('selectedTpl', { read: TemplateRef }) selectedContentTpl:\n    | TemplateRef<OptionBase<T>>\n    | undefined\n  @ContentChild('optionTpl', { read: TemplateRef }) optionContentTpl:\n    | TemplateRef<OptionBase<any>>\n    | undefined\n  @ContentChild('groupLabelTpl', { read: TemplateRef }) groupLabelTpl:\n    | TemplateRef<OptionBase<any>>\n    | undefined\n\n  /**\n   * Special property used for selecting DOM elements during automated UI testing.\n   */\n  @HostBinding('attr.data-thook') @Input() thook: string | null | undefined =\n    'dropdown'\n\n  @HostBinding('class.small') get isSmall(): boolean {\n    return this.size === 'small'\n  }\n\n  @HostBinding('class.large') get isLarge(): boolean {\n    return this.size === 'large'\n  }\n\n  /** Reference to the dropdown list template used for rendering the dropdown in an overlay. */\n  @ViewChild('dropdownTemplate') dropdownTemplate!: TemplateRef<any>\n  // Used for positioning and sizing the dropdown overlay relative to the trigger button.\n  @ViewChild('toggleButton', { read: ElementRef }) toggleButton!: ElementRef\n\n  /**\n   * Sets the displayed size of the dropdown.\n   */\n  @Input() size: 'small' | 'large' = 'large'\n\n  /** Text shown before an option is selected. */\n  @Input() placeholder?: string\n  /** Specific value for aria-label. If not provided, label/labelTpl will be used. */\n  @Input() ariaLabel?: string\n  /** List of {@link Option} and {@link OptionGroup} listed when dropdown is expanded. */\n  @Input() set options(value: OptionBase<T>[]) {\n    // update options\n    this._options = value\n    // already has a null/undefined key\n    const nullishOption = this.dropdownUtils\n      .flattenOptions(value, false)\n      .find((option) => option.key == null)\n    // if the dropdown is optional, add a null value to deselect option\n    if (!this.required && !nullishOption && this.allowControlNullishOption) {\n      this._options = [this.defaultNullishOption].concat(this._options)\n    }\n\n    // set default value and emit if there is only one option\n    if (value.length === 1 && this.required && this.selectOnSingleOption) {\n      const onlyOption = this.dropdownUtils.flattenOptions(value, false)[0]\n      this.updateModel(onlyOption)\n      return\n    }\n\n    // don't update local state if we shouldn't control nullish value and we cant find the selected value amongst the options\n    const matchingOption = this.dropdownUtils\n      .flattenOptions(value, false)\n      .find((option) => option.key == this.ngControl?.value)\n    if (!this.allowControlNullishOption && !matchingOption) return\n\n    // Update local state\n    this.writeValue(this.ngControl?.value)\n  }\n\n  get options(): OptionBase<T>[] {\n    return this._options\n  }\n\n  /** The additional amount to show when option is scrolled into view. */\n  @Input() scrollOffset = 24\n\n  /**\n   * Allow this component to add/ remove nullish options based on wether the control is required or not\n   * Defaults to true.\n   */\n  @Input() allowControlNullishOption = true\n\n  /** Text to highlight in option */\n  @Input() textToHighlight?: string\n\n  /**\n   * If only one option exists in options[], default is to select it.\n   * This input can be used to alter that behaviour so it doesn't automatically\n   * select a value if it's the only one.\n   * Defaults to true.\n   */\n  @Input() selectOnSingleOption = true\n\n  /**\n   * Used to control if the dropdown list should select the current active element, when Space is pressed on the keyboard.\n   * Primary usage is for typeahead, where the should be able to write a filter query containing spaces,\n   * but not select the current active element with Space.\n   */\n  @Input() selectWithSpace = true\n\n  /**\n   * Used to determine which changes should be handled by the dropdown.\n   * If set to false, all changes will be handled by the dropdown.\n   * If set to true, only changes that are distinct from the current value will be handled.\n   * Defaults to true.\n   */\n  @Input() onlyHandleDistinctChanges = true\n\n  /**\n   * If true (default), the dropdown list will close when any scrollable ancestor is scrolled.\n   * If false, the dropdown list will reposition itself instead of closing.\n   */\n  @Input() closeDropdownListOnScroll = true\n\n  /**\n   * Emits changes of the expanded state of the dropdown\n   */\n  @Output() expandedChange = new EventEmitter<boolean>()\n\n  /** @internal nullish option. */\n  get defaultNullishOption(): OptionBase<any> {\n    return { key: null, label: this.placeholder ?? '\\u00A0' }\n  }\n\n  /** The current expanded state of the dropdown options. */\n  public expanded = false\n  /** The current option selected based on numeric index. */\n  public activeIndex = -1\n  /**\n   * Stores the bounding rectangle of the dropdown trigger element,\n   * used for positioning the dropdown list overlay.\n   */\n  public triggerRect: DOMRect | undefined = undefined\n  /** Subscribe if dropdown expanded to listen to click outside to close dropdown. */\n  private onClickSubscription: Subscription | undefined\n  /** Subscribe if dropdown expanded to listen to scroll outside to close dropdown. */\n  private onScrollSubscription: Subscription | undefined\n  /** Subscribe to get dropdown width size changes for a dropdown list width to match. */\n  private resizeSubscription: Subscription | undefined\n  /** Subscription to dropdown list overlay detachments. */\n  private overlayDetachSubscription: Subscription | undefined\n\n  public keyEvent: KeyboardEvent = {} as KeyboardEvent\n  private _options: OptionBase<T>[] = []\n  /** Reference to the currently attached dropdown list overlay. Used for opening/closing and positioning. */\n  private overlayRef?: OverlayRef\n\n  constructor(\n    @Self() @Optional() public ngControl: NgControl,\n    @Optional()\n    @Inject(TRANSLOCO_SCOPE)\n    protected translocoScope: TranslocoScope,\n    protected cdr: ChangeDetectorRef,\n    protected dropdownUtils: DropdownUtils<K, V, T>,\n    protected overlay: Overlay,\n    protected vcr: ViewContainerRef,\n  ) {\n    super(ngControl, translocoScope, cdr)\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.required?.currentValue !== undefined) {\n      const isRequired = changes.required.currentValue\n      // remove nullish option\n      const hasNullishOption =\n        this.dropdownUtils.flattenOptions(this._options, false)[0]?.key == null\n      // if required, remove nullish option\n      if (isRequired && hasNullishOption && this.allowControlNullishOption) {\n        this._options = this._options.slice(1)\n        return\n      }\n      // if not required, add nullish option\n      if (!isRequired && !hasNullishOption && this.allowControlNullishOption) {\n        this._options = [this.defaultNullishOption].concat(this._options)\n        return\n      }\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.onClickSubscription?.unsubscribe()\n    this.onScrollSubscription?.unsubscribe()\n    this.resizeSubscription?.unsubscribe()\n    this.overlayDetachSubscription?.unsubscribe()\n  }\n\n  /** @internal override to correctly set state from form value */\n  writeValue(value: any): void {\n    const options = this.dropdownUtils.flattenOptions(this._options, false)\n    this.state = options.find((option) => option.key === value)\n  }\n\n  // ----------------------------------------------------------------------------\n  // EVENTS\n  // ----------------------------------------------------------------------------\n\n  /** @internal */\n  onSelectChange(option: T) {\n    if (option.disabled) return\n    this.updateModel(option)\n    this.setExpanded(false)\n  }\n\n  // /**\n  //  * @internal\n  //  * Enter toggles the dropdown, home, end, and, arrows change the index.\n  //  * @param event fired containing which key was released.\n  //  */\n  @HostListener('keyup', ['$event'])\n  onKeyUp(event: KeyboardEvent) {\n    this.keyEvent = event\n  }\n\n  /**\n   * Closes the dropdown on click outside.\n   */\n  subscribeToOutsideClickEvent() {\n    this.onClickSubscription = fromEvent(document, 'click').subscribe({\n      next: (event: Event) => {\n        if (\n          this.expanded &&\n          !this.inputRef?.nativeElement.contains(event.target)\n        ) {\n          this.toggleDropdown()\n          this.onClickSubscription?.unsubscribe()\n        }\n      },\n    })\n  }\n\n  // ----------------------------------------------------------------------------\n  // HELPERS\n  // ----------------------------------------------------------------------------\n\n  /**\n   * Set the dropdown value to given option.\n   * @param value the dropdown option to select.\n   */\n  private updateModel(value: T) {\n    this.state = value\n    this.onChange(value.key)\n  }\n\n  /** Toggle the expanded state of the dropdown options. */\n  toggleDropdown() {\n    this.setExpanded(!this.expanded)\n    this.cdr.detectChanges()\n  }\n\n  /**\n   * Set the expanded state of the dropdown options. If true the options are shown below the field.\n   * Activate on click event to be able to close dropdown on click outside.\n   * @param state the expanded state which to set.\n   */\n  setExpanded(state = true) {\n    this.expanded = state\n    this.expandedChange.emit(this.expanded)\n    if (this.expanded) {\n      this.openDropdownOverlay()\n      this.subscribeToOutsideClickEvent()\n    } else {\n      this.closeDropdownOverlay()\n      this.onTouched()\n    }\n  }\n\n  /**\n   * Opens the dropdown overlay by detaching any existing overlay reference,\n   * attaching a new overlay, updating its width, and setting up listeners for overlay detachments.\n   * This method ensures the dropdown overlay is properly initialized and displayed.\n   */\n  openDropdownOverlay() {\n    this.detachOldOverlayRef()\n    this.attachNewOverlayRef()\n    this.updateOverlayWidth()\n    this.listenOverlayDetachments()\n  }\n\n  detachOldOverlayRef(): void {\n    if (this.overlayRef) {\n      this.overlayRef.detach()\n    }\n  }\n\n  attachNewOverlayRef(): void {\n    const positionStrategy = this.overlay\n      .position()\n      .flexibleConnectedTo(this.toggleButton)\n      .withPositions(this.getDropdownListPositionsArray())\n      .withPush(false) // Prevent overlay from overlapping the trigger\n\n    this.overlayRef = this.overlay.create({\n      positionStrategy,\n      scrollStrategy: this.getScrollStrategy(),\n    })\n\n    // Get trigger rect and pass to dropdown-list\n    this.triggerRect = this.toggleButton.nativeElement.getBoundingClientRect()\n\n    this.overlayRef.attach(new TemplatePortal(this.dropdownTemplate, this.vcr))\n  }\n\n  updateOverlayWidth(): void {\n    // sets initial width to match trigger element\n    this.setOverlayWidth()\n\n    // Listen for window resize and update overlay width\n    this.resizeSubscription = fromEvent(window, 'resize').subscribe(() => {\n      this.setOverlayWidth()\n    })\n  }\n\n  // used to catch when overlay is detached after scroll with list expanded\n  listenOverlayDetachments() {\n    if (this.overlayRef) {\n      this.overlayDetachSubscription = this.overlayRef\n        .detachments()\n        .subscribe(() => {\n          if (this.expanded) {\n            this.setExpanded(false)\n          }\n        })\n    }\n  }\n\n  getDropdownListPositionsArray(): ConnectedPosition[] {\n    return [\n      {\n        originX: 'start',\n        originY: 'bottom',\n        overlayX: 'start',\n        overlayY: 'top',\n        offsetY: 8, // 0.5rem gap below the trigger\n      },\n      {\n        originX: 'start',\n        originY: 'top',\n        overlayX: 'start',\n        overlayY: 'bottom',\n        offsetY: -8, // 0.5rem gap above the trigger\n      },\n    ]\n  }\n\n  getScrollStrategy(): ScrollStrategy {\n    return this.closeDropdownListOnScroll\n      ? this.overlay.scrollStrategies.close()\n      : this.overlay.scrollStrategies.reposition()\n  }\n\n  setOverlayWidth() {\n    if (this.overlayRef && this.toggleButton) {\n      const buttonWidth = this.toggleButton.nativeElement.offsetWidth\n      const pane = this.overlayRef.overlayElement as HTMLElement\n\n      pane.style.width = `${buttonWidth}px`\n    }\n  }\n\n  closeDropdownOverlay() {\n    this.overlayRef?.detach()\n    this.resizeSubscription?.unsubscribe()\n    this.overlayDetachSubscription?.unsubscribe()\n  }\n\n  /* TYPE CASTS */\n\n  /**\n   * Typecast anything to an {@link Option}.\n   * @param option the object to typecast.\n   */\n  castOption(option: any): T {\n    return option\n  }\n\n  /**\n   * Typecast anything to an {@link OptionGroup}.\n   * @param group the object to typecast.\n   */\n  castGroup(group: any): OptionGroup<T> {\n    return group\n  }\n\n  /* TYPE CHECKS */\n\n  /**\n   * Returns true if argument is an {@link Option}.\n   * @param option the object to check.\n   */\n  isOption(option: OptionBase<T>): option is OptionGroup<T> {\n    return !('options' in option)\n  }\n}","<!-- LABEL -->\n<ng-container *transloco=\"let t; read: scope\">\n  <label\n    [id]=\"id + '-label'\"\n    class=\"gds-field-label hide-if-empty\"\n    [attr.for]=\"id + '-toggle'\"\n    *ngIf=\"labelContentTpl || label\"\n  >\n    <ng-template\n      *ngTemplateOutlet=\"labelContentTpl || basicLabelContentTpl\"\n    ></ng-template>\n    <ng-template #basicLabelContentTpl>\n      <!-- to trigger css:empty if no label was added -->\n      <ng-container *ngIf=\"label\">\n        {{ label }}\n        <span\n          *ngIf=\"optional === true || (required !== true && optional !== false)\"\n          class=\"gds-field-label--optional\"\n        >\n          ({{ t('label.optional') }})\n        </span>\n      </ng-container>\n    </ng-template>\n  </label>\n\n  <!-- DESCRIPTION -->\n  <div class=\"description\" *ngIf=\"description\">{{ description }}</div>\n\n  <!-- LOCKED INPUT -->\n  <ng-container *ngIf=\"locked\">\n    <ng-template\n      *ngTemplateOutlet=\"\n        lockedTpl || defaultLockedTpl;\n        context: { $implicit: state }\n      \"\n    ></ng-template>\n    <ng-template #defaultLockedTpl>\n      <div\n        [id]=\"id + '-input'\"\n        class=\"nggv-field--locked\"\n        [attr.name]=\"name\"\n        [attr.value]=\"state\"\n        [attr.role]=\"role\"\n        [attr.aria-labelledby]=\"id + '-label ' + id + '-input'\"\n      >\n        <span *ngIf=\"!state\" class=\"unset-state\">-</span>\n        <ng-container *ngIf=\"state\">\n          <ng-template\n            *ngTemplateOutlet=\"\n              selectedContentTpl || defaultSelectedContentTpl;\n              context: { $implicit: state }\n            \"\n          >\n          </ng-template>\n        </ng-container>\n      </div>\n    </ng-template>\n  </ng-container>\n\n  <!-- INPUT -->\n  <ng-container *ngIf=\"!locked\">\n    <div class=\"gds-input-wrapper dropdown-wrapper\">\n      <div #input [id]=\"id + '-input'\" class=\"dropdown\">\n        <button\n          #toggleButton\n          [id]=\"id + '-toggle'\"\n          [disabled]=\"disabled\"\n          type=\"button\"\n          class=\"nggv-field-dropdown__label toggle\"\n          [class.nggv-field--error]=\"invalid\"\n          role=\"combobox\"\n          aria-owns=\"listbox\"\n          aria-haspopup=\"listbox\"\n          aria-controls=\"listbox\"\n          [attr.data-thook]=\"thook + '-toggle'\"\n          [attr.aria-expanded]=\"expanded\"\n          [attr.aria-labelledby]=\"\n            ariaLabel ? null : id + '-label ' + id + '-toggle'\n          \"\n          [attr.aria-label]=\"ariaLabel || null\"\n          (click)=\"toggleDropdown()\"\n        >\n          <span>\n            <ng-template\n              *ngTemplateOutlet=\"\n                selectedContentTpl || defaultSelectedContentTpl;\n                context: { $implicit: state }\n              \"\n            >\n            </ng-template>\n          </span>\n        </button>\n        <ng-template #dropdownTemplate>\n          <nggv-dropdown-list\n            #dropDownList\n            [options]=\"options\"\n            [scrollOffset]=\"scrollOffset\"\n            [state]=\"state\"\n            [expanded]=\"expanded\"\n            [optionContentTpl]=\"optionContentTpl\"\n            [groupLabelTpl]=\"groupLabelTpl\"\n            [textToHighlight]=\"textToHighlight\"\n            [onlyEmitDistinctChanges]=\"onlyHandleDistinctChanges\"\n            [selectWithSpace]=\"selectWithSpace\"\n            [triggerRect]=\"triggerRect\"\n            [useMargin]=\"false\"\n            (closed)=\"setExpanded(false)\"\n            (selectedValueChanged)=\"onSelectChange($event)\"\n          >\n          </nggv-dropdown-list>\n        </ng-template>\n      </div>\n      <!-- ERRORS -->\n      <div class=\"gds-form-item__footer error-wrapper\">\n        <span\n          class=\"form-info form-info--error\"\n          [attr.for]=\"id + '-input'\"\n          *ngIf=\"invalid && (error || ngControl?.invalid)\"\n        >\n          <span class=\"error-icon\">\n            <gds-icon-triangle-exclamation\n              width=\"16\"\n              height=\"16\"\n              [solid]=\"true\"\n              *nggCoreElement\n            ></gds-icon-triangle-exclamation>\n          </span>\n          <span\n            *ngIf=\"error; else errorsRef\"\n            [attr.data-thook]=\"thook + '-errorlabel'\"\n            >{{ error }}</span\n          >\n        </span>\n        <ng-template #errorsRef>\n          <span\n            *ngIf=\"firstError as error\"\n            [attr.data-thook]=\"thook + '-errorlabel'\"\n          >\n            {{ t('error.field' + error?.code, error?.params) }}\n          </span>\n        </ng-template>\n      </div>\n      <!-- CHILDREN -->\n      <ng-content></ng-content>\n    </div>\n  </ng-container>\n\n  <ng-template #defaultSelectedContentTpl let-state>\n    <!-- eslint-disable-next-line @angular-eslint/template/eqeqeq -->\n    {{ state?.key != null && state?.label ? t(state.label) : placeholder }}\n  </ng-template>\n</ng-container>\n"]}
|