aboutsummaryrefslogtreecommitdiff
path: root/Timeline/ClientApp/src/app/debounce-click.directive.ts
diff options
context:
space:
mode:
author杨宇千 <crupest@outlook.com>2019-03-06 23:29:12 +0800
committerGitHub <noreply@github.com>2019-03-06 23:29:12 +0800
commit4b37c96de2c7d3fe046a6f342d2da8ef03d3c807 (patch)
treee5618cddfa6f637d7033ae5b52e6da825eb53c63 /Timeline/ClientApp/src/app/debounce-click.directive.ts
parentaca753fba19a221f1aec65030ba4aec4bc34f576 (diff)
parentb5e01c4571061cbaf5915aa4c0f1b7126ef1ed18 (diff)
downloadtimeline-4b37c96de2c7d3fe046a6f342d2da8ef03d3c807.tar.gz
timeline-4b37c96de2c7d3fe046a6f342d2da8ef03d3c807.tar.bz2
timeline-4b37c96de2c7d3fe046a6f342d2da8ef03d3c807.zip
Merge pull request #3 from crupest/user
Develop user dialog.
Diffstat (limited to 'Timeline/ClientApp/src/app/debounce-click.directive.ts')
-rw-r--r--Timeline/ClientApp/src/app/debounce-click.directive.ts39
1 files changed, 39 insertions, 0 deletions
diff --git a/Timeline/ClientApp/src/app/debounce-click.directive.ts b/Timeline/ClientApp/src/app/debounce-click.directive.ts
new file mode 100644
index 00000000..feb0404e
--- /dev/null
+++ b/Timeline/ClientApp/src/app/debounce-click.directive.ts
@@ -0,0 +1,39 @@
+import { Directive, Output, Input, EventEmitter, ElementRef, OnInit, OnDestroy } from '@angular/core';
+import { fromEvent, Subscription } from 'rxjs';
+import { debounceTime } from 'rxjs/operators';
+
+@Directive({
+ selector: '[appDebounceClick]'
+})
+export class DebounceClickDirective implements OnInit, OnDestroy {
+
+ private subscription: Subscription;
+
+ @Output('appDebounceClick') clickEvent = new EventEmitter<any>();
+
+ // tslint:disable-next-line:no-input-rename
+ @Input('appDebounceClickTime')
+ set debounceTime(value: number) {
+ if (this.subscription) {
+ this.subscription.unsubscribe();
+ }
+ this.subscription = fromEvent(<HTMLElement>this.element.nativeElement, 'click').pipe(
+ debounceTime(value)
+ ).subscribe(o => this.clickEvent.emit(o));
+ }
+
+ constructor(private element: ElementRef) {
+ }
+
+ ngOnInit() {
+ if (!this.subscription) {
+ this.subscription = fromEvent(<HTMLElement>this.element.nativeElement, 'click').pipe(
+ debounceTime(500)
+ ).subscribe(o => this.clickEvent.emit(o));
+ }
+ }
+
+ ngOnDestroy() {
+ this.subscription.unsubscribe();
+ }
+}