UNPKG

materialize-angular

Version:
268 lines 18.2 kB
/** * @fileoverview added by tsickle * Generated from: app/completed-components/radio-group/radio-group.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @license * Copyright Workylab. All Rights Reserved. * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://raw.githubusercontent.com/workylab/materialize-angular/master/LICENSE */ import { Component, ContentChildren, EventEmitter, forwardRef, Input, Output, QueryList } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { config } from '../../config'; import { RadioComponent } from './radio/radio.component'; var RadioGroupComponent = /** @class */ (function () { function RadioGroupComponent() { this.canUncheck = RadioGroupComponent.defaultProps.canUncheck; this.className = RadioGroupComponent.defaultProps.className; this.disabled = RadioGroupComponent.defaultProps.disabled; this.name = RadioGroupComponent.defaultProps.name; this.required = RadioGroupComponent.defaultProps.required; this.value = RadioGroupComponent.defaultProps.value; this.prefix = config.components.prefix; this.isFocused = false; this.initRadios = this.initRadios.bind(this); this.registerRadios = this.registerRadios.bind(this); this.toggleRadios = this.toggleRadios.bind(this); this.onChangeEmitter = new EventEmitter(); } /** * @return {?} */ RadioGroupComponent.prototype.ngAfterContentInit = /** * @return {?} */ function () { this.initRadios(); this.radiosQueryList.changes.subscribe(this.initRadios); }; /** * @return {?} */ RadioGroupComponent.prototype.initRadios = /** * @return {?} */ function () { this.disableAllRadios(this.disabled); setTimeout(this.registerRadios, 0); }; /** * @return {?} */ RadioGroupComponent.prototype.registerRadios = /** * @return {?} */ function () { var _this = this; this.radiosQueryList.forEach((/** * @param {?} radio * @return {?} */ function (radio) { radio.isActive = (radio.value === _this.value); radio.onClickEmitter.subscribe(_this.toggleRadios); })); }; /** * @param {?} value * @return {?} */ RadioGroupComponent.prototype.toggleRadios = /** * @param {?} value * @return {?} */ function (value) { this.setValueAllRadios(value); /** @type {?} */ var currentRadio = this.radiosQueryList.find((/** * @param {?} radio * @return {?} */ function (radio) { return radio.value === value; })); this.value = currentRadio && currentRadio.isActive ? currentRadio.value : ''; this.onTouched(); this.onChange(this.value); this.onChangeEmitter.emit(this.value); }; /** * @param {?} value * @return {?} */ RadioGroupComponent.prototype.setValueAllRadios = /** * @param {?} value * @return {?} */ function (value) { var _this = this; this.radiosQueryList.forEach((/** * @param {?} radio * @return {?} */ function (radio) { if (radio.value !== value) { radio.isActive = false; } if (radio.value === value && !_this.canUncheck) { radio.isActive = true; } })); }; /** * @param {?} disabled * @return {?} */ RadioGroupComponent.prototype.disableAllRadios = /** * @param {?} disabled * @return {?} */ function (disabled) { this.radiosQueryList.forEach((/** * @param {?} radio * @return {?} */ function (radio) { radio.disabled = disabled; })); }; /** * @param {?} isDisabled * @return {?} */ RadioGroupComponent.prototype.setDisabledState = /** * @param {?} isDisabled * @return {?} */ function (isDisabled) { var _this = this; this.disabled = isDisabled; setTimeout((/** * @return {?} */ function () { _this.disableAllRadios(_this.disabled); }), 0); }; /** * @param {?} value * @return {?} */ RadioGroupComponent.prototype.writeValue = /** * @param {?} value * @return {?} */ function (value) { var _this = this; this.value = value; setTimeout((/** * @return {?} */ function () { _this.setValueAllRadios(_this.value); }), 0); }; /** * @param {?} fn * @return {?} */ RadioGroupComponent.prototype.registerOnChange = /** * @param {?} fn * @return {?} */ function (fn) { this.onChange = fn; }; /** * @param {?} fn * @return {?} */ RadioGroupComponent.prototype.registerOnTouched = /** * @param {?} fn * @return {?} */ function (fn) { this.onTouched = fn; }; /** * @param {?} value * @return {?} */ RadioGroupComponent.prototype.onChange = /** * @param {?} value * @return {?} */ function (value) { }; /** * @return {?} */ RadioGroupComponent.prototype.onTouched = /** * @return {?} */ function () { }; RadioGroupComponent.defaultProps = { canUncheck: false, className: '', disabled: false, name: '', required: false, value: '' }; RadioGroupComponent.decorators = [ { type: Component, args: [{ providers: [{ multi: true, provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((/** * @return {?} */ function () { return RadioGroupComponent; })) }], selector: config.components.prefix + "-radio-group }", template: "<div [ngClass]=\"[prefix + '-radio-group', className]\">\n <ng-content select=\"materialize-radio\"></ng-content>\n</div>\n" }] } ]; /** @nocollapse */ RadioGroupComponent.ctorParameters = function () { return []; }; RadioGroupComponent.propDecorators = { radiosQueryList: [{ type: ContentChildren, args: [RadioComponent,] }], onChangeEmitter: [{ type: Output, args: ['onChange',] }], canUncheck: [{ type: Input }], className: [{ type: Input }], disabled: [{ type: Input }], name: [{ type: Input }], required: [{ type: Input }], value: [{ type: Input }] }; return RadioGroupComponent; }()); export { RadioGroupComponent }; if (false) { /** @type {?} */ RadioGroupComponent.defaultProps; /** @type {?} */ RadioGroupComponent.prototype.radiosQueryList; /** @type {?} */ RadioGroupComponent.prototype.onChangeEmitter; /** @type {?} */ RadioGroupComponent.prototype.canUncheck; /** @type {?} */ RadioGroupComponent.prototype.className; /** @type {?} */ RadioGroupComponent.prototype.disabled; /** @type {?} */ RadioGroupComponent.prototype.name; /** @type {?} */ RadioGroupComponent.prototype.required; /** @type {?} */ RadioGroupComponent.prototype.value; /** @type {?} */ RadioGroupComponent.prototype.prefix; /** @type {?} */ RadioGroupComponent.prototype.isFocused; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-group.component.js","sourceRoot":"ng://materialize-angular/","sources":["app/completed-components/radio-group/radio-group.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Workylab. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://raw.githubusercontent.com/workylab/materialize-angular/master/LICENSE\n */\n\nimport {\n  AfterContentInit,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  forwardRef,\n  Input,\n  Output,\n  QueryList\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { config } from '../../config';\nimport { RadioComponent } from './radio/radio.component';\nimport { RadioGroupModel } from './radio-group.model';\n\n@Component({\n  providers: [{\n    multi: true,\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => RadioGroupComponent)\n  }],\n  selector: `${ config.components.prefix }-radio-group }`,\n  templateUrl: './radio-group.component.html'\n})\nexport class RadioGroupComponent implements AfterContentInit, ControlValueAccessor, RadioGroupModel {\n  static readonly defaultProps: RadioGroupModel = {\n    canUncheck: false,\n    className: '',\n    disabled: false,\n    name: '',\n    required: false,\n    value: ''\n  };\n\n  @ContentChildren(RadioComponent) radiosQueryList: QueryList<RadioComponent>;\n\n  @Output('onChange') onChangeEmitter: EventEmitter<string>;\n\n  @Input() canUncheck: boolean = RadioGroupComponent.defaultProps.canUncheck;\n  @Input() className: string = RadioGroupComponent.defaultProps.className;\n  @Input() disabled: boolean = RadioGroupComponent.defaultProps.disabled;\n  @Input() name: string = RadioGroupComponent.defaultProps.name;\n  @Input() required: boolean = RadioGroupComponent.defaultProps.required;\n  @Input() value: string = RadioGroupComponent.defaultProps.value;\n\n  public prefix = config.components.prefix;\n  public isFocused: boolean;\n\n  constructor() {\n    this.isFocused = false;\n\n    this.initRadios = this.initRadios.bind(this);\n    this.registerRadios = this.registerRadios.bind(this);\n    this.toggleRadios = this.toggleRadios.bind(this);\n\n    this.onChangeEmitter = new EventEmitter();\n  }\n\n  ngAfterContentInit() {\n    this.initRadios();\n\n    this.radiosQueryList.changes.subscribe(this.initRadios);\n  }\n\n  initRadios() {\n    this.disableAllRadios(this.disabled);\n\n    setTimeout(this.registerRadios, 0);\n  }\n\n  registerRadios() {\n    this.radiosQueryList.forEach(radio => {\n      radio.isActive = (radio.value === this.value);\n\n      radio.onClickEmitter.subscribe(this.toggleRadios);\n    });\n  }\n\n  toggleRadios(value: string) {\n    this.setValueAllRadios(value);\n\n    const currentRadio = this.radiosQueryList.find(radio => radio.value === value);\n\n    this.value = currentRadio && currentRadio.isActive\n      ? currentRadio.value\n      : '';\n\n    this.onTouched();\n    this.onChange(this.value);\n\n    this.onChangeEmitter.emit(this.value);\n  }\n\n  setValueAllRadios(value: string) {\n    this.radiosQueryList.forEach(radio => {\n      if (radio.value !== value) {\n        radio.isActive = false;\n      }\n\n      if (radio.value === value && !this.canUncheck) {\n        radio.isActive = true;\n      }\n    });\n  }\n\n  disableAllRadios(disabled: boolean) {\n    this.radiosQueryList.forEach(radio => {\n      radio.disabled = disabled;\n    });\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n\n    setTimeout(() => {\n      this.disableAllRadios(this.disabled);\n    }, 0);\n  }\n\n  writeValue(value: string): void {\n    this.value = value;\n\n    setTimeout(() => {\n      this.setValueAllRadios(this.value);\n    }, 0);\n  }\n\n  registerOnChange(fn: (value: string) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  onChange(value: string): void {\n  }\n\n  onTouched(): void {}\n}\n"]}