UNPKG

@doku-dev/doku-fragment

Version:

A new Angular UI library that moving away from Bootstrap and built from scratch.

118 lines 13.3 kB
import { CommonModule } from '@angular/common'; import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Input, Output, ViewEncapsulation, } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { ReplaySubject, map, startWith, takeUntil } from 'rxjs'; import { DOKU_RADIO } from './token'; import * as i0 from "@angular/core"; let nextId = 1; export class DokuRadioGroup { constructor() { /** * Name of the radio button group. * All radio buttons inside this group will use this name. * @default 'd-radio-group-[nextId]' */ this.name = `d-radio-group-${nextId++}`; /** * Whether the radio group is disabled. * If `true`, all radio buttons inside this group will be disabled. * @default false */ this.disabled = false; /** * Value of the checked radio button. * @default '' */ this.value = ''; /** * Event emitted when the value changes. */ this.valueChange = new EventEmitter(); this._notifyChanges$ = new ReplaySubject(); this.destroy$ = new ReplaySubject(); } ngOnChanges() { this.radios?.notifyOnChanges(); } ngAfterContentInit() { this.radios?.changes .pipe(startWith(this.radios), map((radios) => radios.toArray()), takeUntil(this.destroy$)) .subscribe((radios) => { this.injectRadios(radios); }); } ngOnDestroy() { this.destroy$.next(true); this.destroy$.complete(); } writeValue(value) { this.value = value; this.radios?.notifyOnChanges(); } registerOnChange(fn) { this.onChange = fn; } registerOnTouched(fn) { this.onTouched = fn; } setDisabledState(isDisabled) { this.disabled = isDisabled; this.radios?.notifyOnChanges(); } injectRadios(radios) { radios.forEach((radio) => { if (this.name) radio.name = this.name; radio.disabled = this.disabled || radio.disabled; radio['checkedChangeCallback'] = (value, checked) => { this.value = checked ? value : ''; this.onChange?.(this.value); this.onTouched?.(); this.valueChange.emit(this.value); this._notifyChanges$.next(true); }; radio.checked = radio.value === this.value; radio['cdr'].detectChanges(); }); this._notifyChanges$.next(true); } } DokuRadioGroup.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DokuRadioGroup, deps: [], target: i0.ɵɵFactoryTarget.Component }); DokuRadioGroup.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: DokuRadioGroup, isStandalone: true, selector: "doku-radio-group", inputs: { name: "name", disabled: "disabled", value: "value" }, outputs: { valueChange: "valueChange" }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: DokuRadioGroup, multi: true, }, ], queries: [{ propertyName: "radios", predicate: DOKU_RADIO }], exportAs: ["dokuRadioGroup"], usesOnChanges: true, ngImport: i0, template: `<ng-content select="doku-radio"></ng-content>`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DokuRadioGroup, decorators: [{ type: Component, args: [{ selector: 'doku-radio-group', exportAs: 'dokuRadioGroup', standalone: true, imports: [CommonModule], template: `<ng-content select="doku-radio"></ng-content>`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: DokuRadioGroup, multi: true, }, ], }] }], propDecorators: { name: [{ type: Input }], disabled: [{ type: Input }], value: [{ type: Input }], valueChange: [{ type: Output }], radios: [{ type: ContentChildren, args: [DOKU_RADIO] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-group.component.js","sourceRoot":"","sources":["../../../../../../projects/doku-fragment/src/lib/radio/radio-group.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  QueryList,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { ReplaySubject, map, startWith, takeUntil } from 'rxjs';\nimport { DokuRadio } from './radio.component';\nimport { DOKU_RADIO } from './token';\n\nlet nextId = 1;\n\n@Component({\n  selector: 'doku-radio-group',\n  exportAs: 'dokuRadioGroup',\n  standalone: true,\n  imports: [CommonModule],\n  template: `<ng-content select=\"doku-radio\"></ng-content>`,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: DokuRadioGroup,\n      multi: true,\n    },\n  ],\n})\nexport class DokuRadioGroup\n  implements ControlValueAccessor, AfterContentInit, OnDestroy, OnChanges\n{\n  /**\n   * Name of the radio button group.\n   * All radio buttons inside this group will use this name.\n   * @default 'd-radio-group-[nextId]'\n   */\n  @Input() name = `d-radio-group-${nextId++}`;\n\n  /**\n   * Whether the radio group is disabled.\n   * If `true`, all radio buttons inside this group will be disabled.\n   * @default false\n   */\n  @Input() disabled = false;\n\n  /**\n   * Value of the checked radio button.\n   * @default ''\n   */\n  @Input() value = '';\n\n  /**\n   * Event emitted when the value changes.\n   */\n  @Output() valueChange = new EventEmitter<string>();\n\n  @ContentChildren(DOKU_RADIO) private radios?: QueryList<DokuRadio>;\n\n  protected _notifyChanges$ = new ReplaySubject();\n  private destroy$ = new ReplaySubject();\n\n  ngOnChanges(): void {\n    this.radios?.notifyOnChanges();\n  }\n\n  ngAfterContentInit(): void {\n    this.radios?.changes\n      .pipe(\n        startWith(this.radios),\n        map((radios: QueryList<DokuRadio>) => radios.toArray()),\n        takeUntil(this.destroy$)\n      )\n      .subscribe((radios) => {\n        this.injectRadios(radios);\n      });\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next(true);\n    this.destroy$.complete();\n  }\n\n  onChange?: (_: any) => void;\n  onTouched?: () => void;\n\n  writeValue(value: string): void {\n    this.value = value;\n    this.radios?.notifyOnChanges();\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n    this.radios?.notifyOnChanges();\n  }\n\n  private injectRadios(radios: DokuRadio[]) {\n    radios.forEach((radio) => {\n      if (this.name) radio.name = this.name;\n      radio.disabled = this.disabled || radio.disabled;\n      radio['checkedChangeCallback'] = (value: string, checked: boolean) => {\n        this.value = checked ? value : '';\n        this.onChange?.(this.value);\n        this.onTouched?.();\n        this.valueChange.emit(this.value);\n        this._notifyChanges$.next(true);\n      };\n      radio.checked = radio.value === this.value;\n      radio['cdr'].detectChanges();\n    });\n    this._notifyChanges$.next(true);\n  }\n}\n"]}