@energinet/watt 4.2.0 → 4.2.1

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.
@@ -47,6 +47,10 @@ export class WattRadioGroupComponent {
47
47
  * Emits when the radio button group is touched.
48
48
  */
49
49
  touched = output();
50
+ /**
51
+ * Tracks the FormControl instance bound to the directive.
52
+ */
53
+ formControl = input(null, ...(ngDevMode ? [{ debugName: "formControl" }] : []));
50
54
  // Used for generating unique radio button names
51
55
  static instance = 1;
52
56
  instance = WattRadioGroupComponent.instance++;
@@ -82,34 +86,34 @@ export class WattRadioGroupComponent {
82
86
  registerOnTouched = (fn) => this.touched.subscribe(fn);
83
87
  registerOnChange = (fn) => this.value.subscribe(fn);
84
88
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.3.6", ngImport: i0, type: WattRadioGroupComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
85
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "20.3.6", type: WattRadioGroupComponent, isStandalone: true, selector: "watt-radio-group", inputs: { label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null }, value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, name: { classPropertyName: "name", publicName: "name", isSignal: true, isRequired: false, transformFunction: null }, readonly: { classPropertyName: "readonly", publicName: "readonly", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { value: "valueChange", disabled: "disabledChange", touched: "touched" }, host: { properties: { "class.disabled": "disabled()", "class.readonly": "readonly()" } }, providers: [
89
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "20.3.6", type: WattRadioGroupComponent, isStandalone: true, selector: "watt-radio-group", inputs: { label: { classPropertyName: "label", publicName: "label", isSignal: true, isRequired: false, transformFunction: null }, value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, name: { classPropertyName: "name", publicName: "name", isSignal: true, isRequired: false, transformFunction: null }, readonly: { classPropertyName: "readonly", publicName: "readonly", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null }, formControl: { classPropertyName: "formControl", publicName: "formControl", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { value: "valueChange", disabled: "disabledChange", touched: "touched" }, host: { properties: { "class.disabled": "disabled()", "class.readonly": "readonly()" } }, providers: [
86
90
  {
87
91
  provide: NG_VALUE_ACCESSOR,
88
92
  useExisting: forwardRef(() => WattRadioGroupComponent),
89
93
  multi: true,
90
94
  },
91
95
  ], queries: [{ propertyName: "radios", predicate: (WattRadioComponent), descendants: true, isSignal: true }], ngImport: i0, template: `
92
- <watt-field [label]="label()" displayMode="content">
96
+ <watt-field [label]="label()" [control]="formControl()" displayMode="content">
93
97
  <ng-content />
94
98
  </watt-field>
95
99
  `, isInline: true, styles: ["watt-radio-group.readonly watt-radio{pointer-events:none}watt-radio-group.readonly watt-radio input,watt-radio-group.readonly watt-radio:has(input:not(:checked)){display:none}\n"], dependencies: [{ kind: "component", type: WattFieldComponent, selector: "watt-field", inputs: ["control", "label", "id", "chipMode", "tooltip", "placeholder", "anchorName", "displayMode", "autoFocus", "showErrors"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
96
100
  }
97
101
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.3.6", ngImport: i0, type: WattRadioGroupComponent, decorators: [{
98
102
  type: Component,
99
- args: [{ imports: [WattFieldComponent, WattRadioComponent], providers: [
103
+ args: [{ imports: [WattFieldComponent], providers: [
100
104
  {
101
105
  provide: NG_VALUE_ACCESSOR,
102
106
  useExisting: forwardRef(() => WattRadioGroupComponent),
103
107
  multi: true,
104
108
  },
105
109
  ], changeDetection: ChangeDetectionStrategy.OnPush, selector: 'watt-radio-group', template: `
106
- <watt-field [label]="label()" displayMode="content">
110
+ <watt-field [label]="label()" [control]="formControl()" displayMode="content">
107
111
  <ng-content />
108
112
  </watt-field>
109
113
  `, encapsulation: ViewEncapsulation.None, host: {
110
114
  '[class.disabled]': 'disabled()',
111
115
  '[class.readonly]': 'readonly()',
112
116
  }, styles: ["watt-radio-group.readonly watt-radio{pointer-events:none}watt-radio-group.readonly watt-radio input,watt-radio-group.readonly watt-radio:has(input:not(:checked)){display:none}\n"] }]
113
- }], ctorParameters: () => [], propDecorators: { label: [{ type: i0.Input, args: [{ isSignal: true, alias: "label", required: false }] }], value: [{ type: i0.Input, args: [{ isSignal: true, alias: "value", required: false }] }, { type: i0.Output, args: ["valueChange"] }], name: [{ type: i0.Input, args: [{ isSignal: true, alias: "name", required: false }] }], readonly: [{ type: i0.Input, args: [{ isSignal: true, alias: "readonly", required: false }] }], disabled: [{ type: i0.Input, args: [{ isSignal: true, alias: "disabled", required: false }] }, { type: i0.Output, args: ["disabledChange"] }], touched: [{ type: i0.Output, args: ["touched"] }], radios: [{ type: i0.ContentChildren, args: [i0.forwardRef(() => WattRadioComponent), { ...{ descendants: true }, isSignal: true }] }] } });
117
+ }], ctorParameters: () => [], propDecorators: { label: [{ type: i0.Input, args: [{ isSignal: true, alias: "label", required: false }] }], value: [{ type: i0.Input, args: [{ isSignal: true, alias: "value", required: false }] }, { type: i0.Output, args: ["valueChange"] }], name: [{ type: i0.Input, args: [{ isSignal: true, alias: "name", required: false }] }], readonly: [{ type: i0.Input, args: [{ isSignal: true, alias: "readonly", required: false }] }], disabled: [{ type: i0.Input, args: [{ isSignal: true, alias: "disabled", required: false }] }, { type: i0.Output, args: ["disabledChange"] }], touched: [{ type: i0.Output, args: ["touched"] }], formControl: [{ type: i0.Input, args: [{ isSignal: true, alias: "formControl", required: false }] }], radios: [{ type: i0.ContentChildren, args: [i0.forwardRef(() => WattRadioComponent), { ...{ descendants: true }, isSignal: true }] }] } });
114
118
  export const WATT_RADIO = [WattRadioGroupComponent, WattRadioComponent];
115
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watt-radio-group.component.js","sourceRoot":"","sources":["../../../../libs/watt/package/radio/watt-radio-group.component.ts"],"names":[],"mappings":"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","sourcesContent":["//#region License\n/**\n * @license\n * Copyright 2020 Energinet DataHub A/S\n *\n * Licensed under the Apache License, Version 2.0 (the \"License2\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n//#endregion\nimport {\n  Component,\n  forwardRef,\n  ViewEncapsulation,\n  input,\n  model,\n  output,\n  computed,\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  contentChildren,\n  effect,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { WattFieldComponent } from '@energinet/watt/field';\nimport { WattRadioComponent } from './watt-radio.component';\n\n@Component({\n  imports: [WattFieldComponent, WattRadioComponent],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => WattRadioGroupComponent),\n      multi: true,\n    },\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  selector: 'watt-radio-group',\n  styles: `\n    watt-radio-group.readonly watt-radio {\n      pointer-events: none;\n\n      & input,\n      &:has(input:not(:checked)) {\n        display: none;\n      }\n    }\n  `,\n  template: `\n    <watt-field [label]=\"label()\" displayMode=\"content\">\n      <ng-content />\n    </watt-field>\n  `,\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    '[class.disabled]': 'disabled()',\n    '[class.readonly]': 'readonly()',\n  },\n})\nexport class WattRadioGroupComponent<T> implements ControlValueAccessor {\n  /**\n   * The field label.\n   */\n  label = input<string>();\n\n  /**\n   * The value of the radio button group.\n   */\n  value = model<T | null>();\n\n  /**\n   * Optional input for setting the name of the radio buttons.\n   * If no name is provided, the name will be auto-generated.\n   */\n  name = input<string>();\n\n  /**\n   * Whether the radio button group is readonly.\n   */\n  readonly = input(false, { transform: booleanAttribute });\n\n  /**\n   * Whether the radio button group is disabled.\n   */\n  disabled = model(false);\n\n  /**\n   * Emits when the radio button group is touched.\n   */\n  touched = output();\n\n  // Used for generating unique radio button names\n  private static instance = 1;\n  private instance = WattRadioGroupComponent.instance++;\n  private group = computed(() => this.name() ?? `watt-radio-group-${this.instance}`);\n\n  private radios = contentChildren(WattRadioComponent<T>, { descendants: true });\n  protected inheritPropertiesEffect = effect(() => {\n    this.radios().forEach((r) => {\n      r.disabled.set(this.disabled());\n      r.name.set(this.group());\n    });\n  });\n\n  // Two-way binding\n  constructor() {\n    effect(() => {\n      // group -> buttons\n      this.radios().forEach((r) => {\n        r.checked.set(r.value() === this.value());\n      });\n    });\n\n    // buttons -> group\n    effect((onCleanup) => {\n      if (this.readonly()) return;\n      const subscriptions = this.radios().map((r) =>\n        r.isChecked.subscribe(() => {\n          this.value.set(r.value());\n        })\n      );\n\n      onCleanup(() => subscriptions.forEach((s) => s.unsubscribe()));\n    });\n  }\n\n  // Implementation for ControlValueAccessor\n  writeValue = (value: T | null | undefined) => this.value.set(value);\n  setDisabledState = (isDisabled: boolean) => this.disabled.set(isDisabled);\n  registerOnTouched = (fn: () => void) => this.touched.subscribe(fn);\n  registerOnChange = (fn: (value: T | null | undefined) => void) => this.value.subscribe(fn);\n}\n\nexport const WATT_RADIO = [WattRadioGroupComponent, WattRadioComponent] as const;\n"]}
119
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"watt-radio-group.component.js","sourceRoot":"","sources":["../../../../libs/watt/package/radio/watt-radio-group.component.ts"],"names":[],"mappings":"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","sourcesContent":["//#region License\n/**\n * @license\n * Copyright 2020 Energinet DataHub A/S\n *\n * Licensed under the Apache License, Version 2.0 (the \"License2\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n *     http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n//#endregion\nimport {\n  Component,\n  forwardRef,\n  ViewEncapsulation,\n  input,\n  model,\n  output,\n  computed,\n  booleanAttribute,\n  ChangeDetectionStrategy,\n  contentChildren,\n  effect,\n} from '@angular/core';\nimport { ControlValueAccessor, FormControl, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { WattFieldComponent } from '@energinet/watt/field';\nimport { WattRadioComponent } from './watt-radio.component';\n\n@Component({\n  imports: [WattFieldComponent],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => WattRadioGroupComponent),\n      multi: true,\n    },\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  selector: 'watt-radio-group',\n  styles: `\n    watt-radio-group.readonly watt-radio {\n      pointer-events: none;\n\n      & input,\n      &:has(input:not(:checked)) {\n        display: none;\n      }\n    }\n  `,\n  template: `\n    <watt-field [label]=\"label()\" [control]=\"formControl()\" displayMode=\"content\">\n      <ng-content />\n    </watt-field>\n  `,\n  encapsulation: ViewEncapsulation.None,\n  host: {\n    '[class.disabled]': 'disabled()',\n    '[class.readonly]': 'readonly()',\n  },\n})\nexport class WattRadioGroupComponent<T> implements ControlValueAccessor {\n  /**\n   * The field label.\n   */\n  label = input<string>();\n\n  /**\n   * The value of the radio button group.\n   */\n  value = model<T | null>();\n\n  /**\n   * Optional input for setting the name of the radio buttons.\n   * If no name is provided, the name will be auto-generated.\n   */\n  name = input<string>();\n\n  /**\n   * Whether the radio button group is readonly.\n   */\n  readonly = input(false, { transform: booleanAttribute });\n\n  /**\n   * Whether the radio button group is disabled.\n   */\n  disabled = model(false);\n\n  /**\n   * Emits when the radio button group is touched.\n   */\n  touched = output();\n\n  /**\n   * Tracks the FormControl instance bound to the directive.\n   */\n  formControl = input<FormControl | null>(null);\n\n  // Used for generating unique radio button names\n  private static instance = 1;\n  private instance = WattRadioGroupComponent.instance++;\n  private group = computed(() => this.name() ?? `watt-radio-group-${this.instance}`);\n\n  private radios = contentChildren(WattRadioComponent<T>, { descendants: true });\n  protected inheritPropertiesEffect = effect(() => {\n    this.radios().forEach((r) => {\n      r.disabled.set(this.disabled());\n      r.name.set(this.group());\n    });\n  });\n\n  // Two-way binding\n  constructor() {\n    effect(() => {\n      // group -> buttons\n      this.radios().forEach((r) => {\n        r.checked.set(r.value() === this.value());\n      });\n    });\n\n    // buttons -> group\n    effect((onCleanup) => {\n      if (this.readonly()) return;\n      const subscriptions = this.radios().map((r) =>\n        r.isChecked.subscribe(() => {\n          this.value.set(r.value());\n        })\n      );\n\n      onCleanup(() => subscriptions.forEach((s) => s.unsubscribe()));\n    });\n  }\n\n  // Implementation for ControlValueAccessor\n  writeValue = (value: T | null | undefined) => this.value.set(value);\n  setDisabledState = (isDisabled: boolean) => this.disabled.set(isDisabled);\n  registerOnTouched = (fn: () => void) => this.touched.subscribe(fn);\n  registerOnChange = (fn: (value: T | null | undefined) => void) => this.value.subscribe(fn);\n}\n\nexport const WATT_RADIO = [WattRadioGroupComponent, WattRadioComponent] as const;\n"]}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "type": "module",
3
3
  "name": "@energinet/watt",
4
- "version": "4.2.0",
4
+ "version": "4.2.1",
5
5
  "license": "Apache-2.0",
6
6
  "exports": {
7
7
  ".": {
@@ -1,4 +1,4 @@
1
- import { ControlValueAccessor } from '@angular/forms';
1
+ import { ControlValueAccessor, FormControl } from '@angular/forms';
2
2
  import { WattRadioComponent } from './watt-radio.component';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class WattRadioGroupComponent<T> implements ControlValueAccessor {
@@ -27,6 +27,10 @@ export declare class WattRadioGroupComponent<T> implements ControlValueAccessor
27
27
  * Emits when the radio button group is touched.
28
28
  */
29
29
  touched: import("@angular/core").OutputEmitterRef<void>;
30
+ /**
31
+ * Tracks the FormControl instance bound to the directive.
32
+ */
33
+ formControl: import("@angular/core").InputSignal<FormControl<any> | null>;
30
34
  private static instance;
31
35
  private instance;
32
36
  private group;
@@ -38,6 +42,6 @@ export declare class WattRadioGroupComponent<T> implements ControlValueAccessor
38
42
  registerOnTouched: (fn: () => void) => import("@angular/core").OutputRefSubscription;
39
43
  registerOnChange: (fn: (value: T | null | undefined) => void) => import("@angular/core").OutputRefSubscription;
40
44
  static ɵfac: i0.ɵɵFactoryDeclaration<WattRadioGroupComponent<any>, never>;
41
- static ɵcmp: i0.ɵɵComponentDeclaration<WattRadioGroupComponent<any>, "watt-radio-group", never, { "label": { "alias": "label"; "required": false; "isSignal": true; }; "value": { "alias": "value"; "required": false; "isSignal": true; }; "name": { "alias": "name"; "required": false; "isSignal": true; }; "readonly": { "alias": "readonly"; "required": false; "isSignal": true; }; "disabled": { "alias": "disabled"; "required": false; "isSignal": true; }; }, { "value": "valueChange"; "disabled": "disabledChange"; "touched": "touched"; }, ["radios"], ["*"], true, never>;
45
+ static ɵcmp: i0.ɵɵComponentDeclaration<WattRadioGroupComponent<any>, "watt-radio-group", never, { "label": { "alias": "label"; "required": false; "isSignal": true; }; "value": { "alias": "value"; "required": false; "isSignal": true; }; "name": { "alias": "name"; "required": false; "isSignal": true; }; "readonly": { "alias": "readonly"; "required": false; "isSignal": true; }; "disabled": { "alias": "disabled"; "required": false; "isSignal": true; }; "formControl": { "alias": "formControl"; "required": false; "isSignal": true; }; }, { "value": "valueChange"; "disabled": "disabledChange"; "touched": "touched"; }, ["radios"], ["*"], true, never>;
42
46
  }
43
47
  export declare const WATT_RADIO: readonly [typeof WattRadioGroupComponent, typeof WattRadioComponent];