UNPKG

@engie-group/fluid-design-system-angular

Version:

Fluid Design System Angular

264 lines 26.7 kB
import { CommonModule } from '@angular/common'; import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, forwardRef, Input, Output, ViewEncapsulation } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { Subject, takeUntil } from 'rxjs'; import { Utils } from '../../utils/utils.util'; import { IconComponent } from '../icon/icon.component'; import { RadioComponent } from '../radio/radio.component'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; export class RadioGroupComponent { /** * Radio group selected value */ set value(newValue) { if (this._value !== newValue) { this._value = newValue; this._updateSelectedRadioFromValue(); this._checkSelectedRadioButton(); } } get value() { return this._value; } /** * Radio group selected radio component */ set selected(selected) { this._selected = selected; this.value = selected ? selected.value : null; this._checkSelectedRadioButton(); } get selected() { return this._selected; } /** * 'Whether the radio group is disabled or not, this will force all the children radios be disabled or not depending on this value */ set isDisabled(value) { this._isDisabled = value; this._updateAllRadiosDisableValue(); this._markRadiosForCheck(); } get isDisabled() { return this._isDisabled; } /** * Radio group name, this will force all the children radios to have this name */ set name(value) { this._name = value; this._updateAllRadiosName(); this._markRadiosForCheck(); } get name() { return this._name; } /** * Whether radio is required or not */ set required(value) { this._required = value; this._markRadiosForCheck(); } get required() { return this._required; } constructor(cdr) { this.cdr = cdr; /** * @ignore */ this.unsubscribe = new Subject(); /** * @ignore */ this._required = false; /** * @ignore */ this.radioGroupClassName = 'nj-radio-group'; /** * Whether the radio group should be displayed in column or row */ this.orientation = 'column'; /** * Output that emits checked value on change only */ this.valueChange = new EventEmitter(); /** * @ignore */ this._onChange = (_) => { }; /** * @ignore */ this._onTouched = () => { }; } ngAfterContentInit() { this._listenForRadioChange(); this._updateSelectedRadioFromValue(); this._updateAllRadiosDisableValue(); this._updateAllRadiosName(); } ngOnDestroy() { this.unsubscribe.next(); this.unsubscribe.complete(); } /** * @ignore */ _listenForRadioChange() { if (!this.radios) { return; } this.radios.forEach((radio) => { radio?.valueChange.pipe(takeUntil(this.unsubscribe)).subscribe((isSelected) => { if (isSelected) { this.value = radio?.value; this._onChange(this.value); this.valueChange.emit(this._value); } }); }); } /** * @ignore */ _updateAllRadiosDisableValue() { if (!this.radios || Utils.isUndefinedOrNull(this.isDisabled)) { return; } this.radios.forEach((radio) => { if (radio) { radio.isDisabled = this.isDisabled; } }); } /** * @ignore */ _updateAllRadiosName() { if (!this.radios || Utils.isUndefinedOrNull(this.name)) { return; } this.radios.forEach((radio) => { if (radio) { radio.name = this.name; } }); } /** * @ignore */ _checkSelectedRadioButton() { if (this._selected && !this._selected.isChecked) { this._selected.isChecked = true; } } /** * @ignore */ _markRadiosForCheck() { if (this.radios) { this.radios.forEach((radio) => radio?._markForCheck()); } } /** * @ignore */ _updateSelectedRadioFromValue() { // If the value already matches the selected radio, do nothing. const isAlreadySelected = this._selected && this._selected.value === this._value; if (this.radios && !isAlreadySelected) { this._selected = null; this.radios.forEach((radio) => { if (!radio) { return; } radio.isChecked = this.value === radio.value; if (radio.isChecked) { this._selected = radio; } }); this._markRadiosForCheck(); } } /** * @ignore */ registerOnChange(fn) { this._onChange = fn; } /** * @ignore */ registerOnTouched(fn) { this._onTouched = fn; } /** * @ignore */ setDisabledState(isDisabled) { this.isDisabled = isDisabled; this.cdr.markForCheck(); } /** * @ignore */ writeValue(value) { this.value = value; this.cdr.markForCheck(); } /** * @ignore */ getOrientationClass() { if (this.orientation !== 'row') { return ''; } return `${this.radioGroupClassName}--${this.orientation}`; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RadioGroupComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: RadioGroupComponent, isStandalone: true, selector: "nj-radio-group", inputs: { value: "value", selected: "selected", isDisabled: "isDisabled", name: "name", required: "required", orientation: "orientation", legend: "legend", errorMessage: "errorMessage", hasError: "hasError" }, outputs: { valueChange: "valueChange" }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => RadioGroupComponent), multi: true } ], queries: [{ propertyName: "radios", predicate: RadioComponent, descendants: true }], ngImport: i0, template: "<fieldset class=\"nj-radio-group\" [ngClass]=\"[getOrientationClass(), hasError ? 'nj-radio-group--has-error' : '']\">\n <legend class=\"nj-radio-group__legend\">\n {{legend}}\n <p *ngIf=\"errorMessage\" class=\"nj-radio-group__error-message\">\n <nj-icon name=\"warning\"></nj-icon>\n {{errorMessage}}\n </p>\n </legend>\n <ng-content></ng-content>\n</fieldset>\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: IconComponent, selector: "nj-icon", inputs: ["size", "variant"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RadioGroupComponent, decorators: [{ type: Component, args: [{ selector: 'nj-radio-group', providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => RadioGroupComponent), multi: true } ], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, standalone: true, imports: [RadioComponent, CommonModule, IconComponent], template: "<fieldset class=\"nj-radio-group\" [ngClass]=\"[getOrientationClass(), hasError ? 'nj-radio-group--has-error' : '']\">\n <legend class=\"nj-radio-group__legend\">\n {{legend}}\n <p *ngIf=\"errorMessage\" class=\"nj-radio-group__error-message\">\n <nj-icon name=\"warning\"></nj-icon>\n {{errorMessage}}\n </p>\n </legend>\n <ng-content></ng-content>\n</fieldset>\n" }] }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { value: [{ type: Input }], selected: [{ type: Input }], isDisabled: [{ type: Input }], name: [{ type: Input }], required: [{ type: Input }], orientation: [{ type: Input }], legend: [{ type: Input }], errorMessage: [{ type: Input }], hasError: [{ type: Input }], valueChange: [{ type: Output }], radios: [{ type: ContentChildren, args: [RadioComponent, { descendants: true }] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-group.component.js","sourceRoot":"","sources":["../../../../src/components/radio-group/radio-group.component.ts","../../../../src/components/radio-group/radio-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnDestroy,\n  Output,\n  ViewEncapsulation\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Subject, takeUntil } from 'rxjs';\nimport { Utils } from '../../utils/utils.util';\nimport { IconComponent } from '../icon/icon.component';\nimport { RadioComponent } from '../radio/radio.component';\nimport { RadioGroupOrientation } from './radio-group.model';\n\n@Component({\n  selector: 'nj-radio-group',\n  templateUrl: './radio-group.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => RadioGroupComponent),\n      multi: true\n    }\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  standalone: true,\n  imports: [RadioComponent, CommonModule, IconComponent]\n})\nexport class RadioGroupComponent implements ControlValueAccessor, AfterContentInit, OnDestroy {\n  /**\n   * @ignore\n   */\n  private unsubscribe: Subject<void> = new Subject<void>();\n\n  /**\n   * @ignore\n   */\n  private _value;\n\n  /**\n   * @ignore\n   */\n  private _isDisabled;\n\n  /**\n   * @ignore\n   */\n  private _name;\n\n  /**\n   * @ignore\n   */\n  private _required = false;\n\n  /**\n   * @ignore\n   */\n  private _selected: RadioComponent;\n\n  /**\n   * @ignore\n   */\n  private radioGroupClassName = 'nj-radio-group';\n\n  /**\n   * Radio group selected value\n   */\n  @Input()\n  set value(newValue: any) {\n    if (this._value !== newValue) {\n      this._value = newValue;\n\n      this._updateSelectedRadioFromValue();\n      this._checkSelectedRadioButton();\n    }\n  }\n\n  get value(): any {\n    return this._value;\n  }\n\n  /**\n   * Radio group selected radio component\n   */\n  @Input()\n  set selected(selected: RadioComponent) {\n    this._selected = selected;\n    this.value = selected ? selected.value : null;\n    this._checkSelectedRadioButton();\n  }\n\n  get selected() {\n    return this._selected;\n  }\n\n  /**\n   * 'Whether the radio group is disabled or not, this will force all the children radios be disabled or not depending on this value\n   */\n  @Input()\n  set isDisabled(value: boolean) {\n    this._isDisabled = value;\n    this._updateAllRadiosDisableValue();\n    this._markRadiosForCheck();\n  }\n\n  get isDisabled(): boolean {\n    return this._isDisabled;\n  }\n\n  /**\n   * Radio group name, this will force all the children radios to have this name\n   */\n  @Input()\n  set name(value: string) {\n    this._name = value;\n    this._updateAllRadiosName();\n    this._markRadiosForCheck();\n  }\n\n  get name(): string {\n    return this._name;\n  }\n\n  /**\n   * Whether radio is required or not\n   */\n  @Input()\n  set required(value: boolean) {\n    this._required = value;\n    this._markRadiosForCheck();\n  }\n\n  get required(): boolean {\n    return this._required;\n  }\n\n  /**\n   * Whether the radio group should be displayed in column or row\n   */\n  @Input() orientation: RadioGroupOrientation = 'column';\n\n  /**\n   * Legend to label the radio group\n   */\n  @Input() legend: string;\n\n  /**\n   * Message to provide when radio group is in error state\n   */\n  @Input() errorMessage?: string;\n\n  /**\n   * Whether the input group is in error state\n   */\n  @Input() hasError?: boolean;\n\n  /**\n   * Output that emits checked value on change only\n   */\n  @Output() readonly valueChange: EventEmitter<string> = new EventEmitter<string>();\n\n  /**\n   * All children radio components\n   */\n  @ContentChildren(RadioComponent, { descendants: true }) radios;\n\n  constructor(private cdr: ChangeDetectorRef) {}\n\n  /**\n   * @ignore\n   */\n  private _onChange = (_: any): void => {};\n\n  /**\n   * @ignore\n   */\n  private _onTouched = (): void => {};\n\n  ngAfterContentInit() {\n    this._listenForRadioChange();\n    this._updateSelectedRadioFromValue();\n    this._updateAllRadiosDisableValue();\n    this._updateAllRadiosName();\n  }\n\n  ngOnDestroy() {\n    this.unsubscribe.next();\n    this.unsubscribe.complete();\n  }\n\n  /**\n   * @ignore\n   */\n  private _listenForRadioChange() {\n    if (!this.radios) {\n      return;\n    }\n    this.radios.forEach((radio) => {\n      radio?.valueChange.pipe(takeUntil(this.unsubscribe)).subscribe((isSelected) => {\n        if (isSelected) {\n          this.value = radio?.value;\n          this._onChange(this.value);\n          this.valueChange.emit(this._value);\n        }\n      });\n    });\n  }\n\n  /**\n   * @ignore\n   */\n  private _updateAllRadiosDisableValue() {\n    if (!this.radios || Utils.isUndefinedOrNull(this.isDisabled)) {\n      return;\n    }\n    this.radios.forEach((radio) => {\n      if (radio) {\n        radio.isDisabled = this.isDisabled;\n      }\n    });\n  }\n\n  /**\n   * @ignore\n   */\n  private _updateAllRadiosName() {\n    if (!this.radios || Utils.isUndefinedOrNull(this.name)) {\n      return;\n    }\n    this.radios.forEach((radio) => {\n      if (radio) {\n        radio.name = this.name;\n      }\n    });\n  }\n\n  /**\n   * @ignore\n   */\n  private _checkSelectedRadioButton() {\n    if (this._selected && !this._selected.isChecked) {\n      this._selected.isChecked = true;\n    }\n  }\n\n  /**\n   * @ignore\n   */\n  private _markRadiosForCheck() {\n    if (this.radios) {\n      this.radios.forEach((radio) => radio?._markForCheck());\n    }\n  }\n\n  /**\n   * @ignore\n   */\n  private _updateSelectedRadioFromValue(): void {\n    // If the value already matches the selected radio, do nothing.\n    const isAlreadySelected = this._selected && this._selected.value === this._value;\n\n    if (this.radios && !isAlreadySelected) {\n      this._selected = null;\n      this.radios.forEach((radio) => {\n        if (!radio) {\n          return;\n        }\n        radio.isChecked = this.value === radio.value;\n        if (radio.isChecked) {\n          this._selected = radio;\n        }\n      });\n      this._markRadiosForCheck();\n    }\n  }\n\n  /**\n   * @ignore\n   */\n  registerOnChange(fn: any): void {\n    this._onChange = fn;\n  }\n\n  /**\n   * @ignore\n   */\n  registerOnTouched(fn: any): void {\n    this._onTouched = fn;\n  }\n\n  /**\n   * @ignore\n   */\n  setDisabledState(isDisabled: boolean): void {\n    this.isDisabled = isDisabled;\n    this.cdr.markForCheck();\n  }\n\n  /**\n   * @ignore\n   */\n  writeValue(value: any): void {\n    this.value = value;\n    this.cdr.markForCheck();\n  }\n\n  /**\n   * @ignore\n   */\n  getOrientationClass(): string {\n    if (this.orientation !== 'row') {\n      return '';\n    }\n    return `${this.radioGroupClassName}--${this.orientation}`;\n  }\n}\n","<fieldset class=\"nj-radio-group\" [ngClass]=\"[getOrientationClass(), hasError ? 'nj-radio-group--has-error' : '']\">\n  <legend class=\"nj-radio-group__legend\">\n    {{legend}}\n    <p *ngIf=\"errorMessage\" class=\"nj-radio-group__error-message\">\n      <nj-icon name=\"warning\"></nj-icon>\n      {{errorMessage}}\n    </p>\n  </legend>\n  <ng-content></ng-content>\n</fieldset>\n"]}