Skip to content

Commit

Permalink
refactor(checkbox): deprecate value, add checked, don't emit of i…
Browse files Browse the repository at this point in the history
…nput change

Closes #1478
  • Loading branch information
nnixaa committed Jun 6, 2019
1 parent 93b5a38 commit 5fd7db1
Show file tree
Hide file tree
Showing 4 changed files with 74 additions and 20 deletions.
31 changes: 25 additions & 6 deletions src/framework/theme/components/checkbox/checkbox.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -157,17 +157,31 @@ export class NbCheckboxComponent implements ControlValueAccessor {

/**
* Checkbox value
* @deprecated
* @breaking-change Remove @5.0.0
*/
@Input()
get value(): boolean {
return this._value;
return this.checked;
}

/**
* @deprecated
*/
set value(value: boolean) {
this._value = value;
this.valueChange.emit(value);
console.warn('NbCheckbox: `value` is deprecated and will be removed in 5.0.0. Use `checked` instead.');
this.checked = value;
}

@Input()
get checked(): boolean {
return this._checked;
}
set checked(value: boolean) {
this._checked = value;
this.onChange(value);
}
private _value: boolean = false;
private _checked: boolean = false;

/**
* Controls input disabled state
Expand Down Expand Up @@ -201,7 +215,11 @@ export class NbCheckboxComponent implements ControlValueAccessor {
}
private _indeterminate: boolean = false;

@Output() valueChange = new EventEmitter();
/**
* Output when value is changed by a user
* @type EventEmitter<boolean>
*/
@Output() valueChange = new EventEmitter<boolean>();

@HostBinding('class.status-primary')
get primary() {
Expand Down Expand Up @@ -239,7 +257,7 @@ export class NbCheckboxComponent implements ControlValueAccessor {
}

writeValue(val: any) {
this._value = val;
this._checked = val;
this.changeDetector.detectChanges();
}

Expand All @@ -254,6 +272,7 @@ export class NbCheckboxComponent implements ControlValueAccessor {
updateValueAndIndeterminate(event: Event): void {
const input = (event.target as HTMLInputElement);
this.value = input.checked;
this.valueChange.emit(this.value);
this.indeterminate = input.indeterminate;
}
}
52 changes: 39 additions & 13 deletions src/framework/theme/components/checkbox/checkbox.spec.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
import { take } from 'rxjs/operators';
import { ComponentFixture, fakeAsync, TestBed, tick } from '@angular/core/testing';
import { ComponentFixture, TestBed } from '@angular/core/testing';
import { Component, DebugElement } from '@angular/core';
import { By } from '@angular/platform-browser';
import { ReactiveFormsModule, FormControl } from '@angular/forms';
Expand Down Expand Up @@ -41,18 +40,30 @@ describe('Component: NbCheckbox', () => {
expect(checkboxInput.nativeElement.disabled).toBeFalsy();
});

it('Setting value to true makes checkbox input checked', () => {
it('Setting deprecated value to true makes checkbox input checked', () => {
checkbox.value = true;
fixture.detectChanges();
expect(checkboxInput.nativeElement.checked).toBeTruthy();
});

it('Setting value to false makes checkbox input unchecked', () => {
it('Setting deprecated value to false makes checkbox input unchecked', () => {
checkbox.value = false;
fixture.detectChanges();
expect(checkboxInput.nativeElement.checked).toBeFalsy();
});

it('Setting checked to true makes checkbox input checked', () => {
checkbox.checked = true;
fixture.detectChanges();
expect(checkboxInput.nativeElement.checked).toBeTruthy();
});

it('Setting checked to false makes checkbox input unchecked', () => {
checkbox.checked = false;
fixture.detectChanges();
expect(checkboxInput.nativeElement.checked).toBeFalsy();
});

it('Setting status to success apply corresponding class to host element', () => {
checkbox.status = 'success';
fixture.detectChanges();
Expand Down Expand Up @@ -83,26 +94,41 @@ describe('Component: NbCheckbox', () => {
expect(testContainerEl.classList.contains('status-info')).toBeTruthy();
});

it('should emit change event when changed', fakeAsync(() => {
it('should not emit change event when input changed', () => {

const spy = jasmine.createSpy('valueChange subscriber');

checkbox.valueChange
.pipe(take(1))
.subscribe((value: boolean) => expect(value).toEqual(true));
.subscribe(spy);

checkbox.value = true;
checkbox.checked = true;
fixture.detectChanges();
tick();
}));
expect(spy).toHaveBeenCalledTimes(0);
});

it('should emit change event when clicked', () => {

const spy = jasmine.createSpy('valueChange subscriber');

checkbox.valueChange
.subscribe(spy);

label.nativeElement.click();

fixture.detectChanges();
expect(spy).toHaveBeenCalledTimes(1);
});

it('should change value to opposite when clicked', () => {
label.nativeElement.click();
fixture.detectChanges();

expect(checkbox.value).toEqual(true);
expect(checkbox.checked).toEqual(true);

label.nativeElement.click();
fixture.detectChanges();

expect(checkbox.value).toEqual(false);
expect(checkbox.checked).toEqual(false);
});

it('should reset indeterminate state when clicked on unchecked checkbox', () => {
Expand All @@ -117,7 +143,7 @@ describe('Component: NbCheckbox', () => {
});

it('should reset indeterminate state when clicked on unchecked checkbox', () => {
checkbox.value = false;
checkbox.checked = false;
checkbox.indeterminate = true;
fixture.detectChanges();

Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
<nb-card>
<nb-card-body>
<nb-checkbox>Toggle me</nb-checkbox>
<nb-checkbox (valueChange)="toggle($event)">Toggle me</nb-checkbox>
</nb-card-body>
<nb-card-body>
<label>Checked:</label> {{ checked }}
</nb-card-body>
</nb-card>
Original file line number Diff line number Diff line change
Expand Up @@ -6,4 +6,10 @@ import { Component } from '@angular/core';
})

export class CheckboxShowcaseComponent {

checked = false;

toggle(checked: boolean) {
this.checked = checked;
}
}

0 comments on commit 5fd7db1

Please sign in to comment.