From 2768d0d19caeb62248f14b4ea6079416fc1463ec Mon Sep 17 00:00:00 2001 From: Scott Cooper Date: Fri, 13 Apr 2018 12:18:26 -0700 Subject: [PATCH] fix: scroll to top should activate the first category --- src/lib/picker/picker.component.ts | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) diff --git a/src/lib/picker/picker.component.ts b/src/lib/picker/picker.component.ts index d91494ef..cdb40c77 100644 --- a/src/lib/picker/picker.component.ts +++ b/src/lib/picker/picker.component.ts @@ -60,7 +60,7 @@ export class PickerComponent implements OnInit, AfterViewInit { @Input() emoji = 'department_store'; @Input() color = '#ae65c5'; @Input() hideObsolete = true; - /** all categories */ + /** all categories shown */ @Input() categories: EmojiCategory[] = []; /** used to temporarily draw categories */ @Input() activeCategories: EmojiCategory[] = []; @@ -276,7 +276,14 @@ export class PickerComponent implements OnInit, AfterViewInit { } else { const target = this.scrollRef.nativeElement; // check scroll is not at bottom - if (target.scrollHeight - target.scrollTop !== this.clientHeight) { + if (target.scrollTop === 0) { + // hit the TOP + activeCategory = this.categories.find(n => n.first === true); + } else if (target.scrollHeight - target.scrollTop === this.clientHeight) { + // scrolled to bottom activate last category + activeCategory = this.categories[this.categories.length - 1]; + } else { + // scrolling for (const category of this.categories) { const component = this.categoryRefs!.find(n => n.id === category.id); const active = component!.handleScroll(target.scrollTop); @@ -284,9 +291,6 @@ export class PickerComponent implements OnInit, AfterViewInit { activeCategory = category; } } - } else { - // scrolled to bottom activate last category - activeCategory = this.categories[this.categories.length - 1]; } this.scrollTop = target.scrollTop;