Skip to content

Commit

Permalink
fix(module:button): disable wave animation when the type is link (#3545
Browse files Browse the repository at this point in the history
…) (#3572)

* fix(module:button): disable wave animation when the type is link

* test(module:core): fix wave test
close #3546
  • Loading branch information
hsuanxyz authored and vthinkxie committed Jun 14, 2019
1 parent d690692 commit 1bb84fe
Show file tree
Hide file tree
Showing 4 changed files with 48 additions and 19 deletions.
5 changes: 5 additions & 0 deletions components/button/nz-button.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -169,5 +169,10 @@ export class NzButtonComponent implements AfterContentInit, OnInit, OnDestroy, O
if (changes.nzLoading) {
this.updateIconDisplay(this.nzLoading);
}
if (changes.nzType && changes.nzType.currentValue === 'link') {
this.nzWave.disable();
} else {
this.nzWave.enable();
}
}
}
7 changes: 5 additions & 2 deletions components/core/wave/nz-wave-renderer.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,11 +15,13 @@ export class NzWaveRenderer {
private extraNode: HTMLDivElement | null;
private lastTime = 0;
private platform = new Platform();
clickHandler: () => void;
get waveAttributeName(): string {
return this.insertExtraNode ? 'ant-click-animating' : 'ant-click-animating-without-extra-node';
}

constructor(private triggerElement: HTMLElement, private ngZone: NgZone, private insertExtraNode: boolean) {
this.clickHandler = this.onClick.bind(this);
this.bindTriggerEvent();
}

Expand All @@ -39,16 +41,17 @@ export class NzWaveRenderer {
bindTriggerEvent(): void {
if (this.platform.isBrowser) {
this.ngZone.runOutsideAngular(() => {
this.removeTriggerEvent();
if (this.triggerElement) {
this.triggerElement.addEventListener('click', this.onClick, true);
this.triggerElement.addEventListener('click', this.clickHandler, true);
}
});
}
}

removeTriggerEvent(): void {
if (this.triggerElement) {
this.triggerElement.removeEventListener('click', this.onClick, true);
this.triggerElement.removeEventListener('click', this.clickHandler, true);
}
}

Expand Down
19 changes: 12 additions & 7 deletions components/core/wave/nz-wave.directive.ts
Original file line number Diff line number Diff line change
Expand Up @@ -58,15 +58,21 @@ export class NzWaveDirective implements OnInit, OnDestroy {
constructor(
private ngZone: NgZone,
private elementRef: ElementRef,
@Optional() @Inject(NZ_WAVE_GLOBAL_CONFIG) config: NzWaveConfig,
@Optional() @Inject(NZ_WAVE_GLOBAL_CONFIG) private config: NzWaveConfig,
@Optional() @Inject(ANIMATION_MODULE_TYPE) private animationType: string
) {
if (config && typeof config.disabled === 'boolean') {
this.waveDisabled = config.disabled;
this.waveDisabled = this.isConfigDisabled();
}

isConfigDisabled(): boolean {
let disabled = false;
if (this.config && typeof this.config.disabled === 'boolean') {
disabled = this.config.disabled;
}
if (this.animationType === 'NoopAnimations') {
this.waveDisabled = true;
disabled = true;
}
return disabled;
}

ngOnDestroy(): void {
Expand Down Expand Up @@ -94,11 +100,10 @@ export class NzWaveDirective implements OnInit, OnDestroy {
}

enable(): void {
this.waveDisabled = false;
// config priority
this.waveDisabled = this.isConfigDisabled() || false;
if (this.waveRenderer) {
this.waveRenderer.bindTriggerEvent();
} else {
this.renderWaveIfEnabled();
}
}
}
36 changes: 26 additions & 10 deletions components/core/wave/nz-wave.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -185,9 +185,8 @@ describe('nz-wave extra', () => {
});
});

describe('nz-wave disable/enable', () => {
describe('nz-wave NoopAnimationsModule', () => {
let fixture: ComponentFixture<WaveContainerWithButtonComponent>;
let waveTarget: HTMLElement;
let waveRef: NzWaveDirective;
beforeEach(() => {
TestBed.configureTestingModule({
Expand All @@ -196,25 +195,43 @@ describe('nz-wave disable/enable', () => {
});
});

describe('disable/enable', () => {
describe('NoopAnimationsModule', () => {
beforeEach(() => {
fixture = TestBed.createComponent(WaveContainerWithButtonComponent);
fixture.detectChanges();
waveTarget = fixture.componentInstance.trigger.nativeElement;
waveRef = fixture.componentInstance.wave;
});

it('should disable by NoopAnimationsModule ', () => {
expect(waveRef.disabled).toBe(true);
expect(waveRef.rendererRef).toBeFalsy();
waveRef.disable();
expect(waveRef.rendererRef).toBeFalsy();
});

it('should create waveRenderer when called enable', () => {
it('should config priority', () => {
waveRef.enable();
expect(waveRef.disabled).toBe(false);
expect(waveRef.rendererRef).toBeTruthy();
expect(waveRef.disabled).toBe(true);
expect(waveRef.rendererRef).toBeFalsy();
});
});
});

describe('nz-wave disable/enable', () => {
let fixture: ComponentFixture<WaveContainerWithButtonComponent>;
let waveTarget: HTMLElement;
let waveRef: NzWaveDirective;
beforeEach(() => {
TestBed.configureTestingModule({
imports: [NzWaveModule],
declarations: [WaveContainerWithButtonComponent]
});
});

describe('disable/enable', () => {
beforeEach(() => {
fixture = TestBed.createComponent(WaveContainerWithButtonComponent);
fixture.detectChanges();
waveTarget = fixture.componentInstance.trigger.nativeElement;
waveRef = fixture.componentInstance.wave;
});

it('should enable work', () => {
Expand All @@ -229,7 +246,6 @@ describe('nz-wave disable/enable', () => {
it('should disable work', () => {
waveRef.disable();
expect(waveRef.disabled).toBe(true);
expect(waveRef.rendererRef).toBeFalsy();
dispatchMouseEvent(waveTarget, 'click');
expect(waveTarget.hasAttribute(WAVE_ATTRIBUTE_NAME)).toBe(false);
expect(document.body.querySelector('style') === null).toBe(true);
Expand Down

0 comments on commit 1bb84fe

Please sign in to comment.