Skip to content

Commit

Permalink
feat(buttons): update radio button directive to work with ReactiveForms
Browse files Browse the repository at this point in the history
  • Loading branch information
thecontrarycat authored and jtomaszewski committed Oct 22, 2016
1 parent 94f58b7 commit 6b89494
Showing 1 changed file with 51 additions and 49 deletions.
100 changes: 51 additions & 49 deletions components/buttons/button-radio.directive.ts
Original file line number Diff line number Diff line change
@@ -1,67 +1,69 @@
import {
Directive, ElementRef, HostBinding, HostListener, Input, OnInit, Self
Directive, ElementRef, HostBinding, forwardRef, HostListener, Input, OnInit
} from '@angular/core';
import { ControlValueAccessor, NgModel } from '@angular/forms';
import { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';

// TODO: if uncheckable, null should be set to ngModel
// if disabled, button should not be checkable
/*tslint:disable*/
export const RADIO_CONTROL_VALUE_ACCESSOR: any = {
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => ButtonRadioDirective),
multi: true
};
/*tslint:enable*/

@Directive({selector: '[btnRadio][ngModel]'})
@Directive({ selector: '[btnRadio]', providers: [RADIO_CONTROL_VALUE_ACCESSOR] })
export class ButtonRadioDirective implements ControlValueAccessor, OnInit {
public cd:NgModel;
public el:ElementRef;

public onChange:any = Function.prototype;
public onTouched:any = Function.prototype;
public onChange:any = Function.prototype;
public onTouched:any = Function.prototype;

@Input() private btnRadio:string;
@Input() private uncheckable:boolean;
@Input() private btnRadio:any;
@Input() private uncheckable:boolean;
@Input() private value:any;

@HostBinding('class.active')
public get isActive():boolean {
return this.btnRadio === this.value;
}

@HostListener('click')
public onClick():void {
if (this.uncheckable && this.btnRadio === this.value) {
return this.cd.viewToModelUpdate(void 0);
@HostBinding('class.active')
public get isActive(): boolean {
return this.btnRadio === this.value;
}

this.cd.viewToModelUpdate(this.btnRadio);
}
@HostListener('click')
public onClick(): void {
if (this.el.nativeElement.attributes.disabled) {
return;
}

public constructor(@Self() cd:NgModel, el:ElementRef) {
// hack!
this.cd = cd;
this.el = el;
cd.valueAccessor = this;
}
if (this.uncheckable && this.btnRadio === this.value) {
this.value = undefined;
} else {
this.value = this.btnRadio;
}

public ngOnInit():void {
this.uncheckable = typeof this.uncheckable !== 'undefined';
}
this.onTouched();
this.onChange(this.value);
}

// hack view model!
protected get value():any {
return this.cd.viewModel;
}
public constructor( private el: ElementRef) {
}

protected set value(value:any) {
this.cd.viewModel = value;
}
public ngOnInit(): void {
this.uncheckable = typeof this.uncheckable !== 'undefined';
}

// ControlValueAccessor
// model -> view
public writeValue(value:any):void {
this.value = value;
}
public onBlur(): void {
this.onTouched();
}

public registerOnChange(fn:(_:any) => {}):void {
this.onChange = fn;
}
// ControlValueAccessor
// model -> view
public writeValue(value: any): void {
this.value = value;
}

public registerOnChange(fn: any): void {
this.onChange = fn;
}

public registerOnTouched(fn:() => {}):void {
this.onTouched = fn;
}
public registerOnTouched(fn: any): void {
this.onTouched = fn;
}
}

0 comments on commit 6b89494

Please sign in to comment.