@ni/nimble-angular 12.1.0 → 12.1.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.
@@ -1,5 +1,5 @@
1
1
  import { ElementRef, Injector, OnInit, Renderer2 } from '@angular/core';
2
- import { RadioControlValueAccessor, ɵangular_packages_forms_forms_r } from '@angular/forms';
2
+ import { RadioControlValueAccessor, RadioControlRegistry } from '../../thirdparty/directives/radio_control_value_accessor';
3
3
  import * as i0 from "@angular/core";
4
4
  /**
5
5
  * Control Value Accessor implementation for the radio group.
@@ -8,7 +8,7 @@ export declare class NimbleRadioControlValueAccessorDirective extends RadioContr
8
8
  private readonly elementRef;
9
9
  private static _nextOpenId;
10
10
  private _privateOnChange?;
11
- constructor(renderer: Renderer2, elementRef: ElementRef, _registry: ɵangular_packages_forms_forms_r, _injector: Injector);
11
+ constructor(renderer: Renderer2, elementRef: ElementRef, _registry: RadioControlRegistry, _injector: Injector);
12
12
  private static allocateId;
13
13
  ngOnInit(): void;
14
14
  /**
@@ -2,8 +2,9 @@ import * as i0 from "@angular/core";
2
2
  import * as i1 from "./nimble-radio-control-value-accessor.directive";
3
3
  import * as i2 from "./nimble-radio.directive";
4
4
  import * as i3 from "@angular/common";
5
+ import * as i4 from "../../thirdparty/directives/radio_control_value_accessor";
5
6
  export declare class NimbleRadioModule {
6
7
  static ɵfac: i0.ɵɵFactoryDeclaration<NimbleRadioModule, never>;
7
- static ɵmod: i0.ɵɵNgModuleDeclaration<NimbleRadioModule, [typeof i1.NimbleRadioControlValueAccessorDirective, typeof i2.NimbleRadioDirective], [typeof i3.CommonModule], [typeof i1.NimbleRadioControlValueAccessorDirective, typeof i2.NimbleRadioDirective]>;
8
+ static ɵmod: i0.ɵɵNgModuleDeclaration<NimbleRadioModule, [typeof i1.NimbleRadioControlValueAccessorDirective, typeof i2.NimbleRadioDirective], [typeof i3.CommonModule, typeof i4.RadioControlRegistryModule], [typeof i1.NimbleRadioControlValueAccessorDirective, typeof i2.NimbleRadioDirective]>;
8
9
  static ɵinj: i0.ɵɵInjectorDeclaration<NimbleRadioModule>;
9
10
  }
@@ -1,15 +1,14 @@
1
1
  import { Directive, forwardRef } from '@angular/core';
2
2
  // eslint-disable-next-line camelcase
3
- import { NG_VALUE_ACCESSOR, RadioControlValueAccessor } from '@angular/forms';
3
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
4
4
  import { RadioGroup } from '@ni/nimble-components/dist/esm/radio-group';
5
+ import { RadioControlValueAccessor } from '../../thirdparty/directives/radio_control_value_accessor';
5
6
  import * as i0 from "@angular/core";
6
- import * as i1 from "@angular/forms";
7
+ import * as i1 from "../../thirdparty/directives/radio_control_value_accessor";
7
8
  /**
8
9
  * Control Value Accessor implementation for the radio group.
9
10
  */
10
11
  export class NimbleRadioControlValueAccessorDirective extends RadioControlValueAccessor {
11
- // Type ɵangular_packages_forms_forms_r from base class isn't in camelcase
12
- // eslint-disable-next-line camelcase
13
12
  constructor(renderer, elementRef, _registry, _injector) {
14
13
  super(renderer, elementRef, _registry, _injector);
15
14
  this.elementRef = elementRef;
@@ -20,6 +19,7 @@ export class NimbleRadioControlValueAccessorDirective extends RadioControlValueA
20
19
  return id;
21
20
  }
22
21
  ngOnInit() {
22
+ super.ngOnInit();
23
23
  // We need each button element to have a unique string value, because the FAST radio group looks at
24
24
  // these values when trying to manage the checked state.
25
25
  this.elementRef.nativeElement.value = NimbleRadioControlValueAccessorDirective.allocateId();
@@ -63,7 +63,7 @@ export class NimbleRadioControlValueAccessorDirective extends RadioControlValueA
63
63
  }
64
64
  }
65
65
  NimbleRadioControlValueAccessorDirective._nextOpenId = 0;
66
- NimbleRadioControlValueAccessorDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NimbleRadioControlValueAccessorDirective, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i1.ɵangular_packages_forms_forms_r }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Directive });
66
+ NimbleRadioControlValueAccessorDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NimbleRadioControlValueAccessorDirective, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i1.RadioControlRegistry }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Directive });
67
67
  NimbleRadioControlValueAccessorDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.5", type: NimbleRadioControlValueAccessorDirective, selector: "nimble-radio[formControlName],nimble-radio[formControl],nimble-radio[ngModel]", host: { listeners: { "change": "nimbleOnChange($event.target.checked)", "blur": "onTouched()" } }, providers: [{
68
68
  provide: NG_VALUE_ACCESSOR,
69
69
  useExisting: forwardRef(() => NimbleRadioControlValueAccessorDirective),
@@ -82,5 +82,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImpor
82
82
  multi: true
83
83
  }]
84
84
  }]
85
- }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i1.ɵangular_packages_forms_forms_r }, { type: i0.Injector }]; } });
86
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nimble-radio-control-value-accessor.directive.js","sourceRoot":"","sources":["../../../../../../projects/ni/nimble-angular/src/directives/radio/nimble-radio-control-value-accessor.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAc,UAAU,EAA+B,MAAM,eAAe,CAAC;AAC/F,qCAAqC;AACrC,OAAO,EAAE,iBAAiB,EAAE,yBAAyB,EAAmC,MAAM,gBAAgB,CAAC;AAC/G,OAAO,EAAE,UAAU,EAAE,MAAM,4CAA4C,CAAC;;;AAGxE;;GAEG;AAaH,MAAM,OAAO,wCAAyC,SAAQ,yBAAyB;IAInF,0EAA0E;IAC1E,qCAAqC;IACrC,YAAmB,QAAmB,EAAmB,UAAsB,EAAE,SAA0C,EAAE,SAAmB;QAC5I,KAAK,CAAC,QAAQ,EAAE,UAAU,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC;QADG,eAAU,GAAV,UAAU,CAAY;IAE/E,CAAC;IAEO,MAAM,CAAC,UAAU;QACrB,MAAM,EAAE,GAAG,wCAAwC,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC;QAC3E,wCAAwC,CAAC,WAAW,IAAI,CAAC,CAAC;QAC1D,OAAO,EAAE,CAAC;IACd,CAAC;IAEM,QAAQ;QACX,mGAAmG;QACnG,wDAAwD;QACvD,IAAI,CAAC,UAAU,CAAC,aAAuB,CAAC,KAAK,GAAG,wCAAwC,CAAC,UAAU,EAAE,CAAC;IAC3G,CAAC;IAED;;;OAGG;IACa,UAAU,CAAC,KAAc;QACrC,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QACxB,MAAM,WAAW,GAAI,IAAI,CAAC,UAAU,CAAC,aAAuB,CAAC,aAAa,CAAC;QAC3E,IAAI,IAAI,CAAC,KAAK,KAAK,KAAK,IAAI,WAAW,IAAI,WAAW,YAAY,UAAU,EAAE;YAC1E,2FAA2F;YAC3F,8FAA8F;YAC9F,0FAA0F;YAC1F,uFAAuF;YACvF,wEAAwE;YACxE,yFAAyF;YACzF,2FAA2F;YAC3F,gEAAgE;YAChE,WAAW,CAAC,KAAK,GAAI,IAAI,CAAC,UAAU,CAAC,aAAuB,CAAC,KAAK,CAAC;SACtE;IACL,CAAC;IAED,uFAAuF;IACvF,kGAAkG;IAClG,mGAAmG;IACnG,gCAAgC;IAChC,EAAE;IACF,oGAAoG;IACpG,sGAAsG;IACtG,2CAA2C;IACpC,cAAc,CAAC,OAAgB;QAClC,IAAI,OAAO,IAAI,IAAI,CAAC,gBAAgB,EAAE;YAClC,IAAI,CAAC,gBAAgB,EAAE,CAAC;SAC3B;IACL,CAAC;IAEe,gBAAgB,CAAC,EAA8C;QAC3E,KAAK,CAAC,gBAAgB,CAAC,EAAE,CAAC,CAAC;QAC3B,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,QAAQ,CAAC;QACtC,IAAI,CAAC,QAAQ,GAAG,GAAS,EAAE,GAAE,CAAC,CAAC;IACnC,CAAC;;AA3Dc,oDAAW,GAAG,CAAC,CAAC;qIADtB,wCAAwC;yHAAxC,wCAAwC,2MANtC,CAAC;YACR,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,wCAAwC,CAAC;YACvE,KAAK,EAAE,IAAI;SACd,CAAC;2FAEO,wCAAwC;kBAZpD,SAAS;mBAAC;oBACP,QAAQ,EACJ,+EAA+E;oBACnF,2EAA2E;oBAC3E,qEAAqE;oBACrE,IAAI,EAAE,EAAE,UAAU,EAAE,uCAAuC,EAAE,QAAQ,EAAE,aAAa,EAAE;oBACtF,SAAS,EAAE,CAAC;4BACR,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,yCAAyC,CAAC;4BACvE,KAAK,EAAE,IAAI;yBACd,CAAC;iBACL","sourcesContent":["import { Directive, ElementRef, forwardRef, Injector, OnInit, Renderer2 } from '@angular/core';\n// eslint-disable-next-line camelcase\nimport { NG_VALUE_ACCESSOR, RadioControlValueAccessor, ɵangular_packages_forms_forms_r } from '@angular/forms';\nimport { RadioGroup } from '@ni/nimble-components/dist/esm/radio-group';\nimport type { Radio } from '@ni/nimble-components/dist/esm/radio';\n\n/**\n * Control Value Accessor implementation for the radio group.\n */\n@Directive({\n    selector:\n        'nimble-radio[formControlName],nimble-radio[formControl],nimble-radio[ngModel]',\n    // The following host metadata is duplicated from RadioControlValueAccessor\n    // eslint-disable-next-line @angular-eslint/no-host-metadata-property\n    host: { '(change)': 'nimbleOnChange($event.target.checked)', '(blur)': 'onTouched()' },\n    providers: [{\n        provide: NG_VALUE_ACCESSOR,\n        useExisting: forwardRef(() => NimbleRadioControlValueAccessorDirective),\n        multi: true\n    }]\n})\nexport class NimbleRadioControlValueAccessorDirective extends RadioControlValueAccessor implements OnInit {\n    private static _nextOpenId = 0;\n    private _privateOnChange?: () => void;\n\n    // Type ɵangular_packages_forms_forms_r from base class isn't in camelcase\n    // eslint-disable-next-line camelcase\n    public constructor(renderer: Renderer2, private readonly elementRef: ElementRef, _registry: ɵangular_packages_forms_forms_r, _injector: Injector) {\n        super(renderer, elementRef, _registry, _injector);\n    }\n\n    private static allocateId(): string {\n        const id = NimbleRadioControlValueAccessorDirective._nextOpenId.toString();\n        NimbleRadioControlValueAccessorDirective._nextOpenId += 1;\n        return id;\n    }\n\n    public ngOnInit(): void {\n        // We need each button element to have a unique string value, because the FAST radio group looks at\n        // these values when trying to manage the checked state.\n        (this.elementRef.nativeElement as Radio).value = NimbleRadioControlValueAccessorDirective.allocateId();\n    }\n\n    /**\n     * Sets the \"checked\" property value on the radio input element.\n     * @nodoc\n     */\n    public override writeValue(value: unknown): void {\n        super.writeValue(value);\n        const parentGroup = (this.elementRef.nativeElement as Radio).parentElement;\n        if (this.value === value && parentGroup && parentGroup instanceof RadioGroup) {\n            // This is a workaround to a problem where all of the buttons are initialized as unchecked.\n            // The radio group tries to synchronize its value and the checked states of the radio buttons.\n            // In response to the slotchange DOM event, the radio group sets the checked state of each\n            // newly slotted button, based on whether the button's value matches the group's value.\n            // If the group's value is uninitialized, it unchecks all radio buttons.\n            // Unfortunately, this occurs _after_ the CVA initializes the checked state of each radio\n            // button, meaning the initially checked button gets unchecked by the group. To avoid this,\n            // we need to set the group's value to match the checked button.\n            parentGroup.value = (this.elementRef.nativeElement as Radio).value;\n        }\n    }\n\n    // There is a bug in FAST (https://github.com/microsoft/fast/issues/6381) that prevents\n    // RadioControlValueAccessor from working properly. The default onChange handler is supposed to be\n    // called _only_ when radio buttons are checked, but the FAST bug causes it to be called when radio\n    // buttons are _unchecked_, too.\n    //\n    // To work around this, we effectively disable the base class's onChange handler and replace it with\n    // our own nimbleOnChange. NimbleOnChange calls the original onChange (now cached as _privateOnChange)\n    // only if the changed item became checked.\n    public nimbleOnChange(checked: boolean): void {\n        if (checked && this._privateOnChange) {\n            this._privateOnChange();\n        }\n    }\n\n    public override registerOnChange(fn: (_: unknown) => { [key: string]: unknown }): void {\n        super.registerOnChange(fn);\n        this._privateOnChange = this.onChange;\n        this.onChange = (): void => {};\n    }\n}"]}
85
+ }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i1.RadioControlRegistry }, { type: i0.Injector }]; } });
86
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nimble-radio-control-value-accessor.directive.js","sourceRoot":"","sources":["../../../../../../projects/ni/nimble-angular/src/directives/radio/nimble-radio-control-value-accessor.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAc,UAAU,EAA+B,MAAM,eAAe,CAAC;AAC/F,qCAAqC;AACrC,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,UAAU,EAAE,MAAM,4CAA4C,CAAC;AAExE,OAAO,EAAE,yBAAyB,EAAwB,MAAM,0DAA0D,CAAC;;;AAE3H;;GAEG;AAaH,MAAM,OAAO,wCAAyC,SAAQ,yBAAyB;IAInF,YAAmB,QAAmB,EAAmB,UAAsB,EAAE,SAA+B,EAAE,SAAmB;QACjI,KAAK,CAAC,QAAQ,EAAE,UAAU,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC;QADG,eAAU,GAAV,UAAU,CAAY;IAE/E,CAAC;IAEO,MAAM,CAAC,UAAU;QACrB,MAAM,EAAE,GAAG,wCAAwC,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC;QAC3E,wCAAwC,CAAC,WAAW,IAAI,CAAC,CAAC;QAC1D,OAAO,EAAE,CAAC;IACd,CAAC;IAEe,QAAQ;QACpB,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,mGAAmG;QACnG,wDAAwD;QACvD,IAAI,CAAC,UAAU,CAAC,aAAuB,CAAC,KAAK,GAAG,wCAAwC,CAAC,UAAU,EAAE,CAAC;IAC3G,CAAC;IAED;;;OAGG;IACa,UAAU,CAAC,KAAc;QACrC,KAAK,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QACxB,MAAM,WAAW,GAAI,IAAI,CAAC,UAAU,CAAC,aAAuB,CAAC,aAAa,CAAC;QAC3E,IAAI,IAAI,CAAC,KAAK,KAAK,KAAK,IAAI,WAAW,IAAI,WAAW,YAAY,UAAU,EAAE;YAC1E,2FAA2F;YAC3F,8FAA8F;YAC9F,0FAA0F;YAC1F,uFAAuF;YACvF,wEAAwE;YACxE,yFAAyF;YACzF,2FAA2F;YAC3F,gEAAgE;YAChE,WAAW,CAAC,KAAK,GAAI,IAAI,CAAC,UAAU,CAAC,aAAuB,CAAC,KAAK,CAAC;SACtE;IACL,CAAC;IAED,uFAAuF;IACvF,kGAAkG;IAClG,mGAAmG;IACnG,gCAAgC;IAChC,EAAE;IACF,oGAAoG;IACpG,sGAAsG;IACtG,2CAA2C;IACpC,cAAc,CAAC,OAAgB;QAClC,IAAI,OAAO,IAAI,IAAI,CAAC,gBAAgB,EAAE;YAClC,IAAI,CAAC,gBAAgB,EAAE,CAAC;SAC3B;IACL,CAAC;IAEe,gBAAgB,CAAC,EAA8C;QAC3E,KAAK,CAAC,gBAAgB,CAAC,EAAE,CAAC,CAAC;QAC3B,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,QAAQ,CAAC;QACtC,IAAI,CAAC,QAAQ,GAAG,GAAS,EAAE,GAAE,CAAC,CAAC;IACnC,CAAC;;AA1Dc,oDAAW,GAAG,CAAC,CAAC;qIADtB,wCAAwC;yHAAxC,wCAAwC,2MANtC,CAAC;YACR,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,wCAAwC,CAAC;YACvE,KAAK,EAAE,IAAI;SACd,CAAC;2FAEO,wCAAwC;kBAZpD,SAAS;mBAAC;oBACP,QAAQ,EACJ,+EAA+E;oBACnF,2EAA2E;oBAC3E,qEAAqE;oBACrE,IAAI,EAAE,EAAE,UAAU,EAAE,uCAAuC,EAAE,QAAQ,EAAE,aAAa,EAAE;oBACtF,SAAS,EAAE,CAAC;4BACR,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,yCAAyC,CAAC;4BACvE,KAAK,EAAE,IAAI;yBACd,CAAC;iBACL","sourcesContent":["import { Directive, ElementRef, forwardRef, Injector, OnInit, Renderer2 } from '@angular/core';\n// eslint-disable-next-line camelcase\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { RadioGroup } from '@ni/nimble-components/dist/esm/radio-group';\nimport type { Radio } from '@ni/nimble-components/dist/esm/radio';\nimport { RadioControlValueAccessor, RadioControlRegistry } from '../../thirdparty/directives/radio_control_value_accessor';\n\n/**\n * Control Value Accessor implementation for the radio group.\n */\n@Directive({\n    selector:\n        'nimble-radio[formControlName],nimble-radio[formControl],nimble-radio[ngModel]',\n    // The following host metadata is duplicated from RadioControlValueAccessor\n    // eslint-disable-next-line @angular-eslint/no-host-metadata-property\n    host: { '(change)': 'nimbleOnChange($event.target.checked)', '(blur)': 'onTouched()' },\n    providers: [{\n        provide: NG_VALUE_ACCESSOR,\n        useExisting: forwardRef(() => NimbleRadioControlValueAccessorDirective),\n        multi: true\n    }]\n})\nexport class NimbleRadioControlValueAccessorDirective extends RadioControlValueAccessor implements OnInit {\n    private static _nextOpenId = 0;\n    private _privateOnChange?: () => void;\n\n    public constructor(renderer: Renderer2, private readonly elementRef: ElementRef, _registry: RadioControlRegistry, _injector: Injector) {\n        super(renderer, elementRef, _registry, _injector);\n    }\n\n    private static allocateId(): string {\n        const id = NimbleRadioControlValueAccessorDirective._nextOpenId.toString();\n        NimbleRadioControlValueAccessorDirective._nextOpenId += 1;\n        return id;\n    }\n\n    public override ngOnInit(): void {\n        super.ngOnInit();\n        // We need each button element to have a unique string value, because the FAST radio group looks at\n        // these values when trying to manage the checked state.\n        (this.elementRef.nativeElement as Radio).value = NimbleRadioControlValueAccessorDirective.allocateId();\n    }\n\n    /**\n     * Sets the \"checked\" property value on the radio input element.\n     * @nodoc\n     */\n    public override writeValue(value: unknown): void {\n        super.writeValue(value);\n        const parentGroup = (this.elementRef.nativeElement as Radio).parentElement;\n        if (this.value === value && parentGroup && parentGroup instanceof RadioGroup) {\n            // This is a workaround to a problem where all of the buttons are initialized as unchecked.\n            // The radio group tries to synchronize its value and the checked states of the radio buttons.\n            // In response to the slotchange DOM event, the radio group sets the checked state of each\n            // newly slotted button, based on whether the button's value matches the group's value.\n            // If the group's value is uninitialized, it unchecks all radio buttons.\n            // Unfortunately, this occurs _after_ the CVA initializes the checked state of each radio\n            // button, meaning the initially checked button gets unchecked by the group. To avoid this,\n            // we need to set the group's value to match the checked button.\n            parentGroup.value = (this.elementRef.nativeElement as Radio).value;\n        }\n    }\n\n    // There is a bug in FAST (https://github.com/microsoft/fast/issues/6381) that prevents\n    // RadioControlValueAccessor from working properly. The default onChange handler is supposed to be\n    // called _only_ when radio buttons are checked, but the FAST bug causes it to be called when radio\n    // buttons are _unchecked_, too.\n    //\n    // To work around this, we effectively disable the base class's onChange handler and replace it with\n    // our own nimbleOnChange. NimbleOnChange calls the original onChange (now cached as _privateOnChange)\n    // only if the changed item became checked.\n    public nimbleOnChange(checked: boolean): void {\n        if (checked && this._privateOnChange) {\n            this._privateOnChange();\n        }\n    }\n\n    public override registerOnChange(fn: (_: unknown) => { [key: string]: unknown }): void {\n        super.registerOnChange(fn);\n        this._privateOnChange = this.onChange;\n        this.onChange = (): void => {};\n    }\n}"]}
@@ -2,18 +2,19 @@ import { NgModule } from '@angular/core';
2
2
  import { CommonModule } from '@angular/common';
3
3
  import { NimbleRadioControlValueAccessorDirective } from './nimble-radio-control-value-accessor.directive';
4
4
  import { NimbleRadioDirective } from './nimble-radio.directive';
5
+ import { RadioControlRegistryModule } from '../../thirdparty/directives/radio_control_value_accessor';
5
6
  import * as i0 from "@angular/core";
6
7
  export class NimbleRadioModule {
7
8
  }
8
9
  NimbleRadioModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NimbleRadioModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
9
- NimbleRadioModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NimbleRadioModule, declarations: [NimbleRadioControlValueAccessorDirective, NimbleRadioDirective], imports: [CommonModule], exports: [NimbleRadioControlValueAccessorDirective, NimbleRadioDirective] });
10
- NimbleRadioModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NimbleRadioModule, imports: [[CommonModule]] });
10
+ NimbleRadioModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NimbleRadioModule, declarations: [NimbleRadioControlValueAccessorDirective, NimbleRadioDirective], imports: [CommonModule, RadioControlRegistryModule], exports: [NimbleRadioControlValueAccessorDirective, NimbleRadioDirective] });
11
+ NimbleRadioModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NimbleRadioModule, imports: [[CommonModule, RadioControlRegistryModule]] });
11
12
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: NimbleRadioModule, decorators: [{
12
13
  type: NgModule,
13
14
  args: [{
14
15
  declarations: [NimbleRadioControlValueAccessorDirective, NimbleRadioDirective],
15
- imports: [CommonModule],
16
+ imports: [CommonModule, RadioControlRegistryModule],
16
17
  exports: [NimbleRadioControlValueAccessorDirective, NimbleRadioDirective]
17
18
  }]
18
19
  }] });
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmltYmxlLXJhZGlvLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pL25pbWJsZS1hbmd1bGFyL3NyYy9kaXJlY3RpdmVzL3JhZGlvL25pbWJsZS1yYWRpby5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHdDQUF3QyxFQUFFLE1BQU0saURBQWlELENBQUM7QUFDM0csT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7O0FBT2hFLE1BQU0sT0FBTyxpQkFBaUI7OzhHQUFqQixpQkFBaUI7K0dBQWpCLGlCQUFpQixpQkFKWCx3Q0FBd0MsRUFBRSxvQkFBb0IsYUFDbkUsWUFBWSxhQUNaLHdDQUF3QyxFQUFFLG9CQUFvQjsrR0FFL0QsaUJBQWlCLFlBSGpCLENBQUMsWUFBWSxDQUFDOzJGQUdkLGlCQUFpQjtrQkFMN0IsUUFBUTttQkFBQztvQkFDTixZQUFZLEVBQUUsQ0FBQyx3Q0FBd0MsRUFBRSxvQkFBb0IsQ0FBQztvQkFDOUUsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixPQUFPLEVBQUUsQ0FBQyx3Q0FBd0MsRUFBRSxvQkFBb0IsQ0FBQztpQkFDNUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5pbWJsZVJhZGlvQ29udHJvbFZhbHVlQWNjZXNzb3JEaXJlY3RpdmUgfSBmcm9tICcuL25pbWJsZS1yYWRpby1jb250cm9sLXZhbHVlLWFjY2Vzc29yLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBOaW1ibGVSYWRpb0RpcmVjdGl2ZSB9IGZyb20gJy4vbmltYmxlLXJhZGlvLmRpcmVjdGl2ZSc7XG5cbkBOZ01vZHVsZSh7XG4gICAgZGVjbGFyYXRpb25zOiBbTmltYmxlUmFkaW9Db250cm9sVmFsdWVBY2Nlc3NvckRpcmVjdGl2ZSwgTmltYmxlUmFkaW9EaXJlY3RpdmVdLFxuICAgIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICAgIGV4cG9ydHM6IFtOaW1ibGVSYWRpb0NvbnRyb2xWYWx1ZUFjY2Vzc29yRGlyZWN0aXZlLCBOaW1ibGVSYWRpb0RpcmVjdGl2ZV1cbn0pXG5leHBvcnQgY2xhc3MgTmltYmxlUmFkaW9Nb2R1bGUgeyB9XG4iXX0=
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmltYmxlLXJhZGlvLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25pL25pbWJsZS1hbmd1bGFyL3NyYy9kaXJlY3RpdmVzL3JhZGlvL25pbWJsZS1yYWRpby5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHdDQUF3QyxFQUFFLE1BQU0saURBQWlELENBQUM7QUFDM0csT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDaEUsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sMERBQTBELENBQUM7O0FBT3RHLE1BQU0sT0FBTyxpQkFBaUI7OzhHQUFqQixpQkFBaUI7K0dBQWpCLGlCQUFpQixpQkFKWCx3Q0FBd0MsRUFBRSxvQkFBb0IsYUFDbkUsWUFBWSxFQUFFLDBCQUEwQixhQUN4Qyx3Q0FBd0MsRUFBRSxvQkFBb0I7K0dBRS9ELGlCQUFpQixZQUhqQixDQUFDLFlBQVksRUFBRSwwQkFBMEIsQ0FBQzsyRkFHMUMsaUJBQWlCO2tCQUw3QixRQUFRO21CQUFDO29CQUNOLFlBQVksRUFBRSxDQUFDLHdDQUF3QyxFQUFFLG9CQUFvQixDQUFDO29CQUM5RSxPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsMEJBQTBCLENBQUM7b0JBQ25ELE9BQU8sRUFBRSxDQUFDLHdDQUF3QyxFQUFFLG9CQUFvQixDQUFDO2lCQUM1RSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmltYmxlUmFkaW9Db250cm9sVmFsdWVBY2Nlc3NvckRpcmVjdGl2ZSB9IGZyb20gJy4vbmltYmxlLXJhZGlvLWNvbnRyb2wtdmFsdWUtYWNjZXNzb3IuZGlyZWN0aXZlJztcbmltcG9ydCB7IE5pbWJsZVJhZGlvRGlyZWN0aXZlIH0gZnJvbSAnLi9uaW1ibGUtcmFkaW8uZGlyZWN0aXZlJztcbmltcG9ydCB7IFJhZGlvQ29udHJvbFJlZ2lzdHJ5TW9kdWxlIH0gZnJvbSAnLi4vLi4vdGhpcmRwYXJ0eS9kaXJlY3RpdmVzL3JhZGlvX2NvbnRyb2xfdmFsdWVfYWNjZXNzb3InO1xuXG5ATmdNb2R1bGUoe1xuICAgIGRlY2xhcmF0aW9uczogW05pbWJsZVJhZGlvQ29udHJvbFZhbHVlQWNjZXNzb3JEaXJlY3RpdmUsIE5pbWJsZVJhZGlvRGlyZWN0aXZlXSxcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBSYWRpb0NvbnRyb2xSZWdpc3RyeU1vZHVsZV0sXG4gICAgZXhwb3J0czogW05pbWJsZVJhZGlvQ29udHJvbFZhbHVlQWNjZXNzb3JEaXJlY3RpdmUsIE5pbWJsZVJhZGlvRGlyZWN0aXZlXVxufSlcbmV4cG9ydCBjbGFzcyBOaW1ibGVSYWRpb01vZHVsZSB7IH1cbiJdfQ==
@@ -0,0 +1,215 @@
1
+ /**
2
+ * [Nimble]
3
+ * Copied from https://github.com/angular/angular/blob/14.2.6/packages/forms/src/directives/control_value_accessor.ts
4
+ * with the following modifications:
5
+ * - Commented out ControlValueAccessor which is exported from @angular/forms
6
+ * - Commented out NG_VALUE_ACCESSOR which is exported from @angular/forms
7
+ */
8
+ /**
9
+ * @license
10
+ * Copyright Google LLC All Rights Reserved.
11
+ *
12
+ * Use of this source code is governed by an MIT-style license that can be
13
+ * found in the LICENSE file at https://angular.io/license
14
+ */
15
+ import { Directive } from '@angular/core';
16
+ import * as i0 from "@angular/core";
17
+ /**
18
+ * @description
19
+ * Defines an interface that acts as a bridge between the Angular forms API and a
20
+ * native element in the DOM.
21
+ *
22
+ * Implement this interface to create a custom form control directive
23
+ * that integrates with Angular forms.
24
+ *
25
+ * @see DefaultValueAccessor
26
+ *
27
+ * @publicApi
28
+ */
29
+ /* [Nimble] Commenting out public interface
30
+ export interface ControlValueAccessor {
31
+ /**
32
+ * @description
33
+ * Writes a new value to the element.
34
+ *
35
+ * This method is called by the forms API to write to the view when programmatic
36
+ * changes from model to view are requested.
37
+ *
38
+ * @usageNotes
39
+ * ### Write a value to the element
40
+ *
41
+ * The following example writes a value to the native DOM element.
42
+ *
43
+ * ```ts
44
+ * writeValue(value: any): void {
45
+ * this._renderer.setProperty(this._elementRef.nativeElement, 'value', value);
46
+ * }
47
+ * ```
48
+ *
49
+ * @param obj The new value for the element
50
+ *
51
+ writeValue(obj: any): void;
52
+
53
+ /**
54
+ * @description
55
+ * Registers a callback function that is called when the control's value
56
+ * changes in the UI.
57
+ *
58
+ * This method is called by the forms API on initialization to update the form
59
+ * model when values propagate from the view to the model.
60
+ *
61
+ * When implementing the `registerOnChange` method in your own value accessor,
62
+ * save the given function so your class calls it at the appropriate time.
63
+ *
64
+ * @usageNotes
65
+ * ### Store the change function
66
+ *
67
+ * The following example stores the provided function as an internal method.
68
+ *
69
+ * ```ts
70
+ * registerOnChange(fn: (_: any) => void): void {
71
+ * this._onChange = fn;
72
+ * }
73
+ * ```
74
+ *
75
+ * When the value changes in the UI, call the registered
76
+ * function to allow the forms API to update itself:
77
+ *
78
+ * ```ts
79
+ * host: {
80
+ * '(change)': '_onChange($event.target.value)'
81
+ * }
82
+ * ```
83
+ *
84
+ * @param fn The callback function to register
85
+ *
86
+ registerOnChange(fn: any): void;
87
+
88
+ /**
89
+ * @description
90
+ * Registers a callback function that is called by the forms API on initialization
91
+ * to update the form model on blur.
92
+ *
93
+ * When implementing `registerOnTouched` in your own value accessor, save the given
94
+ * function so your class calls it when the control should be considered
95
+ * blurred or "touched".
96
+ *
97
+ * @usageNotes
98
+ * ### Store the callback function
99
+ *
100
+ * The following example stores the provided function as an internal method.
101
+ *
102
+ * ```ts
103
+ * registerOnTouched(fn: any): void {
104
+ * this._onTouched = fn;
105
+ * }
106
+ * ```
107
+ *
108
+ * On blur (or equivalent), your class should call the registered function to allow
109
+ * the forms API to update itself:
110
+ *
111
+ * ```ts
112
+ * host: {
113
+ * '(blur)': '_onTouched()'
114
+ * }
115
+ * ```
116
+ *
117
+ * @param fn The callback function to register
118
+ *
119
+ registerOnTouched(fn: any): void;
120
+
121
+ /**
122
+ * @description
123
+ * Function that is called by the forms API when the control status changes to
124
+ * or from 'DISABLED'. Depending on the status, it enables or disables the
125
+ * appropriate DOM element.
126
+ *
127
+ * @usageNotes
128
+ * The following is an example of writing the disabled property to a native DOM element:
129
+ *
130
+ * ```ts
131
+ * setDisabledState(isDisabled: boolean): void {
132
+ * this._renderer.setProperty(this._elementRef.nativeElement, 'disabled', isDisabled);
133
+ * }
134
+ * ```
135
+ *
136
+ * @param isDisabled The disabled status to set on the element
137
+ *
138
+ setDisabledState?(isDisabled: boolean): void;
139
+ }
140
+ */
141
+ /**
142
+ * Base class for all ControlValueAccessor classes defined in Forms package.
143
+ * Contains common logic and utility functions.
144
+ *
145
+ * Note: this is an *internal-only* class and should not be extended or used directly in
146
+ * applications code.
147
+ */
148
+ export class BaseControlValueAccessor {
149
+ constructor(_renderer, _elementRef) {
150
+ this._renderer = _renderer;
151
+ this._elementRef = _elementRef;
152
+ /**
153
+ * The registered callback function called when a change or input event occurs on the input
154
+ * element.
155
+ * @nodoc
156
+ */
157
+ this.onChange = (_) => { };
158
+ /**
159
+ * The registered callback function called when a blur event occurs on the input element.
160
+ * @nodoc
161
+ */
162
+ this.onTouched = () => { };
163
+ }
164
+ /**
165
+ * Helper method that sets a property on a target element using the current Renderer
166
+ * implementation.
167
+ * @nodoc
168
+ */
169
+ setProperty(key, value) {
170
+ this._renderer.setProperty(this._elementRef.nativeElement, key, value);
171
+ }
172
+ /**
173
+ * Registers a function called when the control is touched.
174
+ * @nodoc
175
+ */
176
+ registerOnTouched(fn) {
177
+ this.onTouched = fn;
178
+ }
179
+ /**
180
+ * Registers a function called when the control value changes.
181
+ * @nodoc
182
+ */
183
+ registerOnChange(fn) {
184
+ this.onChange = fn;
185
+ }
186
+ /**
187
+ * Sets the "disabled" property on the range input element.
188
+ * @nodoc
189
+ */
190
+ setDisabledState(isDisabled) {
191
+ this.setProperty('disabled', isDisabled);
192
+ }
193
+ }
194
+ BaseControlValueAccessor.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: BaseControlValueAccessor, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
195
+ BaseControlValueAccessor.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.5", type: BaseControlValueAccessor, ngImport: i0 });
196
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: BaseControlValueAccessor, decorators: [{
197
+ type: Directive
198
+ }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }]; } });
199
+ /**
200
+ * Base class for all built-in ControlValueAccessor classes (except DefaultValueAccessor, which is
201
+ * used in case no other CVAs can be found). We use this class to distinguish between default CVA,
202
+ * built-in CVAs and custom CVAs, so that Forms logic can recognize built-in CVAs and treat custom
203
+ * ones with higher priority (when both built-in and custom CVAs are present).
204
+ *
205
+ * Note: this is an *internal-only* class and should not be extended or used directly in
206
+ * applications code.
207
+ */
208
+ export class BuiltInControlValueAccessor extends BaseControlValueAccessor {
209
+ }
210
+ BuiltInControlValueAccessor.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: BuiltInControlValueAccessor, deps: null, target: i0.ɵɵFactoryTarget.Directive });
211
+ BuiltInControlValueAccessor.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.5", type: BuiltInControlValueAccessor, usesInheritance: true, ngImport: i0 });
212
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: BuiltInControlValueAccessor, decorators: [{
213
+ type: Directive
214
+ }] });
215
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"control_value_accessor.js","sourceRoot":"","sources":["../../../../../../projects/ni/nimble-angular/src/thirdparty/directives/control_value_accessor.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH;;;;;;GAMG;AAEH,OAAO,EAAC,SAAS,EAAwC,MAAM,eAAe,CAAC;;AAE/E;;;;;;;;;;;GAWG;AACH;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA+GE;AAEF;;;;;;GAMG;AAEH,MAAM,OAAO,wBAAwB;IAcnC,YAAoB,SAAoB,EAAU,WAAuB;QAArD,cAAS,GAAT,SAAS,CAAW;QAAU,gBAAW,GAAX,WAAW,CAAY;QAbzE;;;;WAIG;QACH,aAAQ,GAAG,CAAC,CAAM,EAAE,EAAE,GAAE,CAAC,CAAC;QAE1B;;;WAGG;QACH,cAAS,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;IAEuD,CAAC;IAE7E;;;;OAIG;IACO,WAAW,CAAC,GAAW,EAAE,KAAU;QAC3C,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,GAAG,EAAE,KAAK,CAAC,CAAC;IACzE,CAAC;IAED;;;OAGG;IACH,iBAAiB,CAAC,EAAc;QAC9B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED;;;OAGG;IACH,gBAAgB,CAAC,EAAkB;QACjC,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED;;;OAGG;IACH,gBAAgB,CAAC,UAAmB;QAClC,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;IAC3C,CAAC;;qHA/CU,wBAAwB;yGAAxB,wBAAwB;2FAAxB,wBAAwB;kBADpC,SAAS;;AAmDV;;;;;;;;GAQG;AAEH,MAAM,OAAO,2BAA4B,SAAQ,wBAAwB;;wHAA5D,2BAA2B;4GAA3B,2BAA2B;2FAA3B,2BAA2B;kBADvC,SAAS","sourcesContent":["/**\n * [Nimble]\n * Copied from https://github.com/angular/angular/blob/14.2.6/packages/forms/src/directives/control_value_accessor.ts\n * with the following modifications:\n * - Commented out ControlValueAccessor which is exported from @angular/forms\n * - Commented out NG_VALUE_ACCESSOR which is exported from @angular/forms\n */\n\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {Directive, ElementRef, InjectionToken, Renderer2} from '@angular/core';\n\n/**\n * @description\n * Defines an interface that acts as a bridge between the Angular forms API and a\n * native element in the DOM.\n *\n * Implement this interface to create a custom form control directive\n * that integrates with Angular forms.\n *\n * @see DefaultValueAccessor\n *\n * @publicApi\n */\n/* [Nimble] Commenting out public interface\nexport interface ControlValueAccessor {\n  /**\n   * @description\n   * Writes a new value to the element.\n   *\n   * This method is called by the forms API to write to the view when programmatic\n   * changes from model to view are requested.\n   *\n   * @usageNotes\n   * ### Write a value to the element\n   *\n   * The following example writes a value to the native DOM element.\n   *\n   * ```ts\n   * writeValue(value: any): void {\n   *   this._renderer.setProperty(this._elementRef.nativeElement, 'value', value);\n   * }\n   * ```\n   *\n   * @param obj The new value for the element\n   *\n  writeValue(obj: any): void;\n\n  /**\n   * @description\n   * Registers a callback function that is called when the control's value\n   * changes in the UI.\n   *\n   * This method is called by the forms API on initialization to update the form\n   * model when values propagate from the view to the model.\n   *\n   * When implementing the `registerOnChange` method in your own value accessor,\n   * save the given function so your class calls it at the appropriate time.\n   *\n   * @usageNotes\n   * ### Store the change function\n   *\n   * The following example stores the provided function as an internal method.\n   *\n   * ```ts\n   * registerOnChange(fn: (_: any) => void): void {\n   *   this._onChange = fn;\n   * }\n   * ```\n   *\n   * When the value changes in the UI, call the registered\n   * function to allow the forms API to update itself:\n   *\n   * ```ts\n   * host: {\n   *    '(change)': '_onChange($event.target.value)'\n   * }\n   * ```\n   *\n   * @param fn The callback function to register\n   *\n  registerOnChange(fn: any): void;\n\n  /**\n   * @description\n   * Registers a callback function that is called by the forms API on initialization\n   * to update the form model on blur.\n   *\n   * When implementing `registerOnTouched` in your own value accessor, save the given\n   * function so your class calls it when the control should be considered\n   * blurred or \"touched\".\n   *\n   * @usageNotes\n   * ### Store the callback function\n   *\n   * The following example stores the provided function as an internal method.\n   *\n   * ```ts\n   * registerOnTouched(fn: any): void {\n   *   this._onTouched = fn;\n   * }\n   * ```\n   *\n   * On blur (or equivalent), your class should call the registered function to allow\n   * the forms API to update itself:\n   *\n   * ```ts\n   * host: {\n   *    '(blur)': '_onTouched()'\n   * }\n   * ```\n   *\n   * @param fn The callback function to register\n   *\n  registerOnTouched(fn: any): void;\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   * appropriate DOM element.\n   *\n   * @usageNotes\n   * The following is an example of writing the disabled property to a native DOM element:\n   *\n   * ```ts\n   * setDisabledState(isDisabled: boolean): void {\n   *   this._renderer.setProperty(this._elementRef.nativeElement, 'disabled', isDisabled);\n   * }\n   * ```\n   *\n   * @param isDisabled The disabled status to set on the element\n   *\n  setDisabledState?(isDisabled: boolean): void;\n}\n*/\n\n/**\n * Base class for all ControlValueAccessor classes defined in Forms package.\n * Contains common logic and utility functions.\n *\n * Note: this is an *internal-only* class and should not be extended or used directly in\n * applications code.\n */\n@Directive()\nexport class BaseControlValueAccessor {\n  /**\n   * The registered callback function called when a change or input event occurs on the input\n   * element.\n   * @nodoc\n   */\n  onChange = (_: any) => {};\n\n  /**\n   * The registered callback function called when a blur event occurs on the input element.\n   * @nodoc\n   */\n  onTouched = () => {};\n\n  constructor(private _renderer: Renderer2, private _elementRef: ElementRef) {}\n\n  /**\n   * Helper method that sets a property on a target element using the current Renderer\n   * implementation.\n   * @nodoc\n   */\n  protected setProperty(key: string, value: any): void {\n    this._renderer.setProperty(this._elementRef.nativeElement, key, value);\n  }\n\n  /**\n   * Registers a function called when the control is touched.\n   * @nodoc\n   */\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  /**\n   * Registers a function called when the control value changes.\n   * @nodoc\n   */\n  registerOnChange(fn: (_: any) => {}): void {\n    this.onChange = fn;\n  }\n\n  /**\n   * Sets the \"disabled\" property on the range input element.\n   * @nodoc\n   */\n  setDisabledState(isDisabled: boolean): void {\n    this.setProperty('disabled', isDisabled);\n  }\n}\n\n/**\n * Base class for all built-in ControlValueAccessor classes (except DefaultValueAccessor, which is\n * used in case no other CVAs can be found). We use this class to distinguish between default CVA,\n * built-in CVAs and custom CVAs, so that Forms logic can recognize built-in CVAs and treat custom\n * ones with higher priority (when both built-in and custom CVAs are present).\n *\n * Note: this is an *internal-only* class and should not be extended or used directly in\n * applications code.\n */\n@Directive()\nexport class BuiltInControlValueAccessor extends BaseControlValueAccessor {\n}\n\n/**\n * Used to provide a `ControlValueAccessor` for form controls.\n *\n * See `DefaultValueAccessor` for how to implement one.\n *\n * @publicApi\n */\n/* [Nimble] Commenting out public injection token\nexport const NG_VALUE_ACCESSOR =\n    new InjectionToken<ReadonlyArray<ControlValueAccessor>>('NgValueAccessor');\n*/"]}
@@ -0,0 +1,197 @@
1
+ /**
2
+ * [Nimble]
3
+ * Copied from https://github.com/angular/angular/blob/14.2.6/packages/forms/src/directives/radio_control_value_accessor.ts
4
+ * with the following modifications:
5
+ * - Changed throwNameError() to throw Error instead of RuntimeError. This makes the file compile with Angular version 12.
6
+ * - Removed now-unused import for RuntimeErrorCode and RuntimeError
7
+ * - Updated import of ControlValueAccessor, NgControl, and NG_VALUE_ACCESSOR to pull from package export
8
+ */
9
+ /**
10
+ * @license
11
+ * Copyright Google LLC All Rights Reserved.
12
+ *
13
+ * Use of this source code is governed by an MIT-style license that can be
14
+ * found in the LICENSE file at https://angular.io/license
15
+ */
16
+ import { Directive, forwardRef, Injectable, Input, NgModule } from '@angular/core';
17
+ import { BuiltInControlValueAccessor } from './control_value_accessor';
18
+ import { NgControl, NG_VALUE_ACCESSOR } from '@angular/forms';
19
+ import * as i0 from "@angular/core";
20
+ export const RADIO_VALUE_ACCESSOR = {
21
+ provide: NG_VALUE_ACCESSOR,
22
+ useExisting: forwardRef(() => RadioControlValueAccessor),
23
+ multi: true
24
+ };
25
+ function throwNameError() {
26
+ /* [Nimble] RuntimeErrorCode is not exported from @angular/forms in version 12; falling back to version 12 behavior
27
+ throw new RuntimeError(RuntimeErrorCode.NAME_AND_FORM_CONTROL_NAME_MUST_MATCH, `
28
+ */
29
+ throw new Error(`
30
+ If you define both a name and a formControlName attribute on your radio button, their values
31
+ must match. Ex: <input type="radio" formControlName="food" name="food">
32
+ `);
33
+ }
34
+ /**
35
+ * Internal-only NgModule that works as a host for the `RadioControlRegistry` tree-shakable
36
+ * provider. Note: the `InternalFormsSharedModule` can not be used here directly, since it's
37
+ * declared *after* the `RadioControlRegistry` class and the `providedIn` doesn't support
38
+ * `forwardRef` logic.
39
+ */
40
+ export class RadioControlRegistryModule {
41
+ }
42
+ RadioControlRegistryModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: RadioControlRegistryModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
43
+ RadioControlRegistryModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: RadioControlRegistryModule });
44
+ RadioControlRegistryModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: RadioControlRegistryModule });
45
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: RadioControlRegistryModule, decorators: [{
46
+ type: NgModule
47
+ }] });
48
+ /**
49
+ * @description
50
+ * Class used by Angular to track radio buttons. For internal use only.
51
+ */
52
+ export class RadioControlRegistry {
53
+ constructor() {
54
+ this._accessors = [];
55
+ }
56
+ /**
57
+ * @description
58
+ * Adds a control to the internal registry. For internal use only.
59
+ */
60
+ add(control, accessor) {
61
+ this._accessors.push([control, accessor]);
62
+ }
63
+ /**
64
+ * @description
65
+ * Removes a control from the internal registry. For internal use only.
66
+ */
67
+ remove(accessor) {
68
+ for (let i = this._accessors.length - 1; i >= 0; --i) {
69
+ if (this._accessors[i][1] === accessor) {
70
+ this._accessors.splice(i, 1);
71
+ return;
72
+ }
73
+ }
74
+ }
75
+ /**
76
+ * @description
77
+ * Selects a radio button. For internal use only.
78
+ */
79
+ select(accessor) {
80
+ this._accessors.forEach((c) => {
81
+ if (this._isSameGroup(c, accessor) && c[1] !== accessor) {
82
+ c[1].fireUncheck(accessor.value);
83
+ }
84
+ });
85
+ }
86
+ _isSameGroup(controlPair, accessor) {
87
+ if (!controlPair[0].control)
88
+ return false;
89
+ // @ts-expect-error: [Nimble] Use of internal NgControl member _parent
90
+ return controlPair[0]._parent === accessor._control._parent &&
91
+ controlPair[1].name === accessor.name;
92
+ }
93
+ }
94
+ RadioControlRegistry.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: RadioControlRegistry, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
95
+ RadioControlRegistry.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: RadioControlRegistry, providedIn: RadioControlRegistryModule });
96
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: RadioControlRegistry, decorators: [{
97
+ type: Injectable,
98
+ args: [{ providedIn: RadioControlRegistryModule }]
99
+ }] });
100
+ /**
101
+ * @description
102
+ * The `ControlValueAccessor` for writing radio control values and listening to radio control
103
+ * changes. The value accessor is used by the `FormControlDirective`, `FormControlName`, and
104
+ * `NgModel` directives.
105
+ *
106
+ * @usageNotes
107
+ *
108
+ * ### Using radio buttons with reactive form directives
109
+ *
110
+ * The follow example shows how to use radio buttons in a reactive form. When using radio buttons in
111
+ * a reactive form, radio buttons in the same group should have the same `formControlName`.
112
+ * Providing a `name` attribute is optional.
113
+ *
114
+ * {@example forms/ts/reactiveRadioButtons/reactive_radio_button_example.ts region='Reactive'}
115
+ *
116
+ * @ngModule ReactiveFormsModule
117
+ * @ngModule FormsModule
118
+ * @publicApi
119
+ */
120
+ export class RadioControlValueAccessor extends BuiltInControlValueAccessor {
121
+ constructor(renderer, elementRef, _registry, _injector) {
122
+ super(renderer, elementRef);
123
+ this._registry = _registry;
124
+ this._injector = _injector;
125
+ /**
126
+ * The registered callback function called when a change event occurs on the input element.
127
+ * Note: we declare `onChange` here (also used as host listener) as a function with no arguments
128
+ * to override the `onChange` function (which expects 1 argument) in the parent
129
+ * `BaseControlValueAccessor` class.
130
+ * @nodoc
131
+ */
132
+ this.onChange = () => { };
133
+ }
134
+ /** @nodoc */
135
+ ngOnInit() {
136
+ this._control = this._injector.get(NgControl);
137
+ this._checkName();
138
+ this._registry.add(this._control, this);
139
+ }
140
+ /** @nodoc */
141
+ ngOnDestroy() {
142
+ this._registry.remove(this);
143
+ }
144
+ /**
145
+ * Sets the "checked" property value on the radio input element.
146
+ * @nodoc
147
+ */
148
+ writeValue(value) {
149
+ this._state = value === this.value;
150
+ this.setProperty('checked', this._state);
151
+ }
152
+ /**
153
+ * Registers a function called when the control value changes.
154
+ * @nodoc
155
+ */
156
+ registerOnChange(fn) {
157
+ this._fn = fn;
158
+ this.onChange = () => {
159
+ fn(this.value);
160
+ this._registry.select(this);
161
+ };
162
+ }
163
+ /**
164
+ * Sets the "value" on the radio input element and unchecks it.
165
+ *
166
+ * @param value
167
+ */
168
+ fireUncheck(value) {
169
+ this.writeValue(value);
170
+ }
171
+ _checkName() {
172
+ if (this.name && this.formControlName && this.name !== this.formControlName &&
173
+ // @ts-expect-error: [Nimble] ngDevMode is not defined
174
+ (typeof ngDevMode === 'undefined' || ngDevMode)) {
175
+ throwNameError();
176
+ }
177
+ if (!this.name && this.formControlName)
178
+ this.name = this.formControlName;
179
+ }
180
+ }
181
+ RadioControlValueAccessor.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: RadioControlValueAccessor, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: RadioControlRegistry }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Directive });
182
+ RadioControlValueAccessor.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.5", type: RadioControlValueAccessor, selector: "input[type=radio][formControlName],input[type=radio][formControl],input[type=radio][ngModel]", inputs: { name: "name", formControlName: "formControlName", value: "value" }, host: { listeners: { "change": "onChange()", "blur": "onTouched()" } }, providers: [RADIO_VALUE_ACCESSOR], usesInheritance: true, ngImport: i0 });
183
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.5", ngImport: i0, type: RadioControlValueAccessor, decorators: [{
184
+ type: Directive,
185
+ args: [{
186
+ selector: 'input[type=radio][formControlName],input[type=radio][formControl],input[type=radio][ngModel]',
187
+ host: { '(change)': 'onChange()', '(blur)': 'onTouched()' },
188
+ providers: [RADIO_VALUE_ACCESSOR]
189
+ }]
190
+ }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: RadioControlRegistry }, { type: i0.Injector }]; }, propDecorators: { name: [{
191
+ type: Input
192
+ }], formControlName: [{
193
+ type: Input
194
+ }], value: [{
195
+ type: Input
196
+ }] } });
197
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio_control_value_accessor.js","sourceRoot":"","sources":["../../../../../../projects/ni/nimble-angular/src/thirdparty/directives/radio_control_value_accessor.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * [Nimble]\n * Copied from https://github.com/angular/angular/blob/14.2.6/packages/forms/src/directives/radio_control_value_accessor.ts\n * with the following modifications:\n * - Changed throwNameError() to throw Error instead of RuntimeError. This makes the file compile with Angular version 12.\n * - Removed now-unused import for RuntimeErrorCode and RuntimeError\n * - Updated import of ControlValueAccessor, NgControl, and NG_VALUE_ACCESSOR to pull from package export\n */\n\n/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {Directive, ElementRef, forwardRef, Injectable, Injector, Input, NgModule, OnDestroy, OnInit, Renderer2} from '@angular/core';\n\nimport {BuiltInControlValueAccessor} from './control_value_accessor';\nimport {ControlValueAccessor, NgControl, NG_VALUE_ACCESSOR} from '@angular/forms';\n\nexport const RADIO_VALUE_ACCESSOR: any = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => RadioControlValueAccessor),\n  multi: true\n};\n\nfunction throwNameError() {\n  /* [Nimble] RuntimeErrorCode is not exported from @angular/forms in version 12; falling back to version 12 behavior\n  throw new RuntimeError(RuntimeErrorCode.NAME_AND_FORM_CONTROL_NAME_MUST_MATCH, `\n  */\n  throw new Error(`\n      If you define both a name and a formControlName attribute on your radio button, their values\n      must match. Ex: <input type=\"radio\" formControlName=\"food\" name=\"food\">\n    `);\n}\n\n/**\n * Internal-only NgModule that works as a host for the `RadioControlRegistry` tree-shakable\n * provider. Note: the `InternalFormsSharedModule` can not be used here directly, since it's\n * declared *after* the `RadioControlRegistry` class and the `providedIn` doesn't support\n * `forwardRef` logic.\n */\n@NgModule()\nexport class RadioControlRegistryModule {\n}\n\n/**\n * @description\n * Class used by Angular to track radio buttons. For internal use only.\n */\n@Injectable({providedIn: RadioControlRegistryModule})\nexport class RadioControlRegistry {\n  private _accessors: any[] = [];\n\n  /**\n   * @description\n   * Adds a control to the internal registry. For internal use only.\n   */\n  add(control: NgControl, accessor: RadioControlValueAccessor) {\n    this._accessors.push([control, accessor]);\n  }\n\n  /**\n   * @description\n   * Removes a control from the internal registry. For internal use only.\n   */\n  remove(accessor: RadioControlValueAccessor) {\n    for (let i = this._accessors.length - 1; i >= 0; --i) {\n      if (this._accessors[i][1] === accessor) {\n        this._accessors.splice(i, 1);\n        return;\n      }\n    }\n  }\n\n  /**\n   * @description\n   * Selects a radio button. For internal use only.\n   */\n  select(accessor: RadioControlValueAccessor) {\n    this._accessors.forEach((c) => {\n      if (this._isSameGroup(c, accessor) && c[1] !== accessor) {\n        c[1].fireUncheck(accessor.value);\n      }\n    });\n  }\n\n  private _isSameGroup(\n      controlPair: [NgControl, RadioControlValueAccessor],\n      accessor: RadioControlValueAccessor): boolean {\n    if (!controlPair[0].control) return false;\n    // @ts-expect-error: [Nimble] Use of internal NgControl member _parent\n    return controlPair[0]._parent === accessor._control._parent &&\n        controlPair[1].name === accessor.name;\n  }\n}\n\n/**\n * @description\n * The `ControlValueAccessor` for writing radio control values and listening to radio control\n * changes. The value accessor is used by the `FormControlDirective`, `FormControlName`, and\n * `NgModel` directives.\n *\n * @usageNotes\n *\n * ### Using radio buttons with reactive form directives\n *\n * The follow example shows how to use radio buttons in a reactive form. When using radio buttons in\n * a reactive form, radio buttons in the same group should have the same `formControlName`.\n * Providing a `name` attribute is optional.\n *\n * {@example forms/ts/reactiveRadioButtons/reactive_radio_button_example.ts region='Reactive'}\n *\n * @ngModule ReactiveFormsModule\n * @ngModule FormsModule\n * @publicApi\n */\n@Directive({\n  selector:\n      'input[type=radio][formControlName],input[type=radio][formControl],input[type=radio][ngModel]',\n  host: {'(change)': 'onChange()', '(blur)': 'onTouched()'},\n  providers: [RADIO_VALUE_ACCESSOR]\n})\nexport class RadioControlValueAccessor extends BuiltInControlValueAccessor implements\n    ControlValueAccessor, OnDestroy, OnInit {\n  /** @internal */\n  // TODO(issue/24571): remove '!'.\n  _state!: boolean;\n  /** @internal */\n  // TODO(issue/24571): remove '!'.\n  _control!: NgControl;\n  /** @internal */\n  // TODO(issue/24571): remove '!'.\n  _fn!: Function;\n\n  /**\n   * The registered callback function called when a change event occurs on the input element.\n   * Note: we declare `onChange` here (also used as host listener) as a function with no arguments\n   * to override the `onChange` function (which expects 1 argument) in the parent\n   * `BaseControlValueAccessor` class.\n   * @nodoc\n   */\n  override onChange = () => {};\n\n  /**\n   * @description\n   * Tracks the name of the radio input element.\n   */\n  // TODO(issue/24571): remove '!'.\n  @Input() name!: string;\n\n  /**\n   * @description\n   * Tracks the name of the `FormControl` bound to the directive. The name corresponds\n   * to a key in the parent `FormGroup` or `FormArray`.\n   */\n  // TODO(issue/24571): remove '!'.\n  @Input() formControlName!: string;\n\n  /**\n   * @description\n   * Tracks the value of the radio input element\n   */\n  @Input() value: any;\n\n  constructor(\n      renderer: Renderer2, elementRef: ElementRef, private _registry: RadioControlRegistry,\n      private _injector: Injector) {\n    super(renderer, elementRef);\n  }\n\n  /** @nodoc */\n  ngOnInit(): void {\n    this._control = this._injector.get(NgControl);\n    this._checkName();\n    this._registry.add(this._control, this);\n  }\n\n  /** @nodoc */\n  ngOnDestroy(): void {\n    this._registry.remove(this);\n  }\n\n  /**\n   * Sets the \"checked\" property value on the radio input element.\n   * @nodoc\n   */\n  writeValue(value: any): void {\n    this._state = value === this.value;\n    this.setProperty('checked', this._state);\n  }\n\n  /**\n   * Registers a function called when the control value changes.\n   * @nodoc\n   */\n  override registerOnChange(fn: (_: any) => {}): void {\n    this._fn = fn;\n    this.onChange = () => {\n      fn(this.value);\n      this._registry.select(this);\n    };\n  }\n\n  /**\n   * Sets the \"value\" on the radio input element and unchecks it.\n   *\n   * @param value\n   */\n  fireUncheck(value: any): void {\n    this.writeValue(value);\n  }\n\n  private _checkName(): void {\n    if (this.name && this.formControlName && this.name !== this.formControlName &&\n        // @ts-expect-error: [Nimble] ngDevMode is not defined\n        (typeof ngDevMode === 'undefined' || ngDevMode)) {\n      throwNameError();\n    }\n    if (!this.name && this.formControlName) this.name = this.formControlName;\n  }\n}"]}