UNPKG

@doku-dev/doku-fragment

Version:

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

158 lines 22.5 kB
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":"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","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"]}