@sebgroup/green-angular 4.6.1 → 4.6.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/src/v-angular/dropdown/typeahead/index.mjs +4 -1
- package/esm2022/src/v-angular/dropdown/typeahead/typeahead.directive.mjs +177 -0
- package/esm2022/v-angular/base-control-value-accessor/base-control-value-accessor.component.mjs +287 -0
- package/esm2022/v-angular/base-control-value-accessor/base-control-value-accessor.module.mjs +17 -0
- package/esm2022/v-angular/base-control-value-accessor/index.mjs +3 -0
- package/esm2022/v-angular/breadcrumbs/breadcrumbs.component.mjs +25 -0
- package/esm2022/v-angular/breadcrumbs/breadcrumbs.module.mjs +20 -0
- package/esm2022/v-angular/breadcrumbs/index.mjs +3 -0
- package/esm2022/v-angular/button/button.component.mjs +108 -0
- package/esm2022/v-angular/button/button.module.mjs +20 -0
- package/esm2022/v-angular/button/index.mjs +3 -0
- package/esm2022/v-angular/card/card.component.mjs +11 -0
- package/esm2022/v-angular/card/card.module.mjs +18 -0
- package/esm2022/v-angular/card/index.mjs +3 -0
- package/esm2022/v-angular/checkbox/checkbox.component.mjs +72 -0
- package/esm2022/v-angular/checkbox/checkbox.module.mjs +19 -0
- package/esm2022/v-angular/checkbox/index.mjs +3 -0
- package/esm2022/v-angular/dropdown/dropdown-list/dropdown-list.component.mjs +256 -0
- package/esm2022/v-angular/dropdown/dropdown-list/index.mjs +2 -0
- package/esm2022/v-angular/dropdown/dropdown.component.mjs +239 -0
- package/esm2022/v-angular/dropdown/dropdown.module.mjs +22 -0
- package/esm2022/v-angular/dropdown/index.mjs +6 -0
- package/esm2022/v-angular/dropdown/typeahead/index.mjs +6 -0
- package/esm2022/v-angular/dropdown/typeahead/typeahead-dropdown-list/typeahead-dropdown-list.component.mjs +98 -0
- package/esm2022/v-angular/dropdown/typeahead/typeahead-highlight/typeahead-highlight.component.mjs +85 -0
- package/esm2022/v-angular/dropdown/typeahead/typeahead-input/typeahead-input.component.mjs +132 -0
- package/esm2022/v-angular/dropdown/typeahead/typeahead.directive.mjs +177 -0
- package/esm2022/v-angular/dropdown/typeahead/typeahead.module.mjs +33 -0
- package/esm2022/v-angular/i18n/i18n.json +12 -0
- package/esm2022/v-angular/i18n/i18n.module.mjs +83 -0
- package/esm2022/v-angular/i18n/i18n.test.module.mjs +89 -0
- package/esm2022/v-angular/i18n/index.mjs +3 -0
- package/esm2022/v-angular/index.mjs +17 -0
- package/esm2022/v-angular/info-circle/index.mjs +3 -0
- package/esm2022/v-angular/info-circle/info-circle.component.mjs +28 -0
- package/esm2022/v-angular/info-circle/info-circle.module.mjs +21 -0
- package/esm2022/v-angular/input/index.mjs +3 -0
- package/esm2022/v-angular/input/input.component.mjs +221 -0
- package/esm2022/v-angular/input/input.module.mjs +32 -0
- package/esm2022/v-angular/input-mask/config.mjs +9 -0
- package/esm2022/v-angular/input-mask/constants.mjs +2 -0
- package/esm2022/v-angular/input-mask/index.mjs +6 -0
- package/esm2022/v-angular/input-mask/input-mask-format.pipe.mjs +20 -0
- package/esm2022/v-angular/input-mask/input-mask.directive.mjs +165 -0
- package/esm2022/v-angular/input-mask/input-mask.module.mjs +35 -0
- package/esm2022/v-angular/input-mask/input-mask.types.mjs +2 -0
- package/esm2022/v-angular/modal/dialog/dialog.component.mjs +190 -0
- package/esm2022/v-angular/modal/fold-out/fold-out.component.mjs +56 -0
- package/esm2022/v-angular/modal/fold-out/fold-out.directive.mjs +19 -0
- package/esm2022/v-angular/modal/index.mjs +6 -0
- package/esm2022/v-angular/modal/modal.globals.mjs +20 -0
- package/esm2022/v-angular/modal/modal.module.mjs +40 -0
- package/esm2022/v-angular/modal/modal.types.mjs +2 -0
- package/esm2022/v-angular/modal/slide-out/slide-out.component.mjs +229 -0
- package/esm2022/v-angular/radio/index.mjs +3 -0
- package/esm2022/v-angular/radio/radio.component.mjs +130 -0
- package/esm2022/v-angular/radio/radio.module.mjs +20 -0
- package/esm2022/v-angular/sebgroup-green-angular-v-angular.mjs +5 -0
- package/esm2022/v-angular/textarea/index.mjs +3 -0
- package/esm2022/v-angular/textarea/textarea.component.mjs +101 -0
- package/esm2022/v-angular/textarea/textarea.module.mjs +18 -0
- package/esm2022/v-angular/tooltip/index.mjs +3 -0
- package/esm2022/v-angular/tooltip/tooltip.directive.mjs +273 -0
- package/esm2022/v-angular/tooltip/tooltip.module.mjs +18 -0
- package/esm2022/v-angular/v-angular.module.mjs +76 -0
- package/fesm2022/sebgroup-green-angular-src-v-angular-dropdown.mjs +172 -3
- package/fesm2022/sebgroup-green-angular-src-v-angular-dropdown.mjs.map +1 -1
- package/fesm2022/sebgroup-green-angular-v-angular.mjs +3341 -0
- package/fesm2022/sebgroup-green-angular-v-angular.mjs.map +1 -0
- package/package.json +8 -2
- package/src/v-angular/dropdown/typeahead/index.d.ts +3 -0
- package/src/v-angular/dropdown/typeahead/typeahead.directive.d.ts +76 -0
- package/v-angular/base-control-value-accessor/base-control-value-accessor.component.d.ts +124 -0
- package/v-angular/base-control-value-accessor/base-control-value-accessor.module.d.ts +7 -0
- package/v-angular/base-control-value-accessor/index.d.ts +2 -0
- package/v-angular/breadcrumbs/breadcrumbs.component.d.ts +18 -0
- package/v-angular/breadcrumbs/breadcrumbs.module.d.ts +10 -0
- package/v-angular/breadcrumbs/index.d.ts +2 -0
- package/v-angular/button/button.component.d.ts +62 -0
- package/v-angular/button/button.module.d.ts +10 -0
- package/v-angular/button/index.d.ts +2 -0
- package/v-angular/card/card.component.d.ts +5 -0
- package/v-angular/card/card.module.d.ts +8 -0
- package/v-angular/card/index.d.ts +2 -0
- package/v-angular/checkbox/checkbox.component.d.ts +27 -0
- package/v-angular/checkbox/checkbox.module.d.ts +9 -0
- package/v-angular/checkbox/index.d.ts +2 -0
- package/v-angular/dropdown/dropdown-list/dropdown-list.component.d.ts +89 -0
- package/v-angular/dropdown/dropdown-list/index.d.ts +1 -0
- package/v-angular/dropdown/dropdown.component.d.ts +99 -0
- package/v-angular/dropdown/dropdown.module.d.ts +12 -0
- package/v-angular/dropdown/index.d.ts +5 -0
- package/v-angular/dropdown/typeahead/index.d.ts +5 -0
- package/v-angular/dropdown/typeahead/typeahead-dropdown-list/typeahead-dropdown-list.component.d.ts +34 -0
- package/v-angular/dropdown/typeahead/typeahead-highlight/typeahead-highlight.component.d.ts +34 -0
- package/v-angular/dropdown/typeahead/typeahead-input/typeahead-input.component.d.ts +59 -0
- package/v-angular/dropdown/typeahead/typeahead.directive.d.ts +76 -0
- package/v-angular/dropdown/typeahead/typeahead.module.d.ts +11 -0
- package/v-angular/i18n/i18n.module.d.ts +15 -0
- package/v-angular/i18n/i18n.test.module.d.ts +27 -0
- package/v-angular/i18n/index.d.ts +2 -0
- package/v-angular/index.d.ts +16 -0
- package/v-angular/info-circle/index.d.ts +2 -0
- package/v-angular/info-circle/info-circle.component.d.ts +16 -0
- package/v-angular/info-circle/info-circle.module.d.ts +10 -0
- package/v-angular/input/index.d.ts +2 -0
- package/v-angular/input/input.component.d.ts +90 -0
- package/v-angular/input/input.module.d.ts +11 -0
- package/v-angular/input-mask/config.d.ts +6 -0
- package/v-angular/input-mask/constants.d.ts +2 -0
- package/v-angular/input-mask/index.d.ts +5 -0
- package/v-angular/input-mask/input-mask-format.pipe.d.ts +8 -0
- package/v-angular/input-mask/input-mask.directive.d.ts +39 -0
- package/v-angular/input-mask/input-mask.module.d.ts +11 -0
- package/v-angular/input-mask/input-mask.types.d.ts +20 -0
- package/v-angular/modal/dialog/dialog.component.d.ts +55 -0
- package/v-angular/modal/fold-out/fold-out.component.d.ts +24 -0
- package/v-angular/modal/fold-out/fold-out.directive.d.ts +6 -0
- package/v-angular/modal/index.d.ts +5 -0
- package/v-angular/modal/modal.globals.d.ts +13 -0
- package/v-angular/modal/modal.module.d.ts +13 -0
- package/v-angular/modal/modal.types.d.ts +5 -0
- package/v-angular/modal/slide-out/slide-out.component.d.ts +76 -0
- package/v-angular/radio/index.d.ts +2 -0
- package/v-angular/radio/radio.component.d.ts +48 -0
- package/v-angular/radio/radio.module.d.ts +9 -0
- package/v-angular/textarea/index.d.ts +2 -0
- package/v-angular/textarea/textarea.component.d.ts +44 -0
- package/v-angular/textarea/textarea.module.d.ts +8 -0
- package/v-angular/tooltip/index.d.ts +2 -0
- package/v-angular/tooltip/tooltip.directive.d.ts +106 -0
- package/v-angular/tooltip/tooltip.module.d.ts +8 -0
- package/v-angular/v-angular.module.d.ts +22 -0
|
@@ -1,3 +1,6 @@
|
|
|
1
1
|
export * from './typeahead-highlight/typeahead-highlight.component';
|
|
2
2
|
export * from './typeahead-input/typeahead-input.component';
|
|
3
|
-
|
|
3
|
+
export * from './typeahead-dropdown-list/typeahead-dropdown-list.component';
|
|
4
|
+
export * from './typeahead.directive';
|
|
5
|
+
export * from './typeahead.module';
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvc3JjL3YtYW5ndWxhci9kcm9wZG93bi90eXBlYWhlYWQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxxREFBcUQsQ0FBQTtBQUNuRSxjQUFjLDZDQUE2QyxDQUFBO0FBQzNELGNBQWMsNkRBQTZELENBQUE7QUFDM0UsY0FBYyx1QkFBdUIsQ0FBQTtBQUNyQyxjQUFjLG9CQUFvQixDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi90eXBlYWhlYWQtaGlnaGxpZ2h0L3R5cGVhaGVhZC1oaWdobGlnaHQuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi90eXBlYWhlYWQtaW5wdXQvdHlwZWFoZWFkLWlucHV0LmNvbXBvbmVudCdcbmV4cG9ydCAqIGZyb20gJy4vdHlwZWFoZWFkLWRyb3Bkb3duLWxpc3QvdHlwZWFoZWFkLWRyb3Bkb3duLWxpc3QuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi90eXBlYWhlYWQuZGlyZWN0aXZlJ1xuZXhwb3J0ICogZnJvbSAnLi90eXBlYWhlYWQubW9kdWxlJ1xuIl19
|
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
import { Directive, ElementRef, EventEmitter, Host, HostListener, Input, Optional, Output, ViewContainerRef, } from '@angular/core';
|
|
2
|
+
import { distinctUntilChanged, from, Subject, takeUntil, tap, withLatestFrom, } from 'rxjs';
|
|
3
|
+
import { NgvDropdownComponent } from '../dropdown.component';
|
|
4
|
+
import { NgvInputComponent } from '@sebgroup/green-angular/src/v-angular/input';
|
|
5
|
+
import { NgvTypeaheadDropdownListComponent } from '../typeahead/typeahead-dropdown-list/typeahead-dropdown-list.component';
|
|
6
|
+
import { NgvTypeaheadInputComponent } from './typeahead-input/typeahead-input.component';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "../dropdown.component";
|
|
9
|
+
import * as i2 from "@sebgroup/green-angular/src/v-angular/input";
|
|
10
|
+
export class NgvTypeaheadDirective {
|
|
11
|
+
/** Function that filter the inputvalue */
|
|
12
|
+
set ngvTypeahead(value) {
|
|
13
|
+
this.typeaheadFunction = value;
|
|
14
|
+
// If inputsubscription already exists, unsubscribe and subscribe again
|
|
15
|
+
if (this.inputSubscription$) {
|
|
16
|
+
this.inputSubscription$?.unsubscribe();
|
|
17
|
+
this.inputSubscription$ = undefined;
|
|
18
|
+
this.handleInputChanges();
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
/** Forward text inputs to apply the filter function*/
|
|
22
|
+
onNgvInput(event) {
|
|
23
|
+
this.inputValue$.next(event);
|
|
24
|
+
}
|
|
25
|
+
/** Helper to the determine if the host is nggv-drodpown or nggv-input*/
|
|
26
|
+
get hostIsDropdown() {
|
|
27
|
+
return !!this.hostDropdown;
|
|
28
|
+
}
|
|
29
|
+
/** Predefined options */
|
|
30
|
+
get defaultNullishOption() {
|
|
31
|
+
return { key: null, label: this.unselectLabel || '\u00A0' };
|
|
32
|
+
}
|
|
33
|
+
get emptyOption() {
|
|
34
|
+
return { key: null, label: 'label.nomatchingoptions', disabled: true };
|
|
35
|
+
}
|
|
36
|
+
/** Name of the component. nggv-dropdown if NgvDropdownComponent or nggv-input if NgvInputComponent */
|
|
37
|
+
get localName() {
|
|
38
|
+
return this.element.nativeElement.localName;
|
|
39
|
+
}
|
|
40
|
+
constructor(viewContainerRef, element, hostDropdown, hostInput) {
|
|
41
|
+
this.viewContainerRef = viewContainerRef;
|
|
42
|
+
this.element = element;
|
|
43
|
+
this.hostDropdown = hostDropdown;
|
|
44
|
+
this.hostInput = hostInput;
|
|
45
|
+
/** Allow option to be unselected in the dropdown even if it is required. Defaults to true */
|
|
46
|
+
this.allowUnselect = true;
|
|
47
|
+
/** Emits the entered string the user has written in the input */
|
|
48
|
+
this.filterPhraseChange = new EventEmitter();
|
|
49
|
+
this.inputValue$ = new Subject();
|
|
50
|
+
this.onDestroy$ = new Subject();
|
|
51
|
+
}
|
|
52
|
+
ngOnInit() {
|
|
53
|
+
this.handleInputChanges();
|
|
54
|
+
this.inputValue$.next('');
|
|
55
|
+
if (this.hostIsDropdown)
|
|
56
|
+
this.createInput();
|
|
57
|
+
else
|
|
58
|
+
this.createDropdownList();
|
|
59
|
+
}
|
|
60
|
+
ngOnDestroy() {
|
|
61
|
+
this.onDestroy$.next(true);
|
|
62
|
+
this.onDestroy$.complete();
|
|
63
|
+
}
|
|
64
|
+
/**
|
|
65
|
+
* @internal
|
|
66
|
+
* Core functionality of typeahead. Emits input, then filters the result based on the supplied function
|
|
67
|
+
* If directive is applied on nggv-input, manually show or hide options in the list.
|
|
68
|
+
* If directive is applied on nggv-dropdown, let the dropdown itself choose when to open or close
|
|
69
|
+
*/
|
|
70
|
+
handleInputChanges() {
|
|
71
|
+
this.inputSubscription$ = this.inputValue$
|
|
72
|
+
.pipe(takeUntil(this.onDestroy$), distinctUntilChanged(), tap((inputValue) => this.filterPhraseChange.emit(inputValue)), this.typeaheadFunction ? this.typeaheadFunction : () => from([]), withLatestFrom(this.inputValue$))
|
|
73
|
+
.subscribe(([filteredValues, input]) => this.setOptions(filteredValues, input));
|
|
74
|
+
}
|
|
75
|
+
/**
|
|
76
|
+
* @internal
|
|
77
|
+
* Creates a nggv-input if the host itself is not a text-input
|
|
78
|
+
* Set styles to not display the input when closed
|
|
79
|
+
* Trigger filtering when changes occur in the field
|
|
80
|
+
* */
|
|
81
|
+
createInput() {
|
|
82
|
+
// Create the input component
|
|
83
|
+
this.inputComponent = this.viewContainerRef.createComponent(NgvTypeaheadInputComponent);
|
|
84
|
+
// Forward necessary info to component
|
|
85
|
+
this.inputComponent.setInput('hostComponent', this.hostDropdown);
|
|
86
|
+
this.inputComponent.setInput('selectedFormatter', this.selectedFormatter);
|
|
87
|
+
this.inputComponent.setInput('resultFormatter', this.resultFormatter);
|
|
88
|
+
// Listen to value changes
|
|
89
|
+
this.inputComponent.instance.ngvInput
|
|
90
|
+
.pipe(takeUntil(this.onDestroy$))
|
|
91
|
+
.subscribe((inputValue) => this.inputValue$.next(inputValue));
|
|
92
|
+
}
|
|
93
|
+
/** @internal Creates a nggv-dropdown-list if the host itself is a nggv-input */
|
|
94
|
+
createDropdownList() {
|
|
95
|
+
this.dropdownListComponent = this.viewContainerRef.createComponent(NgvTypeaheadDropdownListComponent);
|
|
96
|
+
this.dropdownListComponent.setInput('hostComponent', this.hostInput);
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* @internal Sets the options the user can select.
|
|
100
|
+
* If the host is a nggv-dropdown, utilize the dropdown itself to display the options
|
|
101
|
+
* If the host is a nggv-input, use the created nggv-dropdown-list to displaye the options
|
|
102
|
+
* @param filteredValues The options to display in the dropdown
|
|
103
|
+
* @param emptyInput If the input is empty
|
|
104
|
+
*/
|
|
105
|
+
setOptions(filteredValues, input) {
|
|
106
|
+
if (!filteredValues)
|
|
107
|
+
return;
|
|
108
|
+
// Conditionally add empty or nullish option if it's allowed, the input is empty and does not already contain nullish
|
|
109
|
+
const allowNullish = this.allowUnselect &&
|
|
110
|
+
!input &&
|
|
111
|
+
!(Object.keys(filteredValues[0]).includes('key') &&
|
|
112
|
+
filteredValues[0].key == null);
|
|
113
|
+
if (filteredValues.length === 0) {
|
|
114
|
+
filteredValues = [this.emptyOption];
|
|
115
|
+
}
|
|
116
|
+
else if (allowNullish) {
|
|
117
|
+
filteredValues = [this.defaultNullishOption].concat(filteredValues);
|
|
118
|
+
}
|
|
119
|
+
if (this.hostIsDropdown) {
|
|
120
|
+
// Add nullish option when no input is written (or when dropdown is epanded and has a selection)
|
|
121
|
+
this.hostDropdown.allowControlNullishOption = false;
|
|
122
|
+
this.hostDropdown.options = this.formatOptions(filteredValues);
|
|
123
|
+
this.hostDropdown.textToHighlight = `${input || ''}`;
|
|
124
|
+
this.hostDropdown.detectChanges();
|
|
125
|
+
return;
|
|
126
|
+
}
|
|
127
|
+
if (!this.hostIsDropdown) {
|
|
128
|
+
this.dropdownListComponent.setInput('options', this.formatOptions(filteredValues));
|
|
129
|
+
this.dropdownListComponent.setInput('textToHighlight', `${input || ''}`);
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
/**
|
|
133
|
+
* @internal Formats the available options to display in the dropdown list
|
|
134
|
+
* @param options The selected value
|
|
135
|
+
* @returns The formatted value
|
|
136
|
+
*/
|
|
137
|
+
formatOptions(options) {
|
|
138
|
+
if (!options)
|
|
139
|
+
return [];
|
|
140
|
+
if (!this.resultFormatter)
|
|
141
|
+
return options;
|
|
142
|
+
return options.map((value) => value?.label ? this.resultFormatter?.(value) : value);
|
|
143
|
+
}
|
|
144
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvTypeaheadDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.ElementRef }, { token: i1.NgvDropdownComponent, host: true, optional: true }, { token: i2.NgvInputComponent, host: true, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
145
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: NgvTypeaheadDirective, isStandalone: true, selector: "nggv-input[ngvTypeahead]", inputs: { ngvTypeahead: "ngvTypeahead", resultFormatter: "resultFormatter", selectedFormatter: "selectedFormatter", allowUnselect: "allowUnselect", unselectLabel: "unselectLabel" }, outputs: { filterPhraseChange: "filterPhraseChange" }, host: { listeners: { "ngvInput": "onNgvInput($event)" } }, ngImport: i0 }); }
|
|
146
|
+
}
|
|
147
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvTypeaheadDirective, decorators: [{
|
|
148
|
+
type: Directive,
|
|
149
|
+
args: [{
|
|
150
|
+
selector: 'nggv-input[ngvTypeahead]',
|
|
151
|
+
standalone: true,
|
|
152
|
+
}]
|
|
153
|
+
}], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.ElementRef }, { type: i1.NgvDropdownComponent, decorators: [{
|
|
154
|
+
type: Optional
|
|
155
|
+
}, {
|
|
156
|
+
type: Host
|
|
157
|
+
}] }, { type: i2.NgvInputComponent, decorators: [{
|
|
158
|
+
type: Optional
|
|
159
|
+
}, {
|
|
160
|
+
type: Host
|
|
161
|
+
}] }]; }, propDecorators: { ngvTypeahead: [{
|
|
162
|
+
type: Input
|
|
163
|
+
}], resultFormatter: [{
|
|
164
|
+
type: Input
|
|
165
|
+
}], selectedFormatter: [{
|
|
166
|
+
type: Input
|
|
167
|
+
}], allowUnselect: [{
|
|
168
|
+
type: Input
|
|
169
|
+
}], unselectLabel: [{
|
|
170
|
+
type: Input
|
|
171
|
+
}], filterPhraseChange: [{
|
|
172
|
+
type: Output
|
|
173
|
+
}], onNgvInput: [{
|
|
174
|
+
type: HostListener,
|
|
175
|
+
args: ['ngvInput', ['$event']]
|
|
176
|
+
}] } });
|
|
177
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"typeahead.directive.js","sourceRoot":"","sources":["../../../../../../../../libs/angular/src/v-angular/dropdown/typeahead/typeahead.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ComponentRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Host,\n  HostListener,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  ViewContainerRef,\n} from '@angular/core'\n\nimport {\n  distinctUntilChanged,\n  from,\n  OperatorFunction,\n  Subject,\n  Subscription,\n  takeUntil,\n  tap,\n  withLatestFrom,\n} from 'rxjs'\n\nimport { Option, OptionBase } from '@sebgroup/green-angular/src/v-angular/core'\nimport { NgvDropdownComponent } from '../dropdown.component'\nimport { NgvInputComponent } from '@sebgroup/green-angular/src/v-angular/input'\nimport { NgvTypeaheadDropdownListComponent } from '../typeahead/typeahead-dropdown-list/typeahead-dropdown-list.component'\nimport { NgvTypeaheadInputComponent } from './typeahead-input/typeahead-input.component'\n\n@Directive({\n  selector: 'nggv-input[ngvTypeahead]',\n  standalone: true,\n})\nexport class NgvTypeaheadDirective<\n    K = string | null | undefined,\n    V = string | null | undefined,\n    T extends Option<K, V> = Option<K, V>,\n  >\n  implements OnInit, OnDestroy\n{\n  /** Function that filter the inputvalue */\n  @Input() set ngvTypeahead(value: OperatorFunction<string, T[]> | undefined) {\n    this.typeaheadFunction = value\n\n    // If inputsubscription already exists, unsubscribe and subscribe again\n    if (this.inputSubscription$) {\n      this.inputSubscription$?.unsubscribe()\n      this.inputSubscription$ = undefined\n      this.handleInputChanges()\n    }\n  }\n\n  /** Formats each item that is displayed as an option. Only applies format if the option if it implement Option interface. */\n  @Input() resultFormatter?: (option: OptionBase<any>) => string\n\n  /** Formats the selected item in the input when dropdown is opened. If no function is provided, it will display the value of the selected objects label property */\n  @Input() selectedFormatter?: (selected: OptionBase<any>) => string\n\n  /** Allow option to be unselected in the dropdown even if it is required. Defaults to true */\n  @Input() allowUnselect = true\n\n  /** Custom label for the unselect option */\n  @Input() unselectLabel?: string\n\n  /** Emits the entered string the user has written in the input */\n  @Output() filterPhraseChange = new EventEmitter<string>()\n\n  /** Forward text inputs to apply the filter function*/\n  @HostListener('ngvInput', ['$event']) onNgvInput(event: any) {\n    this.inputValue$.next(event)\n  }\n\n  /** Helper to the determine if the host is nggv-drodpown or nggv-input*/\n  get hostIsDropdown() {\n    return !!this.hostDropdown\n  }\n\n  /** Predefined options */\n  get defaultNullishOption(): OptionBase<any> {\n    return { key: null, label: this.unselectLabel || '\\u00A0' }\n  }\n\n  get emptyOption(): OptionBase<any> {\n    return { key: null, label: 'label.nomatchingoptions', disabled: true }\n  }\n\n  /** Name of the component. nggv-dropdown if NgvDropdownComponent or nggv-input if NgvInputComponent */\n  get localName() {\n    return this.element.nativeElement.localName\n  }\n\n  dropdownListComponent!: ComponentRef<NgvTypeaheadDropdownListComponent>\n  inputComponent!: ComponentRef<NgvTypeaheadInputComponent>\n\n  private typeaheadFunction?: OperatorFunction<string, T[]>\n  private inputValue$ = new Subject<any>()\n  private inputSubscription$?: Subscription\n  private onDestroy$ = new Subject<boolean>()\n\n  constructor(\n    private viewContainerRef: ViewContainerRef,\n    private element: ElementRef,\n    @Optional() @Host() private hostDropdown: NgvDropdownComponent,\n    @Optional() @Host() private hostInput: NgvInputComponent,\n  ) {}\n\n  ngOnInit() {\n    this.handleInputChanges()\n    this.inputValue$.next('')\n\n    if (this.hostIsDropdown) this.createInput()\n    else this.createDropdownList()\n  }\n\n  ngOnDestroy(): void {\n    this.onDestroy$.next(true)\n    this.onDestroy$.complete()\n  }\n\n  /**\n   * @internal\n   * Core functionality of typeahead. Emits input, then filters the result based on the supplied function\n   * If directive is applied on nggv-input, manually show or hide options in the list.\n   * If directive is applied on nggv-dropdown, let the dropdown itself choose when to open or close\n   */\n  private handleInputChanges() {\n    this.inputSubscription$ = this.inputValue$\n      .pipe(\n        takeUntil(this.onDestroy$),\n        distinctUntilChanged(),\n        tap((inputValue) => this.filterPhraseChange.emit(inputValue)),\n        this.typeaheadFunction ? this.typeaheadFunction : () => from([]),\n        withLatestFrom(this.inputValue$),\n      )\n      .subscribe(([filteredValues, input]) =>\n        this.setOptions(filteredValues, input),\n      )\n  }\n\n  /**\n   * @internal\n   * Creates a nggv-input if the host itself is not a text-input\n   * Set styles to not display the input when closed\n   * Trigger filtering when changes occur in the field\n   * */\n  private createInput() {\n    // Create the input component\n    this.inputComponent = this.viewContainerRef.createComponent(\n      NgvTypeaheadInputComponent,\n    )\n    // Forward necessary info to component\n    this.inputComponent.setInput('hostComponent', this.hostDropdown)\n    this.inputComponent.setInput('selectedFormatter', this.selectedFormatter)\n    this.inputComponent.setInput('resultFormatter', this.resultFormatter)\n    // Listen to value changes\n    this.inputComponent.instance.ngvInput\n      .pipe(takeUntil(this.onDestroy$))\n      .subscribe((inputValue) => this.inputValue$.next(inputValue))\n  }\n\n  /** @internal Creates a nggv-dropdown-list if the host itself is a nggv-input */\n  private createDropdownList() {\n    this.dropdownListComponent = this.viewContainerRef.createComponent(\n      NgvTypeaheadDropdownListComponent,\n    )\n    this.dropdownListComponent.setInput('hostComponent', this.hostInput)\n  }\n\n  /**\n   * @internal Sets the options the user can select.\n   * If the host is a nggv-dropdown, utilize the dropdown itself to display the options\n   * If the host is a nggv-input, use the created nggv-dropdown-list to displaye the options\n   * @param filteredValues The options to display in the dropdown\n   * @param emptyInput If the input is empty\n   */\n  private setOptions(filteredValues: T[], input: string) {\n    if (!filteredValues) return\n    // Conditionally add empty or nullish option if it's allowed, the input is empty and does not already contain nullish\n    const allowNullish =\n      this.allowUnselect &&\n      !input &&\n      !(\n        Object.keys(filteredValues[0]).includes('key') &&\n        filteredValues[0].key == null\n      )\n    if (filteredValues.length === 0) {\n      filteredValues = [this.emptyOption]\n    } else if (allowNullish) {\n      filteredValues = [this.defaultNullishOption].concat(filteredValues)\n    }\n\n    if (this.hostIsDropdown) {\n      // Add nullish option when no input is written (or when dropdown is epanded and has a selection)\n      this.hostDropdown.allowControlNullishOption = false\n      this.hostDropdown.options = this.formatOptions(filteredValues)\n      this.hostDropdown.textToHighlight = `${input || ''}`\n      this.hostDropdown.detectChanges()\n      return\n    }\n\n    if (!this.hostIsDropdown) {\n      this.dropdownListComponent.setInput(\n        'options',\n        this.formatOptions(filteredValues),\n      )\n      this.dropdownListComponent.setInput('textToHighlight', `${input || ''}`)\n    }\n  }\n\n  /**\n   * @internal Formats the available options to display in the dropdown list\n   * @param options The selected value\n   * @returns The formatted value\n   */\n  private formatOptions(options: T[]): OptionBase<any>[] {\n    if (!options) return []\n    if (!this.resultFormatter) return options\n    return options.map((value) =>\n      value?.label ? this.resultFormatter?.(value) : value,\n    )\n  }\n}\n"]}
|
package/esm2022/v-angular/base-control-value-accessor/base-control-value-accessor.component.mjs
ADDED
|
@@ -0,0 +1,287 @@
|
|
|
1
|
+
import { ChangeDetectorRef, ContentChild, Component, ElementRef, EventEmitter, HostBinding, Inject, Injectable, Input, Optional, Output, Self, TemplateRef, ViewChild, } from '@angular/core';
|
|
2
|
+
import { NgControl, Validators, } from '@angular/forms';
|
|
3
|
+
import { Observable, Subject } from 'rxjs';
|
|
4
|
+
import { takeUntil } from 'rxjs/operators';
|
|
5
|
+
import { TRANSLOCO_SCOPE } from '@ngneat/transloco';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/forms";
|
|
8
|
+
// eslint-disable-next-line @angular-eslint/directive-class-suffix
|
|
9
|
+
export class NgvBaseControlValueAccessorComponent {
|
|
10
|
+
/** Hides the input borders and displays current value as a text. */
|
|
11
|
+
set locked(value) {
|
|
12
|
+
this._locked = value;
|
|
13
|
+
this.cdr.detectChanges();
|
|
14
|
+
}
|
|
15
|
+
get locked() {
|
|
16
|
+
return this._locked;
|
|
17
|
+
}
|
|
18
|
+
/** Override the required flag of the component. */
|
|
19
|
+
set required(value) {
|
|
20
|
+
this._required = value;
|
|
21
|
+
}
|
|
22
|
+
/** Child input element is considered required and changes default label template accordingly. */
|
|
23
|
+
get required() {
|
|
24
|
+
// if required is set => return required
|
|
25
|
+
if (this._required !== undefined)
|
|
26
|
+
return this._required;
|
|
27
|
+
// if required can be determined from the control => return control.required
|
|
28
|
+
if (this.ngControl?.control?.validator) {
|
|
29
|
+
const validator = this.ngControl?.control?.validator({});
|
|
30
|
+
// returns true for any error that starts with required
|
|
31
|
+
return Object.keys(validator ?? {}).some((key) => key.startsWith('required'));
|
|
32
|
+
}
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
/** Override the invalid state of the component. */
|
|
36
|
+
set invalid(value) {
|
|
37
|
+
this._invalid = value;
|
|
38
|
+
}
|
|
39
|
+
/** The component has the invalid state, usually decorating the elements red and shows the first error. */
|
|
40
|
+
get invalid() {
|
|
41
|
+
if (this._invalid === true || this._invalid === false)
|
|
42
|
+
return this._invalid;
|
|
43
|
+
return (!!this.ngControl?.control?.invalid && this.ngControl?.control?.touched);
|
|
44
|
+
}
|
|
45
|
+
/** Override the valid state of the component. */
|
|
46
|
+
set valid(value) {
|
|
47
|
+
this._valid = value;
|
|
48
|
+
}
|
|
49
|
+
/** The component has the valid state, usually decorating the elements green. */
|
|
50
|
+
get valid() {
|
|
51
|
+
if (this._valid === true || this._valid === false)
|
|
52
|
+
return this._valid;
|
|
53
|
+
return !!this.ngControl?.control?.valid && this.ngControl?.control?.touched;
|
|
54
|
+
}
|
|
55
|
+
/** Override the disabled state of the component. */
|
|
56
|
+
set disabled(value) {
|
|
57
|
+
this._disabled = value;
|
|
58
|
+
}
|
|
59
|
+
/** The component has the disabled state, usually muting the colors and removes interaction. */
|
|
60
|
+
get disabled() {
|
|
61
|
+
if (this._disabled === true || this._disabled === false)
|
|
62
|
+
return this._disabled;
|
|
63
|
+
return !!this.ngControl?.control?.disabled;
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Creates a new BaseControlValueAccessorComponent.
|
|
67
|
+
* @param ngControl optional FormControl provided when component is used in a form, through dependency injection.
|
|
68
|
+
* @param translocoScope optional TranslocoScope provided if component is used within a scope.
|
|
69
|
+
*/
|
|
70
|
+
constructor(ngControl, translocoScope, cdr) {
|
|
71
|
+
this.ngControl = ngControl;
|
|
72
|
+
this.translocoScope = translocoScope;
|
|
73
|
+
this.cdr = cdr;
|
|
74
|
+
/* ATTRIBUTES */
|
|
75
|
+
/** Id of the host element and is accessible by the children, automatically generated if not provided. */
|
|
76
|
+
this.id = window.ngv?.nextId();
|
|
77
|
+
/** If set to true, the browser will try to automatically set focus to the child input element. */
|
|
78
|
+
this.autofocus = false;
|
|
79
|
+
this._locked = undefined;
|
|
80
|
+
/* STATES */
|
|
81
|
+
this._required = undefined;
|
|
82
|
+
this._invalid = undefined;
|
|
83
|
+
this._valid = undefined;
|
|
84
|
+
/** The component has the focused state, updated by the child input element's focus state. */
|
|
85
|
+
this.focused = false;
|
|
86
|
+
this._disabled = undefined;
|
|
87
|
+
/* TRIGGERS */
|
|
88
|
+
/** Emits focus events triggered by the child elements. */
|
|
89
|
+
this.ngvFocus = new EventEmitter();
|
|
90
|
+
/** Emits focus events triggered by the child elements. */
|
|
91
|
+
this.ngvBlur = new EventEmitter();
|
|
92
|
+
/* VALUE HANDLERS */
|
|
93
|
+
this._state = null;
|
|
94
|
+
/** @internal */
|
|
95
|
+
this.onChange = (_) => {
|
|
96
|
+
// do nothing
|
|
97
|
+
};
|
|
98
|
+
/** @internal */
|
|
99
|
+
this.onTouched = () => {
|
|
100
|
+
// do nothing
|
|
101
|
+
};
|
|
102
|
+
/** @internal */
|
|
103
|
+
this.onValidatorChange = () => null;
|
|
104
|
+
/* LIFE CYCLE VARIABLES */
|
|
105
|
+
this._onDestroy$ = new Subject();
|
|
106
|
+
if (this.ngControl) {
|
|
107
|
+
// Note: we provide the value accessor through here, instead of
|
|
108
|
+
// the `providers` to avoid running into a circular import.
|
|
109
|
+
this.ngControl.valueAccessor = this;
|
|
110
|
+
}
|
|
111
|
+
if (this.translocoScope)
|
|
112
|
+
this.scope = this.translocoScope.toString();
|
|
113
|
+
}
|
|
114
|
+
// eslint-disable-next-line @angular-eslint/contextual-lifecycle
|
|
115
|
+
ngOnInit() {
|
|
116
|
+
if (this.ngControl && this.ngControl.control) {
|
|
117
|
+
this.ngControl.control.setValidators(Validators.compose([this.ngControl.control.validator, this.validate]));
|
|
118
|
+
}
|
|
119
|
+
// if reset observable has been passed, subscribe after updates
|
|
120
|
+
this.reset?.pipe(takeUntil(this._onDestroy$)).subscribe({
|
|
121
|
+
next: () => {
|
|
122
|
+
// reset value of controller
|
|
123
|
+
this.state = this.defaultValue;
|
|
124
|
+
this.onChange(this.state);
|
|
125
|
+
this.cdr.detectChanges();
|
|
126
|
+
},
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
// eslint-disable-next-line @angular-eslint/contextual-lifecycle
|
|
130
|
+
ngAfterViewInit() {
|
|
131
|
+
// if default value is set, then don't alter it. Otherwise, use
|
|
132
|
+
// current value of controller after initiation as default value
|
|
133
|
+
this.defaultValue = this.defaultValue ?? this.ngControl?.value;
|
|
134
|
+
}
|
|
135
|
+
ngOnDestroy() {
|
|
136
|
+
this._onDestroy$.next(true);
|
|
137
|
+
this._onDestroy$.complete();
|
|
138
|
+
}
|
|
139
|
+
detectChanges() {
|
|
140
|
+
this.cdr.detectChanges();
|
|
141
|
+
}
|
|
142
|
+
/** @internal */
|
|
143
|
+
onFocus(event) {
|
|
144
|
+
event.stopPropagation
|
|
145
|
+
? event.stopPropagation()
|
|
146
|
+
: (event.cancelBubble = true);
|
|
147
|
+
this.focused = true;
|
|
148
|
+
this.ngvFocus.emit(event);
|
|
149
|
+
}
|
|
150
|
+
/** @internal */
|
|
151
|
+
onBlur(event) {
|
|
152
|
+
event.stopPropagation
|
|
153
|
+
? event.stopPropagation()
|
|
154
|
+
: (event.cancelBubble = true);
|
|
155
|
+
this.onTouched();
|
|
156
|
+
this.focused = false;
|
|
157
|
+
this.ngvBlur.emit(event);
|
|
158
|
+
}
|
|
159
|
+
/** Sets the focus on the actual input element. */
|
|
160
|
+
setFocus() {
|
|
161
|
+
if (this.inputRef)
|
|
162
|
+
this.inputRef.nativeElement.focus();
|
|
163
|
+
}
|
|
164
|
+
// ----------------------------------------------------------------------------
|
|
165
|
+
// CONTROL VALUE ACCESSOR
|
|
166
|
+
// ----------------------------------------------------------------------------
|
|
167
|
+
/** Internal state/value that the native input element has. */
|
|
168
|
+
get state() {
|
|
169
|
+
return this._state;
|
|
170
|
+
}
|
|
171
|
+
/** Internal state/value that the native input element has. */
|
|
172
|
+
set state(value) {
|
|
173
|
+
if (typeof value === 'undefined')
|
|
174
|
+
value = null;
|
|
175
|
+
this._state = value;
|
|
176
|
+
}
|
|
177
|
+
/** Writes a new value to the child input element. */
|
|
178
|
+
writeValue(value) {
|
|
179
|
+
this.state = value;
|
|
180
|
+
}
|
|
181
|
+
/** Registers a callback function that is called when the child input element's value changes. */
|
|
182
|
+
registerOnChange(fn) {
|
|
183
|
+
this.onChange = fn;
|
|
184
|
+
}
|
|
185
|
+
/** Registers a callback function that is called when the child input element triggers on blur. */
|
|
186
|
+
registerOnTouched(fn) {
|
|
187
|
+
this.onTouched = fn;
|
|
188
|
+
}
|
|
189
|
+
/** Function that is called by the forms API when the control status changes to or from 'DISABLED'. */
|
|
190
|
+
setDisabledState(isDisabled) {
|
|
191
|
+
this.disabled = isDisabled;
|
|
192
|
+
// if displayDisabledAsLocked is enabled - update locked state based on disabled state
|
|
193
|
+
if (this.displayDisabledAsLocked) {
|
|
194
|
+
this.locked = isDisabled;
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
// ----------------------------------------------------------------------------
|
|
198
|
+
// VALIDATORS
|
|
199
|
+
// ----------------------------------------------------------------------------
|
|
200
|
+
/** Method that performs synchronous validation against the provided control. Used for internal validation. */
|
|
201
|
+
validate(_control) {
|
|
202
|
+
return null;
|
|
203
|
+
}
|
|
204
|
+
/** Registers a callback function to call when the validator inputs change. */
|
|
205
|
+
registerOnValidatorChange(fn) {
|
|
206
|
+
this.onValidatorChange = fn;
|
|
207
|
+
}
|
|
208
|
+
// ----------------------------------------------------------------------------
|
|
209
|
+
// HELPERS
|
|
210
|
+
// ----------------------------------------------------------------------------
|
|
211
|
+
/** Returns the first entry in an error object. */
|
|
212
|
+
get firstError() {
|
|
213
|
+
const errors = this.ngControl.errors;
|
|
214
|
+
if (!errors)
|
|
215
|
+
return null;
|
|
216
|
+
const code = Object.keys(errors)[0];
|
|
217
|
+
return { code, params: errors[code] };
|
|
218
|
+
}
|
|
219
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvBaseControlValueAccessorComponent, deps: [{ token: i1.NgControl, optional: true, self: true }, { token: TRANSLOCO_SCOPE, optional: true }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
220
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NgvBaseControlValueAccessorComponent, selector: "ng-component", inputs: { id: "id", name: "name", label: "label", role: "role", value: "value", error: "error", description: "description", autofocus: "autofocus", defaultValue: "defaultValue", reset: "reset", optional: "optional", locked: "locked", displayDisabledAsLocked: "displayDisabledAsLocked", required: "required", invalid: "invalid", valid: "valid", focused: "focused", disabled: "disabled" }, outputs: { ngvFocus: "ngvFocus", ngvBlur: "ngvBlur" }, host: { properties: { "attr.id": "this.id" } }, queries: [{ propertyName: "labelContentTpl", first: true, predicate: ["labelTpl"], descendants: true, read: TemplateRef }], viewQueries: [{ propertyName: "inputRef", first: true, predicate: ["input"], descendants: true, read: ElementRef }], ngImport: i0, template: '', isInline: true }); }
|
|
221
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvBaseControlValueAccessorComponent }); }
|
|
222
|
+
}
|
|
223
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvBaseControlValueAccessorComponent, decorators: [{
|
|
224
|
+
type: Injectable
|
|
225
|
+
}, {
|
|
226
|
+
type: Component,
|
|
227
|
+
args: [{ template: '' }]
|
|
228
|
+
}], ctorParameters: function () { return [{ type: i1.NgControl, decorators: [{
|
|
229
|
+
type: Self
|
|
230
|
+
}, {
|
|
231
|
+
type: Optional
|
|
232
|
+
}] }, { type: undefined, decorators: [{
|
|
233
|
+
type: Optional
|
|
234
|
+
}, {
|
|
235
|
+
type: Inject,
|
|
236
|
+
args: [TRANSLOCO_SCOPE]
|
|
237
|
+
}] }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { labelContentTpl: [{
|
|
238
|
+
type: ContentChild,
|
|
239
|
+
args: ['labelTpl', { read: TemplateRef }]
|
|
240
|
+
}], inputRef: [{
|
|
241
|
+
type: ViewChild,
|
|
242
|
+
args: ['input', { read: ElementRef }]
|
|
243
|
+
}], id: [{
|
|
244
|
+
type: HostBinding,
|
|
245
|
+
args: ['attr.id']
|
|
246
|
+
}, {
|
|
247
|
+
type: Input
|
|
248
|
+
}], name: [{
|
|
249
|
+
type: Input
|
|
250
|
+
}], label: [{
|
|
251
|
+
type: Input
|
|
252
|
+
}], role: [{
|
|
253
|
+
type: Input
|
|
254
|
+
}], value: [{
|
|
255
|
+
type: Input
|
|
256
|
+
}], error: [{
|
|
257
|
+
type: Input
|
|
258
|
+
}], description: [{
|
|
259
|
+
type: Input
|
|
260
|
+
}], autofocus: [{
|
|
261
|
+
type: Input
|
|
262
|
+
}], defaultValue: [{
|
|
263
|
+
type: Input
|
|
264
|
+
}], reset: [{
|
|
265
|
+
type: Input
|
|
266
|
+
}], optional: [{
|
|
267
|
+
type: Input
|
|
268
|
+
}], locked: [{
|
|
269
|
+
type: Input
|
|
270
|
+
}], displayDisabledAsLocked: [{
|
|
271
|
+
type: Input
|
|
272
|
+
}], required: [{
|
|
273
|
+
type: Input
|
|
274
|
+
}], invalid: [{
|
|
275
|
+
type: Input
|
|
276
|
+
}], valid: [{
|
|
277
|
+
type: Input
|
|
278
|
+
}], focused: [{
|
|
279
|
+
type: Input
|
|
280
|
+
}], disabled: [{
|
|
281
|
+
type: Input
|
|
282
|
+
}], ngvFocus: [{
|
|
283
|
+
type: Output
|
|
284
|
+
}], ngvBlur: [{
|
|
285
|
+
type: Output
|
|
286
|
+
}] } });
|
|
287
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-control-value-accessor.component.js","sourceRoot":"","sources":["../../../../../../libs/angular/src/v-angular/base-control-value-accessor/base-control-value-accessor.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectorRef,\n  ContentChild,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Injectable,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Self,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core'\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  NgControl,\n  ValidationErrors,\n  Validator,\n  Validators,\n} from '@angular/forms'\n\nimport { Observable, Subject } from 'rxjs'\nimport { takeUntil } from 'rxjs/operators'\n\nimport { TRANSLOCO_SCOPE, TranslocoScope } from '@ngneat/transloco'\n\n@Injectable() // Workaround for Compodoc https://github.com/compodoc/compodoc/issues/984\n@Component({ template: '' }) // Required with Angular ivy compiler\n// eslint-disable-next-line @angular-eslint/directive-class-suffix\nexport class NgvBaseControlValueAccessorComponent\n  implements AfterViewInit, OnInit, OnDestroy, ControlValueAccessor, Validator\n{\n  /** Custom template for displaying the content of the label.\n   * Specified by nesting an `<ng-template #labelTpl>Custom Label</ng-template>`.\n   */\n  @ContentChild('labelTpl', { read: TemplateRef })\n  labelContentTpl?: TemplateRef<undefined>\n\n  /** Reference to the native child input element. */\n  @ViewChild('input', { read: ElementRef }) inputRef?: ElementRef\n\n  /* ATTRIBUTES */\n\n  /** Id of the host element and is accessible by the children, automatically generated if not provided. */\n  @HostBinding('attr.id') @Input() id = (window as any).ngv?.nextId()\n  /** Name of the child input element. */\n  @Input() name?: string\n  /**\n   * Label of the child input element using the default template.\n   * Can be overwritten by specifying an `<ng-template #labelTpl>Custom Label</ng-template>`.\n   */\n  @Input() label?: string\n  /** Role of the child input element. https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Roles */\n  @Input() role?: string\n  /** Value of the child input element. Mostly used in conjunction with radio and checkboxes. */\n  @Input() value: any\n  /** An error string to be shown under invalid inputs. Overwrites any form errors. */\n  @Input() error?: string\n  /** Description of the child input element. Both visibly and as `aria-label`. */\n  @Input() description?: string\n  /** If set to true, the browser will try to automatically set focus to the child input element. */\n  @Input() autofocus = false\n  /** Deafult value of the child input element. Used when resetting child element. */\n  @Input() defaultValue?: any\n  /** If passed, the component will listen for updates and will reset its value. */\n  @Input() reset?: Observable<any>\n  /** Adds (Optional) to input label. */\n  @Input() optional?: boolean | null | undefined\n\n  private _locked: boolean | null | undefined = undefined\n  /** Hides the input borders and displays current value as a text. */\n  @Input() set locked(value: boolean | null | undefined) {\n    this._locked = value\n    this.cdr.detectChanges()\n  }\n  get locked(): boolean | null | undefined {\n    return this._locked\n  }\n  /** If set to true, using a controls disabled state will display input as locked. */\n  @Input() displayDisabledAsLocked?: boolean | null | undefined\n\n  /* STATES */\n\n  private _required: boolean | null | undefined = undefined\n  /** Override the required flag of the component. */\n  @Input() set required(value: boolean | null | undefined) {\n    this._required = value\n  }\n  /** Child input element is considered required and changes default label template accordingly. */\n  get required(): boolean | null | undefined {\n    // if required is set => return required\n    if (this._required !== undefined) return this._required\n\n    // if required can be determined from the control => return control.required\n    if (this.ngControl?.control?.validator) {\n      const validator = this.ngControl?.control?.validator(\n        {} as AbstractControl,\n      )\n      // returns true for any error that starts with required\n      return Object.keys(validator ?? {}).some((key) =>\n        key.startsWith('required'),\n      )\n    }\n\n    return\n  }\n\n  private _invalid: boolean | undefined = undefined\n  /** Override the invalid state of the component. */\n  @Input() set invalid(value: boolean) {\n    this._invalid = value\n  }\n  /** The component has the invalid state, usually decorating the elements red and shows the first error. */\n  get invalid(): boolean {\n    if (this._invalid === true || this._invalid === false) return this._invalid\n    return (\n      !!this.ngControl?.control?.invalid && this.ngControl?.control?.touched\n    )\n  }\n\n  private _valid: boolean | undefined = undefined\n  /** Override the valid state of the component. */\n  @Input() set valid(value: boolean) {\n    this._valid = value\n  }\n  /** The component has the valid state, usually decorating the elements green. */\n  get valid(): boolean {\n    if (this._valid === true || this._valid === false) return this._valid\n    return !!this.ngControl?.control?.valid && this.ngControl?.control?.touched\n  }\n\n  /** The component has the focused state, updated by the child input element's focus state. */\n  @Input() focused = false\n\n  private _disabled: boolean | undefined = undefined\n  /** Override the disabled state of the component. */\n  @Input() set disabled(value: boolean) {\n    this._disabled = value\n  }\n  /** The component has the disabled state, usually muting the colors and removes interaction. */\n  get disabled(): boolean {\n    if (this._disabled === true || this._disabled === false)\n      return this._disabled\n    return !!this.ngControl?.control?.disabled\n  }\n\n  /* TRIGGERS */\n\n  /** Emits focus events triggered by the child elements. */\n  @Output() readonly ngvFocus = new EventEmitter()\n  /** Emits focus events triggered by the child elements. */\n  @Output() readonly ngvBlur = new EventEmitter()\n\n  /* VALUE HANDLERS */\n\n  private _state: any = null\n  /** @internal */\n  protected onChange = (_: any) => {\n    // do nothing\n  }\n  /** @internal */\n  protected onTouched = () => {\n    // do nothing\n  }\n  /** @internal */\n  protected onValidatorChange: () => void = () => null\n\n  /* OTHER VARIABLES */\n  scope: string | undefined\n\n  /* LIFE CYCLE VARIABLES */\n\n  private _onDestroy$ = new Subject<boolean>()\n\n  /**\n   * Creates a new BaseControlValueAccessorComponent.\n   * @param ngControl optional FormControl provided when component is used in a form, through dependency injection.\n   * @param translocoScope optional TranslocoScope provided if component is used within a scope.\n   */\n  constructor(\n    @Self() @Optional() public ngControl: NgControl,\n    @Optional()\n    @Inject(TRANSLOCO_SCOPE)\n    protected translocoScope: TranslocoScope,\n    protected cdr: ChangeDetectorRef,\n  ) {\n    if (this.ngControl) {\n      // Note: we provide the value accessor through here, instead of\n      // the `providers` to avoid running into a circular import.\n      this.ngControl.valueAccessor = this\n    }\n\n    if (this.translocoScope) this.scope = this.translocoScope.toString()\n  }\n\n  // eslint-disable-next-line @angular-eslint/contextual-lifecycle\n  ngOnInit(): void {\n    if (this.ngControl && this.ngControl.control) {\n      this.ngControl.control.setValidators(\n        Validators.compose([this.ngControl.control.validator, this.validate]),\n      )\n    }\n\n    // if reset observable has been passed, subscribe after updates\n    this.reset?.pipe(takeUntil(this._onDestroy$)).subscribe({\n      next: () => {\n        // reset value of controller\n        this.state = this.defaultValue\n        this.onChange(this.state)\n        this.cdr.detectChanges()\n      },\n    })\n  }\n\n  // eslint-disable-next-line @angular-eslint/contextual-lifecycle\n  ngAfterViewInit(): void {\n    // if default value is set, then don't alter it. Otherwise, use\n    // current value of controller after initiation as default value\n    this.defaultValue = this.defaultValue ?? this.ngControl?.value\n  }\n\n  ngOnDestroy(): void {\n    this._onDestroy$.next(true)\n    this._onDestroy$.complete()\n  }\n\n  detectChanges(): void {\n    this.cdr.detectChanges()\n  }\n\n  /** @internal */\n  onFocus(event: Event) {\n    event.stopPropagation\n      ? event.stopPropagation()\n      : (event.cancelBubble = true)\n    this.focused = true\n    this.ngvFocus.emit(event)\n  }\n\n  /** @internal */\n  onBlur(event: Event) {\n    event.stopPropagation\n      ? event.stopPropagation()\n      : (event.cancelBubble = true)\n    this.onTouched()\n    this.focused = false\n    this.ngvBlur.emit(event)\n  }\n\n  /** Sets the focus on the actual input element. */\n  setFocus() {\n    if (this.inputRef) this.inputRef.nativeElement.focus()\n  }\n\n  // ----------------------------------------------------------------------------\n  // CONTROL VALUE ACCESSOR\n  // ----------------------------------------------------------------------------\n\n  /** Internal state/value that the native input element has.  */\n  get state() {\n    return this._state\n  }\n\n  /** Internal state/value that the native input element has.  */\n  set state(value) {\n    if (typeof value === 'undefined') value = null\n    this._state = value\n  }\n\n  /** Writes a new value to the child input element. */\n  writeValue(value: any): void {\n    this.state = value\n  }\n\n  /** Registers a callback function that is called when the child input element's value changes. */\n  registerOnChange(fn: (_: any) => object): void {\n    this.onChange = fn\n  }\n\n  /** Registers a callback function that is called when the child input element triggers on blur. */\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn\n  }\n\n  /** Function that is called by the forms API when the control status changes to or from 'DISABLED'. */\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled\n\n    // if displayDisabledAsLocked is enabled - update locked state based on disabled state\n    if (this.displayDisabledAsLocked) {\n      this.locked = isDisabled\n    }\n  }\n\n  // ----------------------------------------------------------------------------\n  // VALIDATORS\n  // ----------------------------------------------------------------------------\n\n  /** Method that performs synchronous validation against the provided control. Used for internal validation. */\n  validate(_control: AbstractControl): { [name: string]: any } | null {\n    return null\n  }\n\n  /** Registers a callback function to call when the validator inputs change. */\n  registerOnValidatorChange(fn: () => void): void {\n    this.onValidatorChange = fn\n  }\n\n  // ----------------------------------------------------------------------------\n  // HELPERS\n  // ----------------------------------------------------------------------------\n\n  /** Returns the first entry in an error object. */\n  get firstError(): { code: string; params: any } | null {\n    const errors: ValidationErrors | null = this.ngControl.errors\n    if (!errors) return null\n    const code: string = Object.keys(errors)[0]\n    return { code, params: errors[code] }\n  }\n}\n"]}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { NgvBaseControlValueAccessorComponent } from './base-control-value-accessor.component';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class NgvBaseControlValueAccessorModule {
|
|
5
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvBaseControlValueAccessorModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
6
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: NgvBaseControlValueAccessorModule, declarations: [NgvBaseControlValueAccessorComponent], exports: [NgvBaseControlValueAccessorComponent] }); }
|
|
7
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvBaseControlValueAccessorModule }); }
|
|
8
|
+
}
|
|
9
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvBaseControlValueAccessorModule, decorators: [{
|
|
10
|
+
type: NgModule,
|
|
11
|
+
args: [{
|
|
12
|
+
declarations: [NgvBaseControlValueAccessorComponent],
|
|
13
|
+
imports: [],
|
|
14
|
+
exports: [NgvBaseControlValueAccessorComponent],
|
|
15
|
+
}]
|
|
16
|
+
}] });
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1jb250cm9sLXZhbHVlLWFjY2Vzc29yLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvYW5ndWxhci9zcmMvdi1hbmd1bGFyL2Jhc2UtY29udHJvbC12YWx1ZS1hY2Nlc3Nvci9iYXNlLWNvbnRyb2wtdmFsdWUtYWNjZXNzb3IubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFDeEMsT0FBTyxFQUFFLG9DQUFvQyxFQUFFLE1BQU0seUNBQXlDLENBQUE7O0FBTzlGLE1BQU0sT0FBTyxpQ0FBaUM7K0dBQWpDLGlDQUFpQztnSEFBakMsaUNBQWlDLGlCQUo3QixvQ0FBb0MsYUFFekMsb0NBQW9DO2dIQUVuQyxpQ0FBaUM7OzRGQUFqQyxpQ0FBaUM7a0JBTDdDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsb0NBQW9DLENBQUM7b0JBQ3BELE9BQU8sRUFBRSxFQUFFO29CQUNYLE9BQU8sRUFBRSxDQUFDLG9DQUFvQyxDQUFDO2lCQUNoRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcbmltcG9ydCB7IE5ndkJhc2VDb250cm9sVmFsdWVBY2Nlc3NvckNvbXBvbmVudCB9IGZyb20gJy4vYmFzZS1jb250cm9sLXZhbHVlLWFjY2Vzc29yLmNvbXBvbmVudCdcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbTmd2QmFzZUNvbnRyb2xWYWx1ZUFjY2Vzc29yQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW10sXG4gIGV4cG9ydHM6IFtOZ3ZCYXNlQ29udHJvbFZhbHVlQWNjZXNzb3JDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBOZ3ZCYXNlQ29udHJvbFZhbHVlQWNjZXNzb3JNb2R1bGUge31cbiJdfQ==
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from './base-control-value-accessor.component';
|
|
2
|
+
export * from './base-control-value-accessor.module';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvc3JjL3YtYW5ndWxhci9iYXNlLWNvbnRyb2wtdmFsdWUtYWNjZXNzb3IvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx5Q0FBeUMsQ0FBQTtBQUN2RCxjQUFjLHNDQUFzQyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9iYXNlLWNvbnRyb2wtdmFsdWUtYWNjZXNzb3IuY29tcG9uZW50J1xuZXhwb3J0ICogZnJvbSAnLi9iYXNlLWNvbnRyb2wtdmFsdWUtYWNjZXNzb3IubW9kdWxlJ1xuIl19
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { Component, HostBinding, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "@sebgroup/green-angular/src/v-angular/external-link";
|
|
5
|
+
import * as i3 from "@angular/router";
|
|
6
|
+
export class NgvBreadcrumbsComponent {
|
|
7
|
+
constructor() {
|
|
8
|
+
/** Special property used for selecting DOM elements during automated UI testing. */
|
|
9
|
+
this.thook = 'breadcrumbs';
|
|
10
|
+
}
|
|
11
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvBreadcrumbsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
12
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NgvBreadcrumbsComponent, selector: "nggv-breadcrumbs", inputs: { thook: "thook", breadcrumbs: "breadcrumbs" }, host: { properties: { "attr.data-thook": "this.thook" } }, ngImport: i0, template: "<nav aria-label=\"Breadcrumbs\">\n <ol class=\"gds-breadcrumbs\">\n <ng-container *ngFor=\"let breadcrumb of breadcrumbs; let i = index\">\n <li [attr.aria-current]=\"i === breadcrumbs.length - 1\">\n <a\n [routerLink]=\"breadcrumb.href\"\n [external]=\"!!breadcrumb.external\"\n *ngIf=\"i < breadcrumbs.length - 1; else currentPageRef\"\n >{{ breadcrumb.title }}</a\n >\n <ng-template #currentPageRef>\n <span>{{ breadcrumb.title }}</span>\n </ng-template>\n </li>\n <li class=\"icon\" *ngIf=\"i < breadcrumbs.length - 1\">\n <svg viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M9.22817 5.19072L8.60942 5.80947C8.46255 5.95635 8.46255 6.19385 8.60942 6.34072L14.2563 12.0001L8.60942 17.6595C8.46255 17.8063 8.46255 18.0438 8.60942 18.1907L9.22817 18.8095C9.37505 18.9563 9.61255 18.9563 9.75942 18.8095L16.3032 12.2657C16.45 12.1188 16.45 11.8813 16.3032 11.7345L9.75942 5.19072C9.61255 5.04385 9.37505 5.04385 9.22817 5.19072Z\"\n fill=\"#000\"\n />\n </svg>\n </li>\n </ng-container>\n </ol>\n</nav>\n", styles: [":host ol{padding-left:0;margin-bottom:0;margin-top:0;display:flex;flex-direction:column;list-style:none;flex-direction:row!important;align-items:center;gap:4px}:host ol>li{padding-bottom:.5rem;padding-top:.5rem;border:0;display:block;position:relative}:host ol>li:before{font-weight:500;display:inline-block;left:0;position:absolute;text-align:center}:host ol>li{padding:0!important;font-weight:500}:host ol>li:before{display:none!important}:host ol>li.icon{display:flex}:host ol>li.icon>svg{height:1rem;width:1rem}:host ol a{text-decoration:underline;text-underline-offset:3px;color:#0062bc;font-weight:500;border:none;border-radius:.125rem}:host ol a:hover{text-underline-offset:2px;text-decoration-thickness:2px}:host ol a:active{text-underline-offset:1px}:host ol a:focus:not(:focus-visible){box-shadow:none;outline:0}:host ol a:focus,:host ol a:focus-within{outline-color:var(--gds-sys-color-focus-outline);outline-style:solid;outline-width:.125rem;outline-offset:.125rem}:host ol a:focus:not([aria-disabled]){color:#0092e1}:host ol a.link-history:visited{color:#673ab6}:host ol svg{width:1rem;height:1rem}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgvExternalLinkDirective, selector: "a[routerLink]", inputs: ["external"] }, { kind: "directive", type: i3.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }] }); }
|
|
13
|
+
}
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgvBreadcrumbsComponent, decorators: [{
|
|
15
|
+
type: Component,
|
|
16
|
+
args: [{ selector: 'nggv-breadcrumbs', template: "<nav aria-label=\"Breadcrumbs\">\n <ol class=\"gds-breadcrumbs\">\n <ng-container *ngFor=\"let breadcrumb of breadcrumbs; let i = index\">\n <li [attr.aria-current]=\"i === breadcrumbs.length - 1\">\n <a\n [routerLink]=\"breadcrumb.href\"\n [external]=\"!!breadcrumb.external\"\n *ngIf=\"i < breadcrumbs.length - 1; else currentPageRef\"\n >{{ breadcrumb.title }}</a\n >\n <ng-template #currentPageRef>\n <span>{{ breadcrumb.title }}</span>\n </ng-template>\n </li>\n <li class=\"icon\" *ngIf=\"i < breadcrumbs.length - 1\">\n <svg viewBox=\"0 0 24 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M9.22817 5.19072L8.60942 5.80947C8.46255 5.95635 8.46255 6.19385 8.60942 6.34072L14.2563 12.0001L8.60942 17.6595C8.46255 17.8063 8.46255 18.0438 8.60942 18.1907L9.22817 18.8095C9.37505 18.9563 9.61255 18.9563 9.75942 18.8095L16.3032 12.2657C16.45 12.1188 16.45 11.8813 16.3032 11.7345L9.75942 5.19072C9.61255 5.04385 9.37505 5.04385 9.22817 5.19072Z\"\n fill=\"#000\"\n />\n </svg>\n </li>\n </ng-container>\n </ol>\n</nav>\n", styles: [":host ol{padding-left:0;margin-bottom:0;margin-top:0;display:flex;flex-direction:column;list-style:none;flex-direction:row!important;align-items:center;gap:4px}:host ol>li{padding-bottom:.5rem;padding-top:.5rem;border:0;display:block;position:relative}:host ol>li:before{font-weight:500;display:inline-block;left:0;position:absolute;text-align:center}:host ol>li{padding:0!important;font-weight:500}:host ol>li:before{display:none!important}:host ol>li.icon{display:flex}:host ol>li.icon>svg{height:1rem;width:1rem}:host ol a{text-decoration:underline;text-underline-offset:3px;color:#0062bc;font-weight:500;border:none;border-radius:.125rem}:host ol a:hover{text-underline-offset:2px;text-decoration-thickness:2px}:host ol a:active{text-underline-offset:1px}:host ol a:focus:not(:focus-visible){box-shadow:none;outline:0}:host ol a:focus,:host ol a:focus-within{outline-color:var(--gds-sys-color-focus-outline);outline-style:solid;outline-width:.125rem;outline-offset:.125rem}:host ol a:focus:not([aria-disabled]){color:#0092e1}:host ol a.link-history:visited{color:#673ab6}:host ol svg{width:1rem;height:1rem}\n"] }]
|
|
17
|
+
}], propDecorators: { thook: [{
|
|
18
|
+
type: HostBinding,
|
|
19
|
+
args: ['attr.data-thook']
|
|
20
|
+
}, {
|
|
21
|
+
type: Input
|
|
22
|
+
}], breadcrumbs: [{
|
|
23
|
+
type: Input
|
|
24
|
+
}] } });
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnJlYWRjcnVtYnMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL3NyYy92LWFuZ3VsYXIvYnJlYWRjcnVtYnMvYnJlYWRjcnVtYnMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyL3NyYy92LWFuZ3VsYXIvYnJlYWRjcnVtYnMvYnJlYWRjcnVtYnMuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFBOzs7OztBQWdCN0QsTUFBTSxPQUFPLHVCQUF1QjtJQUxwQztRQU1FLG9GQUFvRjtRQUMzQyxVQUFLLEdBQUcsYUFBYSxDQUFBO0tBSS9EOytHQU5ZLHVCQUF1QjttR0FBdkIsdUJBQXVCLDJLQ2hCcEMsa3JDQXlCQTs7NEZEVGEsdUJBQXVCO2tCQUxuQyxTQUFTOytCQUNFLGtCQUFrQjs4QkFNYSxLQUFLO3NCQUE3QyxXQUFXO3VCQUFDLGlCQUFpQjs7c0JBQUcsS0FBSztnQkFHN0IsV0FBVztzQkFBbkIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcblxudHlwZSBCcmVhZGNydW1iID0ge1xuICAvKiogVGl0bGUgc2hvd24gZm9yIHRoZSBicmVhZGNydW1iIGxpbmsuICovXG4gIHRpdGxlOiBzdHJpbmdcbiAgLyoqIFRoZSBsaW5rIHdoaWNoIGlzIHJlZGlyZWN0ZWQgdG8gd2hlbiBjbGlja2VkLiBDYW4gYmUgcmVsYXRpdmUgd2l0aCBleHRlcm5hbCBzZXQgdG8gYGZhbHNlYC4gKi9cbiAgaHJlZjogc3RyaW5nXG4gIC8qKiBGbGFncyB0aGlzIGxpbmsgdG8gYmUgZWl0aGVyIGludGVybmFsIHVzaW5nIHJvdXRlciBsaW5rIG9yIGV4dGVybmFsIHVzaW5nIGJyb3dzZXIgbG9jYXRpb24uICovXG4gIGV4dGVybmFsPzogYm9vbGVhblxufVxuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICduZ2d2LWJyZWFkY3J1bWJzJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2JyZWFkY3J1bWJzLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vYnJlYWRjcnVtYnMuY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgTmd2QnJlYWRjcnVtYnNDb21wb25lbnQge1xuICAvKiogU3BlY2lhbCBwcm9wZXJ0eSB1c2VkIGZvciBzZWxlY3RpbmcgRE9NIGVsZW1lbnRzIGR1cmluZyBhdXRvbWF0ZWQgVUkgdGVzdGluZy4gKi9cbiAgQEhvc3RCaW5kaW5nKCdhdHRyLmRhdGEtdGhvb2snKSBASW5wdXQoKSB0aG9vayA9ICdicmVhZGNydW1icydcblxuICAvKiogTGlzdCBvZiBicmVhZGNydW1icyB0byBwcmVzZW50LiAqL1xuICBASW5wdXQoKSBicmVhZGNydW1icyE6IEJyZWFkY3J1bWJbXVxufVxuIiwiPG5hdiBhcmlhLWxhYmVsPVwiQnJlYWRjcnVtYnNcIj5cbiAgPG9sIGNsYXNzPVwiZ2RzLWJyZWFkY3J1bWJzXCI+XG4gICAgPG5nLWNvbnRhaW5lciAqbmdGb3I9XCJsZXQgYnJlYWRjcnVtYiBvZiBicmVhZGNydW1iczsgbGV0IGkgPSBpbmRleFwiPlxuICAgICAgPGxpIFthdHRyLmFyaWEtY3VycmVudF09XCJpID09PSBicmVhZGNydW1icy5sZW5ndGggLSAxXCI+XG4gICAgICAgIDxhXG4gICAgICAgICAgW3JvdXRlckxpbmtdPVwiYnJlYWRjcnVtYi5ocmVmXCJcbiAgICAgICAgICBbZXh0ZXJuYWxdPVwiISFicmVhZGNydW1iLmV4dGVybmFsXCJcbiAgICAgICAgICAqbmdJZj1cImkgPCBicmVhZGNydW1icy5sZW5ndGggLSAxOyBlbHNlIGN1cnJlbnRQYWdlUmVmXCJcbiAgICAgICAgICA+e3sgYnJlYWRjcnVtYi50aXRsZSB9fTwvYVxuICAgICAgICA+XG4gICAgICAgIDxuZy10ZW1wbGF0ZSAjY3VycmVudFBhZ2VSZWY+XG4gICAgICAgICAgPHNwYW4+e3sgYnJlYWRjcnVtYi50aXRsZSB9fTwvc3Bhbj5cbiAgICAgICAgPC9uZy10ZW1wbGF0ZT5cbiAgICAgIDwvbGk+XG4gICAgICA8bGkgY2xhc3M9XCJpY29uXCIgKm5nSWY9XCJpIDwgYnJlYWRjcnVtYnMubGVuZ3RoIC0gMVwiPlxuICAgICAgICA8c3ZnIHZpZXdCb3g9XCIwIDAgMjQgMjRcIiBmaWxsPVwibm9uZVwiIHhtbG5zPVwiaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmdcIj5cbiAgICAgICAgICA8cGF0aFxuICAgICAgICAgICAgZD1cIk05LjIyODE3IDUuMTkwNzJMOC42MDk0MiA1LjgwOTQ3QzguNDYyNTUgNS45NTYzNSA4LjQ2MjU1IDYuMTkzODUgOC42MDk0MiA2LjM0MDcyTDE0LjI1NjMgMTIuMDAwMUw4LjYwOTQyIDE3LjY1OTVDOC40NjI1NSAxNy44MDYzIDguNDYyNTUgMTguMDQzOCA4LjYwOTQyIDE4LjE5MDdMOS4yMjgxNyAxOC44MDk1QzkuMzc1MDUgMTguOTU2MyA5LjYxMjU1IDE4Ljk1NjMgOS43NTk0MiAxOC44MDk1TDE2LjMwMzIgMTIuMjY1N0MxNi40NSAxMi4xMTg4IDE2LjQ1IDExLjg4MTMgMTYuMzAzMiAxMS43MzQ1TDkuNzU5NDIgNS4xOTA3MkM5LjYxMjU1IDUuMDQzODUgOS4zNzUwNSA1LjA0Mzg1IDkuMjI4MTcgNS4xOTA3MlpcIlxuICAgICAgICAgICAgZmlsbD1cIiMwMDBcIlxuICAgICAgICAgIC8+XG4gICAgICAgIDwvc3ZnPlxuICAgICAgPC9saT5cbiAgICA8L25nLWNvbnRhaW5lcj5cbiAgPC9vbD5cbjwvbmF2PlxuIl19
|