@doku-dev/doku-fragment
Version:
A new Angular UI library that moving away from Bootstrap and built from scratch.
158 lines • 22.5 kB
JavaScript
import { CommonModule } from '@angular/common';
import { ChangeDetectionStrategy, Component, ContentChild, Host, HostBinding, Input, Optional, ViewChild, ViewEncapsulation, } from '@angular/core';
import { ReplaySubject, takeUntil } from 'rxjs';
import { DokuRadioCustomAppearanceContext } from './context';
import { DokuRadioCustomAppearance } from './radio-custom-appearance.directive';
import { DOKU_RADIO, DOKU_RADIO_BUILT_IN_APPEARANCE } from './token';
import * as i0 from "@angular/core";
import * as i1 from "./radio-group.component";
let nextId = 1;
export class DokuRadio {
constructor(cdr, appRef, renderer, radioGroup) {
this.cdr = cdr;
this.appRef = appRef;
this.renderer = renderer;
this.radioGroup = radioGroup;
/**
* Analog to HTML 'name' attribute used to group radios for unique selection.
* @default 'd-radio-name-[nextId]''
*/
this.name = `d-radio-name-${nextId++}`;
/**
* The value of this radio button.
* @default ''
*/
this.value = '';
/**
* Whether this radio button is checked.
* @default false
*/
this.checked = false;
/**
* Whether the radio button is disabled.
* @default false
*/
this.disabled = false;
/**
* The size of the radio button indicator.
* @default 'medium'
*/
this.size = 'medium';
this.customAppearanceContext = new DokuRadioCustomAppearanceContext();
this.hasIndicator = false;
this.destroy$ = new ReplaySubject();
}
get classes() {
return ['d-radio', `d-radio-${this.size}`];
}
get hasCustomAppearance() {
return !!this.customAppearance || !!this.builtInAppearance;
}
ngAfterViewInit() {
this.cdr.detectChanges();
if (this.hasCustomAppearance) {
this.createAndAppendCustomAppearance();
setTimeout(() => this.appendIndicator({ appendChildTo: this.container?.nativeElement, hidden: true }), 0);
this.label?.nativeElement?.remove();
}
else {
this.appendIndicator();
}
this.watchGroupChanges();
}
ngOnChanges() {
this.updateCustomAppearanceContext();
}
ngOnDestroy() {
this.destroy$.next(true);
this.destroy$.complete();
}
onCheckedChange(ev) {
this.checked = ev.target.checked;
this.cdr.detectChanges();
if (this.hasCustomAppearance) {
this.updateCustomAppearanceContext();
}
this.checkedChangeCallback?.(this.value, this.checked);
}
appendIndicator(props) {
if (!this.indicator || this.hasIndicator)
return;
const viewRef = this.indicator.createEmbeddedView(null);
this.appRef.attachView(viewRef);
viewRef.rootNodes.forEach((node) => {
if (props?.hidden)
this.renderer.setStyle(node, 'display', 'none');
if (props?.appendChildTo) {
this.renderer.appendChild(props.appendChildTo, node);
}
else {
this.renderer.insertBefore(this.container?.nativeElement, node, this.label?.nativeElement);
}
});
this.hasIndicator = true;
this.destroy$.subscribe(() => viewRef.destroy());
}
createAndAppendCustomAppearance() {
const templateRef = this.customAppearance?.templateRef || this.builtInAppearance?.template?.templateRef;
if (!templateRef)
return;
const viewRef = templateRef.createEmbeddedView(this.customAppearanceContext);
this.appRef.attachView(viewRef);
viewRef.rootNodes.forEach((node) => {
this.renderer.appendChild(this.container?.nativeElement, node);
});
this.destroy$.subscribe(() => viewRef.destroy());
}
updateCustomAppearanceContext() {
this.customAppearanceContext.checked = this.checked;
this.customAppearanceContext.disabled = this.disabled;
this.customAppearanceContext.value = this.value;
}
watchGroupChanges() {
this.radioGroup?.['_notifyChanges$'].pipe(takeUntil(this.destroy$)).subscribe(() => {
this.checked = this.value === this.radioGroup?.value;
this.disabled = this.disabled || !!this.radioGroup?.disabled;
this.updateCustomAppearanceContext();
});
}
}
DokuRadio.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: DokuRadio, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ApplicationRef }, { token: i0.Renderer2 }, { token: i1.DokuRadioGroup, host: true, optional: true }], target: i0.ɵɵFactoryTarget.Component });
DokuRadio.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: DokuRadio, isStandalone: true, selector: "doku-radio", inputs: { name: "name", value: "value", checked: "checked", disabled: "disabled", size: "size" }, host: { properties: { "class": "this.classes" } }, providers: [{ provide: DOKU_RADIO, useExisting: DokuRadio }], queries: [{ propertyName: "customAppearance", first: true, predicate: DokuRadioCustomAppearance, descendants: true }, { propertyName: "builtInAppearance", first: true, predicate: DOKU_RADIO_BUILT_IN_APPEARANCE, descendants: true }], viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }, { propertyName: "indicator", first: true, predicate: ["indicator"], descendants: true }, { propertyName: "label", first: true, predicate: ["label"], descendants: true }], exportAs: ["dokuRadio"], usesOnChanges: true, ngImport: i0, template: "<label #container class=\"d-radio-container\">\n <span #label class=\"d-radio-label\"><ng-content></ng-content></span>\n</label>\n\n<ng-template #indicator>\n <input\n type=\"radio\"\n class=\"d-radio-input\"\n [name]=\"name\"\n [value]=\"value\"\n [disabled]=\"disabled\"\n [checked]=\"checked\"\n (change)=\"onCheckedChange($event)\"\n />\n</ng-template>\n", 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: DokuRadio, decorators: [{
type: Component,
args: [{ selector: 'doku-radio', exportAs: 'dokuRadio', standalone: true, imports: [CommonModule], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [{ provide: DOKU_RADIO, useExisting: DokuRadio }], template: "<label #container class=\"d-radio-container\">\n <span #label class=\"d-radio-label\"><ng-content></ng-content></span>\n</label>\n\n<ng-template #indicator>\n <input\n type=\"radio\"\n class=\"d-radio-input\"\n [name]=\"name\"\n [value]=\"value\"\n [disabled]=\"disabled\"\n [checked]=\"checked\"\n (change)=\"onCheckedChange($event)\"\n />\n</ng-template>\n" }]
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ApplicationRef }, { type: i0.Renderer2 }, { type: i1.DokuRadioGroup, decorators: [{
type: Optional
}, {
type: Host
}] }]; }, propDecorators: { name: [{
type: Input
}], value: [{
type: Input
}], checked: [{
type: Input
}], disabled: [{
type: Input
}], size: [{
type: Input
}], container: [{
type: ViewChild,
args: ['container']
}], indicator: [{
type: ViewChild,
args: ['indicator']
}], label: [{
type: ViewChild,
args: ['label']
}], customAppearance: [{
type: ContentChild,
args: [DokuRadioCustomAppearance]
}], builtInAppearance: [{
type: ContentChild,
args: [DOKU_RADIO_BUILT_IN_APPEARANCE]
}], classes: [{
type: HostBinding,
args: ['class']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio.component.js","sourceRoot":"","sources":["../../../../../../projects/doku-fragment/src/lib/radio/radio.component.ts","../../../../../../projects/doku-fragment/src/lib/radio/radio.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAW,MAAM,iBAAiB,CAAC;AACxD,OAAO,EAGL,uBAAuB,EAEvB,SAAS,EACT,YAAY,EAEZ,IAAI,EACJ,WAAW,EACX,KAAK,EAGL,QAAQ,EAGR,SAAS,EACT,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAChD,OAAO,EAAE,gCAAgC,EAAE,MAAM,WAAW,CAAC;AAC7D,OAAO,EAAE,yBAAyB,EAAE,MAAM,qCAAqC,CAAC;AAGhF,OAAO,EAAE,UAAU,EAAE,8BAA8B,EAAE,MAAM,SAAS,CAAC;;;AAErE,IAAI,MAAM,GAAG,CAAC,CAAC;AAYf,MAAM,OAAO,SAAS;IA8CpB,YACU,GAAsB,EACtB,MAAsB,EACtB,QAAmB,EACC,UAA2B;QAH/C,QAAG,GAAH,GAAG,CAAmB;QACtB,WAAM,GAAN,MAAM,CAAgB;QACtB,aAAQ,GAAR,QAAQ,CAAW;QACC,eAAU,GAAV,UAAU,CAAiB;QAjDzD;;;WAGG;QACM,SAAI,GAAG,gBAAgB,MAAM,EAAE,EAAE,CAAC;QAE3C;;;WAGG;QACM,UAAK,GAAG,EAAE,CAAC;QAEpB;;;WAGG;QACM,YAAO,GAAG,KAAK,CAAC;QAEzB;;;WAGG;QACM,aAAQ,GAAG,KAAK,CAAC;QAE1B;;;WAGG;QACM,SAAI,GAAuB,QAAQ,CAAC;QAYnC,4BAAuB,GAAG,IAAI,gCAAgC,EAAE,CAAC;QACjE,iBAAY,GAAG,KAAK,CAAC;QAEvB,aAAQ,GAAG,IAAI,aAAa,EAAE,CAAC;IAOpC,CAAC;IAEJ,IACc,OAAO;QACnB,OAAO,CAAC,SAAS,EAAE,WAAW,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;IAC7C,CAAC;IAED,IAAc,mBAAmB;QAC/B,OAAO,CAAC,CAAC,IAAI,CAAC,gBAAgB,IAAI,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC;IAC7D,CAAC;IAED,eAAe;QACb,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QACzB,IAAI,IAAI,CAAC,mBAAmB,EAAE;YAC5B,IAAI,CAAC,+BAA+B,EAAE,CAAC;YACvC,UAAU,CACR,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,EAAE,aAAa,EAAE,IAAI,CAAC,SAAS,EAAE,aAAa,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,EAC1F,CAAC,CACF,CAAC;YACD,IAAI,CAAC,KAAK,EAAE,aAA6B,EAAE,MAAM,EAAE,CAAC;SACtD;aAAM;YACL,IAAI,CAAC,eAAe,EAAE,CAAC;SACxB;QAED,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAED,WAAW;QACT,IAAI,CAAC,6BAA6B,EAAE,CAAC;IACvC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;IAES,eAAe,CAAC,EAAS;QACjC,IAAI,CAAC,OAAO,GAAI,EAAE,CAAC,MAA2B,CAAC,OAAO,CAAC;QACvD,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QACzB,IAAI,IAAI,CAAC,mBAAmB,EAAE;YAC5B,IAAI,CAAC,6BAA6B,EAAE,CAAC;SACtC;QACD,IAAI,CAAC,qBAAqB,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;IACzD,CAAC;IAEO,eAAe,CAAC,KAAyD;QAC/E,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,YAAY;YAAE,OAAO;QACjD,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;QACxD,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;QAChC,OAAO,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YACjC,IAAI,KAAK,EAAE,MAAM;gBAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC;YACnE,IAAI,KAAK,EAAE,aAAa,EAAE;gBACxB,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,KAAK,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC;aACtD;iBAAM;gBACL,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,EAAE,aAAa,EAAE,IAAI,EAAE,IAAI,CAAC,KAAK,EAAE,aAAa,CAAC,CAAC;aAC5F;QACH,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;IACnD,CAAC;IAEO,+BAA+B;QACrC,MAAM,WAAW,GACf,IAAI,CAAC,gBAAgB,EAAE,WAAW,IAAI,IAAI,CAAC,iBAAiB,EAAE,QAAQ,EAAE,WAAW,CAAC;QACtF,IAAI,CAAC,WAAW;YAAE,OAAO;QAEzB,MAAM,OAAO,GAAG,WAAW,CAAC,kBAAkB,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;QAC7E,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;QAChC,OAAO,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YACjC,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,EAAE,aAAa,EAAE,IAAI,CAAC,CAAC;QACjE,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;IACnD,CAAC;IAEO,6BAA6B;QACnC,IAAI,CAAC,uBAAuB,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;QACpD,IAAI,CAAC,uBAAuB,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QACtD,IAAI,CAAC,uBAAuB,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;IAClD,CAAC;IAEO,iBAAiB;QACvB,IAAI,CAAC,UAAU,EAAE,CAAC,iBAAiB,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YACjF,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,UAAU,EAAE,KAAK,CAAC;YACrD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,IAAI,CAAC,CAAC,IAAI,CAAC,UAAU,EAAE,QAAQ,CAAC;YAC7D,IAAI,CAAC,6BAA6B,EAAE,CAAC;QACvC,CAAC,CAAC,CAAC;IACL,CAAC;;sGAzIU,SAAS;0FAAT,SAAS,8MAFT,CAAC,EAAE,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,SAAS,EAAE,CAAC,wEAqC9C,yBAAyB,oFAGzB,8BAA8B,gXC7E9C,gYAeA,2CDkBY,YAAY;2FAMX,SAAS;kBAVrB,SAAS;+BACE,YAAY,YACZ,WAAW,cACT,IAAI,WACP,CAAC,YAAY,CAAC,iBAER,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM,aACpC,CAAC,EAAE,OAAO,EAAE,UAAU,EAAE,WAAW,WAAW,EAAE,CAAC;;0BAoDzD,QAAQ;;0BAAI,IAAI;4CA7CV,IAAI;sBAAZ,KAAK;gBAMG,KAAK;sBAAb,KAAK;gBAMG,OAAO;sBAAf,KAAK;gBAMG,QAAQ;sBAAhB,KAAK;gBAMG,IAAI;sBAAZ,KAAK;gBAE0B,SAAS;sBAAxC,SAAS;uBAAC,WAAW;gBACU,SAAS;sBAAxC,SAAS;uBAAC,WAAW;gBACM,KAAK;sBAAhC,SAAS;uBAAC,OAAO;gBAGV,gBAAgB;sBADvB,YAAY;uBAAC,yBAAyB;gBAI/B,iBAAiB;sBADxB,YAAY;uBAAC,8BAA8B;gBAgB9B,OAAO;sBADpB,WAAW;uBAAC,OAAO","sourcesContent":["import { CommonModule, NgClass } from '@angular/common';\nimport {\n  AfterViewInit,\n  ApplicationRef,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ElementRef,\n  Host,\n  HostBinding,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Optional,\n  Renderer2,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { ReplaySubject, takeUntil } from 'rxjs';\nimport { DokuRadioCustomAppearanceContext } from './context';\nimport { DokuRadioCustomAppearance } from './radio-custom-appearance.directive';\nimport { DokuRadioGroup } from './radio-group.component';\nimport { DokuRadioBuiltInAppearance } from './radio.interface';\nimport { DOKU_RADIO, DOKU_RADIO_BUILT_IN_APPEARANCE } from './token';\n\nlet nextId = 1;\n\n@Component({\n  selector: 'doku-radio',\n  exportAs: 'dokuRadio',\n  standalone: true,\n  imports: [CommonModule],\n  templateUrl: './radio.component.html',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [{ provide: DOKU_RADIO, useExisting: DokuRadio }],\n})\nexport class DokuRadio implements AfterViewInit, OnChanges, OnDestroy {\n  /**\n   * Analog to HTML 'name' attribute used to group radios for unique selection.\n   * @default 'd-radio-name-[nextId]''\n   */\n  @Input() name = `d-radio-name-${nextId++}`;\n\n  /**\n   * The value of this radio button.\n   * @default ''\n   */\n  @Input() value = '';\n\n  /**\n   * Whether this radio button is checked.\n   * @default false\n   */\n  @Input() checked = false;\n\n  /**\n   * Whether the radio button is disabled.\n   * @default false\n   */\n  @Input() disabled = false;\n\n  /**\n   * The size of the radio button indicator.\n   * @default 'medium'\n   */\n  @Input() size: 'medium' | 'small' = 'medium';\n\n  @ViewChild('container') private container?: ElementRef;\n  @ViewChild('indicator') private indicator?: TemplateRef<any>;\n  @ViewChild('label') private label?: ElementRef;\n\n  @ContentChild(DokuRadioCustomAppearance)\n  private customAppearance?: DokuRadioCustomAppearance;\n\n  @ContentChild(DOKU_RADIO_BUILT_IN_APPEARANCE)\n  private builtInAppearance?: DokuRadioBuiltInAppearance;\n\n  protected customAppearanceContext = new DokuRadioCustomAppearanceContext();\n  protected hasIndicator = false;\n  protected checkedChangeCallback?: (value: string, checked: boolean) => void;\n  private destroy$ = new ReplaySubject();\n\n  constructor(\n    private cdr: ChangeDetectorRef,\n    private appRef: ApplicationRef,\n    private renderer: Renderer2,\n    @Optional() @Host() private radioGroup?: DokuRadioGroup\n  ) {}\n\n  @HostBinding('class')\n  protected get classes(): NgClass['ngClass'] {\n    return ['d-radio', `d-radio-${this.size}`];\n  }\n\n  protected get hasCustomAppearance(): boolean {\n    return !!this.customAppearance || !!this.builtInAppearance;\n  }\n\n  ngAfterViewInit(): void {\n    this.cdr.detectChanges();\n    if (this.hasCustomAppearance) {\n      this.createAndAppendCustomAppearance();\n      setTimeout(\n        () => this.appendIndicator({ appendChildTo: this.container?.nativeElement, hidden: true }),\n        0\n      );\n      (this.label?.nativeElement as HTMLElement)?.remove();\n    } else {\n      this.appendIndicator();\n    }\n\n    this.watchGroupChanges();\n  }\n\n  ngOnChanges(): void {\n    this.updateCustomAppearanceContext();\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next(true);\n    this.destroy$.complete();\n  }\n\n  protected onCheckedChange(ev: Event) {\n    this.checked = (ev.target as HTMLInputElement).checked;\n    this.cdr.detectChanges();\n    if (this.hasCustomAppearance) {\n      this.updateCustomAppearanceContext();\n    }\n    this.checkedChangeCallback?.(this.value, this.checked);\n  }\n\n  private appendIndicator(props?: { appendChildTo?: HTMLElement; hidden?: boolean }) {\n    if (!this.indicator || this.hasIndicator) return;\n    const viewRef = this.indicator.createEmbeddedView(null);\n    this.appRef.attachView(viewRef);\n    viewRef.rootNodes.forEach((node) => {\n      if (props?.hidden) this.renderer.setStyle(node, 'display', 'none');\n      if (props?.appendChildTo) {\n        this.renderer.appendChild(props.appendChildTo, node);\n      } else {\n        this.renderer.insertBefore(this.container?.nativeElement, node, this.label?.nativeElement);\n      }\n    });\n    this.hasIndicator = true;\n    this.destroy$.subscribe(() => viewRef.destroy());\n  }\n\n  private createAndAppendCustomAppearance() {\n    const templateRef: TemplateRef<any> | undefined =\n      this.customAppearance?.templateRef || this.builtInAppearance?.template?.templateRef;\n    if (!templateRef) return;\n\n    const viewRef = templateRef.createEmbeddedView(this.customAppearanceContext);\n    this.appRef.attachView(viewRef);\n    viewRef.rootNodes.forEach((node) => {\n      this.renderer.appendChild(this.container?.nativeElement, node);\n    });\n    this.destroy$.subscribe(() => viewRef.destroy());\n  }\n\n  private updateCustomAppearanceContext() {\n    this.customAppearanceContext.checked = this.checked;\n    this.customAppearanceContext.disabled = this.disabled;\n    this.customAppearanceContext.value = this.value;\n  }\n\n  private watchGroupChanges() {\n    this.radioGroup?.['_notifyChanges$'].pipe(takeUntil(this.destroy$)).subscribe(() => {\n      this.checked = this.value === this.radioGroup?.value;\n      this.disabled = this.disabled || !!this.radioGroup?.disabled;\n      this.updateCustomAppearanceContext();\n    });\n  }\n}\n","<label #container class=\"d-radio-container\">\n  <span #label class=\"d-radio-label\"><ng-content></ng-content></span>\n</label>\n\n<ng-template #indicator>\n  <input\n    type=\"radio\"\n    class=\"d-radio-input\"\n    [name]=\"name\"\n    [value]=\"value\"\n    [disabled]=\"disabled\"\n    [checked]=\"checked\"\n    (change)=\"onCheckedChange($event)\"\n  />\n</ng-template>\n"]}