@ni/nimble-angular 17.1.17 → 17.1.18
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/directives/combobox/nimble-combobox-control-value-accessor.directive.d.ts +6 -2
- package/directives/list-option/nimble-combobox-list-option.directive.d.ts +3 -4
- package/esm2020/directives/combobox/nimble-combobox-control-value-accessor.directive.mjs +12 -1
- package/esm2020/directives/list-option/nimble-combobox-list-option.directive.mjs +5 -9
- package/fesm2015/ni-nimble-angular.mjs +15 -8
- package/fesm2015/ni-nimble-angular.mjs.map +1 -1
- package/fesm2020/ni-nimble-angular.mjs +15 -8
- package/fesm2020/ni-nimble-angular.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -1,5 +1,6 @@
|
|
|
1
|
-
import { ElementRef, Renderer2 } from '@angular/core';
|
|
1
|
+
import { AfterViewChecked, ElementRef, Renderer2 } from '@angular/core';
|
|
2
2
|
import { ControlValueAccessor } from '@angular/forms';
|
|
3
|
+
import type { ListOption } from '../../public-api';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
/**
|
|
5
6
|
* @description
|
|
@@ -15,7 +16,7 @@ export declare type OptionNotFound = typeof OPTION_NOT_FOUND;
|
|
|
15
16
|
* unique. When this isn't the case the behavior is undefined. Additionally, it is expected
|
|
16
17
|
* that when using 'ngModel' that each list-option bind a value via 'ngValue', and not 'value'.
|
|
17
18
|
*/
|
|
18
|
-
export declare class NimbleComboboxControlValueAccessorDirective implements ControlValueAccessor {
|
|
19
|
+
export declare class NimbleComboboxControlValueAccessorDirective implements ControlValueAccessor, AfterViewChecked {
|
|
19
20
|
private readonly _renderer;
|
|
20
21
|
private readonly _elementRef;
|
|
21
22
|
/**
|
|
@@ -26,6 +27,7 @@ export declare class NimbleComboboxControlValueAccessorDirective implements Cont
|
|
|
26
27
|
set compareWith(fn: (o1: unknown, o2: unknown) => boolean);
|
|
27
28
|
private readonly _optionMap;
|
|
28
29
|
private _modelValue;
|
|
30
|
+
private _optionUpdateQueue;
|
|
29
31
|
private _compareWith;
|
|
30
32
|
/**
|
|
31
33
|
* The registered callback function called when a change or input event occurs on the input
|
|
@@ -39,6 +41,7 @@ export declare class NimbleComboboxControlValueAccessorDirective implements Cont
|
|
|
39
41
|
*/
|
|
40
42
|
private onTouched;
|
|
41
43
|
constructor(_renderer: Renderer2, _elementRef: ElementRef);
|
|
44
|
+
ngAfterViewChecked(): void;
|
|
42
45
|
/**
|
|
43
46
|
* Updates the underlying nimble-combobox value with the expected display string.
|
|
44
47
|
* @param value The ngValue set on the nimble-combobox
|
|
@@ -70,6 +73,7 @@ export declare class NimbleComboboxControlValueAccessorDirective implements Cont
|
|
|
70
73
|
* @internal
|
|
71
74
|
*/
|
|
72
75
|
removeOption(displayValue: string): void;
|
|
76
|
+
queueOptionUpdate(listOption: ListOption, modelValue: unknown): void;
|
|
73
77
|
private updateDisplayValue;
|
|
74
78
|
private getValueStringFromValue;
|
|
75
79
|
/**
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ElementRef, Renderer2, AfterViewInit, OnDestroy
|
|
1
|
+
import { ElementRef, Renderer2, AfterViewInit, OnDestroy } from '@angular/core';
|
|
2
2
|
import type { ListOption } from '@ni/nimble-components/dist/esm/list-option';
|
|
3
3
|
import { BooleanValueOrAttribute } from '@ni/nimble-angular/internal-utilities';
|
|
4
4
|
import { NimbleComboboxControlValueAccessorDirective } from '../combobox/nimble-combobox-control-value-accessor.directive';
|
|
@@ -9,7 +9,6 @@ import * as i0 from "@angular/core";
|
|
|
9
9
|
export declare class NimbleComboboxListOptionDirective implements AfterViewInit, OnDestroy {
|
|
10
10
|
private readonly elementRef;
|
|
11
11
|
private readonly renderer;
|
|
12
|
-
private readonly changeDetector;
|
|
13
12
|
private readonly combobox?;
|
|
14
13
|
get disabled(): boolean;
|
|
15
14
|
set disabled(value: BooleanValueOrAttribute);
|
|
@@ -20,10 +19,10 @@ export declare class NimbleComboboxListOptionDirective implements AfterViewInit,
|
|
|
20
19
|
set ngValue(value: unknown);
|
|
21
20
|
private _modelValue;
|
|
22
21
|
private _currentTextContent;
|
|
23
|
-
constructor(elementRef: ElementRef<ListOption>, renderer: Renderer2,
|
|
22
|
+
constructor(elementRef: ElementRef<ListOption>, renderer: Renderer2, combobox?: NimbleComboboxControlValueAccessorDirective | undefined);
|
|
24
23
|
ngAfterViewInit(): void;
|
|
25
24
|
ngOnDestroy(): void;
|
|
26
25
|
private updateComboboxValue;
|
|
27
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<NimbleComboboxListOptionDirective, [null, null,
|
|
26
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NimbleComboboxListOptionDirective, [null, null, { optional: true; host: true; }]>;
|
|
28
27
|
static ɵdir: i0.ɵɵDirectiveDeclaration<NimbleComboboxListOptionDirective, "nimble-list-option", never, { "disabled": "disabled"; "ngValue": "ngValue"; }, {}, never, never, false>;
|
|
29
28
|
}
|
|
@@ -19,6 +19,7 @@ export class NimbleComboboxControlValueAccessorDirective {
|
|
|
19
19
|
this._renderer = _renderer;
|
|
20
20
|
this._elementRef = _elementRef;
|
|
21
21
|
this._optionMap = new Map();
|
|
22
|
+
this._optionUpdateQueue = [];
|
|
22
23
|
this._compareWith = Object.is;
|
|
23
24
|
}
|
|
24
25
|
/**
|
|
@@ -32,6 +33,12 @@ export class NimbleComboboxControlValueAccessorDirective {
|
|
|
32
33
|
}
|
|
33
34
|
this._compareWith = fn;
|
|
34
35
|
}
|
|
36
|
+
ngAfterViewChecked() {
|
|
37
|
+
for (const updateValue of this._optionUpdateQueue) {
|
|
38
|
+
this.addOption(updateValue.listOption.text, updateValue.modelValue);
|
|
39
|
+
}
|
|
40
|
+
this._optionUpdateQueue = [];
|
|
41
|
+
}
|
|
35
42
|
/**
|
|
36
43
|
* Updates the underlying nimble-combobox value with the expected display string.
|
|
37
44
|
* @param value The ngValue set on the nimble-combobox
|
|
@@ -81,6 +88,10 @@ export class NimbleComboboxControlValueAccessorDirective {
|
|
|
81
88
|
removeOption(displayValue) {
|
|
82
89
|
this._optionMap.delete(displayValue);
|
|
83
90
|
}
|
|
91
|
+
queueOptionUpdate(listOption, modelValue) {
|
|
92
|
+
this.removeOption(listOption.text);
|
|
93
|
+
this._optionUpdateQueue.push({ listOption, modelValue });
|
|
94
|
+
}
|
|
84
95
|
updateDisplayValue() {
|
|
85
96
|
const valueAsString = this.getValueStringFromValue(this._modelValue);
|
|
86
97
|
this.setProperty('value', valueAsString ?? '');
|
|
@@ -130,4 +141,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
130
141
|
type: HostListener,
|
|
131
142
|
args: ['blur']
|
|
132
143
|
}] } });
|
|
133
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nimble-combobox-control-value-accessor.directive.js","sourceRoot":"","sources":["../../../../../../projects/ni/nimble-angular/src/directives/combobox/nimble-combobox-control-value-accessor.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, forwardRef, HostListener, Input, Renderer2 } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n/**\n* @description\n* This symbol instance will be returned when the value input of the Combobox is set\n* to a value not found in the set of options.\n*/\nexport const OPTION_NOT_FOUND: unique symbol = Symbol('not found');\nexport type OptionNotFound = typeof OPTION_NOT_FOUND;\n\n/**\n * Control Value Accessor implementation to target combobox inputs.\n * @description\n * The expectation when binding value via 'ngModel', is that the content in each list-option be\n * unique. When this isn't the case the behavior is undefined. Additionally, it is expected\n * that when using 'ngModel' that each list-option bind a value via 'ngValue', and not 'value'.\n */\n@Directive({\n    selector:\n      'nimble-combobox[formControlName],nimble-combobox[formControl],nimble-combobox[ngModel]',\n    providers: [{\n        provide: NG_VALUE_ACCESSOR,\n        useExisting: forwardRef(() => NimbleComboboxControlValueAccessorDirective),\n        multi: true\n    }]\n})\nexport class NimbleComboboxControlValueAccessorDirective implements ControlValueAccessor {\n    /**\n     * @description\n     * Tracks the option comparison algorithm for tracking identities when\n     * checking for changes.\n     */\n    @Input()\n    public set compareWith(fn: (o1: unknown, o2: unknown) => boolean) {\n        if (typeof fn !== 'function') {\n            throw new Error(`compareWith must be a function, but received ${JSON.stringify(fn)}`);\n        }\n        this._compareWith = fn;\n    }\n\n    private readonly _optionMap: Map<string, unknown> = new Map<string, unknown>();\n\n    private _modelValue: unknown;\n\n    private _compareWith: (o1: unknown, o2: unknown) => boolean = Object.is;\n\n    /**\n     * The registered callback function called when a change or input event occurs on the input\n     * element.\n     * @nodoc\n     */\n    @HostListener('input', ['$event.target.control.value]'])\n    @HostListener('change', ['$event.target.value]'])\n    private onChange: (_: string) => void;\n\n    /**\n      * The registered callback function called when a blur event occurs on the input element.\n      * @nodoc\n      */\n    @HostListener('blur')\n    private onTouched: () => void;\n\n    public constructor(private readonly _renderer: Renderer2, private readonly _elementRef: ElementRef) {}\n\n    /**\n     * Updates the underlying nimble-combobox value with the expected display string.\n     * @param value The ngValue set on the nimble-combobox\n     */\n    public writeValue(value: unknown): void {\n        this._modelValue = value;\n        this.updateDisplayValue();\n    }\n\n    /**\n     * Registers a function called when the control value changes.\n     * @nodoc\n     */\n    public registerOnChange(fn: (value: unknown) => void): void {\n        this.onChange = (valueString: string): void => {\n            const modelValue = this._optionMap.has(valueString) ? this._optionMap.get(valueString) : OPTION_NOT_FOUND;\n            this._modelValue = modelValue;\n            fn(modelValue);\n        };\n    }\n\n    /**\n     * Registers a function called when the control is touched.\n     * @nodoc\n     */\n    public registerOnTouched(fn: () => void): void {\n        this.onTouched = fn;\n    }\n\n    /**\n     * @description\n     * Function that is called by the forms API when the control status changes to\n     * or from 'DISABLED'. Depending on the status, it enables or disables the\n     * combobox.\n     * @param isDisabled The disabled status to set on the combobox\n     */\n    public setDisabledState(isDisabled: boolean): void {\n        this.setProperty('disabled', isDisabled);\n    }\n\n    /**\n     * @internal\n     */\n    public addOption(displayValue: string, modelValue: unknown): void {\n        this._optionMap.set(displayValue, modelValue);\n        this.updateDisplayValue();\n    }\n\n    /**\n     * @internal\n     */\n    public removeOption(displayValue: string): void {\n        this._optionMap.delete(displayValue);\n    }\n\n    private updateDisplayValue(): void {\n        const valueAsString = this.getValueStringFromValue(this._modelValue);\n        this.setProperty('value', valueAsString ?? '');\n    }\n\n    private getValueStringFromValue(value: unknown): string | undefined {\n        for (const [optionKey, optionValue] of this._optionMap.entries()) {\n            if (this._compareWith(optionValue, value)) {\n                return optionKey;\n            }\n        }\n        return undefined;\n    }\n\n    /**\n     * Helper method that sets a property on a target element using the current Renderer\n     * implementation.\n     * @nodoc\n     */\n    private setProperty(key: string, value: unknown): void {\n        this._renderer.setProperty(this._elementRef.nativeElement, key, value);\n    }\n}\n"]}
|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nimble-combobox-control-value-accessor.directive.js","sourceRoot":"","sources":["../../../../../../projects/ni/nimble-angular/src/directives/combobox/nimble-combobox-control-value-accessor.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewChecked, Directive, ElementRef, forwardRef, HostListener, Input, Renderer2 } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport type { ListOption } from '../../public-api';\n\n/**\n* @description\n* This symbol instance will be returned when the value input of the Combobox is set\n* to a value not found in the set of options.\n*/\nexport const OPTION_NOT_FOUND: unique symbol = Symbol('not found');\nexport type OptionNotFound = typeof OPTION_NOT_FOUND;\n\n/**\n * Control Value Accessor implementation to target combobox inputs.\n * @description\n * The expectation when binding value via 'ngModel', is that the content in each list-option be\n * unique. When this isn't the case the behavior is undefined. Additionally, it is expected\n * that when using 'ngModel' that each list-option bind a value via 'ngValue', and not 'value'.\n */\n@Directive({\n    selector:\n      'nimble-combobox[formControlName],nimble-combobox[formControl],nimble-combobox[ngModel]',\n    providers: [{\n        provide: NG_VALUE_ACCESSOR,\n        useExisting: forwardRef(() => NimbleComboboxControlValueAccessorDirective),\n        multi: true\n    }]\n})\nexport class NimbleComboboxControlValueAccessorDirective implements ControlValueAccessor, AfterViewChecked {\n    /**\n     * @description\n     * Tracks the option comparison algorithm for tracking identities when\n     * checking for changes.\n     */\n    @Input()\n    public set compareWith(fn: (o1: unknown, o2: unknown) => boolean) {\n        if (typeof fn !== 'function') {\n            throw new Error(`compareWith must be a function, but received ${JSON.stringify(fn)}`);\n        }\n        this._compareWith = fn;\n    }\n\n    private readonly _optionMap: Map<string, unknown> = new Map<string, unknown>();\n\n    private _modelValue: unknown;\n\n    private _optionUpdateQueue: { listOption: ListOption, modelValue: unknown }[] = [];\n\n    private _compareWith: (o1: unknown, o2: unknown) => boolean = Object.is;\n\n    /**\n     * The registered callback function called when a change or input event occurs on the input\n     * element.\n     * @nodoc\n     */\n    @HostListener('input', ['$event.target.control.value]'])\n    @HostListener('change', ['$event.target.value]'])\n    private onChange: (_: string) => void;\n\n    /**\n      * The registered callback function called when a blur event occurs on the input element.\n      * @nodoc\n      */\n    @HostListener('blur')\n    private onTouched: () => void;\n\n    public constructor(\n        private readonly _renderer: Renderer2,\n        private readonly _elementRef: ElementRef\n    ) {}\n\n    public ngAfterViewChecked(): void {\n        for (const updateValue of this._optionUpdateQueue) {\n            this.addOption(updateValue.listOption.text, updateValue.modelValue);\n        }\n        this._optionUpdateQueue = [];\n    }\n\n    /**\n     * Updates the underlying nimble-combobox value with the expected display string.\n     * @param value The ngValue set on the nimble-combobox\n     */\n    public writeValue(value: unknown): void {\n        this._modelValue = value;\n        this.updateDisplayValue();\n    }\n\n    /**\n     * Registers a function called when the control value changes.\n     * @nodoc\n     */\n    public registerOnChange(fn: (value: unknown) => void): void {\n        this.onChange = (valueString: string): void => {\n            const modelValue = this._optionMap.has(valueString) ? this._optionMap.get(valueString) : OPTION_NOT_FOUND;\n            this._modelValue = modelValue;\n            fn(modelValue);\n        };\n    }\n\n    /**\n     * Registers a function called when the control is touched.\n     * @nodoc\n     */\n    public registerOnTouched(fn: () => void): void {\n        this.onTouched = fn;\n    }\n\n    /**\n     * @description\n     * Function that is called by the forms API when the control status changes to\n     * or from 'DISABLED'. Depending on the status, it enables or disables the\n     * combobox.\n     * @param isDisabled The disabled status to set on the combobox\n     */\n    public setDisabledState(isDisabled: boolean): void {\n        this.setProperty('disabled', isDisabled);\n    }\n\n    /**\n     * @internal\n     */\n    public addOption(displayValue: string, modelValue: unknown): void {\n        this._optionMap.set(displayValue, modelValue);\n        this.updateDisplayValue();\n    }\n\n    /**\n     * @internal\n     */\n    public removeOption(displayValue: string): void {\n        this._optionMap.delete(displayValue);\n    }\n\n    public queueOptionUpdate(listOption: ListOption, modelValue: unknown): void {\n        this.removeOption(listOption.text);\n        this._optionUpdateQueue.push({ listOption, modelValue });\n    }\n\n    private updateDisplayValue(): void {\n        const valueAsString = this.getValueStringFromValue(this._modelValue);\n        this.setProperty('value', valueAsString ?? '');\n    }\n\n    private getValueStringFromValue(value: unknown): string | undefined {\n        for (const [optionKey, optionValue] of this._optionMap.entries()) {\n            if (this._compareWith(optionValue, value)) {\n                return optionKey;\n            }\n        }\n        return undefined;\n    }\n\n    /**\n     * Helper method that sets a property on a target element using the current Renderer\n     * implementation.\n     * @nodoc\n     */\n    private setProperty(key: string, value: unknown): void {\n        this._renderer.setProperty(this._elementRef.nativeElement, key, value);\n    }\n}\n"]}
|
|
@@ -7,10 +7,9 @@ import * as i1 from "../combobox/nimble-combobox-control-value-accessor.directiv
|
|
|
7
7
|
* Directive to provide Angular integration for the list option when used with a combobox.
|
|
8
8
|
*/
|
|
9
9
|
export class NimbleComboboxListOptionDirective {
|
|
10
|
-
constructor(elementRef, renderer,
|
|
10
|
+
constructor(elementRef, renderer, combobox) {
|
|
11
11
|
this.elementRef = elementRef;
|
|
12
12
|
this.renderer = renderer;
|
|
13
|
-
this.changeDetector = changeDetector;
|
|
14
13
|
this.combobox = combobox;
|
|
15
14
|
this._modelValue = undefined;
|
|
16
15
|
}
|
|
@@ -42,20 +41,17 @@ export class NimbleComboboxListOptionDirective {
|
|
|
42
41
|
}
|
|
43
42
|
}
|
|
44
43
|
updateComboboxValue(value) {
|
|
45
|
-
this.combobox.
|
|
46
|
-
this.changeDetector.detectChanges();
|
|
47
|
-
this._currentTextContent = this.elementRef.nativeElement.text;
|
|
48
|
-
this.combobox.addOption(this._currentTextContent, value);
|
|
44
|
+
this.combobox.queueOptionUpdate(this.elementRef.nativeElement, value);
|
|
49
45
|
}
|
|
50
46
|
}
|
|
51
|
-
NimbleComboboxListOptionDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NimbleComboboxListOptionDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token:
|
|
47
|
+
NimbleComboboxListOptionDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NimbleComboboxListOptionDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: NimbleComboboxControlValueAccessorDirective, host: true, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
|
|
52
48
|
NimbleComboboxListOptionDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.3.0", type: NimbleComboboxListOptionDirective, selector: "nimble-list-option", inputs: { disabled: "disabled", ngValue: "ngValue" }, ngImport: i0 });
|
|
53
49
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NimbleComboboxListOptionDirective, decorators: [{
|
|
54
50
|
type: Directive,
|
|
55
51
|
args: [{
|
|
56
52
|
selector: 'nimble-list-option'
|
|
57
53
|
}]
|
|
58
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type:
|
|
54
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.NimbleComboboxControlValueAccessorDirective, decorators: [{
|
|
59
55
|
type: Inject,
|
|
60
56
|
args: [NimbleComboboxControlValueAccessorDirective]
|
|
61
57
|
}, {
|
|
@@ -67,4 +63,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
67
63
|
}], ngValue: [{
|
|
68
64
|
type: Input
|
|
69
65
|
}] } });
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmltYmxlLWNvbWJvYm94LWxpc3Qtb3B0aW9uLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pL25pbWJsZS1hbmd1bGFyL3NyYy9kaXJlY3RpdmVzL2xpc3Qtb3B0aW9uL25pbWJsZS1jb21ib2JveC1saXN0LW9wdGlvbi5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBYyxJQUFJLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxRQUFRLEVBQXVDLE1BQU0sZUFBZSxDQUFDO0FBRTFILE9BQU8sRUFBMkIsaUJBQWlCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUNuRyxPQUFPLEVBQUUsMkNBQTJDLEVBQUUsTUFBTSw4REFBOEQsQ0FBQzs7O0FBRTNIOztHQUVHO0FBSUgsTUFBTSxPQUFPLGlDQUFpQztJQXdCMUMsWUFDcUIsVUFBa0MsRUFDbEMsUUFBbUIsRUFDc0QsUUFBc0Q7UUFGL0gsZUFBVSxHQUFWLFVBQVUsQ0FBd0I7UUFDbEMsYUFBUSxHQUFSLFFBQVEsQ0FBVztRQUNzRCxhQUFRLEdBQVIsUUFBUSxDQUE4QztRQU41SSxnQkFBVyxHQUFZLFNBQVMsQ0FBQztJQU9yQyxDQUFDO0lBM0JMLElBQVcsUUFBUTtRQUNmLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDO0lBQ2xELENBQUM7SUFFRCxJQUFvQixRQUFRLENBQUMsS0FBOEI7UUFDdkQsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLEVBQUUsVUFBVSxFQUFFLGlCQUFpQixDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7SUFDbkcsQ0FBQztJQUVEOzs7T0FHRztJQUNILElBQ1csT0FBTyxDQUFDLEtBQWM7UUFDN0IsSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2YsSUFBSSxDQUFDLFdBQVcsR0FBRyxLQUFLLENBQUM7WUFDekIsSUFBSSxDQUFDLG1CQUFtQixDQUFDLEtBQUssQ0FBQyxDQUFDO1NBQ25DO0lBQ0wsQ0FBQztJQVdNLGVBQWU7UUFDbEIsSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2YsSUFBSSxDQUFDLG1CQUFtQixHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQztZQUM5RCxJQUFJLENBQUMsUUFBUSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsbUJBQW1CLEVBQUUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1NBQ3ZFO0lBQ0wsQ0FBQztJQUVNLFdBQVc7UUFDZCxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDZixJQUFJLENBQUMsUUFBUSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsQ0FBQztTQUN4RDtJQUNMLENBQUM7SUFFTyxtQkFBbUIsQ0FBQyxLQUFjO1FBQ3RDLElBQUksQ0FBQyxRQUFTLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDM0UsQ0FBQzs7OEhBN0NRLGlDQUFpQyxxRUEyQjlCLDJDQUEyQztrSEEzQjlDLGlDQUFpQzsyRkFBakMsaUNBQWlDO2tCQUg3QyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxvQkFBb0I7aUJBQ2pDOzswQkE0QlEsTUFBTTsyQkFBQywyQ0FBMkM7OzBCQUFHLFFBQVE7OzBCQUFJLElBQUk7NENBdEJ0RCxRQUFRO3NCQUEzQixLQUFLO2dCQVNLLE9BQU87c0JBRGpCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIEhvc3QsIEluamVjdCwgSW5wdXQsIE9wdGlvbmFsLCBSZW5kZXJlcjIsIEFmdGVyVmlld0luaXQsIE9uRGVzdHJveSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHR5cGUgeyBMaXN0T3B0aW9uIH0gZnJvbSAnQG5pL25pbWJsZS1jb21wb25lbnRzL2Rpc3QvZXNtL2xpc3Qtb3B0aW9uJztcbmltcG9ydCB7IEJvb2xlYW5WYWx1ZU9yQXR0cmlidXRlLCB0b0Jvb2xlYW5Qcm9wZXJ0eSB9IGZyb20gJ0BuaS9uaW1ibGUtYW5ndWxhci9pbnRlcm5hbC11dGlsaXRpZXMnO1xuaW1wb3J0IHsgTmltYmxlQ29tYm9ib3hDb250cm9sVmFsdWVBY2Nlc3NvckRpcmVjdGl2ZSB9IGZyb20gJy4uL2NvbWJvYm94L25pbWJsZS1jb21ib2JveC1jb250cm9sLXZhbHVlLWFjY2Vzc29yLmRpcmVjdGl2ZSc7XG5cbi8qKlxuICogRGlyZWN0aXZlIHRvIHByb3ZpZGUgQW5ndWxhciBpbnRlZ3JhdGlvbiBmb3IgdGhlIGxpc3Qgb3B0aW9uIHdoZW4gdXNlZCB3aXRoIGEgY29tYm9ib3guXG4gKi9cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnbmltYmxlLWxpc3Qtb3B0aW9uJ1xufSlcbmV4cG9ydCBjbGFzcyBOaW1ibGVDb21ib2JveExpc3RPcHRpb25EaXJlY3RpdmUgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0LCBPbkRlc3Ryb3kge1xuICAgIHB1YmxpYyBnZXQgZGlzYWJsZWQoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiB0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudC5kaXNhYmxlZDtcbiAgICB9XG5cbiAgICBASW5wdXQoKSBwdWJsaWMgc2V0IGRpc2FibGVkKHZhbHVlOiBCb29sZWFuVmFsdWVPckF0dHJpYnV0ZSkge1xuICAgICAgICB0aGlzLnJlbmRlcmVyLnNldFByb3BlcnR5KHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LCAnZGlzYWJsZWQnLCB0b0Jvb2xlYW5Qcm9wZXJ0eSh2YWx1ZSkpO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIEBkZXNjcmlwdGlvblxuICAgICAqIFRyYWNrcyB0aGUgdmFsdWUgYm91bmQgdG8gdGhlIG9wdGlvbiBlbGVtZW50LlxuICAgICAqL1xuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIHNldCBuZ1ZhbHVlKHZhbHVlOiB1bmtub3duKSB7XG4gICAgICAgIGlmICh0aGlzLmNvbWJvYm94KSB7XG4gICAgICAgICAgICB0aGlzLl9tb2RlbFZhbHVlID0gdmFsdWU7XG4gICAgICAgICAgICB0aGlzLnVwZGF0ZUNvbWJvYm94VmFsdWUodmFsdWUpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBfbW9kZWxWYWx1ZTogdW5rbm93biA9IHVuZGVmaW5lZDtcbiAgICBwcml2YXRlIF9jdXJyZW50VGV4dENvbnRlbnQ6IHN0cmluZztcblxuICAgIHB1YmxpYyBjb25zdHJ1Y3RvcihcbiAgICAgICAgcHJpdmF0ZSByZWFkb25seSBlbGVtZW50UmVmOiBFbGVtZW50UmVmPExpc3RPcHRpb24+LFxuICAgICAgICBwcml2YXRlIHJlYWRvbmx5IHJlbmRlcmVyOiBSZW5kZXJlcjIsXG4gICAgICAgIEBJbmplY3QoTmltYmxlQ29tYm9ib3hDb250cm9sVmFsdWVBY2Nlc3NvckRpcmVjdGl2ZSkgQE9wdGlvbmFsKCkgQEhvc3QoKSBwcml2YXRlIHJlYWRvbmx5IGNvbWJvYm94PzogTmltYmxlQ29tYm9ib3hDb250cm9sVmFsdWVBY2Nlc3NvckRpcmVjdGl2ZVxuICAgICkgeyB9XG5cbiAgICBwdWJsaWMgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xuICAgICAgICBpZiAodGhpcy5jb21ib2JveCkge1xuICAgICAgICAgICAgdGhpcy5fY3VycmVudFRleHRDb250ZW50ID0gdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQudGV4dDtcbiAgICAgICAgICAgIHRoaXMuY29tYm9ib3guYWRkT3B0aW9uKHRoaXMuX2N1cnJlbnRUZXh0Q29udGVudCwgdGhpcy5fbW9kZWxWYWx1ZSk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBwdWJsaWMgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgICAgIGlmICh0aGlzLmNvbWJvYm94KSB7XG4gICAgICAgICAgICB0aGlzLmNvbWJvYm94LnJlbW92ZU9wdGlvbih0aGlzLl9jdXJyZW50VGV4dENvbnRlbnQpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHJpdmF0ZSB1cGRhdGVDb21ib2JveFZhbHVlKHZhbHVlOiB1bmtub3duKTogdm9pZCB7XG4gICAgICAgIHRoaXMuY29tYm9ib3ghLnF1ZXVlT3B0aW9uVXBkYXRlKHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LCB2YWx1ZSk7XG4gICAgfVxufVxuIl19
|
|
@@ -1242,6 +1242,7 @@ class NimbleComboboxControlValueAccessorDirective {
|
|
|
1242
1242
|
this._renderer = _renderer;
|
|
1243
1243
|
this._elementRef = _elementRef;
|
|
1244
1244
|
this._optionMap = new Map();
|
|
1245
|
+
this._optionUpdateQueue = [];
|
|
1245
1246
|
this._compareWith = Object.is;
|
|
1246
1247
|
}
|
|
1247
1248
|
/**
|
|
@@ -1255,6 +1256,12 @@ class NimbleComboboxControlValueAccessorDirective {
|
|
|
1255
1256
|
}
|
|
1256
1257
|
this._compareWith = fn;
|
|
1257
1258
|
}
|
|
1259
|
+
ngAfterViewChecked() {
|
|
1260
|
+
for (const updateValue of this._optionUpdateQueue) {
|
|
1261
|
+
this.addOption(updateValue.listOption.text, updateValue.modelValue);
|
|
1262
|
+
}
|
|
1263
|
+
this._optionUpdateQueue = [];
|
|
1264
|
+
}
|
|
1258
1265
|
/**
|
|
1259
1266
|
* Updates the underlying nimble-combobox value with the expected display string.
|
|
1260
1267
|
* @param value The ngValue set on the nimble-combobox
|
|
@@ -1304,6 +1311,10 @@ class NimbleComboboxControlValueAccessorDirective {
|
|
|
1304
1311
|
removeOption(displayValue) {
|
|
1305
1312
|
this._optionMap.delete(displayValue);
|
|
1306
1313
|
}
|
|
1314
|
+
queueOptionUpdate(listOption, modelValue) {
|
|
1315
|
+
this.removeOption(listOption.text);
|
|
1316
|
+
this._optionUpdateQueue.push({ listOption, modelValue });
|
|
1317
|
+
}
|
|
1307
1318
|
updateDisplayValue() {
|
|
1308
1319
|
const valueAsString = this.getValueStringFromValue(this._modelValue);
|
|
1309
1320
|
this.setProperty('value', valueAsString !== null && valueAsString !== void 0 ? valueAsString : '');
|
|
@@ -6497,10 +6508,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
6497
6508
|
* Directive to provide Angular integration for the list option when used with a combobox.
|
|
6498
6509
|
*/
|
|
6499
6510
|
class NimbleComboboxListOptionDirective {
|
|
6500
|
-
constructor(elementRef, renderer,
|
|
6511
|
+
constructor(elementRef, renderer, combobox) {
|
|
6501
6512
|
this.elementRef = elementRef;
|
|
6502
6513
|
this.renderer = renderer;
|
|
6503
|
-
this.changeDetector = changeDetector;
|
|
6504
6514
|
this.combobox = combobox;
|
|
6505
6515
|
this._modelValue = undefined;
|
|
6506
6516
|
}
|
|
@@ -6532,13 +6542,10 @@ class NimbleComboboxListOptionDirective {
|
|
|
6532
6542
|
}
|
|
6533
6543
|
}
|
|
6534
6544
|
updateComboboxValue(value) {
|
|
6535
|
-
this.combobox.
|
|
6536
|
-
this.changeDetector.detectChanges();
|
|
6537
|
-
this._currentTextContent = this.elementRef.nativeElement.text;
|
|
6538
|
-
this.combobox.addOption(this._currentTextContent, value);
|
|
6545
|
+
this.combobox.queueOptionUpdate(this.elementRef.nativeElement, value);
|
|
6539
6546
|
}
|
|
6540
6547
|
}
|
|
6541
|
-
NimbleComboboxListOptionDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NimbleComboboxListOptionDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token:
|
|
6548
|
+
NimbleComboboxListOptionDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NimbleComboboxListOptionDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: NimbleComboboxControlValueAccessorDirective, host: true, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
|
|
6542
6549
|
NimbleComboboxListOptionDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.3.0", type: NimbleComboboxListOptionDirective, selector: "nimble-list-option", inputs: { disabled: "disabled", ngValue: "ngValue" }, ngImport: i0 });
|
|
6543
6550
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NimbleComboboxListOptionDirective, decorators: [{
|
|
6544
6551
|
type: Directive,
|
|
@@ -6546,7 +6553,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
6546
6553
|
selector: 'nimble-list-option'
|
|
6547
6554
|
}]
|
|
6548
6555
|
}], ctorParameters: function () {
|
|
6549
|
-
return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type:
|
|
6556
|
+
return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: NimbleComboboxControlValueAccessorDirective, decorators: [{
|
|
6550
6557
|
type: Inject,
|
|
6551
6558
|
args: [NimbleComboboxControlValueAccessorDirective]
|
|
6552
6559
|
}, {
|