@doku-dev/doku-fragment
Version:
A new Angular UI library that moving away from Bootstrap and built from scratch.
118 lines • 13.3 kB
JavaScript
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"]}