UNPKG

angular2

Version:

Angular 2 - a web framework for modern web apps

116 lines 13.8 kB
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); }; import { Directive, ElementRef, Renderer, forwardRef, Provider, Input, Injector, Injectable } from 'angular2/core'; import { NG_VALUE_ACCESSOR } from 'angular2/src/common/forms/directives/control_value_accessor'; import { NgControl } from 'angular2/src/common/forms/directives/ng_control'; import { CONST_EXPR, isPresent } from 'angular2/src/facade/lang'; import { ListWrapper } from 'angular2/src/facade/collection'; const RADIO_VALUE_ACCESSOR = CONST_EXPR(new Provider(NG_VALUE_ACCESSOR, { useExisting: forwardRef(() => RadioControlValueAccessor), multi: true })); /** * Internal class used by Angular to uncheck radio buttons with the matching name. */ export let RadioControlRegistry = class RadioControlRegistry { constructor() { this._accessors = []; } add(control, accessor) { this._accessors.push([control, accessor]); } remove(accessor) { var indexToRemove = -1; for (var i = 0; i < this._accessors.length; ++i) { if (this._accessors[i][1] === accessor) { indexToRemove = i; } } ListWrapper.removeAt(this._accessors, indexToRemove); } select(accessor) { this._accessors.forEach((c) => { if (c[0].control.root === accessor._control.control.root && c[1] !== accessor) { c[1].fireUncheck(); } }); } }; RadioControlRegistry = __decorate([ Injectable(), __metadata('design:paramtypes', []) ], RadioControlRegistry); /** * The value provided by the forms API for radio buttons. */ export class RadioButtonState { constructor(checked, value) { this.checked = checked; this.value = value; } } /** * 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"); * } * ``` */ export let RadioControlValueAccessor = class RadioControlValueAccessor { constructor(_renderer, _elementRef, _registry, _injector) { this._renderer = _renderer; this._elementRef = _elementRef; this._registry = _registry; this._injector = _injector; this.onChange = () => { }; this.onTouched = () => { }; } ngOnInit() { this._control = this._injector.get(NgControl); this._registry.add(this._control, this); } ngOnDestroy() { this._registry.remove(this); } writeValue(value) { this._state = value; if (isPresent(value) && value.checked) { this._renderer.setElementProperty(this._elementRef.nativeElement, 'checked', true); } } registerOnChange(fn) { this._fn = fn; this.onChange = () => { fn(new RadioButtonState(true, this._state.value)); this._registry.select(this); }; } fireUncheck() { this._fn(new RadioButtonState(false, this._state.value)); } registerOnTouched(fn) { this.onTouched = fn; } }; __decorate([ Input(), __metadata('design:type', String) ], RadioControlValueAccessor.prototype, "name", void 0); RadioControlValueAccessor = __decorate([ 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', [Renderer, ElementRef, RadioControlRegistry, Injector]) ], RadioControlValueAccessor); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio_control_value_accessor.js","sourceRoot":"","sources":["diffing_plugin_wrapper-output_path-xBLIBrVR.tmp/angular2/src/common/forms/directives/radio_control_value_accessor.ts"],"names":[],"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  /** @internal */\n  _state: RadioButtonState;\n  /** @internal */\n  _control: NgControl;\n  @Input() name: string;\n  /** @internal */\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"]}