@stratio/egeo
Version:
570 lines • 39.2 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: lib/st-radio/st-radio.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/*
* © 2017 Stratio Big Data Inc., Sucursal en España.
*
* This software is licensed under the Apache License, Version 2.0.
* This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the terms of the License for more details.
*
* SPDX-License-Identifier: Apache-2.0.
*/
import { Component, Input, EventEmitter, Output, Optional, forwardRef, Directive, ContentChildren, QueryList } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { RadioChange } from './st-radio.change';
import { SelectOneDispatcher } from '../utils/unique-dispatcher';
/** @type {?} */
export var MD_RADIO_GROUP_CONTROL_VALUE_ACCESSOR = {
provide: NG_VALUE_ACCESSOR,
// tslint:disable-next-line:no-use-before-declare
useExisting: forwardRef((/**
* @return {?}
*/
function () { return StRadioGroupComponent; })),
multi: true
};
/** @type {?} */
var _uniqueIdCounter = 0;
// tslint:disable-next-line:max-classes-per-file
var StRadioGroupComponent = /** @class */ (function () {
function StRadioGroupComponent() {
this.change = new EventEmitter();
// tslint:disable-next-line:no-use-before-declare
this._radios = null;
this._value = null;
this._selected = null;
this._disabled = false;
this._name = "st-radio-group-" + _uniqueIdCounter++;
this._controlValueAccessorChangeFn = (/**
* @param {?} value
* @return {?}
*/
function (value) { });
this.onTouched = (/**
* @return {?}
*/
function () { });
}
Object.defineProperty(StRadioGroupComponent.prototype, "value", {
get: /**
* @return {?}
*/
function () {
return this._value;
},
set: /**
* @param {?} newValue
* @return {?}
*/
function (newValue) {
if (this._value !== newValue) {
this._value = newValue;
}
this.updatedSelectRadioFromValue();
this.checkSelectRadio();
},
enumerable: true,
configurable: true
});
Object.defineProperty(StRadioGroupComponent.prototype, "name", {
get: /**
* @return {?}
*/
function () {
return this._name;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._name = value;
this.updateRadioName();
},
enumerable: true,
configurable: true
});
Object.defineProperty(StRadioGroupComponent.prototype, "selected", {
get: /**
* @return {?}
*/
function () {
return this._selected;
},
set: /**
* @param {?} selected
* @return {?}
*/
function (selected) {
this._selected = selected;
this.value = selected ? selected.value : null;
this.checkSelectRadio();
},
enumerable: true,
configurable: true
});
Object.defineProperty(StRadioGroupComponent.prototype, "disabled", {
get: /**
* @return {?}
*/
function () { return this._disabled; },
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._disabled = (value != null && value !== false) ? true : null;
},
enumerable: true,
configurable: true
});
/**
* @param {?} value
* @return {?}
*/
StRadioGroupComponent.prototype.writeValue = /**
* @param {?} value
* @return {?}
*/
function (value) {
this.value = value;
};
/**
* @param {?} fn
* @return {?}
*/
StRadioGroupComponent.prototype.registerOnChange = /**
* @param {?} fn
* @return {?}
*/
function (fn) {
this._controlValueAccessorChangeFn = fn;
};
/**
* @param {?} fn
* @return {?}
*/
StRadioGroupComponent.prototype.registerOnTouched = /**
* @param {?} fn
* @return {?}
*/
function (fn) {
this.onTouched = fn;
};
/**
* @return {?}
*/
StRadioGroupComponent.prototype.emitChangeEvent = /**
* @return {?}
*/
function () {
/** @type {?} */
var event = new RadioChange();
event.source = this._selected;
event.value = this._value;
this.change.emit(event);
};
/**
* @return {?}
*/
StRadioGroupComponent.prototype.checkSelectRadio = /**
* @return {?}
*/
function () {
if (this.selected && !this._selected.checked) {
this._selected.checked = true;
}
};
/**
* @return {?}
*/
StRadioGroupComponent.prototype.touch = /**
* @return {?}
*/
function () {
if (this.onTouched) {
this.onTouched();
}
};
/**
* @param {?} isDisabled
* @return {?}
*/
StRadioGroupComponent.prototype.setDisabledState = /**
* @param {?} isDisabled
* @return {?}
*/
function (isDisabled) {
this.disabled = isDisabled;
};
/**
* @private
* @return {?}
*/
StRadioGroupComponent.prototype.updateRadioName = /**
* @private
* @return {?}
*/
function () {
var _this = this;
if (this._radios) {
this._radios.forEach((/**
* @param {?} radio
* @return {?}
*/
function (radio) {
radio.name = _this.name;
}));
}
};
/**
* @private
* @return {?}
*/
StRadioGroupComponent.prototype.updatedSelectRadioFromValue = /**
* @private
* @return {?}
*/
function () {
var _this = this;
/** @type {?} */
var isAlreadySelected = this._selected != null && this._selected.value === this._value;
if (this._radios != null && !isAlreadySelected) {
this._selected = null;
this._radios.forEach((/**
* @param {?} radio
* @return {?}
*/
function (radio) {
radio.checked = _this.value === radio.value;
if (radio.checked) {
_this._selected = radio;
}
}));
}
};
StRadioGroupComponent.decorators = [
{ type: Directive, args: [{
selector: 'st-radio-group',
providers: [MD_RADIO_GROUP_CONTROL_VALUE_ACCESSOR],
host: {
role: 'radiogroup'
}
},] }
];
/** @nocollapse */
StRadioGroupComponent.ctorParameters = function () { return []; };
StRadioGroupComponent.propDecorators = {
change: [{ type: Output }],
qaTag: [{ type: Input }],
value: [{ type: Input }],
name: [{ type: Input }],
selected: [{ type: Input }],
disabled: [{ type: Input }],
_radios: [{ type: ContentChildren, args: [forwardRef((/**
* @return {?}
*/
function () { return StRadioComponent; })), { descendants: true },] }]
};
return StRadioGroupComponent;
}());
export { StRadioGroupComponent };
if (false) {
/** @type {?} */
StRadioGroupComponent.prototype.change;
/** @type {?} */
StRadioGroupComponent.prototype.qaTag;
/** @type {?} */
StRadioGroupComponent.prototype._radios;
/** @type {?} */
StRadioGroupComponent.prototype._value;
/** @type {?} */
StRadioGroupComponent.prototype._selected;
/** @type {?} */
StRadioGroupComponent.prototype._disabled;
/** @type {?} */
StRadioGroupComponent.prototype._name;
/** @type {?} */
StRadioGroupComponent.prototype._controlValueAccessorChangeFn;
/** @type {?} */
StRadioGroupComponent.prototype.onTouched;
}
/** @type {?} */
var idUnique = 0;
/**
* \@description {Component} [Radio]
*
* The radio component is used normally in a form acting as the standard html radio input but also user can use it out of a form like a template driven form.
*
* \@example
*
* {html}
*
* ```
* <st-radio-group class ="radio-inline">
* <st-radio value="1">Enabled</st-radio>
* <st-radio value="2" [disabled]="true">Disabled</st-radio>
* <st-radio value="2" [checked]= "true" [disabled]="true">Disabled checked</st-radio>
* </st-radio-group>
* ```
*
*/
var StRadioComponent = /** @class */ (function () {
function StRadioComponent(radioGroup, _radioDispatcher) {
var _this = this;
this._radioDispatcher = _radioDispatcher;
/**
* \@Input {string} [id='st-radio-<unique id>'] Input Id value
*/
this.id = "st-radio-" + idUnique++;
/**
* \@Input {string} [qaTag='st-radio-<unique id>'] Id value for qa test
*/
this.qaTag = "st-radio-" + idUnique++;
/**
* \@Output {boolean} [change=''] Boolean emitted when radio button is changed
*/
this.change = new EventEmitter();
this._value = null;
this.radioGroup = radioGroup;
_radioDispatcher.listen((/**
* @param {?} id
* @param {?} name
* @return {?}
*/
function (id, name) {
if (id !== _this.id && name === _this.name) {
_this.checked = false;
}
}));
}
Object.defineProperty(StRadioComponent.prototype, "checked", {
/** @Input {boolean} [checked=''] Boolean to check the radio button */
get: /**
* \@Input {boolean} [checked=''] Boolean to check the radio button
* @return {?}
*/
function () {
return this._checked;
},
set: /**
* @param {?} newCheckedState
* @return {?}
*/
function (newCheckedState) {
if (this._checked !== newCheckedState) {
this._checked = newCheckedState;
}
if (newCheckedState && this.radioGroup && this.radioGroup.value !== this.value) {
this.radioGroup.selected = this;
}
else if (!newCheckedState && this.radioGroup && this.radioGroup.value === this.value) {
this.radioGroup.selected = null;
}
if (newCheckedState) {
this._radioDispatcher.notify(this.id, this.name);
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(StRadioComponent.prototype, "disabled", {
/** @Input {boolean} [disabled=''] Boolean to disable the radio button */
get: /**
* \@Input {boolean} [disabled=''] Boolean to disable the radio button
* @return {?}
*/
function () {
return this._disabled || (this.radioGroup != null && this.radioGroup.disabled);
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._disabled = (value != null && value !== false) ? true : null;
},
enumerable: true,
configurable: true
});
Object.defineProperty(StRadioComponent.prototype, "value", {
/** @Input {boolean} [value=''] Value of the radio button */
get: /**
* \@Input {boolean} [value=''] Value of the radio button
* @return {?}
*/
function () {
return this._value;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
if (this._value !== value) {
this._value = value;
if (this.radioGroup != null) {
if (!this.checked) {
this.checked = this.radioGroup.value === value;
}
else {
this.radioGroup.selected = null;
}
}
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(StRadioComponent.prototype, "inputId", {
get: /**
* @return {?}
*/
function () {
return this.id + "-input";
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
StRadioComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
if (this.radioGroup && this.radioGroup.value) {
this.checked = this.radioGroup.value === this._value;
}
if (this.radioGroup) {
this.name = this.radioGroup.name;
}
};
/**
* @return {?}
*/
StRadioComponent.prototype.onInputBlur = /**
* @return {?}
*/
function () {
if (this.radioGroup) {
this.radioGroup.touch();
}
};
/**
* @param {?} event
* @return {?}
*/
StRadioComponent.prototype.onInputClick = /**
* @param {?} event
* @return {?}
*/
function (event) {
event.stopPropagation();
};
/**
* @param {?} event
* @return {?}
*/
StRadioComponent.prototype.toggleRadio = /**
* @param {?} event
* @return {?}
*/
function (event) {
event.stopPropagation();
/** @type {?} */
var groupValueChanged = this.radioGroup && this.value !== this.radioGroup.value;
if (!this.disabled) {
this.checked = !this.checked;
this.emitChangeEvent();
}
if (this.radioGroup) {
this.radioGroup._controlValueAccessorChangeFn(this.value);
if (groupValueChanged) {
this.radioGroup.emitChangeEvent();
}
}
};
/**
* @private
* @return {?}
*/
StRadioComponent.prototype.emitChangeEvent = /**
* @private
* @return {?}
*/
function () {
/** @type {?} */
var event = new RadioChange();
event.source = this;
event.value = this._value;
this.change.emit(event);
};
StRadioComponent.decorators = [
{ type: Component, args: [{
selector: 'st-radio',
template: "<!--\n\n \u00A9 2017 Stratio Big Data Inc., Sucursal en Espa\u00F1a.\n\n This software is licensed under the Apache License, Version 2.0.\n This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;\n without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n See the terms of the License for more details.\n\n SPDX-License-Identifier: Apache-2.0.\n\n-->\n<label [attr.for]=\"inputId\" class=\"st-radio\" [ngClass]=\"{'disabled': disabled}\" #label [attr.id]=\"qaTag\">\n <input\n type=\"radio\"\n [id]=\"inputId\"\n [attr.id]=\"\"\n [name]=\"name\"\n [hidden]=\"true\"\n [checked]=\"checked\"\n [disabled]=\"disabled\"\n (blur)=\"onInputBlur()\"\n (change)=\"toggleRadio($event)\"\n (click)=\"onInputClick($event)\"\n [value]=\"value\">\n\n <div class=\"custom-radio\" [ngClass]=\"{'checked' : checked, 'disabled': disabled}\"></div>\n <ng-content></ng-content>\n</label>\n",
host: {
'[class.sth-radio-checked]': 'checked',
'[attr.id]': 'id'
},
styles: ["@charset \"UTF-8\";.st-radio{box-sizing:border-box;display:flex;align-content:center;align-items:center;cursor:pointer}.st-radio.disabled .custom-radio{cursor:default}.st-radio .custom-radio{width:15px;height:15px;cursor:pointer;display:inline-block;border-radius:100%;text-align:center;position:relative;box-sizing:border-box;margin-right:5px}.st-radio .custom-radio.checked:before{display:block;position:absolute;content:'';border-radius:100%;height:5px;width:5px;top:4px;left:4px;margin:auto;box-sizing:border-box}"]
}] }
];
/** @nocollapse */
StRadioComponent.ctorParameters = function () { return [
{ type: StRadioGroupComponent, decorators: [{ type: Optional }] },
{ type: SelectOneDispatcher }
]; };
StRadioComponent.propDecorators = {
id: [{ type: Input }],
qaTag: [{ type: Input }],
name: [{ type: Input }],
checked: [{ type: Input }],
disabled: [{ type: Input }],
value: [{ type: Input }],
change: [{ type: Output }]
};
return StRadioComponent;
}());
export { StRadioComponent };
if (false) {
/** @type {?} */
StRadioComponent.prototype.radioGroup;
/**
* \@Input {string} [id='st-radio-<unique id>'] Input Id value
* @type {?}
*/
StRadioComponent.prototype.id;
/**
* \@Input {string} [qaTag='st-radio-<unique id>'] Id value for qa test
* @type {?}
*/
StRadioComponent.prototype.qaTag;
/**
* \@Input {string} [name=''] Input name value
* @type {?}
*/
StRadioComponent.prototype.name;
/**
* \@Output {boolean} [change=''] Boolean emitted when radio button is changed
* @type {?}
*/
StRadioComponent.prototype.change;
/** @type {?} */
StRadioComponent.prototype._value;
/** @type {?} */
StRadioComponent.prototype._checked;
/** @type {?} */
StRadioComponent.prototype._disabled;
/**
* @type {?}
* @private
*/
StRadioComponent.prototype._radioDispatcher;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"st-radio.component.js","sourceRoot":"ng://@stratio/egeo/","sources":["lib/st-radio/st-radio.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * © 2017 Stratio Big Data Inc., Sucursal en España.\n *\n * This software is licensed under the Apache License, Version 2.0.\n * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;\n * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n * See the terms of the License for more details.\n *\n * SPDX-License-Identifier: Apache-2.0.\n */\nimport {\n   Component,\n   Input,\n   EventEmitter,\n   Output,\n   OnInit,\n   Optional, forwardRef, Directive, ContentChildren, QueryList\n} from '@angular/core';\n\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { RadioChange } from './st-radio.change';\nimport { SelectOneDispatcher } from '../utils/unique-dispatcher';\n\nexport const MD_RADIO_GROUP_CONTROL_VALUE_ACCESSOR: any = {\n   provide: NG_VALUE_ACCESSOR,\n   // tslint:disable-next-line:no-use-before-declare\n   useExisting: forwardRef(() => StRadioGroupComponent),\n   multi: true\n};\n\nlet _uniqueIdCounter = 0;\n\n// tslint:disable-next-line:max-classes-per-file\n@Directive({\n   selector: 'st-radio-group',\n   providers: [MD_RADIO_GROUP_CONTROL_VALUE_ACCESSOR],\n   host: {\n      role: 'radiogroup'\n   }\n})\nexport class StRadioGroupComponent implements ControlValueAccessor {\n\n   @Output()\n   change: EventEmitter<RadioChange> = new EventEmitter<RadioChange>();\n\n   @Input()\n   qaTag: string;\n\n   @Input()\n   get value(): any {\n      return this._value;\n   }\n\n   set value(newValue: any) {\n      if (this._value !== newValue) {\n         this._value = newValue;\n      }\n\n      this.updatedSelectRadioFromValue();\n      this.checkSelectRadio();\n   }\n\n   @Input()\n   get name(): string {\n      return this._name;\n   }\n\n   set name(value: string) {\n      this._name = value;\n      this.updateRadioName();\n   }\n\n   @Input()\n   get selected(): StRadioComponent {\n      return this._selected;\n   }\n   set selected(selected: StRadioComponent) {\n      this._selected = selected;\n      this.value = selected ? selected.value : null;\n      this.checkSelectRadio();\n   }\n\n   @Input()\n   get disabled(): boolean { return this._disabled; }\n   set disabled(value: boolean) {\n      this._disabled = (value != null && value !== false) ? true : null;\n   }\n\n   // tslint:disable-next-line:no-use-before-declare\n   @ContentChildren(forwardRef(() => StRadioComponent), { descendants: true })\n   _radios: QueryList<StRadioComponent> = null;\n\n   _value: any = null;\n   _selected: StRadioComponent = null;\n   _disabled: boolean = false;\n   _name: string = `st-radio-group-${_uniqueIdCounter++}`;\n\n   constructor(\n   ) { }\n\n   _controlValueAccessorChangeFn: (value: any) => void = (value) => { };\n\n   onTouched: () => any = () => { };\n\n   writeValue(value: any): void {\n      this.value = value;\n   }\n\n   registerOnChange(fn: (value: any) => void): void {\n      this._controlValueAccessorChangeFn = fn;\n   }\n\n   registerOnTouched(fn: any): void {\n      this.onTouched = fn;\n   }\n\n   emitChangeEvent(): void {\n      let event = new RadioChange();\n      event.source = this._selected;\n      event.value = this._value;\n      this.change.emit(event);\n   }\n\n   checkSelectRadio(): void {\n      if (this.selected && !this._selected.checked) {\n         this._selected.checked = true;\n      }\n   }\n\n   touch(): void {\n      if (this.onTouched) {\n         this.onTouched();\n      }\n   }\n\n   setDisabledState(isDisabled: boolean): void {\n      this.disabled = isDisabled;\n   }\n\n   private updateRadioName(): void {\n      if (this._radios) {\n         this._radios.forEach((radio) => {\n            radio.name = this.name;\n         });\n      }\n   }\n\n   private updatedSelectRadioFromValue(): void {\n      let isAlreadySelected = this._selected != null && this._selected.value === this._value;\n\n      if (this._radios != null && !isAlreadySelected) {\n         this._selected = null;\n         this._radios.forEach((radio) => {\n            radio.checked = this.value === radio.value;\n            if (radio.checked) {\n               this._selected = radio;\n            }\n         });\n      }\n   }\n}\n\n\nlet idUnique: number = 0;\n\n/**\n * @description {Component} [Radio]\n *\n * The radio component is used normally in a form acting as the standard html radio input but also user can use it out of a form like a template driven form.\n *\n * @example\n *\n * {html}\n *\n * ```\n * <st-radio-group class =\"radio-inline\">\n *    <st-radio value=\"1\">Enabled</st-radio>\n *    <st-radio value=\"2\" [disabled]=\"true\">Disabled</st-radio>\n *    <st-radio value=\"2\" [checked]= \"true\" [disabled]=\"true\">Disabled checked</st-radio>\n * </st-radio-group>\n * ```\n *\n */\n@Component({\n   selector: 'st-radio',\n   templateUrl: './st-radio.component.html',\n   styleUrls: ['./st-radio.component.scss'],\n   host: {\n      '[class.sth-radio-checked]': 'checked',\n      '[attr.id]': 'id'\n   }\n})\nexport class StRadioComponent implements OnInit {\n\n   radioGroup: StRadioGroupComponent;\n   /** @Input {string} [id='st-radio-<unique id>'] Input Id value */\n   @Input() id: string = `st-radio-${idUnique++}`;\n   /** @Input {string} [qaTag='st-radio-<unique id>'] Id value for qa test */\n   @Input() qaTag: string = `st-radio-${idUnique++}`;\n   /** @Input {string} [name=''] Input name value */\n   @Input() name: string;\n   /** @Input {boolean} [checked=''] Boolean to check the radio button */\n   @Input()\n   get checked(): boolean {\n      return this._checked;\n   }\n\n   set checked(newCheckedState: boolean) {\n\n      if (this._checked !== newCheckedState) {\n         this._checked = newCheckedState;\n      }\n\n      if (newCheckedState && this.radioGroup && this.radioGroup.value !== this.value) {\n         this.radioGroup.selected = this;\n      } else if (!newCheckedState && this.radioGroup && this.radioGroup.value === this.value) {\n         this.radioGroup.selected = null;\n      }\n\n      if (newCheckedState) {\n         this._radioDispatcher.notify(this.id, this.name);\n      }\n   }\n   /** @Input {boolean} [disabled=''] Boolean to disable the radio button */\n   @Input()\n   get disabled(): boolean {\n      return this._disabled || (this.radioGroup != null && this.radioGroup.disabled);\n   }\n\n   set disabled(value: boolean) {\n      this._disabled = (value != null && value !== false) ? true : null;\n   }\n   /** @Input {boolean} [value=''] Value of the radio button */\n   @Input()\n   get value(): any {\n      return this._value;\n   }\n\n   set value(value: any) {\n      if (this._value !== value) {\n         this._value = value;\n\n         if (this.radioGroup != null) {\n            if (!this.checked) {\n               this.checked = this.radioGroup.value === value;\n            } else {\n               this.radioGroup.selected = null;\n            }\n         }\n      }\n   }\n\n   /** @Output {boolean} [change=''] Boolean emitted when radio button is changed */\n   @Output() change: EventEmitter<RadioChange> = new EventEmitter<RadioChange>();\n\n   get inputId(): string {\n      return `${this.id}-input`;\n   }\n\n   _value: any = null;\n   _checked: boolean;\n   _disabled: boolean;\n\n   constructor(\n      @Optional() radioGroup: StRadioGroupComponent,\n      private _radioDispatcher: SelectOneDispatcher\n   ) {\n\n      this.radioGroup = radioGroup;\n      _radioDispatcher.listen((id: string, name: string) => {\n         if (id !== this.id && name === this.name) {\n            this.checked = false;\n         }\n      });\n   }\n\n   ngOnInit(): void {\n      if (this.radioGroup && this.radioGroup.value) {\n         this.checked = this.radioGroup.value === this._value;\n      }\n\n      if (this.radioGroup) {\n         this.name = this.radioGroup.name;\n      }\n   }\n\n   onInputBlur(): void {\n      if (this.radioGroup) {\n         this.radioGroup.touch();\n      }\n   }\n\n   onInputClick(event: Event): void {\n      event.stopPropagation();\n   }\n\n   toggleRadio(event: Event): void {\n      event.stopPropagation();\n      let groupValueChanged = this.radioGroup && this.value !== this.radioGroup.value;\n\n      if (!this.disabled) {\n         this.checked = !this.checked;\n         this.emitChangeEvent();\n      }\n\n      if (this.radioGroup) {\n         this.radioGroup._controlValueAccessorChangeFn(this.value);\n\n         if (groupValueChanged) {\n            this.radioGroup.emitChangeEvent();\n         }\n      }\n   }\n\n   private emitChangeEvent(): void {\n      let event = new RadioChange();\n      event.source = this;\n      event.value = this._value;\n      this.change.emit(event);\n   }\n}\n"]}