@ni/nimble-angular 7.4.0 → 8.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/ni-nimble-angular.umd.js +244 -57
- package/bundles/ni-nimble-angular.umd.js.map +1 -1
- package/directives/combobox/nimble-combobox-control-value-accessor.directive.d.ts +61 -7
- package/directives/list-option/nimble-combobox-list-option.directive.d.ts +29 -0
- package/directives/list-option/nimble-list-option.module.d.ts +6 -4
- package/directives/list-option/{nimble-list-option.directive.d.ts → nimble-select-list-option.directive.d.ts} +4 -5
- package/directives/select/nimble-select.directive.d.ts +11 -1
- package/esm2015/directives/combobox/nimble-combobox-control-value-accessor.directive.js +87 -20
- package/esm2015/directives/combobox/nimble-combobox.directive.js +1 -1
- package/esm2015/directives/list-option/nimble-combobox-list-option.directive.js +70 -0
- package/esm2015/directives/list-option/nimble-list-option.module.js +7 -6
- package/esm2015/directives/list-option/nimble-select-list-option.directive.js +40 -0
- package/esm2015/directives/select/nimble-select.directive.js +26 -5
- package/esm2015/public-api.js +4 -2
- package/fesm2015/ni-nimble-angular.js +185 -32
- package/fesm2015/ni-nimble-angular.js.map +1 -1
- package/package.json +2 -2
- package/public-api.d.ts +3 -1
- package/esm2015/directives/list-option/nimble-list-option.directive.js +0 -40
|
@@ -1,12 +1,66 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ElementRef, Renderer2 } from '@angular/core';
|
|
2
|
+
import { ControlValueAccessor } from '@angular/forms';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
4
|
/**
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
5
|
+
* @description
|
|
6
|
+
* This symbol instance will be returned when the value input of the Combobox is set
|
|
7
|
+
* to a value not found in the set of options.
|
|
8
|
+
*/
|
|
9
|
+
export declare const OPTION_NOT_FOUND: unique symbol;
|
|
10
|
+
export declare type OptionNotFound = typeof OPTION_NOT_FOUND;
|
|
11
|
+
/**
|
|
12
|
+
* Control Value Accessor implementation to target combobox inputs.
|
|
13
|
+
* @description
|
|
14
|
+
* The expectation when binding value via 'ngModel', is that the content in each list-option be
|
|
15
|
+
* unique. When this isn't the case the behavior is undefined. Additionally, it is expected
|
|
16
|
+
* that when using 'ngModel' that each list-option bind a value via 'ngValue', and not 'value'.
|
|
8
17
|
*/
|
|
9
|
-
export declare class NimbleComboboxControlValueAccessorDirective
|
|
18
|
+
export declare class NimbleComboboxControlValueAccessorDirective implements ControlValueAccessor {
|
|
19
|
+
private readonly _renderer;
|
|
20
|
+
private readonly _elementRef;
|
|
21
|
+
/**
|
|
22
|
+
* @description
|
|
23
|
+
* Tracks the option comparison algorithm for tracking identities when
|
|
24
|
+
* checking for changes.
|
|
25
|
+
*/
|
|
26
|
+
set compareWith(fn: (o1: unknown, o2: unknown) => boolean);
|
|
27
|
+
/** @internal */
|
|
28
|
+
readonly _optionMap: Map<string, unknown>;
|
|
29
|
+
private _compareWith;
|
|
30
|
+
/**
|
|
31
|
+
* The registered callback function called when a change or input event occurs on the input
|
|
32
|
+
* element.
|
|
33
|
+
* @nodoc
|
|
34
|
+
*/
|
|
35
|
+
private onChange;
|
|
36
|
+
/**
|
|
37
|
+
* The registered callback function called when a blur event occurs on the input element.
|
|
38
|
+
* @nodoc
|
|
39
|
+
*/
|
|
40
|
+
private onTouched;
|
|
41
|
+
constructor(_renderer: Renderer2, _elementRef: ElementRef);
|
|
42
|
+
/**
|
|
43
|
+
* Updates the underlying nimble-combobox value with the expected display string.
|
|
44
|
+
* @param value The ngValue set on the nimble-combobox
|
|
45
|
+
*/
|
|
46
|
+
writeValue(value: unknown): void;
|
|
47
|
+
/**
|
|
48
|
+
* Registers a function called when the control value changes.
|
|
49
|
+
* @nodoc
|
|
50
|
+
*/
|
|
51
|
+
registerOnChange(fn: (value: unknown) => void): void;
|
|
52
|
+
/**
|
|
53
|
+
* Registers a function called when the control is touched.
|
|
54
|
+
* @nodoc
|
|
55
|
+
*/
|
|
56
|
+
registerOnTouched(fn: () => void): void;
|
|
57
|
+
private getValueStringFromValue;
|
|
58
|
+
/**
|
|
59
|
+
* Helper method that sets a property on a target element using the current Renderer
|
|
60
|
+
* implementation.
|
|
61
|
+
* @nodoc
|
|
62
|
+
*/
|
|
63
|
+
private setProperty;
|
|
10
64
|
static ɵfac: i0.ɵɵFactoryDeclaration<NimbleComboboxControlValueAccessorDirective, never>;
|
|
11
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<NimbleComboboxControlValueAccessorDirective, "nimble-combobox[formControlName],nimble-combobox[formControl],nimble-combobox[ngModel]", never, {}, {}, never>;
|
|
65
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<NimbleComboboxControlValueAccessorDirective, "nimble-combobox[formControlName],nimble-combobox[formControl],nimble-combobox[ngModel]", never, { "compareWith": "compareWith"; }, {}, never>;
|
|
12
66
|
}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { ElementRef, Renderer2, AfterViewInit, OnDestroy, ChangeDetectorRef } from '@angular/core';
|
|
2
|
+
import type { ListOption } from '@ni/nimble-components/dist/esm/list-option';
|
|
3
|
+
import { NimbleComboboxControlValueAccessorDirective } from '../combobox/nimble-combobox-control-value-accessor.directive';
|
|
4
|
+
import { BooleanValueOrAttribute } from '../utilities/template-value-helpers';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
/**
|
|
7
|
+
* Directive to provide Angular integration for the list option when used with a combobox.
|
|
8
|
+
*/
|
|
9
|
+
export declare class NimbleComboboxListOptionDirective implements AfterViewInit, OnDestroy {
|
|
10
|
+
private readonly elementRef;
|
|
11
|
+
private readonly renderer;
|
|
12
|
+
private readonly changeDetector;
|
|
13
|
+
private readonly combobox?;
|
|
14
|
+
get disabled(): boolean;
|
|
15
|
+
set disabled(value: BooleanValueOrAttribute);
|
|
16
|
+
/**
|
|
17
|
+
* @description
|
|
18
|
+
* Tracks the value bound to the option element.
|
|
19
|
+
*/
|
|
20
|
+
set ngValue(value: unknown);
|
|
21
|
+
private _modelValue;
|
|
22
|
+
private _currentTextContent;
|
|
23
|
+
constructor(elementRef: ElementRef<ListOption>, renderer: Renderer2, changeDetector: ChangeDetectorRef, combobox?: NimbleComboboxControlValueAccessorDirective | undefined);
|
|
24
|
+
ngAfterViewInit(): void;
|
|
25
|
+
ngOnDestroy(): void;
|
|
26
|
+
private updateComboboxValue;
|
|
27
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NimbleComboboxListOptionDirective, [null, null, null, { optional: true; host: true; }]>;
|
|
28
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<NimbleComboboxListOptionDirective, "nimble-list-option", never, { "disabled": "disabled"; "ngValue": "ngValue"; }, {}, never>;
|
|
29
|
+
}
|
|
@@ -1,9 +1,11 @@
|
|
|
1
|
-
import '@ni/nimble-components/dist/esm/list-option';
|
|
1
|
+
import { ListOption } from '@ni/nimble-components/dist/esm/list-option';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "./nimble-list-option.directive";
|
|
4
|
-
import * as i2 from "
|
|
3
|
+
import * as i1 from "./nimble-select-list-option.directive";
|
|
4
|
+
import * as i2 from "./nimble-combobox-list-option.directive";
|
|
5
|
+
import * as i3 from "@angular/common";
|
|
6
|
+
export type { ListOption };
|
|
5
7
|
export declare class NimbleListOptionModule {
|
|
6
8
|
static ɵfac: i0.ɵɵFactoryDeclaration<NimbleListOptionModule, never>;
|
|
7
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<NimbleListOptionModule, [typeof i1.
|
|
9
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<NimbleListOptionModule, [typeof i1.NimbleSelectListOptionDirective, typeof i2.NimbleComboboxListOptionDirective], [typeof i3.CommonModule], [typeof i1.NimbleSelectListOptionDirective, typeof i2.NimbleComboboxListOptionDirective]>;
|
|
8
10
|
static ɵinj: i0.ɵɵInjectorDeclaration<NimbleListOptionModule>;
|
|
9
11
|
}
|
|
@@ -4,16 +4,15 @@ import type { ListOption } from '@ni/nimble-components/dist/esm/list-option';
|
|
|
4
4
|
import { NimbleSelectControlValueAccessorDirective } from '../select/nimble-select-control-value-accessor.directive';
|
|
5
5
|
import { BooleanValueOrAttribute } from '../utilities/template-value-helpers';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
|
-
export type { ListOption };
|
|
8
7
|
/**
|
|
9
|
-
* Directive to provide Angular integration for the list option.
|
|
8
|
+
* Directive to provide Angular integration for the list option when used with a select.
|
|
10
9
|
*/
|
|
11
|
-
export declare class
|
|
10
|
+
export declare class NimbleSelectListOptionDirective extends NgSelectOption {
|
|
12
11
|
private readonly elementRef;
|
|
13
12
|
private readonly renderer;
|
|
14
13
|
get disabled(): boolean;
|
|
15
14
|
set disabled(value: BooleanValueOrAttribute);
|
|
16
15
|
constructor(elementRef: ElementRef<ListOption>, renderer: Renderer2, select: NimbleSelectControlValueAccessorDirective);
|
|
17
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<
|
|
18
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<
|
|
16
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<NimbleSelectListOptionDirective, [null, null, { optional: true; host: true; }]>;
|
|
17
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<NimbleSelectListOptionDirective, "nimble-list-option", never, { "disabled": "disabled"; }, {}, never>;
|
|
19
18
|
}
|
|
@@ -1,10 +1,20 @@
|
|
|
1
|
+
import { ElementRef, Renderer2 } from '@angular/core';
|
|
1
2
|
import type { Select } from '@ni/nimble-components/dist/esm/select';
|
|
3
|
+
import type { DropdownAppearance } from '@ni/nimble-components/dist/esm/patterns/dropdown/types';
|
|
4
|
+
import { BooleanValueOrAttribute } from '../utilities/template-value-helpers';
|
|
2
5
|
import * as i0 from "@angular/core";
|
|
3
6
|
export type { Select };
|
|
4
7
|
/**
|
|
5
8
|
* Directive for Nimble select control Angular integration
|
|
6
9
|
*/
|
|
7
10
|
export declare class NimbleSelectDirective {
|
|
11
|
+
private readonly renderer;
|
|
12
|
+
private readonly elementRef;
|
|
13
|
+
get appearance(): DropdownAppearance;
|
|
14
|
+
set appearance(value: DropdownAppearance);
|
|
15
|
+
get disabled(): boolean;
|
|
16
|
+
set disabled(value: BooleanValueOrAttribute);
|
|
17
|
+
constructor(renderer: Renderer2, elementRef: ElementRef<Select>);
|
|
8
18
|
static ɵfac: i0.ɵɵFactoryDeclaration<NimbleSelectDirective, never>;
|
|
9
|
-
static ɵdir: i0.ɵɵDirectiveDeclaration<NimbleSelectDirective, "nimble-select", never, {}, {}, never>;
|
|
19
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<NimbleSelectDirective, "nimble-select", never, { "appearance": "appearance"; "disabled": "disabled"; }, {}, never>;
|
|
10
20
|
}
|
|
@@ -1,37 +1,104 @@
|
|
|
1
|
-
import { Directive, forwardRef } from '@angular/core';
|
|
2
|
-
import {
|
|
1
|
+
import { Directive, forwardRef, HostListener, Input } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
/**
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
5
|
+
* @description
|
|
6
|
+
* This symbol instance will be returned when the value input of the Combobox is set
|
|
7
|
+
* to a value not found in the set of options.
|
|
8
|
+
*/
|
|
9
|
+
export const OPTION_NOT_FOUND = Symbol('not found');
|
|
10
|
+
/**
|
|
11
|
+
* Control Value Accessor implementation to target combobox inputs.
|
|
12
|
+
* @description
|
|
13
|
+
* The expectation when binding value via 'ngModel', is that the content in each list-option be
|
|
14
|
+
* unique. When this isn't the case the behavior is undefined. Additionally, it is expected
|
|
15
|
+
* that when using 'ngModel' that each list-option bind a value via 'ngValue', and not 'value'.
|
|
9
16
|
*/
|
|
10
|
-
export class NimbleComboboxControlValueAccessorDirective
|
|
17
|
+
export class NimbleComboboxControlValueAccessorDirective {
|
|
18
|
+
constructor(_renderer, _elementRef) {
|
|
19
|
+
this._renderer = _renderer;
|
|
20
|
+
this._elementRef = _elementRef;
|
|
21
|
+
/** @internal */
|
|
22
|
+
this._optionMap = new Map();
|
|
23
|
+
this._compareWith = Object.is;
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* @description
|
|
27
|
+
* Tracks the option comparison algorithm for tracking identities when
|
|
28
|
+
* checking for changes.
|
|
29
|
+
*/
|
|
30
|
+
set compareWith(fn) {
|
|
31
|
+
if (typeof fn !== 'function') {
|
|
32
|
+
throw new Error(`compareWith must be a function, but received ${JSON.stringify(fn)}`);
|
|
33
|
+
}
|
|
34
|
+
this._compareWith = fn;
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Updates the underlying nimble-combobox value with the expected display string.
|
|
38
|
+
* @param value The ngValue set on the nimble-combobox
|
|
39
|
+
*/
|
|
40
|
+
writeValue(value) {
|
|
41
|
+
const valueAsString = this.getValueStringFromValue(value);
|
|
42
|
+
this.setProperty('value', valueAsString !== null && valueAsString !== void 0 ? valueAsString : '');
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Registers a function called when the control value changes.
|
|
46
|
+
* @nodoc
|
|
47
|
+
*/
|
|
48
|
+
registerOnChange(fn) {
|
|
49
|
+
this.onChange = (valueString) => {
|
|
50
|
+
var _a;
|
|
51
|
+
const modelValue = (_a = this._optionMap.get(valueString)) !== null && _a !== void 0 ? _a : OPTION_NOT_FOUND;
|
|
52
|
+
fn(modelValue);
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Registers a function called when the control is touched.
|
|
57
|
+
* @nodoc
|
|
58
|
+
*/
|
|
59
|
+
registerOnTouched(fn) {
|
|
60
|
+
this.onTouched = fn;
|
|
61
|
+
}
|
|
62
|
+
getValueStringFromValue(value) {
|
|
63
|
+
for (const [optionKey, optionValue] of this._optionMap.entries()) {
|
|
64
|
+
if (this._compareWith(optionValue, value)) {
|
|
65
|
+
return optionKey;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
return undefined;
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Helper method that sets a property on a target element using the current Renderer
|
|
72
|
+
* implementation.
|
|
73
|
+
* @nodoc
|
|
74
|
+
*/
|
|
75
|
+
setProperty(key, value) {
|
|
76
|
+
this._renderer.setProperty(this._elementRef.nativeElement, key, value);
|
|
77
|
+
}
|
|
11
78
|
}
|
|
12
|
-
NimbleComboboxControlValueAccessorDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NimbleComboboxControlValueAccessorDirective, deps:
|
|
13
|
-
NimbleComboboxControlValueAccessorDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.5", type: NimbleComboboxControlValueAccessorDirective, selector: "nimble-combobox[formControlName],nimble-combobox[formControl],nimble-combobox[ngModel]", host: { listeners: { "
|
|
79
|
+
NimbleComboboxControlValueAccessorDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NimbleComboboxControlValueAccessorDirective, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
80
|
+
NimbleComboboxControlValueAccessorDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.5", type: NimbleComboboxControlValueAccessorDirective, selector: "nimble-combobox[formControlName],nimble-combobox[formControl],nimble-combobox[ngModel]", inputs: { compareWith: "compareWith" }, host: { listeners: { "change": "onChange($event.target.value])", "blur": "onTouched()" } }, providers: [{
|
|
14
81
|
provide: NG_VALUE_ACCESSOR,
|
|
15
82
|
useExisting: forwardRef(() => NimbleComboboxControlValueAccessorDirective),
|
|
16
83
|
multi: true
|
|
17
|
-
}],
|
|
84
|
+
}], ngImport: i0 });
|
|
18
85
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NimbleComboboxControlValueAccessorDirective, decorators: [{
|
|
19
86
|
type: Directive,
|
|
20
87
|
args: [{
|
|
21
88
|
selector: 'nimble-combobox[formControlName],nimble-combobox[formControl],nimble-combobox[ngModel]',
|
|
22
|
-
// The following host metadata is duplicated from DefaultValueAccessor
|
|
23
|
-
// eslint-disable-next-line @angular-eslint/no-host-metadata-property
|
|
24
|
-
host: {
|
|
25
|
-
'(input)': '$any(this)._handleInput($event.target.value)',
|
|
26
|
-
'(blur)': 'onTouched()',
|
|
27
|
-
'(compositionstart)': '$any(this)._compositionStart()',
|
|
28
|
-
'(compositionend)': '$any(this)._compositionEnd($event.target.value)'
|
|
29
|
-
},
|
|
30
89
|
providers: [{
|
|
31
90
|
provide: NG_VALUE_ACCESSOR,
|
|
32
91
|
useExisting: forwardRef(() => NimbleComboboxControlValueAccessorDirective),
|
|
33
92
|
multi: true
|
|
34
93
|
}]
|
|
35
94
|
}]
|
|
36
|
-
}] }
|
|
37
|
-
|
|
95
|
+
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }]; }, propDecorators: { compareWith: [{
|
|
96
|
+
type: Input
|
|
97
|
+
}], onChange: [{
|
|
98
|
+
type: HostListener,
|
|
99
|
+
args: ['change', ['$event.target.value]']]
|
|
100
|
+
}], onTouched: [{
|
|
101
|
+
type: HostListener,
|
|
102
|
+
args: ['blur']
|
|
103
|
+
}] } });
|
|
104
|
+
//# 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":"AAAA,OAAO,EAAE,SAAS,EAAc,UAAU,EAAE,YAAY,EAAE,KAAK,EAAa,MAAM,eAAe,CAAC;AAClG,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;;AAEzE;;;;EAIE;AACF,MAAM,CAAC,MAAM,gBAAgB,GAAkB,MAAM,CAAC,WAAW,CAAC,CAAC;AAGnE;;;;;;GAMG;AAUH,MAAM,OAAO,2CAA2C;IAkCpD,YAAoC,SAAoB,EAAmB,WAAuB;QAA9D,cAAS,GAAT,SAAS,CAAW;QAAmB,gBAAW,GAAX,WAAW,CAAY;QApBlG,gBAAgB;QACA,eAAU,GAAyB,IAAI,GAAG,EAAmB,CAAC;QAEtE,iBAAY,GAA0C,MAAM,CAAC,EAAE,CAAC;IAiB6B,CAAC;IAjCtG;;;;OAIG;IACH,IACW,WAAW,CAAC,EAAyC;QAC5D,IAAI,OAAO,EAAE,KAAK,UAAU,EAAE;YAC1B,MAAM,IAAI,KAAK,CAAC,gDAAgD,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;SACzF;QACD,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;IAC3B,CAAC;IAwBD;;;OAGG;IACI,UAAU,CAAC,KAAc;QAC5B,MAAM,aAAa,GAAG,IAAI,CAAC,uBAAuB,CAAC,KAAK,CAAC,CAAC;QAC1D,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,aAAa,aAAb,aAAa,cAAb,aAAa,GAAI,EAAE,CAAC,CAAC;IACnD,CAAC;IAED;;;OAGG;IACI,gBAAgB,CAAC,EAA4B;QAChD,IAAI,CAAC,QAAQ,GAAG,CAAC,WAAmB,EAAQ,EAAE;;YAC1C,MAAM,UAAU,GAAG,MAAA,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,WAAW,CAAC,mCAAI,gBAAgB,CAAC;YACxE,EAAE,CAAC,UAAU,CAAC,CAAC;QACnB,CAAC,CAAC;IACN,CAAC;IAED;;;OAGG;IACI,iBAAiB,CAAC,EAAc;QACnC,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACxB,CAAC;IAEO,uBAAuB,CAAC,KAAc;QAC1C,KAAK,MAAM,CAAC,SAAS,EAAE,WAAW,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,EAAE;YAC9D,IAAI,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,KAAK,CAAC,EAAE;gBACvC,OAAO,SAAS,CAAC;aACpB;SACJ;QACD,OAAO,SAAS,CAAC;IACrB,CAAC;IAED;;;;OAIG;IACK,WAAW,CAAC,GAAW,EAAE,KAAa;QAC1C,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC;IAC3E,CAAC;;wIAhFQ,2CAA2C;4HAA3C,2CAA2C,qPANzC,CAAC;YACR,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,2CAA2C,CAAC;YAC1E,KAAK,EAAE,IAAI;SACd,CAAC;2FAEO,2CAA2C;kBATvD,SAAS;mBAAC;oBACP,QAAQ,EACN,wFAAwF;oBAC1F,SAAS,EAAE,CAAC;4BACR,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,4CAA4C,CAAC;4BAC1E,KAAK,EAAE,IAAI;yBACd,CAAC;iBACL;yHAQc,WAAW;sBADrB,KAAK;gBAmBE,QAAQ;sBADf,YAAY;uBAAC,QAAQ,EAAE,CAAC,sBAAsB,CAAC;gBAQxC,SAAS;sBADhB,YAAY;uBAAC,MAAM","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    /** @internal */\n    public readonly _optionMap: Map<string, unknown> = new Map<string, 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('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        const valueAsString = this.getValueStringFromValue(value);\n        this.setProperty('value', valueAsString ?? '');\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.get(valueString) ?? OPTION_NOT_FOUND;\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    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: string): void {\n        this._renderer.setProperty(this._elementRef.nativeElement, key, value);\n    }\n}\n"]}
|
|
@@ -47,4 +47,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
|
|
|
47
47
|
type: Input,
|
|
48
48
|
args: ['error-text']
|
|
49
49
|
}] } });
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmltYmxlLWNvbWJvYm94LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pL25pbWJsZS1hbmd1bGFyL3NyYy9kaXJlY3RpdmVzL2NvbWJvYm94L25pbWJsZS1jb21ib2JveC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBYyxLQUFLLEVBQWEsTUFBTSxlQUFlLENBQUM7QUFFeEUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sK0NBQStDLENBQUM7QUFDckYsT0FBTyxFQUEyQixpQkFBaUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDOztBQUdqRyxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsQ0FBQztBQUVoQzs7R0FFRztBQUlILE1BQU0sT0FBTyx1QkFBdUI7SUEyQmhDLFlBQW9DLFFBQW1CLEVBQW1CLFVBQWdDO1FBQXRFLGFBQVEsR0FBUixRQUFRLENBQVc7UUFBbUIsZUFBVSxHQUFWLFVBQVUsQ0FBc0I7SUFBRyxDQUFDO0lBMUI5RyxJQUFXLFFBQVE7UUFDZixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQztJQUNsRCxDQUFDO0lBRUQsSUFBb0IsUUFBUSxDQUFDLEtBQThCO1FBQ3ZELElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxFQUFFLFVBQVUsRUFBRSxpQkFBaUIsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBQ25HLENBQUM7SUFFRCxJQUFXLFlBQVk7UUFDbkIsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxZQUFZLENBQUM7SUFDdEQsQ0FBQztJQUVELElBQW9CLFlBQVksQ0FBQyxLQUF1QztRQUNwRSxJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsRUFBRSxjQUFjLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDcEYsQ0FBQztJQUVELElBQVcsU0FBUztRQUNoQixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQztJQUNuRCxDQUFDO0lBRUQsK0VBQStFO0lBQy9FLDJEQUEyRDtJQUMzRCxJQUFnQyxTQUFTLENBQUMsS0FBeUI7UUFDL0QsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLEVBQUUsV0FBVyxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ2pGLENBQUM7O29IQXpCUSx1QkFBdUI7d0dBQXZCLHVCQUF1QjsyRkFBdkIsdUJBQXVCO2tCQUhuQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxpQkFBaUI7aUJBQzlCO3lIQU11QixRQUFRO3NCQUEzQixLQUFLO2dCQVFjLFlBQVk7c0JBQS9CLEtBQUs7Z0JBVTBCLFNBQVM7c0JBQXhDLEtBQUs7dUJBQUMsWUFBWSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgSW5wdXQsIFJlbmRlcmVyMiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHR5cGUgeyBDb21ib2JveCB9IGZyb20gJ0BuaS9uaW1ibGUtY29tcG9uZW50cy9kaXN0L2VzbS9jb21ib2JveCc7XG5pbXBvcnQgeyBDb21ib2JveEF1dG9jb21wbGV0ZSB9IGZyb20gJ0BuaS9uaW1ibGUtY29tcG9uZW50cy9kaXN0L2VzbS9jb21ib2JveC90eXBlcyc7XG5pbXBvcnQgeyBCb29sZWFuVmFsdWVPckF0dHJpYnV0ZSwgdG9Cb29sZWFuUHJvcGVydHkgfSBmcm9tICcuLi91dGlsaXRpZXMvdGVtcGxhdGUtdmFsdWUtaGVscGVycyc7XG5cbmV4cG9ydCB0eXBlIHsgQ29tYm9ib3ggfTtcbmV4cG9ydCB7IENvbWJvYm94QXV0b2NvbXBsZXRlIH07XG5cbi8qKlxuICogRGlyZWN0aXZlIGZvciBOaW1ibGUgY29tYm9ib3ggY29udHJvbCBBbmd1bGFyIGludGVncmF0aW9uXG4gKi9cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnbmltYmxlLWNvbWJvYm94Jyxcbn0pXG5leHBvcnQgY2xhc3MgTmltYmxlQ29tYm9ib3hEaXJlY3RpdmUge1xuICAgIHB1YmxpYyBnZXQgZGlzYWJsZWQoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiB0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudC5kaXNhYmxlZDtcbiAgICB9XG5cbiAgICBASW5wdXQoKSBwdWJsaWMgc2V0IGRpc2FibGVkKHZhbHVlOiBCb29sZWFuVmFsdWVPckF0dHJpYnV0ZSkge1xuICAgICAgICB0aGlzLnJlbmRlcmVyLnNldFByb3BlcnR5KHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LCAnZGlzYWJsZWQnLCB0b0Jvb2xlYW5Qcm9wZXJ0eSh2YWx1ZSkpO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXQgYXV0b2NvbXBsZXRlKCk6IENvbWJvYm94QXV0b2NvbXBsZXRlIHwgdW5kZWZpbmVkIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LmF1dG9jb21wbGV0ZTtcbiAgICB9XG5cbiAgICBASW5wdXQoKSBwdWJsaWMgc2V0IGF1dG9jb21wbGV0ZSh2YWx1ZTogQ29tYm9ib3hBdXRvY29tcGxldGUgfCB1bmRlZmluZWQpIHtcbiAgICAgICAgdGhpcy5yZW5kZXJlci5zZXRQcm9wZXJ0eSh0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudCwgJ2F1dG9jb21wbGV0ZScsIHZhbHVlKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgZ2V0IGVycm9yVGV4dCgpOiBzdHJpbmcgfCB1bmRlZmluZWQge1xuICAgICAgICByZXR1cm4gdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQuZXJyb3JUZXh0O1xuICAgIH1cblxuICAgIC8vIFJlbmFtaW5nIGJlY2F1c2UgcHJvcGVydHkgc2hvdWxkIGhhdmUgY2FtZWwgY2FzaW5nLCBidXQgYXR0cmlidXRlIHNob3VsZCBub3RcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQGFuZ3VsYXItZXNsaW50L25vLWlucHV0LXJlbmFtZVxuICAgIEBJbnB1dCgnZXJyb3ItdGV4dCcpIHB1YmxpYyBzZXQgZXJyb3JUZXh0KHZhbHVlOiBzdHJpbmcgfCB1bmRlZmluZWQpIHtcbiAgICAgICAgdGhpcy5yZW5kZXJlci5zZXRQcm9wZXJ0eSh0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudCwgJ2Vycm9yVGV4dCcsIHZhbHVlKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSByZW5kZXJlcjogUmVuZGVyZXIyLCBwcml2YXRlIHJlYWRvbmx5IGVsZW1lbnRSZWY6IEVsZW1lbnRSZWY8Q29tYm9ib3g+KSB7fVxufVxuIl19
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { Directive, Host, Inject, Input, Optional } from '@angular/core';
|
|
2
|
+
import { NimbleComboboxControlValueAccessorDirective } from '../combobox/nimble-combobox-control-value-accessor.directive';
|
|
3
|
+
import { toBooleanProperty } from '../utilities/template-value-helpers';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "../combobox/nimble-combobox-control-value-accessor.directive";
|
|
6
|
+
/**
|
|
7
|
+
* Directive to provide Angular integration for the list option when used with a combobox.
|
|
8
|
+
*/
|
|
9
|
+
export class NimbleComboboxListOptionDirective {
|
|
10
|
+
constructor(elementRef, renderer, changeDetector, combobox) {
|
|
11
|
+
this.elementRef = elementRef;
|
|
12
|
+
this.renderer = renderer;
|
|
13
|
+
this.changeDetector = changeDetector;
|
|
14
|
+
this.combobox = combobox;
|
|
15
|
+
this._modelValue = undefined;
|
|
16
|
+
}
|
|
17
|
+
get disabled() {
|
|
18
|
+
return this.elementRef.nativeElement.disabled;
|
|
19
|
+
}
|
|
20
|
+
set disabled(value) {
|
|
21
|
+
this.renderer.setProperty(this.elementRef.nativeElement, 'disabled', toBooleanProperty(value));
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* @description
|
|
25
|
+
* Tracks the value bound to the option element.
|
|
26
|
+
*/
|
|
27
|
+
set ngValue(value) {
|
|
28
|
+
if (this.combobox) {
|
|
29
|
+
this._modelValue = value;
|
|
30
|
+
this.updateComboboxValue(value);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
ngAfterViewInit() {
|
|
34
|
+
if (this.combobox) {
|
|
35
|
+
this._currentTextContent = this.elementRef.nativeElement.textContent;
|
|
36
|
+
this.combobox._optionMap.set(this._currentTextContent, this._modelValue);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
ngOnDestroy() {
|
|
40
|
+
if (this.combobox) {
|
|
41
|
+
this.combobox._optionMap.delete(this._currentTextContent);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
updateComboboxValue(value) {
|
|
45
|
+
this.combobox._optionMap.delete(this._currentTextContent);
|
|
46
|
+
this.changeDetector.detectChanges();
|
|
47
|
+
this._currentTextContent = this.elementRef.nativeElement.textContent;
|
|
48
|
+
this.combobox._optionMap.set(this._currentTextContent, value);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
NimbleComboboxListOptionDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NimbleComboboxListOptionDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token: NimbleComboboxControlValueAccessorDirective, host: true, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
|
|
52
|
+
NimbleComboboxListOptionDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.5", type: NimbleComboboxListOptionDirective, selector: "nimble-list-option", inputs: { disabled: "disabled", ngValue: "ngValue" }, ngImport: i0 });
|
|
53
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NimbleComboboxListOptionDirective, decorators: [{
|
|
54
|
+
type: Directive,
|
|
55
|
+
args: [{
|
|
56
|
+
selector: 'nimble-list-option'
|
|
57
|
+
}]
|
|
58
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type: i1.NimbleComboboxControlValueAccessorDirective, decorators: [{
|
|
59
|
+
type: Inject,
|
|
60
|
+
args: [NimbleComboboxControlValueAccessorDirective]
|
|
61
|
+
}, {
|
|
62
|
+
type: Optional
|
|
63
|
+
}, {
|
|
64
|
+
type: Host
|
|
65
|
+
}] }]; }, propDecorators: { disabled: [{
|
|
66
|
+
type: Input
|
|
67
|
+
}], ngValue: [{
|
|
68
|
+
type: Input
|
|
69
|
+
}] } });
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmltYmxlLWNvbWJvYm94LWxpc3Qtb3B0aW9uLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pL25pbWJsZS1hbmd1bGFyL3NyYy9kaXJlY3RpdmVzL2xpc3Qtb3B0aW9uL25pbWJsZS1jb21ib2JveC1saXN0LW9wdGlvbi5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBYyxJQUFJLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxRQUFRLEVBQTBELE1BQU0sZUFBZSxDQUFDO0FBRTdJLE9BQU8sRUFBRSwyQ0FBMkMsRUFBRSxNQUFNLDhEQUE4RCxDQUFDO0FBQzNILE9BQU8sRUFBMkIsaUJBQWlCLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQzs7O0FBRWpHOztHQUVHO0FBSUgsTUFBTSxPQUFPLGlDQUFpQztJQXdCMUMsWUFDcUIsVUFBa0MsRUFDbEMsUUFBbUIsRUFDbkIsY0FBaUMsRUFDd0MsUUFBc0Q7UUFIL0gsZUFBVSxHQUFWLFVBQVUsQ0FBd0I7UUFDbEMsYUFBUSxHQUFSLFFBQVEsQ0FBVztRQUNuQixtQkFBYyxHQUFkLGNBQWMsQ0FBbUI7UUFDd0MsYUFBUSxHQUFSLFFBQVEsQ0FBOEM7UUFQNUksZ0JBQVcsR0FBWSxTQUFTLENBQUM7SUFRckMsQ0FBQztJQTVCTCxJQUFXLFFBQVE7UUFDZixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQztJQUNsRCxDQUFDO0lBRUQsSUFBb0IsUUFBUSxDQUFDLEtBQThCO1FBQ3ZELElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxFQUFFLFVBQVUsRUFBRSxpQkFBaUIsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBQ25HLENBQUM7SUFFRDs7O09BR0c7SUFDSCxJQUNXLE9BQU8sQ0FBQyxLQUFjO1FBQzdCLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNmLElBQUksQ0FBQyxXQUFXLEdBQUcsS0FBSyxDQUFDO1lBQ3pCLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxLQUFLLENBQUMsQ0FBQztTQUNuQztJQUNMLENBQUM7SUFZTSxlQUFlO1FBQ2xCLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNmLElBQUksQ0FBQyxtQkFBbUIsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxXQUFZLENBQUM7WUFDdEUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxtQkFBbUIsRUFBRSxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7U0FDNUU7SUFDTCxDQUFDO0lBRU0sV0FBVztRQUNkLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNmLElBQUksQ0FBQyxRQUFRLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsQ0FBQztTQUM3RDtJQUNMLENBQUM7SUFFTyxtQkFBbUIsQ0FBQyxLQUFjO1FBQ3RDLElBQUksQ0FBQyxRQUFTLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsQ0FBQztRQUMzRCxJQUFJLENBQUMsY0FBYyxDQUFDLGFBQWEsRUFBRSxDQUFDO1FBQ3BDLElBQUksQ0FBQyxtQkFBbUIsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxXQUFZLENBQUM7UUFDdEUsSUFBSSxDQUFDLFFBQVMsQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxtQkFBbUIsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUNuRSxDQUFDOzs4SEFqRFEsaUNBQWlDLHNHQTRCOUIsMkNBQTJDO2tIQTVCOUMsaUNBQWlDOzJGQUFqQyxpQ0FBaUM7a0JBSDdDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLG9CQUFvQjtpQkFDakM7OzBCQTZCUSxNQUFNOzJCQUFDLDJDQUEyQzs7MEJBQUcsUUFBUTs7MEJBQUksSUFBSTs0Q0F2QnRELFFBQVE7c0JBQTNCLEtBQUs7Z0JBU0ssT0FBTztzQkFEakIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgSG9zdCwgSW5qZWN0LCBJbnB1dCwgT3B0aW9uYWwsIFJlbmRlcmVyMiwgQWZ0ZXJWaWV3SW5pdCwgT25EZXN0cm95LCBDaGFuZ2VEZXRlY3RvclJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHR5cGUgeyBMaXN0T3B0aW9uIH0gZnJvbSAnQG5pL25pbWJsZS1jb21wb25lbnRzL2Rpc3QvZXNtL2xpc3Qtb3B0aW9uJztcbmltcG9ydCB7IE5pbWJsZUNvbWJvYm94Q29udHJvbFZhbHVlQWNjZXNzb3JEaXJlY3RpdmUgfSBmcm9tICcuLi9jb21ib2JveC9uaW1ibGUtY29tYm9ib3gtY29udHJvbC12YWx1ZS1hY2Nlc3Nvci5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgQm9vbGVhblZhbHVlT3JBdHRyaWJ1dGUsIHRvQm9vbGVhblByb3BlcnR5IH0gZnJvbSAnLi4vdXRpbGl0aWVzL3RlbXBsYXRlLXZhbHVlLWhlbHBlcnMnO1xuXG4vKipcbiAqIERpcmVjdGl2ZSB0byBwcm92aWRlIEFuZ3VsYXIgaW50ZWdyYXRpb24gZm9yIHRoZSBsaXN0IG9wdGlvbiB3aGVuIHVzZWQgd2l0aCBhIGNvbWJvYm94LlxuICovXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ25pbWJsZS1saXN0LW9wdGlvbidcbn0pXG5leHBvcnQgY2xhc3MgTmltYmxlQ29tYm9ib3hMaXN0T3B0aW9uRGlyZWN0aXZlIGltcGxlbWVudHMgQWZ0ZXJWaWV3SW5pdCwgT25EZXN0cm95IHtcbiAgICBwdWJsaWMgZ2V0IGRpc2FibGVkKCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQuZGlzYWJsZWQ7XG4gICAgfVxuXG4gICAgQElucHV0KCkgcHVibGljIHNldCBkaXNhYmxlZCh2YWx1ZTogQm9vbGVhblZhbHVlT3JBdHRyaWJ1dGUpIHtcbiAgICAgICAgdGhpcy5yZW5kZXJlci5zZXRQcm9wZXJ0eSh0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudCwgJ2Rpc2FibGVkJywgdG9Cb29sZWFuUHJvcGVydHkodmFsdWUpKTtcbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBAZGVzY3JpcHRpb25cbiAgICAgKiBUcmFja3MgdGhlIHZhbHVlIGJvdW5kIHRvIHRoZSBvcHRpb24gZWxlbWVudC5cbiAgICAgKi9cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBzZXQgbmdWYWx1ZSh2YWx1ZTogdW5rbm93bikge1xuICAgICAgICBpZiAodGhpcy5jb21ib2JveCkge1xuICAgICAgICAgICAgdGhpcy5fbW9kZWxWYWx1ZSA9IHZhbHVlO1xuICAgICAgICAgICAgdGhpcy51cGRhdGVDb21ib2JveFZhbHVlKHZhbHVlKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHByaXZhdGUgX21vZGVsVmFsdWU6IHVua25vd24gPSB1bmRlZmluZWQ7XG4gICAgcHJpdmF0ZSBfY3VycmVudFRleHRDb250ZW50OiBzdHJpbmc7XG5cbiAgICBwdWJsaWMgY29uc3RydWN0b3IoXG4gICAgICAgIHByaXZhdGUgcmVhZG9ubHkgZWxlbWVudFJlZjogRWxlbWVudFJlZjxMaXN0T3B0aW9uPixcbiAgICAgICAgcHJpdmF0ZSByZWFkb25seSByZW5kZXJlcjogUmVuZGVyZXIyLFxuICAgICAgICBwcml2YXRlIHJlYWRvbmx5IGNoYW5nZURldGVjdG9yOiBDaGFuZ2VEZXRlY3RvclJlZixcbiAgICAgICAgQEluamVjdChOaW1ibGVDb21ib2JveENvbnRyb2xWYWx1ZUFjY2Vzc29yRGlyZWN0aXZlKSBAT3B0aW9uYWwoKSBASG9zdCgpIHByaXZhdGUgcmVhZG9ubHkgY29tYm9ib3g/OiBOaW1ibGVDb21ib2JveENvbnRyb2xWYWx1ZUFjY2Vzc29yRGlyZWN0aXZlXG4gICAgKSB7IH1cblxuICAgIHB1YmxpYyBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XG4gICAgICAgIGlmICh0aGlzLmNvbWJvYm94KSB7XG4gICAgICAgICAgICB0aGlzLl9jdXJyZW50VGV4dENvbnRlbnQgPSB0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudC50ZXh0Q29udGVudCE7XG4gICAgICAgICAgICB0aGlzLmNvbWJvYm94Ll9vcHRpb25NYXAuc2V0KHRoaXMuX2N1cnJlbnRUZXh0Q29udGVudCwgdGhpcy5fbW9kZWxWYWx1ZSk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBwdWJsaWMgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgICAgIGlmICh0aGlzLmNvbWJvYm94KSB7XG4gICAgICAgICAgICB0aGlzLmNvbWJvYm94Ll9vcHRpb25NYXAuZGVsZXRlKHRoaXMuX2N1cnJlbnRUZXh0Q29udGVudCk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBwcml2YXRlIHVwZGF0ZUNvbWJvYm94VmFsdWUodmFsdWU6IHVua25vd24pOiB2b2lkIHtcbiAgICAgICAgdGhpcy5jb21ib2JveCEuX29wdGlvbk1hcC5kZWxldGUodGhpcy5fY3VycmVudFRleHRDb250ZW50KTtcbiAgICAgICAgdGhpcy5jaGFuZ2VEZXRlY3Rvci5kZXRlY3RDaGFuZ2VzKCk7XG4gICAgICAgIHRoaXMuX2N1cnJlbnRUZXh0Q29udGVudCA9IHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LnRleHRDb250ZW50ITtcbiAgICAgICAgdGhpcy5jb21ib2JveCEuX29wdGlvbk1hcC5zZXQodGhpcy5fY3VycmVudFRleHRDb250ZW50LCB2YWx1ZSk7XG4gICAgfVxufVxuIl19
|
|
@@ -1,19 +1,20 @@
|
|
|
1
1
|
import { NgModule } from '@angular/core';
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
|
-
import {
|
|
4
|
-
import '
|
|
3
|
+
import { ListOption } from '@ni/nimble-components/dist/esm/list-option';
|
|
4
|
+
import { NimbleSelectListOptionDirective } from './nimble-select-list-option.directive';
|
|
5
|
+
import { NimbleComboboxListOptionDirective } from './nimble-combobox-list-option.directive';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
7
|
export class NimbleListOptionModule {
|
|
7
8
|
}
|
|
8
9
|
NimbleListOptionModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NimbleListOptionModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
9
|
-
NimbleListOptionModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NimbleListOptionModule, declarations: [
|
|
10
|
+
NimbleListOptionModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NimbleListOptionModule, declarations: [NimbleSelectListOptionDirective, NimbleComboboxListOptionDirective], imports: [CommonModule], exports: [NimbleSelectListOptionDirective, NimbleComboboxListOptionDirective] });
|
|
10
11
|
NimbleListOptionModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NimbleListOptionModule, imports: [[CommonModule]] });
|
|
11
12
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NimbleListOptionModule, decorators: [{
|
|
12
13
|
type: NgModule,
|
|
13
14
|
args: [{
|
|
14
|
-
declarations: [
|
|
15
|
+
declarations: [NimbleSelectListOptionDirective, NimbleComboboxListOptionDirective],
|
|
15
16
|
imports: [CommonModule],
|
|
16
|
-
exports: [
|
|
17
|
+
exports: [NimbleSelectListOptionDirective, NimbleComboboxListOptionDirective]
|
|
17
18
|
}]
|
|
18
19
|
}] });
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmltYmxlLWxpc3Qtb3B0aW9uLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pL25pbWJsZS1hbmd1bGFyL3NyYy9kaXJlY3RpdmVzL2xpc3Qtb3B0aW9uL25pbWJsZS1saXN0LW9wdGlvbi5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLDRDQUE0QyxDQUFDO0FBQ3hFLE9BQU8sRUFBRSwrQkFBK0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQ3hGLE9BQU8sRUFBRSxpQ0FBaUMsRUFBRSxNQUFNLHlDQUF5QyxDQUFDOztBQVM1RixNQUFNLE9BQU8sc0JBQXNCOzttSEFBdEIsc0JBQXNCO29IQUF0QixzQkFBc0IsaUJBSmhCLCtCQUErQixFQUFFLGlDQUFpQyxhQUN2RSxZQUFZLGFBQ1osK0JBQStCLEVBQUUsaUNBQWlDO29IQUVuRSxzQkFBc0IsWUFIdEIsQ0FBQyxZQUFZLENBQUM7MkZBR2Qsc0JBQXNCO2tCQUxsQyxRQUFRO21CQUFDO29CQUNOLFlBQVksRUFBRSxDQUFDLCtCQUErQixFQUFFLGlDQUFpQyxDQUFDO29CQUNsRixPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUM7b0JBQ3ZCLE9BQU8sRUFBRSxDQUFDLCtCQUErQixFQUFFLGlDQUFpQyxDQUFDO2lCQUNoRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTGlzdE9wdGlvbiB9IGZyb20gJ0BuaS9uaW1ibGUtY29tcG9uZW50cy9kaXN0L2VzbS9saXN0LW9wdGlvbic7XG5pbXBvcnQgeyBOaW1ibGVTZWxlY3RMaXN0T3B0aW9uRGlyZWN0aXZlIH0gZnJvbSAnLi9uaW1ibGUtc2VsZWN0LWxpc3Qtb3B0aW9uLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBOaW1ibGVDb21ib2JveExpc3RPcHRpb25EaXJlY3RpdmUgfSBmcm9tICcuL25pbWJsZS1jb21ib2JveC1saXN0LW9wdGlvbi5kaXJlY3RpdmUnO1xuXG5leHBvcnQgdHlwZSB7IExpc3RPcHRpb24gfTtcblxuQE5nTW9kdWxlKHtcbiAgICBkZWNsYXJhdGlvbnM6IFtOaW1ibGVTZWxlY3RMaXN0T3B0aW9uRGlyZWN0aXZlLCBOaW1ibGVDb21ib2JveExpc3RPcHRpb25EaXJlY3RpdmVdLFxuICAgIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICAgIGV4cG9ydHM6IFtOaW1ibGVTZWxlY3RMaXN0T3B0aW9uRGlyZWN0aXZlLCBOaW1ibGVDb21ib2JveExpc3RPcHRpb25EaXJlY3RpdmVdXG59KVxuZXhwb3J0IGNsYXNzIE5pbWJsZUxpc3RPcHRpb25Nb2R1bGUgeyB9XG4iXX0=
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { Directive, Host, Inject, Input, Optional } from '@angular/core';
|
|
2
|
+
import { NgSelectOption } from '@angular/forms';
|
|
3
|
+
import { NimbleSelectControlValueAccessorDirective } from '../select/nimble-select-control-value-accessor.directive';
|
|
4
|
+
import { toBooleanProperty } from '../utilities/template-value-helpers';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../select/nimble-select-control-value-accessor.directive";
|
|
7
|
+
/**
|
|
8
|
+
* Directive to provide Angular integration for the list option when used with a select.
|
|
9
|
+
*/
|
|
10
|
+
export class NimbleSelectListOptionDirective extends NgSelectOption {
|
|
11
|
+
constructor(elementRef, renderer, select) {
|
|
12
|
+
super(elementRef, renderer, select);
|
|
13
|
+
this.elementRef = elementRef;
|
|
14
|
+
this.renderer = renderer;
|
|
15
|
+
}
|
|
16
|
+
get disabled() {
|
|
17
|
+
return this.elementRef.nativeElement.disabled;
|
|
18
|
+
}
|
|
19
|
+
set disabled(value) {
|
|
20
|
+
this.renderer.setProperty(this.elementRef.nativeElement, 'disabled', toBooleanProperty(value));
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
NimbleSelectListOptionDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NimbleSelectListOptionDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: NimbleSelectControlValueAccessorDirective, host: true, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
|
|
24
|
+
NimbleSelectListOptionDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.5", type: NimbleSelectListOptionDirective, selector: "nimble-list-option", inputs: { disabled: "disabled" }, usesInheritance: true, ngImport: i0 });
|
|
25
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NimbleSelectListOptionDirective, decorators: [{
|
|
26
|
+
type: Directive,
|
|
27
|
+
args: [{
|
|
28
|
+
selector: 'nimble-list-option'
|
|
29
|
+
}]
|
|
30
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.NimbleSelectControlValueAccessorDirective, decorators: [{
|
|
31
|
+
type: Inject,
|
|
32
|
+
args: [NimbleSelectControlValueAccessorDirective]
|
|
33
|
+
}, {
|
|
34
|
+
type: Optional
|
|
35
|
+
}, {
|
|
36
|
+
type: Host
|
|
37
|
+
}] }]; }, propDecorators: { disabled: [{
|
|
38
|
+
type: Input
|
|
39
|
+
}] } });
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmltYmxlLXNlbGVjdC1saXN0LW9wdGlvbi5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uaS9uaW1ibGUtYW5ndWxhci9zcmMvZGlyZWN0aXZlcy9saXN0LW9wdGlvbi9uaW1ibGUtc2VsZWN0LWxpc3Qtb3B0aW9uLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLElBQUksRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLFFBQVEsRUFBYSxNQUFNLGVBQWUsQ0FBQztBQUNoRyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFaEQsT0FBTyxFQUFFLHlDQUF5QyxFQUFFLE1BQU0sMERBQTBELENBQUM7QUFDckgsT0FBTyxFQUEyQixpQkFBaUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDOzs7QUFFakc7O0dBRUc7QUFJSCxNQUFNLE9BQU8sK0JBQWdDLFNBQVEsY0FBYztJQVMvRCxZQUNxQixVQUFrQyxFQUNsQyxRQUFtQixFQUNtQyxNQUFpRDtRQUV4SCxLQUFLLENBQUMsVUFBVSxFQUFFLFFBQVEsRUFBRSxNQUFNLENBQUMsQ0FBQztRQUpuQixlQUFVLEdBQVYsVUFBVSxDQUF3QjtRQUNsQyxhQUFRLEdBQVIsUUFBUSxDQUFXO0lBSXhDLENBQUM7SUFkRCxJQUFXLFFBQVE7UUFDZixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQztJQUNsRCxDQUFDO0lBRUQsSUFBb0IsUUFBUSxDQUFDLEtBQThCO1FBQ3ZELElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxFQUFFLFVBQVUsRUFBRSxpQkFBaUIsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBQ25HLENBQUM7OzRIQVBRLCtCQUErQixxRUFZNUIseUNBQXlDO2dIQVo1QywrQkFBK0I7MkZBQS9CLCtCQUErQjtrQkFIM0MsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsb0JBQW9CO2lCQUNqQzs7MEJBYVEsTUFBTTsyQkFBQyx5Q0FBeUM7OzBCQUFHLFFBQVE7OzBCQUFJLElBQUk7NENBUHBELFFBQVE7c0JBQTNCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIEhvc3QsIEluamVjdCwgSW5wdXQsIE9wdGlvbmFsLCBSZW5kZXJlcjIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5nU2VsZWN0T3B0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHR5cGUgeyBMaXN0T3B0aW9uIH0gZnJvbSAnQG5pL25pbWJsZS1jb21wb25lbnRzL2Rpc3QvZXNtL2xpc3Qtb3B0aW9uJztcbmltcG9ydCB7IE5pbWJsZVNlbGVjdENvbnRyb2xWYWx1ZUFjY2Vzc29yRGlyZWN0aXZlIH0gZnJvbSAnLi4vc2VsZWN0L25pbWJsZS1zZWxlY3QtY29udHJvbC12YWx1ZS1hY2Nlc3Nvci5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgQm9vbGVhblZhbHVlT3JBdHRyaWJ1dGUsIHRvQm9vbGVhblByb3BlcnR5IH0gZnJvbSAnLi4vdXRpbGl0aWVzL3RlbXBsYXRlLXZhbHVlLWhlbHBlcnMnO1xuXG4vKipcbiAqIERpcmVjdGl2ZSB0byBwcm92aWRlIEFuZ3VsYXIgaW50ZWdyYXRpb24gZm9yIHRoZSBsaXN0IG9wdGlvbiB3aGVuIHVzZWQgd2l0aCBhIHNlbGVjdC5cbiAqL1xuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICduaW1ibGUtbGlzdC1vcHRpb24nXG59KVxuZXhwb3J0IGNsYXNzIE5pbWJsZVNlbGVjdExpc3RPcHRpb25EaXJlY3RpdmUgZXh0ZW5kcyBOZ1NlbGVjdE9wdGlvbiB7XG4gICAgcHVibGljIGdldCBkaXNhYmxlZCgpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LmRpc2FibGVkO1xuICAgIH1cblxuICAgIEBJbnB1dCgpIHB1YmxpYyBzZXQgZGlzYWJsZWQodmFsdWU6IEJvb2xlYW5WYWx1ZU9yQXR0cmlidXRlKSB7XG4gICAgICAgIHRoaXMucmVuZGVyZXIuc2V0UHJvcGVydHkodGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQsICdkaXNhYmxlZCcsIHRvQm9vbGVhblByb3BlcnR5KHZhbHVlKSk7XG4gICAgfVxuXG4gICAgcHVibGljIGNvbnN0cnVjdG9yKFxuICAgICAgICBwcml2YXRlIHJlYWRvbmx5IGVsZW1lbnRSZWY6IEVsZW1lbnRSZWY8TGlzdE9wdGlvbj4sXG4gICAgICAgIHByaXZhdGUgcmVhZG9ubHkgcmVuZGVyZXI6IFJlbmRlcmVyMixcbiAgICAgICAgQEluamVjdChOaW1ibGVTZWxlY3RDb250cm9sVmFsdWVBY2Nlc3NvckRpcmVjdGl2ZSkgQE9wdGlvbmFsKCkgQEhvc3QoKSBzZWxlY3Q6IE5pbWJsZVNlbGVjdENvbnRyb2xWYWx1ZUFjY2Vzc29yRGlyZWN0aXZlXG4gICAgKSB7XG4gICAgICAgIHN1cGVyKGVsZW1lbnRSZWYsIHJlbmRlcmVyLCBzZWxlY3QpO1xuICAgIH1cbn0iXX0=
|
|
@@ -1,16 +1,37 @@
|
|
|
1
|
-
import { Directive } from '@angular/core';
|
|
1
|
+
import { Directive, Input } from '@angular/core';
|
|
2
|
+
import { toBooleanProperty } from '../utilities/template-value-helpers';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
4
|
/**
|
|
4
5
|
* Directive for Nimble select control Angular integration
|
|
5
6
|
*/
|
|
6
7
|
export class NimbleSelectDirective {
|
|
8
|
+
constructor(renderer, elementRef) {
|
|
9
|
+
this.renderer = renderer;
|
|
10
|
+
this.elementRef = elementRef;
|
|
11
|
+
}
|
|
12
|
+
get appearance() {
|
|
13
|
+
return this.elementRef.nativeElement.appearance;
|
|
14
|
+
}
|
|
15
|
+
set appearance(value) {
|
|
16
|
+
this.renderer.setProperty(this.elementRef.nativeElement, 'appearance', value);
|
|
17
|
+
}
|
|
18
|
+
get disabled() {
|
|
19
|
+
return this.elementRef.nativeElement.disabled;
|
|
20
|
+
}
|
|
21
|
+
set disabled(value) {
|
|
22
|
+
this.renderer.setProperty(this.elementRef.nativeElement, 'disabled', toBooleanProperty(value));
|
|
23
|
+
}
|
|
7
24
|
}
|
|
8
|
-
NimbleSelectDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NimbleSelectDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
9
|
-
NimbleSelectDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.5", type: NimbleSelectDirective, selector: "nimble-select", ngImport: i0 });
|
|
25
|
+
NimbleSelectDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NimbleSelectDirective, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
26
|
+
NimbleSelectDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.5", type: NimbleSelectDirective, selector: "nimble-select", inputs: { appearance: "appearance", disabled: "disabled" }, ngImport: i0 });
|
|
10
27
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NimbleSelectDirective, decorators: [{
|
|
11
28
|
type: Directive,
|
|
12
29
|
args: [{
|
|
13
30
|
selector: 'nimble-select',
|
|
14
31
|
}]
|
|
15
|
-
}] }
|
|
16
|
-
|
|
32
|
+
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }]; }, propDecorators: { appearance: [{
|
|
33
|
+
type: Input
|
|
34
|
+
}], disabled: [{
|
|
35
|
+
type: Input
|
|
36
|
+
}] } });
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmltYmxlLXNlbGVjdC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uaS9uaW1ibGUtYW5ndWxhci9zcmMvZGlyZWN0aXZlcy9zZWxlY3QvbmltYmxlLXNlbGVjdC5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBYyxLQUFLLEVBQWEsTUFBTSxlQUFlLENBQUM7QUFHeEUsT0FBTyxFQUEyQixpQkFBaUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDOztBQUlqRzs7R0FFRztBQUlILE1BQU0sT0FBTyxxQkFBcUI7SUFpQjlCLFlBQW9DLFFBQW1CLEVBQW1CLFVBQThCO1FBQXBFLGFBQVEsR0FBUixRQUFRLENBQVc7UUFBbUIsZUFBVSxHQUFWLFVBQVUsQ0FBb0I7SUFBRyxDQUFDO0lBaEI1RyxJQUFXLFVBQVU7UUFDakIsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxVQUFVLENBQUM7SUFDcEQsQ0FBQztJQUVELElBQW9CLFVBQVUsQ0FBQyxLQUF5QjtRQUNwRCxJQUFJLENBQUMsUUFBUSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsRUFBRSxZQUFZLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDbEYsQ0FBQztJQUVELElBQVcsUUFBUTtRQUNmLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDO0lBQ2xELENBQUM7SUFFRCxJQUFvQixRQUFRLENBQUMsS0FBOEI7UUFDdkQsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLEVBQUUsVUFBVSxFQUFFLGlCQUFpQixDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7SUFDbkcsQ0FBQzs7a0hBZlEscUJBQXFCO3NHQUFyQixxQkFBcUI7MkZBQXJCLHFCQUFxQjtrQkFIakMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsZUFBZTtpQkFDNUI7eUhBTXVCLFVBQVU7c0JBQTdCLEtBQUs7Z0JBUWMsUUFBUTtzQkFBM0IsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgSW5wdXQsIFJlbmRlcmVyMiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHR5cGUgeyBTZWxlY3QgfSBmcm9tICdAbmkvbmltYmxlLWNvbXBvbmVudHMvZGlzdC9lc20vc2VsZWN0JztcbmltcG9ydCB0eXBlIHsgRHJvcGRvd25BcHBlYXJhbmNlIH0gZnJvbSAnQG5pL25pbWJsZS1jb21wb25lbnRzL2Rpc3QvZXNtL3BhdHRlcm5zL2Ryb3Bkb3duL3R5cGVzJztcbmltcG9ydCB7IEJvb2xlYW5WYWx1ZU9yQXR0cmlidXRlLCB0b0Jvb2xlYW5Qcm9wZXJ0eSB9IGZyb20gJy4uL3V0aWxpdGllcy90ZW1wbGF0ZS12YWx1ZS1oZWxwZXJzJztcblxuZXhwb3J0IHR5cGUgeyBTZWxlY3QgfTtcblxuLyoqXG4gKiBEaXJlY3RpdmUgZm9yIE5pbWJsZSBzZWxlY3QgY29udHJvbCBBbmd1bGFyIGludGVncmF0aW9uXG4gKi9cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnbmltYmxlLXNlbGVjdCcsXG59KVxuZXhwb3J0IGNsYXNzIE5pbWJsZVNlbGVjdERpcmVjdGl2ZSB7XG4gICAgcHVibGljIGdldCBhcHBlYXJhbmNlKCk6IERyb3Bkb3duQXBwZWFyYW5jZSB7XG4gICAgICAgIHJldHVybiB0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudC5hcHBlYXJhbmNlO1xuICAgIH1cblxuICAgIEBJbnB1dCgpIHB1YmxpYyBzZXQgYXBwZWFyYW5jZSh2YWx1ZTogRHJvcGRvd25BcHBlYXJhbmNlKSB7XG4gICAgICAgIHRoaXMucmVuZGVyZXIuc2V0UHJvcGVydHkodGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQsICdhcHBlYXJhbmNlJywgdmFsdWUpO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXQgZGlzYWJsZWQoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiB0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudC5kaXNhYmxlZDtcbiAgICB9XG5cbiAgICBASW5wdXQoKSBwdWJsaWMgc2V0IGRpc2FibGVkKHZhbHVlOiBCb29sZWFuVmFsdWVPckF0dHJpYnV0ZSkge1xuICAgICAgICB0aGlzLnJlbmRlcmVyLnNldFByb3BlcnR5KHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LCAnZGlzYWJsZWQnLCB0b0Jvb2xlYW5Qcm9wZXJ0eSh2YWx1ZSkpO1xuICAgIH1cblxuICAgIHB1YmxpYyBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IHJlbmRlcmVyOiBSZW5kZXJlcjIsIHByaXZhdGUgcmVhZG9ubHkgZWxlbWVudFJlZjogRWxlbWVudFJlZjxTZWxlY3Q+KSB7fVxufVxuIl19
|
package/esm2015/public-api.js
CHANGED
|
@@ -18,7 +18,8 @@ export * from './directives/combobox/nimble-combobox.module';
|
|
|
18
18
|
export * from './directives/drawer/nimble-drawer.directive';
|
|
19
19
|
export * from './directives/drawer/nimble-drawer.module';
|
|
20
20
|
export * from './directives/icons';
|
|
21
|
-
export * from './directives/list-option/nimble-list-option.directive';
|
|
21
|
+
export * from './directives/list-option/nimble-combobox-list-option.directive';
|
|
22
|
+
export * from './directives/list-option/nimble-select-list-option.directive';
|
|
22
23
|
export * from './directives/list-option/nimble-list-option.module';
|
|
23
24
|
export * from './directives/menu/nimble-menu.directive';
|
|
24
25
|
export * from './directives/menu/nimble-menu.module';
|
|
@@ -63,5 +64,6 @@ export * from './directives/tree-view/nimble-tree-view.module';
|
|
|
63
64
|
export * from './testing/async-helpers';
|
|
64
65
|
// Export enums that are used by multiple components here to avoid exporting them multiple times.
|
|
65
66
|
export { ButtonAppearance } from '@ni/nimble-components/dist/esm/patterns/button/types';
|
|
67
|
+
export { DropdownAppearance } from '@ni/nimble-components/dist/esm/patterns/dropdown/types';
|
|
66
68
|
export { IconStatus } from '@ni/nimble-components/dist/esm/icon-base/types';
|
|
67
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"public-api.js","sourceRoot":"","sources":["../../../../projects/ni/nimble-angular/src/public-api.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,cAAc,qDAAqD,CAAC;AACpE,cAAc,kDAAkD,CAAC;AACjE,cAAc,qFAAqF,CAAC;AACpG,cAAc,2EAA2E,CAAC;AAC1F,cAAc,+DAA+D,CAAC;AAC9E,cAAc,4DAA4D,CAAC;AAC3E,cAAc,6CAA6C,CAAC;AAC5D,cAAc,0CAA0C,CAAC;AACzD,cAAc,wEAAwE,CAAC;AACvF,cAAc,iDAAiD,CAAC;AAChE,cAAc,8CAA8C,CAAC;AAC7D,cAAc,wEAAwE,CAAC;AACvF,cAAc,iDAAiD,CAAC;AAChE,cAAc,8CAA8C,CAAC;AAC7D,cAAc,6CAA6C,CAAC;AAC5D,cAAc,0CAA0C,CAAC;AACzD,cAAc,oBAAoB,CAAC;AACnC,cAAc,gEAAgE,CAAC;AAC/E,cAAc,8DAA8D,CAAC;AAC7E,cAAc,oDAAoD,CAAC;AACnE,cAAc,yCAAyC,CAAC;AACxD,cAAc,sCAAsC,CAAC;AACrD,cAAc,uDAAuD,CAAC;AACtE,cAAc,oDAAoD,CAAC;AACnE,cAAc,mDAAmD,CAAC;AAClE,cAAc,gDAAgD,CAAC;AAC/D,cAAc,gFAAgF,CAAC;AAC/F,cAAc,yDAAyD,CAAC;AACxE,cAAc,sDAAsD,CAAC;AACrE,cAAc,oEAAoE,CAAC;AACnF,cAAc,6CAA6C,CAAC;AAC5D,cAAc,0CAA0C,CAAC;AACzD,cAAc,oEAAoE,CAAC;AACnF,cAAc,6CAA6C,CAAC;AAC5D,cAAc,0CAA0C,CAAC;AACzD,cAAc,uCAAuC,CAAC;AACtD,cAAc,oCAAoC,CAAC;AACnD,cAAc,mDAAmD,CAAC;AAClE,cAAc,gDAAgD,CAAC;AAC/D,cAAc,yCAAyC,CAAC;AACxD,cAAc,sCAAsC,CAAC;AACrD,cAAc,yDAAyD,CAAC;AACxE,cAAc,sDAAsD,CAAC;AACrE,cAAc,0EAA0E,CAAC;AACzF,cAAc,mDAAmD,CAAC;AAClE,cAAc,gDAAgD,CAAC;AAC/D,cAAc,4EAA4E,CAAC;AAC3F,cAAc,qDAAqD,CAAC;AACpE,cAAc,kDAAkD,CAAC;AACjE,cAAc,6DAA6D,CAAC;AAC5E,cAAc,0DAA0D,CAAC;AACzE,cAAc,kFAAkF,CAAC;AACjG,cAAc,2DAA2D,CAAC;AAC1E,cAAc,wDAAwD,CAAC;AACvE,cAAc,+CAA+C,CAAC;AAC9D,cAAc,4CAA4C,CAAC;AAC3D,cAAc,mDAAmD,CAAC;AAClE,cAAc,gDAAgD,CAAC;AAC/D,cAAc,mDAAmD,CAAC;AAClE,cAAc,gDAAgD,CAAC;AAC/D,cAAc,yBAAyB,CAAC;AAExC,iGAAiG;AACjG,OAAO,EAAE,gBAAgB,EAAE,MAAM,sDAAsD,CAAC;AACxF,OAAO,EAAE,kBAAkB,EAAE,MAAM,wDAAwD,CAAC;AAC5F,OAAO,EAAE,UAAU,EAAE,MAAM,gDAAgD,CAAC","sourcesContent":["/*\n * Public API Surface of nimble-angular\n */\n\nexport * from './directives/breadcrumb/nimble-breadcrumb.directive';\nexport * from './directives/breadcrumb/nimble-breadcrumb.module';\nexport * from './directives/breadcrumb-item/nimble-breadcrumb-item-router-link-with-href.directive';\nexport * from './directives/breadcrumb-item/nimble-breadcrumb-item-router-link.directive';\nexport * from './directives/breadcrumb-item/nimble-breadcrumb-item.directive';\nexport * from './directives/breadcrumb-item/nimble-breadcrumb-item.module';\nexport * from './directives/button/nimble-button.directive';\nexport * from './directives/button/nimble-button.module';\nexport * from './directives/checkbox/nimble-checkbox-control-value-accessor.directive';\nexport * from './directives/checkbox/nimble-checkbox.directive';\nexport * from './directives/checkbox/nimble-checkbox.module';\nexport * from './directives/combobox/nimble-combobox-control-value-accessor.directive';\nexport * from './directives/combobox/nimble-combobox.directive';\nexport * from './directives/combobox/nimble-combobox.module';\nexport * from './directives/drawer/nimble-drawer.directive';\nexport * from './directives/drawer/nimble-drawer.module';\nexport * from './directives/icons';\nexport * from './directives/list-option/nimble-combobox-list-option.directive';\nexport * from './directives/list-option/nimble-select-list-option.directive';\nexport * from './directives/list-option/nimble-list-option.module';\nexport * from './directives/menu/nimble-menu.directive';\nexport * from './directives/menu/nimble-menu.module';\nexport * from './directives/menu-button/nimble-menu-button.directive';\nexport * from './directives/menu-button/nimble-menu-button.module';\nexport * from './directives/menu-item/nimble-menu-item.directive';\nexport * from './directives/menu-item/nimble-menu-item.module';\nexport * from './directives/number-field/nimble-number-field-control-value-accessor.directive';\nexport * from './directives/number-field/nimble-number-field.directive';\nexport * from './directives/number-field/nimble-number-field.module';\nexport * from './directives/select/nimble-select-control-value-accessor.directive';\nexport * from './directives/select/nimble-select.directive';\nexport * from './directives/select/nimble-select.module';\nexport * from './directives/switch/nimble-switch-control-value-accessor.directive';\nexport * from './directives/switch/nimble-switch.directive';\nexport * from './directives/switch/nimble-switch.module';\nexport * from './directives/tab/nimble-tab.directive';\nexport * from './directives/tab/nimble-tab.module';\nexport * from './directives/tab-panel/nimble-tab-panel.directive';\nexport * from './directives/tab-panel/nimble-tab-panel.module';\nexport * from './directives/tabs/nimble-tabs.directive';\nexport * from './directives/tabs/nimble-tabs.module';\nexport * from './directives/tabs-toolbar/nimble-tabs-toolbar.directive';\nexport * from './directives/tabs-toolbar/nimble-tabs-toolbar.module';\nexport * from './directives/text-area/nimble-text-area-control-value-accessor.directive';\nexport * from './directives/text-area/nimble-text-area.directive';\nexport * from './directives/text-area/nimble-text-area.module';\nexport * from './directives/text-field/nimble-text-field-control-value-accessor.directive';\nexport * from './directives/text-field/nimble-text-field.directive';\nexport * from './directives/text-field/nimble-text-field.module';\nexport * from './directives/theme-provider/nimble-theme-provider.directive';\nexport * from './directives/theme-provider/nimble-theme-provider.module';\nexport * from './directives/toggle-button/nimble-toggle-button-control-value-accessor.directive';\nexport * from './directives/toggle-button/nimble-toggle-button.directive';\nexport * from './directives/toggle-button/nimble-toggle-button.module';\nexport * from './directives/toolbar/nimble-toolbar.directive';\nexport * from './directives/toolbar/nimble-toolbar.module';\nexport * from './directives/tree-item/nimble-tree-item.directive';\nexport * from './directives/tree-item/nimble-tree-item.module';\nexport * from './directives/tree-view/nimble-tree-view.directive';\nexport * from './directives/tree-view/nimble-tree-view.module';\nexport * from './testing/async-helpers';\n\n// Export enums that are used by multiple components here to avoid exporting them multiple times.\nexport { ButtonAppearance } from '@ni/nimble-components/dist/esm/patterns/button/types';\nexport { DropdownAppearance } from '@ni/nimble-components/dist/esm/patterns/dropdown/types';\nexport { IconStatus } from '@ni/nimble-components/dist/esm/icon-base/types';"]}
|