angular2
Version:
Angular 2 - a web framework for modern web apps
123 lines • 16 kB
JavaScript
;var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
var __metadata = (this && this.__metadata) || function (k, v) {
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
};
var core_1 = require('angular2/core');
var control_value_accessor_1 = require('angular2/src/common/forms/directives/control_value_accessor');
var ng_control_1 = require('angular2/src/common/forms/directives/ng_control');
var lang_1 = require('angular2/src/facade/lang');
var collection_1 = require('angular2/src/facade/collection');
var RADIO_VALUE_ACCESSOR = lang_1.CONST_EXPR(new core_1.Provider(control_value_accessor_1.NG_VALUE_ACCESSOR, { useExisting: core_1.forwardRef(function () { return RadioControlValueAccessor; }), multi: true }));
/**
* Internal class used by Angular to uncheck radio buttons with the matching name.
*/
var RadioControlRegistry = (function () {
function RadioControlRegistry() {
this._accessors = [];
}
RadioControlRegistry.prototype.add = function (control, accessor) {
this._accessors.push([control, accessor]);
};
RadioControlRegistry.prototype.remove = function (accessor) {
var indexToRemove = -1;
for (var i = 0; i < this._accessors.length; ++i) {
if (this._accessors[i][1] === accessor) {
indexToRemove = i;
}
}
collection_1.ListWrapper.removeAt(this._accessors, indexToRemove);
};
RadioControlRegistry.prototype.select = function (accessor) {
this._accessors.forEach(function (c) {
if (c[0].control.root === accessor._control.control.root && c[1] !== accessor) {
c[1].fireUncheck();
}
});
};
RadioControlRegistry = __decorate([
core_1.Injectable(),
__metadata('design:paramtypes', [])
], RadioControlRegistry);
return RadioControlRegistry;
})();
exports.RadioControlRegistry = RadioControlRegistry;
/**
* The value provided by the forms API for radio buttons.
*/
var RadioButtonState = (function () {
function RadioButtonState(checked, value) {
this.checked = checked;
this.value = value;
}
return RadioButtonState;
})();
exports.RadioButtonState = RadioButtonState;
/**
* The accessor for writing a radio control value and listening to changes that is used by the
* {@link NgModel}, {@link NgFormControl}, and {@link NgControlName} directives.
*
* ### Example
* ```
* @Component({
* template: `
* <input type="radio" name="food" [(ngModel)]="foodChicken">
* <input type="radio" name="food" [(ngModel)]="foodFish">
* `
* })
* class FoodCmp {
* foodChicken = new RadioButtonState(true, "chicken");
* foodFish = new RadioButtonState(false, "fish");
* }
* ```
*/
var RadioControlValueAccessor = (function () {
function RadioControlValueAccessor(_renderer, _elementRef, _registry, _injector) {
this._renderer = _renderer;
this._elementRef = _elementRef;
this._registry = _registry;
this._injector = _injector;
this.onChange = function () { };
this.onTouched = function () { };
}
RadioControlValueAccessor.prototype.ngOnInit = function () {
this._control = this._injector.get(ng_control_1.NgControl);
this._registry.add(this._control, this);
};
RadioControlValueAccessor.prototype.ngOnDestroy = function () { this._registry.remove(this); };
RadioControlValueAccessor.prototype.writeValue = function (value) {
this._state = value;
if (lang_1.isPresent(value) && value.checked) {
this._renderer.setElementProperty(this._elementRef.nativeElement, 'checked', true);
}
};
RadioControlValueAccessor.prototype.registerOnChange = function (fn) {
var _this = this;
this._fn = fn;
this.onChange = function () {
fn(new RadioButtonState(true, _this._state.value));
_this._registry.select(_this);
};
};
RadioControlValueAccessor.prototype.fireUncheck = function () { this._fn(new RadioButtonState(false, this._state.value)); };
RadioControlValueAccessor.prototype.registerOnTouched = function (fn) { this.onTouched = fn; };
__decorate([
core_1.Input(),
__metadata('design:type', String)
], RadioControlValueAccessor.prototype, "name", void 0);
RadioControlValueAccessor = __decorate([
core_1.Directive({
selector: 'input[type=radio][ngControl],input[type=radio][ngFormControl],input[type=radio][ngModel]',
host: { '(change)': 'onChange()', '(blur)': 'onTouched()' },
providers: [RADIO_VALUE_ACCESSOR]
}),
__metadata('design:paramtypes', [core_1.Renderer, core_1.ElementRef, RadioControlRegistry, core_1.Injector])
], RadioControlValueAccessor);
return RadioControlValueAccessor;
})();
exports.RadioControlValueAccessor = RadioControlValueAccessor;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio_control_value_accessor.js","sourceRoot":"","sources":["angular2/src/common/forms/directives/radio_control_value_accessor.ts"],"names":["RadioControlRegistry","RadioControlRegistry.constructor","RadioControlRegistry.add","RadioControlRegistry.remove","RadioControlRegistry.select","RadioButtonState","RadioButtonState.constructor","RadioControlValueAccessor","RadioControlValueAccessor.constructor","RadioControlValueAccessor.ngOnInit","RadioControlValueAccessor.ngOnDestroy","RadioControlValueAccessor.writeValue","RadioControlValueAccessor.registerOnChange","RadioControlValueAccessor.fireUncheck","RadioControlValueAccessor.registerOnTouched"],"mappings":"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","sourcesContent":["import {\n  Directive,\n  ElementRef,\n  Renderer,\n  Self,\n  forwardRef,\n  Provider,\n  Attribute,\n  Input,\n  OnInit,\n  OnDestroy,\n  Injector,\n  Injectable\n} from 'angular2/core';\nimport {\n  NG_VALUE_ACCESSOR,\n  ControlValueAccessor\n} from 'angular2/src/common/forms/directives/control_value_accessor';\nimport {NgControl} from 'angular2/src/common/forms/directives/ng_control';\nimport {CONST_EXPR, looseIdentical, isPresent} from 'angular2/src/facade/lang';\nimport {ListWrapper} from 'angular2/src/facade/collection';\n\nconst RADIO_VALUE_ACCESSOR = CONST_EXPR(new Provider(\n    NG_VALUE_ACCESSOR, {useExisting: forwardRef(() => RadioControlValueAccessor), multi: true}));\n\n\n/**\n * Internal class used by Angular to uncheck radio buttons with the matching name.\n */\n@Injectable()\nexport class RadioControlRegistry {\n  private _accessors: any[] = [];\n\n  add(control: NgControl, accessor: RadioControlValueAccessor) {\n    this._accessors.push([control, accessor]);\n  }\n\n  remove(accessor: RadioControlValueAccessor) {\n    var indexToRemove = -1;\n    for (var i = 0; i < this._accessors.length; ++i) {\n      if (this._accessors[i][1] === accessor) {\n        indexToRemove = i;\n      }\n    }\n    ListWrapper.removeAt(this._accessors, indexToRemove);\n  }\n\n  select(accessor: RadioControlValueAccessor) {\n    this._accessors.forEach((c) => {\n      if (c[0].control.root === accessor._control.control.root && c[1] !== accessor) {\n        c[1].fireUncheck();\n      }\n    });\n  }\n}\n\n/**\n * The value provided by the forms API for radio buttons.\n */\nexport class RadioButtonState {\n  constructor(public checked: boolean, public value: string) {}\n}\n\n\n/**\n * The accessor for writing a radio control value and listening to changes that is used by the\n * {@link NgModel}, {@link NgFormControl}, and {@link NgControlName} directives.\n *\n *  ### Example\n *  ```\n *  @Component({\n *    template: `\n *      <input type=\"radio\" name=\"food\" [(ngModel)]=\"foodChicken\">\n *      <input type=\"radio\" name=\"food\" [(ngModel)]=\"foodFish\">\n *    `\n *  })\n *  class FoodCmp {\n *    foodChicken = new RadioButtonState(true, \"chicken\");\n *    foodFish = new RadioButtonState(false, \"fish\");\n *  }\n *  ```\n */\n@Directive({\n  selector:\n      'input[type=radio][ngControl],input[type=radio][ngFormControl],input[type=radio][ngModel]',\n  host: {'(change)': 'onChange()', '(blur)': 'onTouched()'},\n  providers: [RADIO_VALUE_ACCESSOR]\n})\nexport class RadioControlValueAccessor implements ControlValueAccessor,\n    OnDestroy, OnInit {\n  _state: RadioButtonState;\n  _control: NgControl;\n  @Input() name: string;\n  _fn: Function;\n  onChange = () => {};\n  onTouched = () => {};\n\n  constructor(private _renderer: Renderer, private _elementRef: ElementRef,\n              private _registry: RadioControlRegistry, private _injector: Injector) {}\n\n  ngOnInit(): void {\n    this._control = this._injector.get(NgControl);\n    this._registry.add(this._control, this);\n  }\n\n  ngOnDestroy(): void { this._registry.remove(this); }\n\n  writeValue(value: any): void {\n    this._state = value;\n    if (isPresent(value) && value.checked) {\n      this._renderer.setElementProperty(this._elementRef.nativeElement, 'checked', true);\n    }\n  }\n\n  registerOnChange(fn: (_: any) => {}): void {\n    this._fn = fn;\n    this.onChange = () => {\n      fn(new RadioButtonState(true, this._state.value));\n      this._registry.select(this);\n    };\n  }\n\n  fireUncheck(): void { this._fn(new RadioButtonState(false, this._state.value)); }\n\n  registerOnTouched(fn: () => {}): void { this.onTouched = fn; }\n}\n"]}