cps-ui-kit 17.5.0 → 17.6.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/esm2022/lib/components/cps-autocomplete/cps-autocomplete.component.mjs +1 -3
- package/esm2022/lib/components/cps-datepicker/cps-datepicker.component.mjs +1 -3
- package/esm2022/lib/components/cps-input/cps-input.component.mjs +1 -3
- package/esm2022/lib/components/cps-radio-group/cps-radio/cps-radio.component.mjs +1 -1
- package/esm2022/lib/components/cps-radio-group/cps-radio-button/cps-radio-button.component.mjs +25 -3
- package/esm2022/lib/components/cps-radio-group/cps-radio-group.component.mjs +71 -4
- package/esm2022/lib/components/cps-scheduler/cps-scheduler.component.mjs +2 -2
- package/esm2022/lib/components/cps-select/cps-select.component.mjs +1 -3
- package/esm2022/lib/components/cps-textarea/cps-textarea.component.mjs +1 -3
- package/esm2022/lib/components/cps-timepicker/cps-timepicker.component.mjs +11 -13
- package/esm2022/lib/components/internal/cps-base-tree-dropdown/cps-base-tree-dropdown.component.mjs +1 -3
- package/fesm2022/cps-ui-kit.mjs +107 -25
- package/fesm2022/cps-ui-kit.mjs.map +1 -1
- package/lib/components/cps-autocomplete/cps-autocomplete.component.d.ts +1 -1
- package/lib/components/cps-datepicker/cps-datepicker.component.d.ts +1 -1
- package/lib/components/cps-input/cps-input.component.d.ts +1 -1
- package/lib/components/cps-radio-group/cps-radio-button/cps-radio-button.component.d.ts +15 -1
- package/lib/components/cps-radio-group/cps-radio-group.component.d.ts +32 -3
- package/lib/components/cps-select/cps-select.component.d.ts +1 -1
- package/lib/components/cps-textarea/cps-textarea.component.d.ts +1 -1
- package/lib/components/cps-timepicker/cps-timepicker.component.d.ts +14 -14
- package/lib/components/internal/cps-base-tree-dropdown/cps-base-tree-dropdown.component.d.ts +1 -1
- package/package.json +1 -1
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
|
2
2
|
import { Component, EventEmitter, Input, Optional, Output, Self, ViewChild } from '@angular/core';
|
|
3
3
|
import { CpsIconComponent } from '../cps-icon/cps-icon.component';
|
|
4
|
-
import { Subscription } from 'rxjs';
|
|
5
4
|
import { convertSize } from '../../utils/internal/size-utils';
|
|
6
5
|
import { CpsProgressLinearComponent } from '../cps-progress-linear/cps-progress-linear.component';
|
|
7
6
|
import { CpsInfoCircleComponent } from '../cps-info-circle/cps-info-circle.component';
|
|
@@ -184,7 +183,6 @@ export class CpsInputComponent {
|
|
|
184
183
|
this.currentType = '';
|
|
185
184
|
this.prefixWidth = '';
|
|
186
185
|
this.cvtWidth = '';
|
|
187
|
-
this._statusChangesSubscription = new Subscription();
|
|
188
186
|
this._value = '';
|
|
189
187
|
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
190
188
|
this.onChange = (event) => { };
|
|
@@ -383,4 +381,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
|
383
381
|
type: ViewChild,
|
|
384
382
|
args: ['prefixTextSpan']
|
|
385
383
|
}] } });
|
|
386
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-input.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-input/cps-input.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-input/cps-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Self,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport {\n  CpsIconComponent,\n  IconType,\n  iconSizeType\n} from '../cps-icon/cps-icon.component';\nimport { Subscription } from 'rxjs';\nimport { convertSize } from '../../utils/internal/size-utils';\nimport { CpsProgressLinearComponent } from '../cps-progress-linear/cps-progress-linear.component';\nimport { CpsInfoCircleComponent } from '../cps-info-circle/cps-info-circle.component';\nimport { CpsTooltipPosition } from '../../directives/cps-tooltip/cps-tooltip.directive';\n\nexport type CpsInputAppearanceType = 'outlined' | 'underlined' | 'borderless';\n\n/**\n * CpsInputComponent is used to enter values in a certain formats such as numeric, text or password.\n * @group Components\n */\n@Component({\n  standalone: true,\n  imports: [\n    CommonModule,\n    CpsIconComponent,\n    CpsInfoCircleComponent,\n    CpsProgressLinearComponent\n  ],\n  selector: 'cps-input',\n  templateUrl: './cps-input.component.html',\n  styleUrls: ['./cps-input.component.scss']\n})\nexport class CpsInputComponent\n  implements ControlValueAccessor, OnInit, AfterViewInit, OnDestroy\n{\n  /**\n   * Label of the input element.\n   * @group Props\n   */\n  @Input() label = '';\n\n  /**\n   * Bottom hint text for the input field.\n   * @group Props\n   */\n  @Input() hint = '';\n\n  /**\n   * Placeholder text for the input field.\n   * @group Props\n   */\n  @Input() placeholder = 'Please enter';\n\n  /**\n   * Determines whether input is disabled.\n   * @group Props\n   */\n  @Input() disabled = false;\n\n  /**\n   * Determines whether input is readonly.\n   * @group Props\n   */\n  @Input() readonly = false;\n\n  /**\n   * Width of the input field, of type number denoting pixels or string.\n   * @group Props\n   */\n  @Input() width: number | string = '100%';\n\n  /**\n   * Type of the input of type 'text', 'number' or 'password'.\n   * @group Props\n   */\n  @Input() type: 'text' | 'number' | 'password' = 'text';\n\n  /**\n   * When enabled, a loading bar is displayed.\n   * @group Props\n   */\n  @Input() loading = false;\n\n  /**\n   * When enabled, a clear icon is displayed to clear the value.\n   * @group Props\n   */\n  @Input() clearable = false;\n\n  /**\n   * Icon before input value.\n   * @group Props\n   */\n  @Input() prefixIcon: IconType = '';\n\n  /**\n   * When enabled, prefixIcon is clickable.\n   * @group Props\n   */\n  @Input() prefixIconClickable = false;\n\n  /**\n   * Size of icon before input value, of type number or string or it can be a value 'fill', 'xsmall', 'small', 'normal' or 'large'.\n   * @group Props\n   */\n  @Input() prefixIconSize: iconSizeType = '18px';\n\n  /**\n   * Text before input value.\n   * @group Props\n   */\n  @Input() prefixText = '';\n\n  /**\n   * Hides hint and validation errors.\n   * @group Props\n   */\n  @Input() hideDetails = false;\n\n  /**\n   * Determines whether the component should have persistent clear icon.\n   * @group Props\n   */\n  @Input() persistentClear = false;\n\n  /**\n   * Error message.\n   * @group Props\n   */\n  @Input() error = '';\n\n  /**\n   * When it is not an empty string, an info icon is displayed to show text for more info.\n   * @group Props\n   */\n  @Input() infoTooltip = '';\n\n  /**\n   * InfoTooltip class for styling.\n   * @group Props\n   */\n  @Input() infoTooltipClass = 'cps-tooltip-content';\n\n  /**\n   * Max width of infoTooltip, of type number denoting pixels or string.\n   * @group Props\n   */\n  @Input() infoTooltipMaxWidth: number | string = '100%';\n\n  /**\n   * Determines whether the infoTooltip is persistent.\n   * @group Props\n   */\n  @Input() infoTooltipPersistent = false;\n\n  /**\n   * Position of infoTooltip, it can be 'top', 'bottom', 'left' or 'right'.\n   * @group Props\n   */\n  @Input() infoTooltipPosition: CpsTooltipPosition = 'top';\n\n  /**\n   * Styling appearance of input field, it can be \"outlined\" or \"underlined\" or \"borderless\".\n   * @group Props\n   */\n  @Input() appearance: CpsInputAppearanceType = 'outlined';\n\n  /**\n   * Readonly value to display inside of input field.\n   * @group Props\n   */\n  @Input() valueToDisplay = '';\n\n  /**\n   * Value of the input.\n   * @group Props\n   */\n  @Input() set value(value: string) {\n    if (!value) value = '';\n    this._value = value;\n    this.onChange(value);\n  }\n\n  get value(): string {\n    return this._value;\n  }\n\n  /**\n   * Callback to invoke on value change.\n   * @param {string} string - value changed.\n   * @group Emits\n   */\n  @Output() valueChanged = new EventEmitter<string>();\n\n  /**\n   * Callback to invoke when the component receives focus.\n   * @param {any}\n   * @group Emits\n   */\n  @Output() focused = new EventEmitter();\n\n  /**\n   * Callback to invoke when the prefix icon is clicked.\n   * @param {any}\n   * @group Emits\n   */\n  @Output() prefixIconClicked = new EventEmitter();\n\n  /**\n   * Callback to invoke when the component loses focus.\n   * @param {any}\n   * @group Emits\n   */\n  @Output() blurred = new EventEmitter();\n\n  /**\n   * Callback to invoke when x icon is clicked.\n   * @param {any}\n   * @group Emits\n   */\n  @Output() cleared = new EventEmitter();\n\n  /**\n   * Callback to invoke when enter is clicked.\n   * @param {any}\n   * @group Emits\n   */\n  @Output() enterClicked = new EventEmitter();\n\n  @ViewChild('prefixTextSpan') prefixTextSpan: ElementRef | undefined;\n\n  currentType = '';\n  prefixWidth = '';\n  cvtWidth = '';\n\n  private _statusChangesSubscription: Subscription = new Subscription();\n  private _value = '';\n\n  constructor(\n    @Self() @Optional() private _control: NgControl,\n    public elementRef: ElementRef<HTMLElement>,\n    private cdRef: ChangeDetectorRef\n  ) {\n    if (this._control) {\n      this._control.valueAccessor = this;\n    }\n  }\n\n  ngOnInit(): void {\n    this.currentType = this.type;\n    this.cvtWidth = convertSize(this.width);\n\n    this._statusChangesSubscription = this._control?.statusChanges?.subscribe(\n      () => {\n        this._checkErrors();\n      }\n    ) as Subscription;\n  }\n\n  ngAfterViewInit() {\n    let w = 0;\n    if (this.prefixText) {\n      w = this.prefixTextSpan?.nativeElement?.offsetWidth + 22;\n    }\n    if (this.prefixIcon) {\n      w += 38 - (this.prefixText ? 14 : 0);\n    }\n    this.prefixWidth = w > 0 ? `${w}px` : '';\n    this.cdRef.detectChanges();\n  }\n\n  ngOnDestroy() {\n    this._statusChangesSubscription?.unsubscribe();\n  }\n\n  private _checkErrors() {\n    if (!this._control) return;\n    const errors = this._control?.errors;\n\n    if (!this._control?.control?.touched || !errors) {\n      this.error = '';\n      return;\n    }\n\n    if ('required' in errors) {\n      this.error = 'Field is required';\n      return;\n    }\n\n    if ('pattern' in errors) {\n      this.error = 'Value is invalid';\n      return;\n    }\n\n    if ('email' in errors) {\n      this.error = 'Email format is invalid';\n      return;\n    }\n\n    if ('minlength' in errors) {\n      // eslint-disable-next-line dot-notation\n      this.error = `Field must contain at least ${errors['minlength'].requiredLength} characters`;\n      return;\n    }\n\n    if ('maxlength' in errors) {\n      // eslint-disable-next-line dot-notation\n      this.error = `Field must contain ${errors['maxlength'].requiredLength} characters maximum`;\n      return;\n    }\n\n    const errArr = Object.values(errors);\n    if (errArr.length < 1) {\n      this.error = '';\n      return;\n    }\n    const message = errArr.find((msg) => typeof msg === 'string');\n\n    this.error = message || 'Unknown error';\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange = (event: any) => {};\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched = () => {};\n\n  onInputEnterKeyDown() {\n    this.elementRef?.nativeElement?.querySelector('input')?.blur();\n    this.enterClicked.emit();\n  }\n\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  writeValue(value: string) {\n    this.value = value;\n  }\n\n  updateValueEvent(event: any) {\n    const value = event?.target?.value || '';\n    this._updateValue(value);\n  }\n\n  private _updateValue(value: string) {\n    this.writeValue(value);\n    this.onChange(value);\n    this.valueChanged.emit(value);\n  }\n\n  onClear() {\n    this.clear();\n    this.cleared.emit();\n  }\n\n  clear() {\n    if (this.value !== '') this._updateValue('');\n  }\n\n  togglePassword() {\n    this.currentType = this.currentType === 'password' ? 'text' : 'password';\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  setDisabledState(disabled: boolean) {}\n\n  onBlur() {\n    this._control?.control?.markAsTouched();\n    this._checkErrors();\n    this.blurred.emit();\n  }\n\n  onClickPrefixIcon() {\n    if (!this.prefixIconClickable || this.readonly || this.disabled) return;\n    this.prefixIconClicked.emit();\n  }\n\n  onFocus() {\n    this.focused.emit();\n  }\n\n  focus() {\n    this.elementRef?.nativeElement?.querySelector('input')?.focus();\n  }\n}\n","<div class=\"cps-input-container\" [ngStyle]=\"{ width: cvtWidth }\">\n  <div\n    class=\"cps-input-label\"\n    [ngClass]=\"{ 'cps-input-label-disabled': disabled && !readonly }\"\n    *ngIf=\"label\">\n    <label>{{ label }}</label>\n    <cps-info-circle\n      *ngIf=\"infoTooltip\"\n      class=\"cps-input-label-info-circle\"\n      size=\"xsmall\"\n      [tooltipPosition]=\"infoTooltipPosition\"\n      [tooltipContentClass]=\"infoTooltipClass\"\n      [tooltipMaxWidth]=\"infoTooltipMaxWidth\"\n      [tooltipPersistent]=\"infoTooltipPersistent\"\n      [tooltipText]=\"infoTooltip\">\n    </cps-info-circle>\n  </div>\n\n  <div\n    class=\"cps-input-wrap\"\n    [ngClass]=\"{\n      password: type === 'password',\n      'cps-input-wrap-error': error,\n      clearable: clearable,\n      'persistent-clear': persistentClear,\n      borderless: appearance === 'borderless',\n      underlined: appearance === 'underlined'\n    }\">\n    <input\n      *ngIf=\"!valueToDisplay\"\n      spellcheck=\"false\"\n      [type]=\"currentType\"\n      [value]=\"value\"\n      (input)=\"updateValueEvent($event)\"\n      [placeholder]=\"placeholder\"\n      [disabled]=\"disabled\"\n      [readonly]=\"readonly\"\n      (keydown.enter)=\"onInputEnterKeyDown()\"\n      [ngStyle]=\"{\n        width: cvtWidth,\n        'padding-left': prefixWidth || 'none'\n      }\"\n      (blur)=\"onBlur()\"\n      (focus)=\"onFocus()\" />\n\n    <input\n      *ngIf=\"valueToDisplay\"\n      [value]=\"valueToDisplay\"\n      [disabled]=\"true\"\n      [readonly]=\"true\"\n      [ngStyle]=\"{\n        width: cvtWidth,\n        'padding-left': prefixWidth || 'none'\n      }\" />\n\n    <div class=\"cps-input-prefix\">\n      <span *ngIf=\"prefixIcon\" class=\"cps-input-prefix-icon\">\n        <cps-icon\n          [icon]=\"prefixIcon\"\n          [size]=\"prefixIconSize\"\n          [style.color]=\"disabled ? '#9a9595' : null\"\n          [style.cursor]=\"\n            prefixIconClickable && !disabled && !readonly\n              ? 'pointer'\n              : 'default'\n          \"\n          (click)=\"onClickPrefixIcon()\">\n        </cps-icon>\n      </span>\n\n      <span *ngIf=\"prefixText\" class=\"cps-input-prefix-text\" #prefixTextSpan>\n        {{ prefixText }}\n      </span>\n    </div>\n\n    <div class=\"cps-input-action-btns\" *ngIf=\"!disabled && !readonly\">\n      <span\n        *ngIf=\"clearable\"\n        [style.visibility]=\"\n          persistentClear || (!persistentClear && value) ? 'visible' : 'hidden'\n        \"\n        class=\"clear-btn\">\n        <cps-icon icon=\"delete\" size=\"small\" (click)=\"onClear()\"></cps-icon>\n      </span>\n\n      <span\n        *ngIf=\"type === 'password'\"\n        class=\"password-show-btn\"\n        [ngClass]=\"{ 'password-show-btn-active': currentType === 'text' }\">\n        <cps-icon icon=\"eye\" size=\"18px\" (click)=\"togglePassword()\"></cps-icon>\n      </span>\n    </div>\n    <cps-progress-linear\n      *ngIf=\"loading\"\n      height=\"3\"\n      radius=\"4\"\n      opacity=\"0.3\"\n      class=\"cps-input-progress-bar\"\n      bgColor=\"transparent\">\n    </cps-progress-linear>\n  </div>\n  <div *ngIf=\"!error && !hideDetails\" class=\"cps-input-hint\">\n    {{ hint }}\n  </div>\n  <div *ngIf=\"error && !hideDetails\" class=\"cps-input-error\">\n    {{ error }}\n  </div>\n</div>\n"]}
|
|
384
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-input.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-input/cps-input.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-input/cps-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Self,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport {\n  CpsIconComponent,\n  IconType,\n  iconSizeType\n} from '../cps-icon/cps-icon.component';\nimport { Subscription } from 'rxjs';\nimport { convertSize } from '../../utils/internal/size-utils';\nimport { CpsProgressLinearComponent } from '../cps-progress-linear/cps-progress-linear.component';\nimport { CpsInfoCircleComponent } from '../cps-info-circle/cps-info-circle.component';\nimport { CpsTooltipPosition } from '../../directives/cps-tooltip/cps-tooltip.directive';\n\nexport type CpsInputAppearanceType = 'outlined' | 'underlined' | 'borderless';\n\n/**\n * CpsInputComponent is used to enter values in a certain formats such as numeric, text or password.\n * @group Components\n */\n@Component({\n  standalone: true,\n  imports: [\n    CommonModule,\n    CpsIconComponent,\n    CpsInfoCircleComponent,\n    CpsProgressLinearComponent\n  ],\n  selector: 'cps-input',\n  templateUrl: './cps-input.component.html',\n  styleUrls: ['./cps-input.component.scss']\n})\nexport class CpsInputComponent\n  implements ControlValueAccessor, OnInit, AfterViewInit, OnDestroy\n{\n  /**\n   * Label of the input element.\n   * @group Props\n   */\n  @Input() label = '';\n\n  /**\n   * Bottom hint text for the input field.\n   * @group Props\n   */\n  @Input() hint = '';\n\n  /**\n   * Placeholder text for the input field.\n   * @group Props\n   */\n  @Input() placeholder = 'Please enter';\n\n  /**\n   * Determines whether input is disabled.\n   * @group Props\n   */\n  @Input() disabled = false;\n\n  /**\n   * Determines whether input is readonly.\n   * @group Props\n   */\n  @Input() readonly = false;\n\n  /**\n   * Width of the input field, of type number denoting pixels or string.\n   * @group Props\n   */\n  @Input() width: number | string = '100%';\n\n  /**\n   * Type of the input of type 'text', 'number' or 'password'.\n   * @group Props\n   */\n  @Input() type: 'text' | 'number' | 'password' = 'text';\n\n  /**\n   * When enabled, a loading bar is displayed.\n   * @group Props\n   */\n  @Input() loading = false;\n\n  /**\n   * When enabled, a clear icon is displayed to clear the value.\n   * @group Props\n   */\n  @Input() clearable = false;\n\n  /**\n   * Icon before input value.\n   * @group Props\n   */\n  @Input() prefixIcon: IconType = '';\n\n  /**\n   * When enabled, prefixIcon is clickable.\n   * @group Props\n   */\n  @Input() prefixIconClickable = false;\n\n  /**\n   * Size of icon before input value, of type number or string or it can be a value 'fill', 'xsmall', 'small', 'normal' or 'large'.\n   * @group Props\n   */\n  @Input() prefixIconSize: iconSizeType = '18px';\n\n  /**\n   * Text before input value.\n   * @group Props\n   */\n  @Input() prefixText = '';\n\n  /**\n   * Hides hint and validation errors.\n   * @group Props\n   */\n  @Input() hideDetails = false;\n\n  /**\n   * Determines whether the component should have persistent clear icon.\n   * @group Props\n   */\n  @Input() persistentClear = false;\n\n  /**\n   * Error message.\n   * @group Props\n   */\n  @Input() error = '';\n\n  /**\n   * When it is not an empty string, an info icon is displayed to show text for more info.\n   * @group Props\n   */\n  @Input() infoTooltip = '';\n\n  /**\n   * InfoTooltip class for styling.\n   * @group Props\n   */\n  @Input() infoTooltipClass = 'cps-tooltip-content';\n\n  /**\n   * Max width of infoTooltip, of type number denoting pixels or string.\n   * @group Props\n   */\n  @Input() infoTooltipMaxWidth: number | string = '100%';\n\n  /**\n   * Determines whether the infoTooltip is persistent.\n   * @group Props\n   */\n  @Input() infoTooltipPersistent = false;\n\n  /**\n   * Position of infoTooltip, it can be 'top', 'bottom', 'left' or 'right'.\n   * @group Props\n   */\n  @Input() infoTooltipPosition: CpsTooltipPosition = 'top';\n\n  /**\n   * Styling appearance of input field, it can be \"outlined\" or \"underlined\" or \"borderless\".\n   * @group Props\n   */\n  @Input() appearance: CpsInputAppearanceType = 'outlined';\n\n  /**\n   * Readonly value to display inside of input field.\n   * @group Props\n   */\n  @Input() valueToDisplay = '';\n\n  /**\n   * Value of the input.\n   * @group Props\n   */\n  @Input() set value(value: string) {\n    if (!value) value = '';\n    this._value = value;\n    this.onChange(value);\n  }\n\n  get value(): string {\n    return this._value;\n  }\n\n  /**\n   * Callback to invoke on value change.\n   * @param {string} string - value changed.\n   * @group Emits\n   */\n  @Output() valueChanged = new EventEmitter<string>();\n\n  /**\n   * Callback to invoke when the component receives focus.\n   * @param {any}\n   * @group Emits\n   */\n  @Output() focused = new EventEmitter();\n\n  /**\n   * Callback to invoke when the prefix icon is clicked.\n   * @param {any}\n   * @group Emits\n   */\n  @Output() prefixIconClicked = new EventEmitter();\n\n  /**\n   * Callback to invoke when the component loses focus.\n   * @param {any}\n   * @group Emits\n   */\n  @Output() blurred = new EventEmitter();\n\n  /**\n   * Callback to invoke when x icon is clicked.\n   * @param {any}\n   * @group Emits\n   */\n  @Output() cleared = new EventEmitter();\n\n  /**\n   * Callback to invoke when enter is clicked.\n   * @param {any}\n   * @group Emits\n   */\n  @Output() enterClicked = new EventEmitter();\n\n  @ViewChild('prefixTextSpan') prefixTextSpan: ElementRef | undefined;\n\n  currentType = '';\n  prefixWidth = '';\n  cvtWidth = '';\n\n  private _statusChangesSubscription?: Subscription;\n  private _value = '';\n\n  constructor(\n    @Self() @Optional() private _control: NgControl,\n    public elementRef: ElementRef<HTMLElement>,\n    private cdRef: ChangeDetectorRef\n  ) {\n    if (this._control) {\n      this._control.valueAccessor = this;\n    }\n  }\n\n  ngOnInit(): void {\n    this.currentType = this.type;\n    this.cvtWidth = convertSize(this.width);\n\n    this._statusChangesSubscription = this._control?.statusChanges?.subscribe(\n      () => {\n        this._checkErrors();\n      }\n    );\n  }\n\n  ngAfterViewInit() {\n    let w = 0;\n    if (this.prefixText) {\n      w = this.prefixTextSpan?.nativeElement?.offsetWidth + 22;\n    }\n    if (this.prefixIcon) {\n      w += 38 - (this.prefixText ? 14 : 0);\n    }\n    this.prefixWidth = w > 0 ? `${w}px` : '';\n    this.cdRef.detectChanges();\n  }\n\n  ngOnDestroy() {\n    this._statusChangesSubscription?.unsubscribe();\n  }\n\n  private _checkErrors() {\n    if (!this._control) return;\n    const errors = this._control?.errors;\n\n    if (!this._control?.control?.touched || !errors) {\n      this.error = '';\n      return;\n    }\n\n    if ('required' in errors) {\n      this.error = 'Field is required';\n      return;\n    }\n\n    if ('pattern' in errors) {\n      this.error = 'Value is invalid';\n      return;\n    }\n\n    if ('email' in errors) {\n      this.error = 'Email format is invalid';\n      return;\n    }\n\n    if ('minlength' in errors) {\n      // eslint-disable-next-line dot-notation\n      this.error = `Field must contain at least ${errors['minlength'].requiredLength} characters`;\n      return;\n    }\n\n    if ('maxlength' in errors) {\n      // eslint-disable-next-line dot-notation\n      this.error = `Field must contain ${errors['maxlength'].requiredLength} characters maximum`;\n      return;\n    }\n\n    const errArr = Object.values(errors);\n    if (errArr.length < 1) {\n      this.error = '';\n      return;\n    }\n    const message = errArr.find((msg) => typeof msg === 'string');\n\n    this.error = message || 'Unknown error';\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange = (event: any) => {};\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched = () => {};\n\n  onInputEnterKeyDown() {\n    this.elementRef?.nativeElement?.querySelector('input')?.blur();\n    this.enterClicked.emit();\n  }\n\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  writeValue(value: string) {\n    this.value = value;\n  }\n\n  updateValueEvent(event: any) {\n    const value = event?.target?.value || '';\n    this._updateValue(value);\n  }\n\n  private _updateValue(value: string) {\n    this.writeValue(value);\n    this.onChange(value);\n    this.valueChanged.emit(value);\n  }\n\n  onClear() {\n    this.clear();\n    this.cleared.emit();\n  }\n\n  clear() {\n    if (this.value !== '') this._updateValue('');\n  }\n\n  togglePassword() {\n    this.currentType = this.currentType === 'password' ? 'text' : 'password';\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  setDisabledState(disabled: boolean) {}\n\n  onBlur() {\n    this._control?.control?.markAsTouched();\n    this._checkErrors();\n    this.blurred.emit();\n  }\n\n  onClickPrefixIcon() {\n    if (!this.prefixIconClickable || this.readonly || this.disabled) return;\n    this.prefixIconClicked.emit();\n  }\n\n  onFocus() {\n    this.focused.emit();\n  }\n\n  focus() {\n    this.elementRef?.nativeElement?.querySelector('input')?.focus();\n  }\n}\n","<div class=\"cps-input-container\" [ngStyle]=\"{ width: cvtWidth }\">\n  <div\n    class=\"cps-input-label\"\n    [ngClass]=\"{ 'cps-input-label-disabled': disabled && !readonly }\"\n    *ngIf=\"label\">\n    <label>{{ label }}</label>\n    <cps-info-circle\n      *ngIf=\"infoTooltip\"\n      class=\"cps-input-label-info-circle\"\n      size=\"xsmall\"\n      [tooltipPosition]=\"infoTooltipPosition\"\n      [tooltipContentClass]=\"infoTooltipClass\"\n      [tooltipMaxWidth]=\"infoTooltipMaxWidth\"\n      [tooltipPersistent]=\"infoTooltipPersistent\"\n      [tooltipText]=\"infoTooltip\">\n    </cps-info-circle>\n  </div>\n\n  <div\n    class=\"cps-input-wrap\"\n    [ngClass]=\"{\n      password: type === 'password',\n      'cps-input-wrap-error': error,\n      clearable: clearable,\n      'persistent-clear': persistentClear,\n      borderless: appearance === 'borderless',\n      underlined: appearance === 'underlined'\n    }\">\n    <input\n      *ngIf=\"!valueToDisplay\"\n      spellcheck=\"false\"\n      [type]=\"currentType\"\n      [value]=\"value\"\n      (input)=\"updateValueEvent($event)\"\n      [placeholder]=\"placeholder\"\n      [disabled]=\"disabled\"\n      [readonly]=\"readonly\"\n      (keydown.enter)=\"onInputEnterKeyDown()\"\n      [ngStyle]=\"{\n        width: cvtWidth,\n        'padding-left': prefixWidth || 'none'\n      }\"\n      (blur)=\"onBlur()\"\n      (focus)=\"onFocus()\" />\n\n    <input\n      *ngIf=\"valueToDisplay\"\n      [value]=\"valueToDisplay\"\n      [disabled]=\"true\"\n      [readonly]=\"true\"\n      [ngStyle]=\"{\n        width: cvtWidth,\n        'padding-left': prefixWidth || 'none'\n      }\" />\n\n    <div class=\"cps-input-prefix\">\n      <span *ngIf=\"prefixIcon\" class=\"cps-input-prefix-icon\">\n        <cps-icon\n          [icon]=\"prefixIcon\"\n          [size]=\"prefixIconSize\"\n          [style.color]=\"disabled ? '#9a9595' : null\"\n          [style.cursor]=\"\n            prefixIconClickable && !disabled && !readonly\n              ? 'pointer'\n              : 'default'\n          \"\n          (click)=\"onClickPrefixIcon()\">\n        </cps-icon>\n      </span>\n\n      <span *ngIf=\"prefixText\" class=\"cps-input-prefix-text\" #prefixTextSpan>\n        {{ prefixText }}\n      </span>\n    </div>\n\n    <div class=\"cps-input-action-btns\" *ngIf=\"!disabled && !readonly\">\n      <span\n        *ngIf=\"clearable\"\n        [style.visibility]=\"\n          persistentClear || (!persistentClear && value) ? 'visible' : 'hidden'\n        \"\n        class=\"clear-btn\">\n        <cps-icon icon=\"delete\" size=\"small\" (click)=\"onClear()\"></cps-icon>\n      </span>\n\n      <span\n        *ngIf=\"type === 'password'\"\n        class=\"password-show-btn\"\n        [ngClass]=\"{ 'password-show-btn-active': currentType === 'text' }\">\n        <cps-icon icon=\"eye\" size=\"18px\" (click)=\"togglePassword()\"></cps-icon>\n      </span>\n    </div>\n    <cps-progress-linear\n      *ngIf=\"loading\"\n      height=\"3\"\n      radius=\"4\"\n      opacity=\"0.3\"\n      class=\"cps-input-progress-bar\"\n      bgColor=\"transparent\">\n    </cps-progress-linear>\n  </div>\n  <div *ngIf=\"!error && !hideDetails\" class=\"cps-input-hint\">\n    {{ hint }}\n  </div>\n  <div *ngIf=\"error && !hideDetails\" class=\"cps-input-error\">\n    {{ error }}\n  </div>\n</div>\n"]}
|
|
@@ -21,7 +21,7 @@ export class CpsRadioComponent {
|
|
|
21
21
|
this.radioGroup?.updateValueEvent(value);
|
|
22
22
|
}
|
|
23
23
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsRadioComponent, deps: [{ token: CPS_RADIO_GROUP, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
24
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: CpsRadioComponent, isStandalone: true, selector: "cps-radio", inputs: { option: "option" }, ngImport: i0, template: "<cps-radio-button\n [option]=\"option\"\n [groupDisabled]=\"groupDisabled\"\n [checked]=\"radioGroup?.value == option.value\"\n (updateValueEvent)=\"updateValueEvent($event)\">\n <ng-content></ng-content>\n</cps-radio-button>\n", styles: [":host{display:flex;align-items:center}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: CpsRadioButtonComponent, selector: "cps-radio-button", inputs: ["option", "checked", "groupDisabled"], outputs: ["updateValueEvent"] }] }); }
|
|
24
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: CpsRadioComponent, isStandalone: true, selector: "cps-radio", inputs: { option: "option" }, ngImport: i0, template: "<cps-radio-button\n [option]=\"option\"\n [groupDisabled]=\"groupDisabled\"\n [checked]=\"radioGroup?.value == option.value\"\n (updateValueEvent)=\"updateValueEvent($event)\">\n <ng-content></ng-content>\n</cps-radio-button>\n", styles: [":host{display:flex;align-items:center}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: CpsRadioButtonComponent, selector: "cps-radio-button", inputs: ["option", "checked", "groupDisabled"], outputs: ["updateValueEvent", "blurred", "focused"] }] }); }
|
|
25
25
|
}
|
|
26
26
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsRadioComponent, decorators: [{
|
|
27
27
|
type: Component,
|
package/esm2022/lib/components/cps-radio-group/cps-radio-button/cps-radio-button.component.mjs
CHANGED
|
@@ -27,6 +27,18 @@ export class CpsRadioButtonComponent {
|
|
|
27
27
|
* @group Emits
|
|
28
28
|
*/
|
|
29
29
|
this.updateValueEvent = new EventEmitter();
|
|
30
|
+
/**
|
|
31
|
+
* Callback to invoke when the radio button loses focus.
|
|
32
|
+
* @param {any}
|
|
33
|
+
* @group Emits
|
|
34
|
+
*/
|
|
35
|
+
this.blurred = new EventEmitter();
|
|
36
|
+
/**
|
|
37
|
+
* Callback to invoke when the radio button receives focus.
|
|
38
|
+
* @param {any}
|
|
39
|
+
* @group Emits
|
|
40
|
+
*/
|
|
41
|
+
this.focused = new EventEmitter();
|
|
30
42
|
}
|
|
31
43
|
get inputId() {
|
|
32
44
|
return `${this._uniqueId}-input`;
|
|
@@ -37,12 +49,18 @@ export class CpsRadioButtonComponent {
|
|
|
37
49
|
return;
|
|
38
50
|
this.updateValueEvent.emit(this.option.value);
|
|
39
51
|
}
|
|
52
|
+
onBlur() {
|
|
53
|
+
this.blurred.emit();
|
|
54
|
+
}
|
|
55
|
+
onFocus() {
|
|
56
|
+
this.focused.emit();
|
|
57
|
+
}
|
|
40
58
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsRadioButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
41
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: CpsRadioButtonComponent, isStandalone: true, selector: "cps-radio-button", inputs: { option: "option", checked: "checked", groupDisabled: "groupDisabled" }, outputs: { updateValueEvent: "updateValueEvent" }, ngImport: i0, template: "<div\n *ngIf=\"option.tooltip\"\n class=\"cps-radio-group-content-button\"\n [cpsTooltip]=\"option.tooltip\"\n tooltipCloseDelay=\"0\"\n tooltipPosition=\"bottom\">\n <ng-container\n *ngTemplateOutlet=\"\n optionRadioTemplate;\n context: {\n option: option\n }\n \"></ng-container>\n</div>\n<div *ngIf=\"!option?.tooltip\" class=\"cps-radio-group-content-button\">\n <ng-container\n *ngTemplateOutlet=\"\n optionRadioTemplate;\n context: {\n option: option\n }\n \"></ng-container>\n</div>\n\n<ng-template #optionRadioTemplate let-option=\"option\">\n <input\n [id]=\"inputId\"\n type=\"radio\"\n [disabled]=\"option.disabled || groupDisabled\"\n [value]=\"option.value\"\n [checked]=\"checked\"\n (change)=\"updateValue($event)\" />\n <div #contentRef class=\"content\">\n <ng-content></ng-content>\n </div>\n <label\n *ngIf=\"!contentRef.innerHTML.trim()\"\n [for]=\"inputId\"\n class=\"cps-radio-group-content-button-label\"\n [ngStyle]=\"{\n cursor: option.disabled || groupDisabled ? 'default' : 'pointer'\n }\"\n >{{ option.label }}\n </label>\n</ng-template>\n", styles: [":host .cps-radio-group-content-button{display:grid;grid-template-columns:1rem auto;align-items:center;gap:.75rem}:host .cps-radio-group-content-button-label{font-size:1rem;color:var(--cps-color-text-dark);font-style:normal;font-weight:400;line-height:1rem}:host .cps-radio-group-content-button input[type=radio]{-webkit-appearance:none;appearance:none;background-color:transparent;margin:0;cursor:pointer;font:inherit;color:var(--cps-color-text-mild);width:1.25rem;height:1.25rem;border:.15rem solid currentColor;border-radius:50%;display:grid;place-content:center}:host .cps-radio-group-content-button input[type=radio]:hover,:host .cps-radio-group-content-button input[type=radio]:checked{color:var(--cps-color-calm)}:host .cps-radio-group-content-button input[type=radio]:disabled{color:var(--cps-color-text-lightest);cursor:default}:host .cps-radio-group-content-button input[type=radio]:before{content:\"\";width:1.25rem;height:1.25rem;border-radius:50%;transform:scale(0);transition:.12s transform ease-in-out;box-shadow:inset 1rem 1rem var(--cps-color-calm);background-color:CanvasText}:host .cps-radio-group-content-button input[type=radio][disabled]:before{box-shadow:inset 1rem 1rem var(--cps-color-text-lightest)}:host .cps-radio-group-content-button input[type=radio]:disabled+.cps-radio-group-content-button-label{color:var(--cps-color-text-light)}:host .cps-radio-group-content-button input[type=radio]:checked:before{transform:scale(.5)}:host .cps-radio-group-content-button .cps-radio-group-content-button-label{-webkit-user-select:none;user-select:none}:host .cps-radio-group-content-button .content:empty{display:none}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: CpsTooltipDirective, selector: "[cpsTooltip]", inputs: ["cpsTooltip", "tooltipOpenDelay", "tooltipCloseDelay", "tooltipOpenOn", "tooltipPosition", "tooltipPersistent", "tooltipDisabled", "tooltipMaxWidth", "tooltipContentClass"] }] }); }
|
|
59
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: CpsRadioButtonComponent, isStandalone: true, selector: "cps-radio-button", inputs: { option: "option", checked: "checked", groupDisabled: "groupDisabled" }, outputs: { updateValueEvent: "updateValueEvent", blurred: "blurred", focused: "focused" }, ngImport: i0, template: "<div\n *ngIf=\"option.tooltip\"\n class=\"cps-radio-group-content-button\"\n [cpsTooltip]=\"option.tooltip\"\n tooltipCloseDelay=\"0\"\n tooltipPosition=\"bottom\">\n <ng-container\n *ngTemplateOutlet=\"\n optionRadioTemplate;\n context: {\n option: option\n }\n \"></ng-container>\n</div>\n<div *ngIf=\"!option?.tooltip\" class=\"cps-radio-group-content-button\">\n <ng-container\n *ngTemplateOutlet=\"\n optionRadioTemplate;\n context: {\n option: option\n }\n \"></ng-container>\n</div>\n\n<ng-template #optionRadioTemplate let-option=\"option\">\n <input\n [id]=\"inputId\"\n type=\"radio\"\n [disabled]=\"option.disabled || groupDisabled\"\n [value]=\"option.value\"\n [checked]=\"checked\"\n (change)=\"updateValue($event)\"\n (focus)=\"onFocus()\"\n (blur)=\"onBlur()\" />\n <div #contentRef class=\"content\">\n <ng-content></ng-content>\n </div>\n <label\n *ngIf=\"!contentRef.innerHTML.trim()\"\n [for]=\"inputId\"\n class=\"cps-radio-group-content-button-label\"\n [ngStyle]=\"{\n cursor: option.disabled || groupDisabled ? 'default' : 'pointer'\n }\"\n >{{ option.label }}\n </label>\n</ng-template>\n", styles: [":host .cps-radio-group-content-button{display:grid;grid-template-columns:1rem auto;align-items:center;gap:.75rem}:host .cps-radio-group-content-button-label{font-size:1rem;color:var(--cps-color-text-dark);font-style:normal;font-weight:400;line-height:1rem}:host .cps-radio-group-content-button input[type=radio]{-webkit-appearance:none;appearance:none;background-color:transparent;margin:0;cursor:pointer;font:inherit;color:var(--cps-color-text-mild);width:1.25rem;height:1.25rem;border:.15rem solid currentColor;border-radius:50%;display:grid;place-content:center}:host .cps-radio-group-content-button input[type=radio]:hover,:host .cps-radio-group-content-button input[type=radio]:checked{color:var(--cps-color-calm)}:host .cps-radio-group-content-button input[type=radio]:disabled{color:var(--cps-color-text-lightest);cursor:default}:host .cps-radio-group-content-button input[type=radio]:before{content:\"\";width:1.25rem;height:1.25rem;border-radius:50%;transform:scale(0);transition:.12s transform ease-in-out;box-shadow:inset 1rem 1rem var(--cps-color-calm);background-color:CanvasText}:host .cps-radio-group-content-button input[type=radio][disabled]:before{box-shadow:inset 1rem 1rem var(--cps-color-text-lightest)}:host .cps-radio-group-content-button input[type=radio]:disabled+.cps-radio-group-content-button-label{color:var(--cps-color-text-light)}:host .cps-radio-group-content-button input[type=radio]:checked:before{transform:scale(.5)}:host .cps-radio-group-content-button .cps-radio-group-content-button-label{-webkit-user-select:none;user-select:none}:host .cps-radio-group-content-button .content:empty{display:none}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: CpsTooltipDirective, selector: "[cpsTooltip]", inputs: ["cpsTooltip", "tooltipOpenDelay", "tooltipCloseDelay", "tooltipOpenOn", "tooltipPosition", "tooltipPersistent", "tooltipDisabled", "tooltipMaxWidth", "tooltipContentClass"] }] }); }
|
|
42
60
|
}
|
|
43
61
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsRadioButtonComponent, decorators: [{
|
|
44
62
|
type: Component,
|
|
45
|
-
args: [{ standalone: true, imports: [CommonModule, CpsTooltipDirective], selector: 'cps-radio-button', template: "<div\n *ngIf=\"option.tooltip\"\n class=\"cps-radio-group-content-button\"\n [cpsTooltip]=\"option.tooltip\"\n tooltipCloseDelay=\"0\"\n tooltipPosition=\"bottom\">\n <ng-container\n *ngTemplateOutlet=\"\n optionRadioTemplate;\n context: {\n option: option\n }\n \"></ng-container>\n</div>\n<div *ngIf=\"!option?.tooltip\" class=\"cps-radio-group-content-button\">\n <ng-container\n *ngTemplateOutlet=\"\n optionRadioTemplate;\n context: {\n option: option\n }\n \"></ng-container>\n</div>\n\n<ng-template #optionRadioTemplate let-option=\"option\">\n <input\n [id]=\"inputId\"\n type=\"radio\"\n [disabled]=\"option.disabled || groupDisabled\"\n [value]=\"option.value\"\n [checked]=\"checked\"\n (change)=\"updateValue($event)\" />\n <div #contentRef class=\"content\">\n <ng-content></ng-content>\n </div>\n <label\n *ngIf=\"!contentRef.innerHTML.trim()\"\n [for]=\"inputId\"\n class=\"cps-radio-group-content-button-label\"\n [ngStyle]=\"{\n cursor: option.disabled || groupDisabled ? 'default' : 'pointer'\n }\"\n >{{ option.label }}\n </label>\n</ng-template>\n", styles: [":host .cps-radio-group-content-button{display:grid;grid-template-columns:1rem auto;align-items:center;gap:.75rem}:host .cps-radio-group-content-button-label{font-size:1rem;color:var(--cps-color-text-dark);font-style:normal;font-weight:400;line-height:1rem}:host .cps-radio-group-content-button input[type=radio]{-webkit-appearance:none;appearance:none;background-color:transparent;margin:0;cursor:pointer;font:inherit;color:var(--cps-color-text-mild);width:1.25rem;height:1.25rem;border:.15rem solid currentColor;border-radius:50%;display:grid;place-content:center}:host .cps-radio-group-content-button input[type=radio]:hover,:host .cps-radio-group-content-button input[type=radio]:checked{color:var(--cps-color-calm)}:host .cps-radio-group-content-button input[type=radio]:disabled{color:var(--cps-color-text-lightest);cursor:default}:host .cps-radio-group-content-button input[type=radio]:before{content:\"\";width:1.25rem;height:1.25rem;border-radius:50%;transform:scale(0);transition:.12s transform ease-in-out;box-shadow:inset 1rem 1rem var(--cps-color-calm);background-color:CanvasText}:host .cps-radio-group-content-button input[type=radio][disabled]:before{box-shadow:inset 1rem 1rem var(--cps-color-text-lightest)}:host .cps-radio-group-content-button input[type=radio]:disabled+.cps-radio-group-content-button-label{color:var(--cps-color-text-light)}:host .cps-radio-group-content-button input[type=radio]:checked:before{transform:scale(.5)}:host .cps-radio-group-content-button .cps-radio-group-content-button-label{-webkit-user-select:none;user-select:none}:host .cps-radio-group-content-button .content:empty{display:none}\n"] }]
|
|
63
|
+
args: [{ standalone: true, imports: [CommonModule, CpsTooltipDirective], selector: 'cps-radio-button', template: "<div\n *ngIf=\"option.tooltip\"\n class=\"cps-radio-group-content-button\"\n [cpsTooltip]=\"option.tooltip\"\n tooltipCloseDelay=\"0\"\n tooltipPosition=\"bottom\">\n <ng-container\n *ngTemplateOutlet=\"\n optionRadioTemplate;\n context: {\n option: option\n }\n \"></ng-container>\n</div>\n<div *ngIf=\"!option?.tooltip\" class=\"cps-radio-group-content-button\">\n <ng-container\n *ngTemplateOutlet=\"\n optionRadioTemplate;\n context: {\n option: option\n }\n \"></ng-container>\n</div>\n\n<ng-template #optionRadioTemplate let-option=\"option\">\n <input\n [id]=\"inputId\"\n type=\"radio\"\n [disabled]=\"option.disabled || groupDisabled\"\n [value]=\"option.value\"\n [checked]=\"checked\"\n (change)=\"updateValue($event)\"\n (focus)=\"onFocus()\"\n (blur)=\"onBlur()\" />\n <div #contentRef class=\"content\">\n <ng-content></ng-content>\n </div>\n <label\n *ngIf=\"!contentRef.innerHTML.trim()\"\n [for]=\"inputId\"\n class=\"cps-radio-group-content-button-label\"\n [ngStyle]=\"{\n cursor: option.disabled || groupDisabled ? 'default' : 'pointer'\n }\"\n >{{ option.label }}\n </label>\n</ng-template>\n", styles: [":host .cps-radio-group-content-button{display:grid;grid-template-columns:1rem auto;align-items:center;gap:.75rem}:host .cps-radio-group-content-button-label{font-size:1rem;color:var(--cps-color-text-dark);font-style:normal;font-weight:400;line-height:1rem}:host .cps-radio-group-content-button input[type=radio]{-webkit-appearance:none;appearance:none;background-color:transparent;margin:0;cursor:pointer;font:inherit;color:var(--cps-color-text-mild);width:1.25rem;height:1.25rem;border:.15rem solid currentColor;border-radius:50%;display:grid;place-content:center}:host .cps-radio-group-content-button input[type=radio]:hover,:host .cps-radio-group-content-button input[type=radio]:checked{color:var(--cps-color-calm)}:host .cps-radio-group-content-button input[type=radio]:disabled{color:var(--cps-color-text-lightest);cursor:default}:host .cps-radio-group-content-button input[type=radio]:before{content:\"\";width:1.25rem;height:1.25rem;border-radius:50%;transform:scale(0);transition:.12s transform ease-in-out;box-shadow:inset 1rem 1rem var(--cps-color-calm);background-color:CanvasText}:host .cps-radio-group-content-button input[type=radio][disabled]:before{box-shadow:inset 1rem 1rem var(--cps-color-text-lightest)}:host .cps-radio-group-content-button input[type=radio]:disabled+.cps-radio-group-content-button-label{color:var(--cps-color-text-light)}:host .cps-radio-group-content-button input[type=radio]:checked:before{transform:scale(.5)}:host .cps-radio-group-content-button .cps-radio-group-content-button-label{-webkit-user-select:none;user-select:none}:host .cps-radio-group-content-button .content:empty{display:none}\n"] }]
|
|
46
64
|
}], propDecorators: { option: [{
|
|
47
65
|
type: Input
|
|
48
66
|
}], checked: [{
|
|
@@ -51,5 +69,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
|
51
69
|
type: Input
|
|
52
70
|
}], updateValueEvent: [{
|
|
53
71
|
type: Output
|
|
72
|
+
}], blurred: [{
|
|
73
|
+
type: Output
|
|
74
|
+
}], focused: [{
|
|
75
|
+
type: Output
|
|
54
76
|
}] } });
|
|
55
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
77
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3BzLXJhZGlvLWJ1dHRvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jcHMtdWkta2l0L3NyYy9saWIvY29tcG9uZW50cy9jcHMtcmFkaW8tZ3JvdXAvY3BzLXJhZGlvLWJ1dHRvbi9jcHMtcmFkaW8tYnV0dG9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Nwcy11aS1raXQvc3JjL2xpYi9jb21wb25lbnRzL2Nwcy1yYWRpby1ncm91cC9jcHMtcmFkaW8tYnV0dG9uL2Nwcy1yYWRpby1idXR0b24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV2RSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sdURBQXVELENBQUM7OztBQUU1RixJQUFJLFlBQVksR0FBRyxDQUFDLENBQUM7QUFFckI7OztHQUdHO0FBUUgsTUFBTSxPQUFPLHVCQUF1QjtJQVBwQztRQVFVLGNBQVMsR0FBRyxvQkFBb0IsRUFBRSxZQUFZLEVBQUUsQ0FBQztRQVF6RDs7O1dBR0c7UUFDTSxZQUFPLEdBQUcsS0FBSyxDQUFDO1FBRXpCOzs7V0FHRztRQUNNLGtCQUFhLEdBQUcsS0FBSyxDQUFDO1FBRS9COzs7O1dBSUc7UUFDTyxxQkFBZ0IsR0FBRyxJQUFJLFlBQVksRUFBUyxDQUFDO1FBRXZEOzs7O1dBSUc7UUFDTyxZQUFPLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUV2Qzs7OztXQUlHO1FBQ08sWUFBTyxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7S0FtQnhDO0lBakJDLElBQUksT0FBTztRQUNULE9BQU8sR0FBRyxJQUFJLENBQUMsU0FBUyxRQUFRLENBQUM7SUFDbkMsQ0FBQztJQUVELFdBQVcsQ0FBQyxLQUFZO1FBQ3RCLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUN2QixJQUFJLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUTtZQUFFLE9BQU87UUFDakMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2hELENBQUM7SUFFRCxNQUFNO1FBQ0osSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUN0QixDQUFDO0lBRUQsT0FBTztRQUNMLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDdEIsQ0FBQzs4R0ExRFUsdUJBQXVCO2tHQUF2Qix1QkFBdUIseVBDbEJwQyxpdENBK0NBLCtwRERsQ1ksWUFBWSwrWEFBRSxtQkFBbUI7OzJGQUtoQyx1QkFBdUI7a0JBUG5DLFNBQVM7aUNBQ0ksSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLG1CQUFtQixDQUFDLFlBQ2xDLGtCQUFrQjs4QkFXbkIsTUFBTTtzQkFBZCxLQUFLO2dCQU1HLE9BQU87c0JBQWYsS0FBSztnQkFNRyxhQUFhO3NCQUFyQixLQUFLO2dCQU9JLGdCQUFnQjtzQkFBekIsTUFBTTtnQkFPRyxPQUFPO3NCQUFoQixNQUFNO2dCQU9HLE9BQU87c0JBQWhCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ3BzUmFkaW9PcHRpb24gfSBmcm9tICcuLi9jcHMtcmFkaW8tZ3JvdXAuY29tcG9uZW50JztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDcHNUb29sdGlwRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vLi4vZGlyZWN0aXZlcy9jcHMtdG9vbHRpcC9jcHMtdG9vbHRpcC5kaXJlY3RpdmUnO1xuXG5sZXQgbmV4dFVuaXF1ZUlkID0gMDtcblxuLyoqXG4gKiBDcHNSYWRpb0J1dHRvbkNvbXBvbmVudCBpcyBhbiBpbnRlcm5hbCByYWRpbyBidXR0b24gY29tcG9uZW50LlxuICogQGdyb3VwIENvbXBvbmVudHNcbiAqL1xuQENvbXBvbmVudCh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIENwc1Rvb2x0aXBEaXJlY3RpdmVdLFxuICBzZWxlY3RvcjogJ2Nwcy1yYWRpby1idXR0b24nLFxuICB0ZW1wbGF0ZVVybDogJy4vY3BzLXJhZGlvLWJ1dHRvbi5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2Nwcy1yYWRpby1idXR0b24uY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBDcHNSYWRpb0J1dHRvbkNvbXBvbmVudCB7XG4gIHByaXZhdGUgX3VuaXF1ZUlkID0gYGNwcy1yYWRpby1idXR0b24tJHsrK25leHRVbmlxdWVJZH1gO1xuXG4gIC8qKlxuICAgKiBBbiBvcHRpb24uXG4gICAqIEBncm91cCBQcm9wc1xuICAgKi9cbiAgQElucHV0KCkgb3B0aW9uITogQ3BzUmFkaW9PcHRpb247XG5cbiAgLyoqXG4gICAqIERldGVybWluZXMgd2hldGhlciB0aGUgcmFkaW8gYnV0dG9uIGlzIGNoZWNrZWQuXG4gICAqIEBncm91cCBQcm9wc1xuICAgKi9cbiAgQElucHV0KCkgY2hlY2tlZCA9IGZhbHNlO1xuXG4gIC8qKlxuICAgKiBEZXRlcm1pbmVzIHdoZXRoZXIgdGhlIHJhZGlvIGJ1dHRvbiBpcyBkaXNhYmxlZC5cbiAgICogQGdyb3VwIFByb3BzXG4gICAqL1xuICBASW5wdXQoKSBncm91cERpc2FibGVkID0gZmFsc2U7XG5cbiAgLyoqXG4gICAqIENhbGxiYWNrIHRvIGludm9rZSBvbiB2YWx1ZSB1cGRhdGUuXG4gICAqIEBwYXJhbSB7RXZlbnR9IGV2ZW50IC0gQ3VzdG9tIHVwZGF0ZSB2YWx1ZSBldmVudC5cbiAgICogQGdyb3VwIEVtaXRzXG4gICAqL1xuICBAT3V0cHV0KCkgdXBkYXRlVmFsdWVFdmVudCA9IG5ldyBFdmVudEVtaXR0ZXI8RXZlbnQ+KCk7XG5cbiAgLyoqXG4gICAqIENhbGxiYWNrIHRvIGludm9rZSB3aGVuIHRoZSByYWRpbyBidXR0b24gbG9zZXMgZm9jdXMuXG4gICAqIEBwYXJhbSB7YW55fVxuICAgKiBAZ3JvdXAgRW1pdHNcbiAgICovXG4gIEBPdXRwdXQoKSBibHVycmVkID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gIC8qKlxuICAgKiBDYWxsYmFjayB0byBpbnZva2Ugd2hlbiB0aGUgcmFkaW8gYnV0dG9uIHJlY2VpdmVzIGZvY3VzLlxuICAgKiBAcGFyYW0ge2FueX1cbiAgICogQGdyb3VwIEVtaXRzXG4gICAqL1xuICBAT3V0cHV0KCkgZm9jdXNlZCA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcblxuICBnZXQgaW5wdXRJZCgpOiBzdHJpbmcge1xuICAgIHJldHVybiBgJHt0aGlzLl91bmlxdWVJZH0taW5wdXRgO1xuICB9XG5cbiAgdXBkYXRlVmFsdWUoZXZlbnQ6IEV2ZW50KTogdm9pZCB7XG4gICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbiAgICBpZiAodGhpcy5vcHRpb24uZGlzYWJsZWQpIHJldHVybjtcbiAgICB0aGlzLnVwZGF0ZVZhbHVlRXZlbnQuZW1pdCh0aGlzLm9wdGlvbi52YWx1ZSk7XG4gIH1cblxuICBvbkJsdXIoKSB7XG4gICAgdGhpcy5ibHVycmVkLmVtaXQoKTtcbiAgfVxuXG4gIG9uRm9jdXMoKSB7XG4gICAgdGhpcy5mb2N1c2VkLmVtaXQoKTtcbiAgfVxufVxuIiwiPGRpdlxuICAqbmdJZj1cIm9wdGlvbi50b29sdGlwXCJcbiAgY2xhc3M9XCJjcHMtcmFkaW8tZ3JvdXAtY29udGVudC1idXR0b25cIlxuICBbY3BzVG9vbHRpcF09XCJvcHRpb24udG9vbHRpcFwiXG4gIHRvb2x0aXBDbG9zZURlbGF5PVwiMFwiXG4gIHRvb2x0aXBQb3NpdGlvbj1cImJvdHRvbVwiPlxuICA8bmctY29udGFpbmVyXG4gICAgKm5nVGVtcGxhdGVPdXRsZXQ9XCJcbiAgICAgIG9wdGlvblJhZGlvVGVtcGxhdGU7XG4gICAgICBjb250ZXh0OiB7XG4gICAgICAgIG9wdGlvbjogb3B0aW9uXG4gICAgICB9XG4gICAgXCI+PC9uZy1jb250YWluZXI+XG48L2Rpdj5cbjxkaXYgKm5nSWY9XCIhb3B0aW9uPy50b29sdGlwXCIgY2xhc3M9XCJjcHMtcmFkaW8tZ3JvdXAtY29udGVudC1idXR0b25cIj5cbiAgPG5nLWNvbnRhaW5lclxuICAgICpuZ1RlbXBsYXRlT3V0bGV0PVwiXG4gICAgICBvcHRpb25SYWRpb1RlbXBsYXRlO1xuICAgICAgY29udGV4dDoge1xuICAgICAgICBvcHRpb246IG9wdGlvblxuICAgICAgfVxuICAgIFwiPjwvbmctY29udGFpbmVyPlxuPC9kaXY+XG5cbjxuZy10ZW1wbGF0ZSAjb3B0aW9uUmFkaW9UZW1wbGF0ZSBsZXQtb3B0aW9uPVwib3B0aW9uXCI+XG4gIDxpbnB1dFxuICAgIFtpZF09XCJpbnB1dElkXCJcbiAgICB0eXBlPVwicmFkaW9cIlxuICAgIFtkaXNhYmxlZF09XCJvcHRpb24uZGlzYWJsZWQgfHwgZ3JvdXBEaXNhYmxlZFwiXG4gICAgW3ZhbHVlXT1cIm9wdGlvbi52YWx1ZVwiXG4gICAgW2NoZWNrZWRdPVwiY2hlY2tlZFwiXG4gICAgKGNoYW5nZSk9XCJ1cGRhdGVWYWx1ZSgkZXZlbnQpXCJcbiAgICAoZm9jdXMpPVwib25Gb2N1cygpXCJcbiAgICAoYmx1cik9XCJvbkJsdXIoKVwiIC8+XG4gIDxkaXYgI2NvbnRlbnRSZWYgY2xhc3M9XCJjb250ZW50XCI+XG4gICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICA8L2Rpdj5cbiAgPGxhYmVsXG4gICAgKm5nSWY9XCIhY29udGVudFJlZi5pbm5lckhUTUwudHJpbSgpXCJcbiAgICBbZm9yXT1cImlucHV0SWRcIlxuICAgIGNsYXNzPVwiY3BzLXJhZGlvLWdyb3VwLWNvbnRlbnQtYnV0dG9uLWxhYmVsXCJcbiAgICBbbmdTdHlsZV09XCJ7XG4gICAgICBjdXJzb3I6IG9wdGlvbi5kaXNhYmxlZCB8fCBncm91cERpc2FibGVkID8gJ2RlZmF1bHQnIDogJ3BvaW50ZXInXG4gICAgfVwiXG4gICAgPnt7IG9wdGlvbi5sYWJlbCB9fVxuICA8L2xhYmVsPlxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==
|
|
@@ -71,13 +71,36 @@ export class CpsRadioGroupComponent {
|
|
|
71
71
|
* @group Props
|
|
72
72
|
*/
|
|
73
73
|
this.infoTooltipPosition = 'top';
|
|
74
|
+
/**
|
|
75
|
+
* Bottom hint text for the radio group.
|
|
76
|
+
* @group Props
|
|
77
|
+
*/
|
|
78
|
+
this.hint = '';
|
|
79
|
+
/**
|
|
80
|
+
* Hides hint and validation errors.
|
|
81
|
+
* @group Props
|
|
82
|
+
*/
|
|
83
|
+
this.hideDetails = false;
|
|
74
84
|
/**
|
|
75
85
|
* Callback to invoke on value change.
|
|
76
86
|
* @param {boolean} boolean - value changed.
|
|
77
87
|
* @group Emits
|
|
78
88
|
*/
|
|
79
89
|
this.valueChanged = new EventEmitter();
|
|
90
|
+
/**
|
|
91
|
+
* Callback to invoke when the radio group loses focus.
|
|
92
|
+
* @param {any}
|
|
93
|
+
* @group Emits
|
|
94
|
+
*/
|
|
95
|
+
this.blurred = new EventEmitter();
|
|
96
|
+
/**
|
|
97
|
+
* Callback to invoke when the radio group receives focus.
|
|
98
|
+
* @param {any}
|
|
99
|
+
* @group Emits
|
|
100
|
+
*/
|
|
101
|
+
this.focused = new EventEmitter();
|
|
80
102
|
this._value = undefined;
|
|
103
|
+
this.error = '';
|
|
81
104
|
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
82
105
|
this.onChange = (event) => { };
|
|
83
106
|
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
@@ -86,6 +109,14 @@ export class CpsRadioGroupComponent {
|
|
|
86
109
|
this._control.valueAccessor = this;
|
|
87
110
|
}
|
|
88
111
|
}
|
|
112
|
+
ngOnInit() {
|
|
113
|
+
this._statusChangesSubscription = this._control?.statusChanges?.subscribe(() => {
|
|
114
|
+
this._checkErrors();
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
ngOnDestroy() {
|
|
118
|
+
this._statusChangesSubscription?.unsubscribe();
|
|
119
|
+
}
|
|
89
120
|
registerOnChange(fn) {
|
|
90
121
|
this.onChange = fn;
|
|
91
122
|
}
|
|
@@ -107,13 +138,41 @@ export class CpsRadioGroupComponent {
|
|
|
107
138
|
}
|
|
108
139
|
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
109
140
|
setDisabledState(disabled) { }
|
|
141
|
+
onBlur() {
|
|
142
|
+
this._control?.control?.markAsTouched();
|
|
143
|
+
this._checkErrors();
|
|
144
|
+
this.blurred.emit();
|
|
145
|
+
}
|
|
146
|
+
onFocus() {
|
|
147
|
+
this.focused.emit();
|
|
148
|
+
}
|
|
149
|
+
_checkErrors() {
|
|
150
|
+
if (!this._control)
|
|
151
|
+
return;
|
|
152
|
+
const errors = this._control?.errors;
|
|
153
|
+
if (!this._control?.control?.touched || !errors) {
|
|
154
|
+
this.error = '';
|
|
155
|
+
return;
|
|
156
|
+
}
|
|
157
|
+
if ('required' in errors) {
|
|
158
|
+
this.error = 'Field is required';
|
|
159
|
+
return;
|
|
160
|
+
}
|
|
161
|
+
const errArr = Object.values(errors);
|
|
162
|
+
if (errArr.length < 1) {
|
|
163
|
+
this.error = '';
|
|
164
|
+
return;
|
|
165
|
+
}
|
|
166
|
+
const message = errArr.find((msg) => typeof msg === 'string');
|
|
167
|
+
this.error = message || 'Unknown error';
|
|
168
|
+
}
|
|
110
169
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsRadioGroupComponent, deps: [{ token: i1.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
111
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: CpsRadioGroupComponent, isStandalone: true, selector: "cps-radio-group", inputs: { options: "options", groupLabel: "groupLabel", vertical: "vertical", disabled: "disabled", infoTooltip: "infoTooltip", infoTooltipClass: "infoTooltipClass", infoTooltipMaxWidth: "infoTooltipMaxWidth", infoTooltipPersistent: "infoTooltipPersistent", infoTooltipPosition: "infoTooltipPosition", value: "value" }, outputs: { valueChanged: "valueChanged" }, providers: [
|
|
170
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: CpsRadioGroupComponent, isStandalone: true, selector: "cps-radio-group", inputs: { options: "options", groupLabel: "groupLabel", vertical: "vertical", disabled: "disabled", infoTooltip: "infoTooltip", infoTooltipClass: "infoTooltipClass", infoTooltipMaxWidth: "infoTooltipMaxWidth", infoTooltipPersistent: "infoTooltipPersistent", infoTooltipPosition: "infoTooltipPosition", hint: "hint", hideDetails: "hideDetails", value: "value" }, outputs: { valueChanged: "valueChanged", blurred: "blurred", focused: "focused" }, providers: [
|
|
112
171
|
{
|
|
113
172
|
provide: CPS_RADIO_GROUP,
|
|
114
173
|
useExisting: CpsRadioGroupComponent
|
|
115
174
|
}
|
|
116
|
-
], ngImport: i0, template: "<div class=\"cps-radio-group\">\n <div class=\"cps-radio-group-label\" *ngIf=\"groupLabel\">\n <span>{{ groupLabel }}</span>\n <cps-info-circle\n *ngIf=\"infoTooltip\"\n class=\"cps-radio-group-label-info-circle\"\n size=\"xsmall\"\n [tooltipPosition]=\"infoTooltipPosition\"\n [tooltipContentClass]=\"infoTooltipClass\"\n [tooltipMaxWidth]=\"infoTooltipMaxWidth\"\n [tooltipPersistent]=\"infoTooltipPersistent\"\n [tooltipText]=\"infoTooltip\">\n </cps-info-circle>\n </div>\n\n <div\n #contentRef\n class=\"cps-radio-group-content\"\n [ngClass]=\"\n vertical\n ? 'cps-radio-group-content-vertical'\n : 'cps-radio-group-content-horizontal'\n \">\n <ng-content></ng-content>\n </div>\n\n <div\n *ngIf=\"!contentRef.innerHTML.trim()\"\n class=\"cps-radio-group-content\"\n [ngClass]=\"\n vertical\n ? 'cps-radio-group-content-vertical'\n : 'cps-radio-group-content-horizontal'\n \">\n <cps-radio-button\n *ngFor=\"let option of options\"\n [option]=\"option\"\n [checked]=\"option.value === value\"\n [groupDisabled]=\"disabled\"\n (updateValueEvent)=\"updateValueEvent($event)\">\n </cps-radio-button>\n </div>\n</div>\n", styles: [":host{width:fit-content;display:inline-block}:host .cps-radio-group{font-family:Source Sans Pro,sans-serif}:host .cps-radio-group-label{font-style:normal;font-weight:700;font-size:1rem;color:var(--cps-color-text-dark);margin-bottom:.75rem;align-items:center;display:inline-flex;cursor:default}:host .cps-radio-group-label .cps-radio-group-label-info-circle{margin-left:8px}:host .cps-radio-group-label .cps-radio-group-label-info-circle ::ng-deep cps-icon i{width:14px;height:14px}:host .cps-radio-group-content{margin-left:.5rem;gap:1.25rem}:host .cps-radio-group-content-vertical{display:grid;grid-auto-rows:1fr}:host .cps-radio-group-content-horizontal{display:flex;flex-direction:row;flex-wrap:wrap}:host .cps-radio-group-content .content:empty{display:none}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: CpsInfoCircleComponent, selector: "cps-info-circle", inputs: ["size", "tooltipText", "tooltipPosition", "tooltipContentClass", "tooltipMaxWidth", "tooltipPersistent"] }, { kind: "component", type: CpsRadioButtonComponent, selector: "cps-radio-button", inputs: ["option", "checked", "groupDisabled"], outputs: ["updateValueEvent"] }] }); }
|
|
175
|
+
], ngImport: i0, template: "<div class=\"cps-radio-group\">\n <div class=\"cps-radio-group-label\" *ngIf=\"groupLabel\">\n <span>{{ groupLabel }}</span>\n <cps-info-circle\n *ngIf=\"infoTooltip\"\n class=\"cps-radio-group-label-info-circle\"\n size=\"xsmall\"\n [tooltipPosition]=\"infoTooltipPosition\"\n [tooltipContentClass]=\"infoTooltipClass\"\n [tooltipMaxWidth]=\"infoTooltipMaxWidth\"\n [tooltipPersistent]=\"infoTooltipPersistent\"\n [tooltipText]=\"infoTooltip\">\n </cps-info-circle>\n </div>\n\n <div\n #contentRef\n class=\"cps-radio-group-content\"\n [ngClass]=\"\n vertical\n ? 'cps-radio-group-content-vertical'\n : 'cps-radio-group-content-horizontal'\n \">\n <ng-content></ng-content>\n </div>\n\n <div\n *ngIf=\"!contentRef.innerHTML.trim()\"\n class=\"cps-radio-group-content\"\n [ngClass]=\"\n vertical\n ? 'cps-radio-group-content-vertical'\n : 'cps-radio-group-content-horizontal'\n \">\n <cps-radio-button\n *ngFor=\"let option of options\"\n [option]=\"option\"\n [checked]=\"option.value === value\"\n [groupDisabled]=\"disabled\"\n (blurred)=\"onBlur()\"\n (focused)=\"onFocus()\"\n (updateValueEvent)=\"updateValueEvent($event)\">\n </cps-radio-button>\n </div>\n <div *ngIf=\"!error && !hideDetails\" class=\"cps-radio-hint\">\n {{ hint }}\n </div>\n <div *ngIf=\"error && !hideDetails\" class=\"cps-radio-error\">\n {{ error }}\n </div>\n</div>\n", styles: [":host{width:fit-content;display:inline-block}:host .cps-radio-group{font-family:Source Sans Pro,sans-serif}:host .cps-radio-group-label{font-style:normal;font-weight:700;font-size:1rem;color:var(--cps-color-text-dark);margin-bottom:.75rem;align-items:center;display:inline-flex;cursor:default}:host .cps-radio-group-label .cps-radio-group-label-info-circle{margin-left:8px}:host .cps-radio-group-label .cps-radio-group-label-info-circle ::ng-deep cps-icon i{width:14px;height:14px}:host .cps-radio-group-content{margin-left:.5rem;gap:1.25rem}:host .cps-radio-group-content-vertical{display:grid;grid-auto-rows:1fr}:host .cps-radio-group-content-horizontal{display:flex;flex-direction:row;flex-wrap:wrap}:host .cps-radio-group-content .content:empty{display:none}:host .cps-radio-group .cps-radio-hint{margin-top:4px;color:var(--cps-color-text-mild);font-size:.75rem;min-height:1.125rem;line-height:1.125rem;cursor:default}:host .cps-radio-group .cps-radio-error{margin-top:4px;color:var(--cps-color-error);font-weight:700;font-size:.75rem;min-height:1.125rem;line-height:1.125rem;cursor:default}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: CpsInfoCircleComponent, selector: "cps-info-circle", inputs: ["size", "tooltipText", "tooltipPosition", "tooltipContentClass", "tooltipMaxWidth", "tooltipPersistent"] }, { kind: "component", type: CpsRadioButtonComponent, selector: "cps-radio-button", inputs: ["option", "checked", "groupDisabled"], outputs: ["updateValueEvent", "blurred", "focused"] }] }); }
|
|
117
176
|
}
|
|
118
177
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsRadioGroupComponent, decorators: [{
|
|
119
178
|
type: Component,
|
|
@@ -127,7 +186,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
|
127
186
|
provide: CPS_RADIO_GROUP,
|
|
128
187
|
useExisting: CpsRadioGroupComponent
|
|
129
188
|
}
|
|
130
|
-
], template: "<div class=\"cps-radio-group\">\n <div class=\"cps-radio-group-label\" *ngIf=\"groupLabel\">\n <span>{{ groupLabel }}</span>\n <cps-info-circle\n *ngIf=\"infoTooltip\"\n class=\"cps-radio-group-label-info-circle\"\n size=\"xsmall\"\n [tooltipPosition]=\"infoTooltipPosition\"\n [tooltipContentClass]=\"infoTooltipClass\"\n [tooltipMaxWidth]=\"infoTooltipMaxWidth\"\n [tooltipPersistent]=\"infoTooltipPersistent\"\n [tooltipText]=\"infoTooltip\">\n </cps-info-circle>\n </div>\n\n <div\n #contentRef\n class=\"cps-radio-group-content\"\n [ngClass]=\"\n vertical\n ? 'cps-radio-group-content-vertical'\n : 'cps-radio-group-content-horizontal'\n \">\n <ng-content></ng-content>\n </div>\n\n <div\n *ngIf=\"!contentRef.innerHTML.trim()\"\n class=\"cps-radio-group-content\"\n [ngClass]=\"\n vertical\n ? 'cps-radio-group-content-vertical'\n : 'cps-radio-group-content-horizontal'\n \">\n <cps-radio-button\n *ngFor=\"let option of options\"\n [option]=\"option\"\n [checked]=\"option.value === value\"\n [groupDisabled]=\"disabled\"\n (updateValueEvent)=\"updateValueEvent($event)\">\n </cps-radio-button>\n </div>\n</div>\n", styles: [":host{width:fit-content;display:inline-block}:host .cps-radio-group{font-family:Source Sans Pro,sans-serif}:host .cps-radio-group-label{font-style:normal;font-weight:700;font-size:1rem;color:var(--cps-color-text-dark);margin-bottom:.75rem;align-items:center;display:inline-flex;cursor:default}:host .cps-radio-group-label .cps-radio-group-label-info-circle{margin-left:8px}:host .cps-radio-group-label .cps-radio-group-label-info-circle ::ng-deep cps-icon i{width:14px;height:14px}:host .cps-radio-group-content{margin-left:.5rem;gap:1.25rem}:host .cps-radio-group-content-vertical{display:grid;grid-auto-rows:1fr}:host .cps-radio-group-content-horizontal{display:flex;flex-direction:row;flex-wrap:wrap}:host .cps-radio-group-content .content:empty{display:none}\n"] }]
|
|
189
|
+
], template: "<div class=\"cps-radio-group\">\n <div class=\"cps-radio-group-label\" *ngIf=\"groupLabel\">\n <span>{{ groupLabel }}</span>\n <cps-info-circle\n *ngIf=\"infoTooltip\"\n class=\"cps-radio-group-label-info-circle\"\n size=\"xsmall\"\n [tooltipPosition]=\"infoTooltipPosition\"\n [tooltipContentClass]=\"infoTooltipClass\"\n [tooltipMaxWidth]=\"infoTooltipMaxWidth\"\n [tooltipPersistent]=\"infoTooltipPersistent\"\n [tooltipText]=\"infoTooltip\">\n </cps-info-circle>\n </div>\n\n <div\n #contentRef\n class=\"cps-radio-group-content\"\n [ngClass]=\"\n vertical\n ? 'cps-radio-group-content-vertical'\n : 'cps-radio-group-content-horizontal'\n \">\n <ng-content></ng-content>\n </div>\n\n <div\n *ngIf=\"!contentRef.innerHTML.trim()\"\n class=\"cps-radio-group-content\"\n [ngClass]=\"\n vertical\n ? 'cps-radio-group-content-vertical'\n : 'cps-radio-group-content-horizontal'\n \">\n <cps-radio-button\n *ngFor=\"let option of options\"\n [option]=\"option\"\n [checked]=\"option.value === value\"\n [groupDisabled]=\"disabled\"\n (blurred)=\"onBlur()\"\n (focused)=\"onFocus()\"\n (updateValueEvent)=\"updateValueEvent($event)\">\n </cps-radio-button>\n </div>\n <div *ngIf=\"!error && !hideDetails\" class=\"cps-radio-hint\">\n {{ hint }}\n </div>\n <div *ngIf=\"error && !hideDetails\" class=\"cps-radio-error\">\n {{ error }}\n </div>\n</div>\n", styles: [":host{width:fit-content;display:inline-block}:host .cps-radio-group{font-family:Source Sans Pro,sans-serif}:host .cps-radio-group-label{font-style:normal;font-weight:700;font-size:1rem;color:var(--cps-color-text-dark);margin-bottom:.75rem;align-items:center;display:inline-flex;cursor:default}:host .cps-radio-group-label .cps-radio-group-label-info-circle{margin-left:8px}:host .cps-radio-group-label .cps-radio-group-label-info-circle ::ng-deep cps-icon i{width:14px;height:14px}:host .cps-radio-group-content{margin-left:.5rem;gap:1.25rem}:host .cps-radio-group-content-vertical{display:grid;grid-auto-rows:1fr}:host .cps-radio-group-content-horizontal{display:flex;flex-direction:row;flex-wrap:wrap}:host .cps-radio-group-content .content:empty{display:none}:host .cps-radio-group .cps-radio-hint{margin-top:4px;color:var(--cps-color-text-mild);font-size:.75rem;min-height:1.125rem;line-height:1.125rem;cursor:default}:host .cps-radio-group .cps-radio-error{margin-top:4px;color:var(--cps-color-error);font-weight:700;font-size:.75rem;min-height:1.125rem;line-height:1.125rem;cursor:default}\n"] }]
|
|
131
190
|
}], ctorParameters: () => [{ type: i1.NgControl, decorators: [{
|
|
132
191
|
type: Self
|
|
133
192
|
}, {
|
|
@@ -150,9 +209,17 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImpor
|
|
|
150
209
|
type: Input
|
|
151
210
|
}], infoTooltipPosition: [{
|
|
152
211
|
type: Input
|
|
212
|
+
}], hint: [{
|
|
213
|
+
type: Input
|
|
214
|
+
}], hideDetails: [{
|
|
215
|
+
type: Input
|
|
153
216
|
}], value: [{
|
|
154
217
|
type: Input
|
|
155
218
|
}], valueChanged: [{
|
|
156
219
|
type: Output
|
|
220
|
+
}], blurred: [{
|
|
221
|
+
type: Output
|
|
222
|
+
}], focused: [{
|
|
223
|
+
type: Output
|
|
157
224
|
}] } });
|
|
158
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-radio-group.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-radio-group/cps-radio-group.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-radio-group/cps-radio-group.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-use-before-define */\nimport { CommonModule } from '@angular/common';\nimport {\n  Component,\n  EventEmitter,\n  InjectionToken,\n  Input,\n  Optional,\n  Output,\n  Self\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { CpsInfoCircleComponent } from '../cps-info-circle/cps-info-circle.component';\nimport {\n  CpsTooltipDirective,\n  CpsTooltipPosition\n} from '../../directives/cps-tooltip/cps-tooltip.directive';\nimport { CpsRadioButtonComponent } from './cps-radio-button/cps-radio-button.component';\n\nexport type CpsRadioOption = {\n  value: any;\n  label?: string;\n  disabled?: boolean;\n  tooltip?: string;\n};\n\nexport const CPS_RADIO_GROUP = new InjectionToken<CpsRadioGroupComponent>(\n  'CpsRadioGroupComponent'\n);\n\n/**\n * CpsRadioGroupComponent is a radio buttons group.\n * @group Components\n */\n@Component({\n  standalone: true,\n  imports: [\n    CommonModule,\n    CpsInfoCircleComponent,\n    CpsTooltipDirective,\n    CpsRadioButtonComponent\n  ],\n  selector: 'cps-radio-group',\n  templateUrl: './cps-radio-group.component.html',\n  styleUrls: ['./cps-radio-group.component.scss'],\n  providers: [\n    {\n      provide: CPS_RADIO_GROUP,\n      useExisting: CpsRadioGroupComponent\n    }\n  ]\n})\nexport class CpsRadioGroupComponent implements ControlValueAccessor {\n  /**\n   * An array of options.\n   * @group Props\n   */\n  @Input() options: CpsRadioOption[] = [];\n\n  /**\n   * Label of the radio group.\n   * @group Props\n   */\n  @Input() groupLabel = '';\n\n  /**\n   * Determines whether the radio group should be vertical.\n   * @group Props\n   */\n  @Input() vertical = false;\n\n  /**\n   * Determines whether the radio group is disabled.\n   * @group Props\n   */\n  @Input() disabled = false;\n\n  /**\n   * When it is not an empty string, an info icon is displayed to show text for more info.\n   * @group Props\n   */\n  @Input() infoTooltip = '';\n\n  /**\n   * InfoTooltip class for styling.\n   * @group Props\n   */\n  @Input() infoTooltipClass = 'cps-tooltip-content';\n\n  /**\n   * Size of infoTooltip, of type number denoting pixels or string.\n   * @group Props\n   */\n  @Input() infoTooltipMaxWidth: number | string = '100%';\n\n  /**\n   * Determines whether the infoTooltip is persistent.\n   * @group Props\n   */\n  @Input() infoTooltipPersistent = false;\n\n  /**\n   * Position of infoTooltip, it can be \"top\", \"bottom\", \"left\" or \"right\".\n   * @group Props\n   */\n  @Input() infoTooltipPosition: CpsTooltipPosition = 'top';\n\n  /**\n   * Value of the radio group.\n   * @group Props\n   */\n  @Input() set value(value: any) {\n    this._value = value;\n    this.onChange(value);\n  }\n\n  get value(): any {\n    return this._value;\n  }\n\n  /**\n   * Callback to invoke on value change.\n   * @param {boolean} boolean - value changed.\n   * @group Emits\n   */\n  @Output() valueChanged = new EventEmitter<boolean>();\n\n  private _value: any = undefined;\n\n  constructor(@Self() @Optional() private _control: NgControl) {\n    if (this._control) {\n      this._control.valueAccessor = this;\n    }\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange = (event: any) => {};\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched = () => {};\n\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  writeValue(value: any) {\n    this.value = value;\n  }\n\n  updateValueEvent(value: any) {\n    if (this.disabled) return;\n    this._updateValue(value);\n  }\n\n  private _updateValue(value: any) {\n    this.writeValue(value);\n    this.onChange(value);\n    this.valueChanged.emit(value);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  setDisabledState(disabled: boolean) {}\n}\n","<div class=\"cps-radio-group\">\n  <div class=\"cps-radio-group-label\" *ngIf=\"groupLabel\">\n    <span>{{ groupLabel }}</span>\n    <cps-info-circle\n      *ngIf=\"infoTooltip\"\n      class=\"cps-radio-group-label-info-circle\"\n      size=\"xsmall\"\n      [tooltipPosition]=\"infoTooltipPosition\"\n      [tooltipContentClass]=\"infoTooltipClass\"\n      [tooltipMaxWidth]=\"infoTooltipMaxWidth\"\n      [tooltipPersistent]=\"infoTooltipPersistent\"\n      [tooltipText]=\"infoTooltip\">\n    </cps-info-circle>\n  </div>\n\n  <div\n    #contentRef\n    class=\"cps-radio-group-content\"\n    [ngClass]=\"\n      vertical\n        ? 'cps-radio-group-content-vertical'\n        : 'cps-radio-group-content-horizontal'\n    \">\n    <ng-content></ng-content>\n  </div>\n\n  <div\n    *ngIf=\"!contentRef.innerHTML.trim()\"\n    class=\"cps-radio-group-content\"\n    [ngClass]=\"\n      vertical\n        ? 'cps-radio-group-content-vertical'\n        : 'cps-radio-group-content-horizontal'\n    \">\n    <cps-radio-button\n      *ngFor=\"let option of options\"\n      [option]=\"option\"\n      [checked]=\"option.value === value\"\n      [groupDisabled]=\"disabled\"\n      (updateValueEvent)=\"updateValueEvent($event)\">\n    </cps-radio-button>\n  </div>\n</div>\n"]}
|
|
225
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-radio-group.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-radio-group/cps-radio-group.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-radio-group/cps-radio-group.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-use-before-define */\nimport { CommonModule } from '@angular/common';\nimport {\n  Component,\n  EventEmitter,\n  InjectionToken,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Self\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { CpsInfoCircleComponent } from '../cps-info-circle/cps-info-circle.component';\nimport {\n  CpsTooltipDirective,\n  CpsTooltipPosition\n} from '../../directives/cps-tooltip/cps-tooltip.directive';\nimport { CpsRadioButtonComponent } from './cps-radio-button/cps-radio-button.component';\nimport { Subscription } from 'rxjs';\n\nexport type CpsRadioOption = {\n  value: any;\n  label?: string;\n  disabled?: boolean;\n  tooltip?: string;\n};\n\nexport const CPS_RADIO_GROUP = new InjectionToken<CpsRadioGroupComponent>(\n  'CpsRadioGroupComponent'\n);\n\n/**\n * CpsRadioGroupComponent is a radio buttons group.\n * @group Components\n */\n@Component({\n  standalone: true,\n  imports: [\n    CommonModule,\n    CpsInfoCircleComponent,\n    CpsTooltipDirective,\n    CpsRadioButtonComponent\n  ],\n  selector: 'cps-radio-group',\n  templateUrl: './cps-radio-group.component.html',\n  styleUrls: ['./cps-radio-group.component.scss'],\n  providers: [\n    {\n      provide: CPS_RADIO_GROUP,\n      useExisting: CpsRadioGroupComponent\n    }\n  ]\n})\nexport class CpsRadioGroupComponent\n  implements ControlValueAccessor, OnInit, OnDestroy\n{\n  /**\n   * An array of options.\n   * @group Props\n   */\n  @Input() options: CpsRadioOption[] = [];\n\n  /**\n   * Label of the radio group.\n   * @group Props\n   */\n  @Input() groupLabel = '';\n\n  /**\n   * Determines whether the radio group should be vertical.\n   * @group Props\n   */\n  @Input() vertical = false;\n\n  /**\n   * Determines whether the radio group is disabled.\n   * @group Props\n   */\n  @Input() disabled = false;\n\n  /**\n   * When it is not an empty string, an info icon is displayed to show text for more info.\n   * @group Props\n   */\n  @Input() infoTooltip = '';\n\n  /**\n   * InfoTooltip class for styling.\n   * @group Props\n   */\n  @Input() infoTooltipClass = 'cps-tooltip-content';\n\n  /**\n   * Size of infoTooltip, of type number denoting pixels or string.\n   * @group Props\n   */\n  @Input() infoTooltipMaxWidth: number | string = '100%';\n\n  /**\n   * Determines whether the infoTooltip is persistent.\n   * @group Props\n   */\n  @Input() infoTooltipPersistent = false;\n\n  /**\n   * Position of infoTooltip, it can be \"top\", \"bottom\", \"left\" or \"right\".\n   * @group Props\n   */\n  @Input() infoTooltipPosition: CpsTooltipPosition = 'top';\n\n  /**\n   * Bottom hint text for the radio group.\n   * @group Props\n   */\n  @Input() hint = '';\n\n  /**\n   * Hides hint and validation errors.\n   * @group Props\n   */\n  @Input() hideDetails = false;\n\n  /**\n   * Value of the radio group.\n   * @group Props\n   */\n  @Input() set value(value: any) {\n    this._value = value;\n    this.onChange(value);\n  }\n\n  get value(): any {\n    return this._value;\n  }\n\n  /**\n   * Callback to invoke on value change.\n   * @param {boolean} boolean - value changed.\n   * @group Emits\n   */\n  @Output() valueChanged = new EventEmitter<boolean>();\n\n  /**\n   * Callback to invoke when the radio group loses focus.\n   * @param {any}\n   * @group Emits\n   */\n  @Output() blurred = new EventEmitter();\n\n  /**\n   * Callback to invoke when the radio group receives focus.\n   * @param {any}\n   * @group Emits\n   */\n  @Output() focused = new EventEmitter();\n\n  private _statusChangesSubscription?: Subscription;\n  private _value: any = undefined;\n\n  error = '';\n\n  constructor(@Self() @Optional() private _control: NgControl) {\n    if (this._control) {\n      this._control.valueAccessor = this;\n    }\n  }\n\n  ngOnInit(): void {\n    this._statusChangesSubscription = this._control?.statusChanges?.subscribe(\n      () => {\n        this._checkErrors();\n      }\n    );\n  }\n\n  ngOnDestroy() {\n    this._statusChangesSubscription?.unsubscribe();\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange = (event: any) => {};\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched = () => {};\n\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  writeValue(value: any) {\n    this.value = value;\n  }\n\n  updateValueEvent(value: any) {\n    if (this.disabled) return;\n    this._updateValue(value);\n  }\n\n  private _updateValue(value: any) {\n    this.writeValue(value);\n    this.onChange(value);\n    this.valueChanged.emit(value);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  setDisabledState(disabled: boolean) {}\n\n  onBlur() {\n    this._control?.control?.markAsTouched();\n    this._checkErrors();\n    this.blurred.emit();\n  }\n\n  onFocus() {\n    this.focused.emit();\n  }\n\n  private _checkErrors() {\n    if (!this._control) return;\n    const errors = this._control?.errors;\n\n    if (!this._control?.control?.touched || !errors) {\n      this.error = '';\n      return;\n    }\n\n    if ('required' in errors) {\n      this.error = 'Field is required';\n      return;\n    }\n\n    const errArr = Object.values(errors);\n    if (errArr.length < 1) {\n      this.error = '';\n      return;\n    }\n    const message = errArr.find((msg) => typeof msg === 'string');\n\n    this.error = message || 'Unknown error';\n  }\n}\n","<div class=\"cps-radio-group\">\n  <div class=\"cps-radio-group-label\" *ngIf=\"groupLabel\">\n    <span>{{ groupLabel }}</span>\n    <cps-info-circle\n      *ngIf=\"infoTooltip\"\n      class=\"cps-radio-group-label-info-circle\"\n      size=\"xsmall\"\n      [tooltipPosition]=\"infoTooltipPosition\"\n      [tooltipContentClass]=\"infoTooltipClass\"\n      [tooltipMaxWidth]=\"infoTooltipMaxWidth\"\n      [tooltipPersistent]=\"infoTooltipPersistent\"\n      [tooltipText]=\"infoTooltip\">\n    </cps-info-circle>\n  </div>\n\n  <div\n    #contentRef\n    class=\"cps-radio-group-content\"\n    [ngClass]=\"\n      vertical\n        ? 'cps-radio-group-content-vertical'\n        : 'cps-radio-group-content-horizontal'\n    \">\n    <ng-content></ng-content>\n  </div>\n\n  <div\n    *ngIf=\"!contentRef.innerHTML.trim()\"\n    class=\"cps-radio-group-content\"\n    [ngClass]=\"\n      vertical\n        ? 'cps-radio-group-content-vertical'\n        : 'cps-radio-group-content-horizontal'\n    \">\n    <cps-radio-button\n      *ngFor=\"let option of options\"\n      [option]=\"option\"\n      [checked]=\"option.value === value\"\n      [groupDisabled]=\"disabled\"\n      (blurred)=\"onBlur()\"\n      (focused)=\"onFocus()\"\n      (updateValueEvent)=\"updateValueEvent($event)\">\n    </cps-radio-button>\n  </div>\n  <div *ngIf=\"!error && !hideDetails\" class=\"cps-radio-hint\">\n    {{ hint }}\n  </div>\n  <div *ngIf=\"error && !hideDetails\" class=\"cps-radio-error\">\n    {{ error }}\n  </div>\n</div>\n"]}
|