UNPKG

@angular-mdl/core

Version:

Angular components, directives and styles based on material design lite https://getmdl.io.

231 lines 25 kB
import { Component, ElementRef, EventEmitter, forwardRef, HostBinding, HostListener, Injectable, Input, Optional, Output, Renderer2, ViewEncapsulation, } from "@angular/core"; import { FormGroupName, NG_VALUE_ACCESSOR, } from "@angular/forms"; import { toBoolean } from "../common/boolean-property"; import { noop } from "../common/noop"; import * as i0 from "@angular/core"; import * as i1 from "@angular/forms"; const throwNameError = () => { throw new Error(` If you define both a name and a formControlName attribute on your radio button, their values must match. Ex: <mdl-radio formControlName="food" name="food"></mdl-radio> `); }; const IS_FOCUSED = "is-focused"; // Registry for mdl-readio compnents. Is responsible to keep the // right state of the radio buttons of a radio group. It would be // easier if i had a mdl-radio-group component. but this would be // a big braking change. export class MdlRadioGroupRegisty { constructor() { this.defaultFormGroup = "defaultFromGroup"; this.radioComponents = []; } add(radioComponent, formGroupName) { this.radioComponents.push({ radio: radioComponent, group: formGroupName || this.defaultFormGroup, }); } remove(radioComponent) { this.radioComponents = this.radioComponents.filter((radioComponentInArray) => radioComponentInArray.radio !== radioComponent); } select(radioComponent, formGroupName) { // unselect every radioComponent that is not the provided radiocomponent // and has the same name and is in teh same group. const groupToTest = formGroupName || this.defaultFormGroup; this.radioComponents.forEach((component) => { if (component.radio.name === radioComponent.name && component.group === groupToTest) { if (component.radio !== radioComponent) { component.radio.deselect(radioComponent.value); } } }); } } MdlRadioGroupRegisty.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlRadioGroupRegisty, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); MdlRadioGroupRegisty.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlRadioGroupRegisty, providedIn: "root" }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlRadioGroupRegisty, decorators: [{ type: Injectable, args: [{ providedIn: "root", }] }] }); /* <mdl-radio name="group1" value="1" [(ngModel)]="radioOption">Value 1</mdl-radio> */ export class MdlRadioComponent { constructor(elementRef, renderer, radioGroupRegistry, formGroupName) { this.elementRef = elementRef; this.renderer = renderer; this.radioGroupRegistry = radioGroupRegistry; this.formGroupName = formGroupName; this.tabindex = null; // eslint-disable-next-line @angular-eslint/no-output-native this.change = new EventEmitter(); // the internal state - used to set the underlaying radio button state. this.checked = false; this.isUpgraded = true; this.isRadio = true; this.onTouchedCallback = noop; this.onChangeCallback = noop; this.disabledIntern = false; this.el = elementRef.nativeElement; } get disabled() { return this.disabledIntern; } set disabled(value) { this.disabledIntern = toBoolean(value); } onClick() { if (this.disabled) { return; } this.optionValue = this.value; this.updateCheckState(); this.onChangeCallback(); this.change.emit(this.optionValue); } ngOnInit() { // we need a name and it must be the same as in the formcontrol. // a radio group without name is useless. this.checkName(); // register the radio button - this is the only chance to unselect the // radio button that is no longer active - scope the radio button with it's group // if there is one. this.radioGroupRegistry.add(this, this.formGroupName); } ngOnDestroy() { this.radioGroupRegistry.remove(this); } writeValue(optionValue) { this.optionValue = optionValue; this.updateCheckState(); } deselect(value) { // called from the registry. the value is the value of the selected radio button // e.g. the radio button get unselected if it isnÄt the selected one. this.writeValue(value); } registerOnChange(fn) { // wrap the callback, so that we can call select on the registry this.onChangeCallback = () => { fn(this.value); this.radioGroupRegistry.select(this, this.formGroupName); }; } registerOnTouched(fn) { this.onTouchedCallback = fn; } setDisabledState(isDisabled) { this.disabled = isDisabled; } onFocus() { this.renderer.addClass(this.el, IS_FOCUSED); } onBlur() { this.renderer.removeClass(this.el, IS_FOCUSED); } spaceKeyPress() { this.checked = false; // in case of space key is pressed radio button value must remain same } updateCheckState() { this.checked = this.optionValue === this.value; } checkName() { if (this.name && this.formControlName && this.name !== this.formControlName) { throwNameError(); } if (!this.name && this.formControlName) { this.name = this.formControlName; } } } MdlRadioComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlRadioComponent, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: MdlRadioGroupRegisty }, { token: i1.FormGroupName, optional: true }], target: i0.ɵɵFactoryTarget.Component }); MdlRadioComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.4", type: MdlRadioComponent, selector: "mdl-radio", inputs: { name: "name", formControlName: "formControlName", value: "value", tabindex: "tabindex", disabled: "disabled" }, outputs: { change: "change" }, host: { listeners: { "click": "onClick()" }, properties: { "class.is-checked": "this.checked", "class.is-upgraded": "this.isUpgraded", "class.mdl-radio": "this.isRadio", "class.is-disabled": "this.disabled" } }, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => MdlRadioComponent), multi: true, }, ], ngImport: i0, template: ` <input type="checkbox" class="mdl-radio__button" [attr.name]="name" (focus)="onFocus()" (blur)="onBlur()" (keyup.space)="spaceKeyPress()" [disabled]="disabled" [attr.tabindex]="tabindex" [(ngModel)]="checked" /> <span class="mdl-radio__label"><ng-content></ng-content></span> <span class="mdl-radio__outer-circle"></span> <span class="mdl-radio__inner-circle"></span> `, isInline: true, dependencies: [{ kind: "directive", type: i1.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], encapsulation: i0.ViewEncapsulation.None }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.4", ngImport: i0, type: MdlRadioComponent, decorators: [{ type: Component, args: [{ selector: "mdl-radio", providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => MdlRadioComponent), multi: true, }, ], template: ` <input type="checkbox" class="mdl-radio__button" [attr.name]="name" (focus)="onFocus()" (blur)="onBlur()" (keyup.space)="spaceKeyPress()" [disabled]="disabled" [attr.tabindex]="tabindex" [(ngModel)]="checked" /> <span class="mdl-radio__label"><ng-content></ng-content></span> <span class="mdl-radio__outer-circle"></span> <span class="mdl-radio__inner-circle"></span> `, encapsulation: ViewEncapsulation.None, }] }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: MdlRadioGroupRegisty }, { type: i1.FormGroupName, decorators: [{ type: Optional }] }]; }, propDecorators: { name: [{ type: Input }], formControlName: [{ type: Input }], value: [{ type: Input }], tabindex: [{ type: Input }], // eslint-disable-next-line @angular-eslint/no-output-native change: [{ type: Output }], checked: [{ type: HostBinding, args: ["class.is-checked"] }], isUpgraded: [{ type: HostBinding, args: ["class.is-upgraded"] }], isRadio: [{ type: HostBinding, args: ["class.mdl-radio"] }], disabled: [{ type: HostBinding, args: ["class.is-disabled"] }, { type: Input }], onClick: [{ type: HostListener, args: ["click"] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mdl-radio.component.js","sourceRoot":"","sources":["../../../../../../projects/core/src/lib/radio/mdl-radio.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  forwardRef,\n  HostBinding,\n  HostListener,\n  Injectable,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Renderer2,\n  ViewEncapsulation,\n} from \"@angular/core\";\nimport {\n  ControlValueAccessor,\n  FormGroupName,\n  NG_VALUE_ACCESSOR,\n} from \"@angular/forms\";\nimport { toBoolean } from \"../common/boolean-property\";\nimport { noop } from \"../common/noop\";\n\nconst throwNameError = (): void => {\n  throw new Error(`\n      If you define both a name and a formControlName attribute on your radio button, their values\n      must match. Ex: <mdl-radio formControlName=\"food\" name=\"food\"></mdl-radio>\n    `);\n};\n\nconst IS_FOCUSED = \"is-focused\";\n\n// Registry for mdl-readio compnents. Is responsible to keep the\n// right state of the radio buttons of a radio group. It would be\n// easier if i had a mdl-radio-group component. but this would be\n// a big braking change.\n@Injectable({\n  providedIn: \"root\",\n})\nexport class MdlRadioGroupRegisty {\n  private defaultFormGroup = \"defaultFromGroup\";\n  private radioComponents: {\n    radio: MdlRadioComponent;\n    group: FormGroupName | string;\n  }[] = [];\n\n  add(radioComponent: MdlRadioComponent, formGroupName: FormGroupName): void {\n    this.radioComponents.push({\n      radio: radioComponent,\n      group: formGroupName || this.defaultFormGroup,\n    });\n  }\n\n  remove(radioComponent: MdlRadioComponent): void {\n    this.radioComponents = this.radioComponents.filter(\n      (radioComponentInArray) => radioComponentInArray.radio !== radioComponent\n    );\n  }\n\n  select(\n    radioComponent: MdlRadioComponent,\n    formGroupName: FormGroupName\n  ): void {\n    // unselect every radioComponent that is not the provided radiocomponent\n    // and has the same name and is in teh same group.\n    const groupToTest = formGroupName || this.defaultFormGroup;\n    this.radioComponents.forEach((component) => {\n      if (\n        component.radio.name === radioComponent.name &&\n        component.group === groupToTest\n      ) {\n        if (component.radio !== radioComponent) {\n          component.radio.deselect(radioComponent.value);\n        }\n      }\n    });\n  }\n}\n\n/*\n <mdl-radio name=\"group1\" value=\"1\" [(ngModel)]=\"radioOption\">Value 1</mdl-radio>\n */\n\n@Component({\n  selector: \"mdl-radio\",\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => MdlRadioComponent),\n      multi: true,\n    },\n  ],\n  template: `\n    <input\n      type=\"checkbox\"\n      class=\"mdl-radio__button\"\n      [attr.name]=\"name\"\n      (focus)=\"onFocus()\"\n      (blur)=\"onBlur()\"\n      (keyup.space)=\"spaceKeyPress()\"\n      [disabled]=\"disabled\"\n      [attr.tabindex]=\"tabindex\"\n      [(ngModel)]=\"checked\"\n    />\n    <span class=\"mdl-radio__label\"><ng-content></ng-content></span>\n    <span class=\"mdl-radio__outer-circle\"></span>\n    <span class=\"mdl-radio__inner-circle\"></span>\n  `,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class MdlRadioComponent\n  implements ControlValueAccessor, OnInit, OnDestroy\n{\n  @Input()\n  name: string | undefined;\n  @Input()\n  formControlName: string | undefined;\n  @Input()\n  value: unknown;\n  @Input()\n  tabindex = null;\n  @Output()\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  change: EventEmitter<unknown> = new EventEmitter<unknown>();\n  // the internal state - used to set the underlaying radio button state.\n  @HostBinding(\"class.is-checked\")\n  checked = false;\n  @HostBinding(\"class.is-upgraded\") isUpgraded = true;\n  @HostBinding(\"class.mdl-radio\") isRadio = true;\n\n  public optionValue: unknown;\n\n  private readonly el: HTMLElement;\n  private onTouchedCallback: () => void = noop;\n  private onChangeCallback: () => void = noop;\n  private disabledIntern = false;\n\n  constructor(\n    private elementRef: ElementRef,\n    private renderer: Renderer2,\n    private radioGroupRegistry: MdlRadioGroupRegisty,\n    @Optional() private formGroupName: FormGroupName\n  ) {\n    this.el = elementRef.nativeElement;\n  }\n\n  @HostBinding(\"class.is-disabled\")\n  @Input()\n  get disabled(): boolean {\n    return this.disabledIntern;\n  }\n\n  set disabled(value: boolean) {\n    this.disabledIntern = toBoolean(value);\n  }\n\n  @HostListener(\"click\")\n  onClick(): void {\n    if (this.disabled) {\n      return;\n    }\n    this.optionValue = this.value;\n    this.updateCheckState();\n    this.onChangeCallback();\n    this.change.emit(this.optionValue);\n  }\n\n  ngOnInit(): void {\n    // we need a name and it must be the same as in the formcontrol.\n    // a radio group without name is useless.\n    this.checkName();\n    // register the radio button - this is the only chance to unselect the\n    // radio button that is no longer active - scope the radio button with it's group\n    // if there is one.\n    this.radioGroupRegistry.add(this, this.formGroupName);\n  }\n\n  ngOnDestroy(): void {\n    this.radioGroupRegistry.remove(this);\n  }\n\n  writeValue(optionValue: unknown): void {\n    this.optionValue = optionValue;\n    this.updateCheckState();\n  }\n\n  deselect(value: unknown): void {\n    // called from the registry. the value is the value of the selected radio button\n    // e.g. the radio button get unselected if it isnÄt the selected one.\n    this.writeValue(value);\n  }\n\n  registerOnChange(fn: (v: unknown) => unknown): void {\n    // wrap the callback, so that we can call select on the registry\n    this.onChangeCallback = () => {\n      fn(this.value);\n      this.radioGroupRegistry.select(this, this.formGroupName);\n    };\n  }\n\n  registerOnTouched(fn: () => unknown): void {\n    this.onTouchedCallback = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  onFocus(): void {\n    this.renderer.addClass(this.el, IS_FOCUSED);\n  }\n\n  onBlur(): void {\n    this.renderer.removeClass(this.el, IS_FOCUSED);\n  }\n\n  spaceKeyPress(): void {\n    this.checked = false; // in case of space key is pressed radio button value must remain same\n  }\n\n  private updateCheckState() {\n    this.checked = this.optionValue === this.value;\n  }\n\n  private checkName(): void {\n    if (\n      this.name &&\n      this.formControlName &&\n      this.name !== this.formControlName\n    ) {\n      throwNameError();\n    }\n    if (!this.name && this.formControlName) {\n      this.name = this.formControlName;\n    }\n  }\n}\n"]}