@angular-mdl/core
Version:
Angular components, directives and styles based on material design lite https://getmdl.io.
231 lines • 25 kB
JavaScript
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"]}