Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Inconsistency in scrollNext and scrollPrev #3365

Closed
norikois opened this issue Dec 10, 2018 · 6 comments · Fixed by #3470
Closed

Inconsistency in scrollNext and scrollPrev #3365

norikois opened this issue Dec 10, 2018 · 6 comments · Fixed by #3470
Assignees
Labels
🐛 bug Any issue that describes a bug 📉 regression 🧨 severity: medium grid: general scroll version: 7.0.1 ✅ status: resolved Applies to issues that have pending PRs resolving them, or PRs that have already merged.

Comments

@norikois
Copy link

norikois commented Dec 10, 2018

Description

There are inconsistencies in scrollNext and scrollPrev

  • Inconsistency in cyclic scrolling: scrollNext scrolls back to the top when the scroll position is at the bottom. On the other hand, scrollPrev does not scroll to the bottom when the scroll position is at the top.
  • Inconsistency in behaviors between an old version (ex. 6.1.3) and 7.0.1: scrollNext and scrollPrev stops scrolling when the scroll position comes to the bottom or the top in 6.1.3. On the other hand, in 7.0.1, scrollNext scrolls to the top when the scroll position is at the bottom.
  • Inconsistency in scroll position between contents and the scroll bar thumb: The scroll bar thumb goes to the top position if scrollNext is called when the scroll position is at the bottom. On the other hand, the contents does not go to the top.
  • igniteui-angular version: 7.0.1
  • browser: any

Steps to reproduce

  1. npm install and npm start the attached sample. Open it in a browser.
  2. Click "Down" button several times until "14: Name 14" the last item comes into view.
  3. Click "Down" button again.
    -> Observe the positions of the scroll bar's thumb and the contents.
  4. Click "Down" button again.
    -> The scroll positions of the scroll bar's thumb and the contents get aligned again.
  5. Click "Up" button several times.
    -> Observe whether it scrolls to the bottom when the scroll position is at the top.

Result

Step3:
The scroll bar's thumb is at the top, but the items at the bottom are still displayed.

Step5:
The igx-list does not scroll to the bottom.

Expected result

The behaviors should be consistent. That is:

  • If scrollNext's cyclic scrolling is an expected behavior, scrollPrev should also cyclicly scroll. Or if scrollPrev's non-cyclic scrolling is an expected behavior, scrollNext should not cyclicly scroll (Step5).
  • Contents and scroll bar's thumb positions should be aligned (Step3).

Attachments

Attach a sample if available, and screenshots, if applicable.
cas30409-app1.zip

@tkiryu
Copy link

tkiryu commented Dec 12, 2018

https://github.com/IgniteUI/igniteui-angular/blob/master/projects/igniteui-angular/src/lib/directives/for-of/for_of.directive.ts#L427-L430

    public scrollTo(index) {
        if (index < 0 || index > (this.isRemote ? this.totalItemCount : this.igxForOf.length)) {
            return;
        }

In the first place, it seems that this guard clause doesn't work as expected.

When "this.igxForOf.length" is 15, the index range is 0 - 14. But, if 15 is passed to scrollTo(), the program passes through the guard statement. As a result, this.sizesCache[index + 1] returns undefined and calculation fails.

The guard statement should be fixed like this.

    public scrollTo(index) {
        const lastIndex = (this.isRemote ? this.totalItemCount : this.igxForOf.length) - 1;
        if (index < 0 || lastIndex < index) {
            return;
        }

@tkiryu
Copy link

tkiryu commented Dec 14, 2018

Any updates?

@mpavlinov
Copy link
Contributor

We haven't had a chance to investigate it.

@mpavlinov mpavlinov assigned MayaKirova and unassigned mpavlinov Dec 14, 2018
@MayaKirova MayaKirova removed their assignment Dec 14, 2018
@mpavlinov mpavlinov self-assigned this Dec 14, 2018
@mpavlinov
Copy link
Contributor

@tkiryu What you suggest looks correct. You can make a PR, but don't forget to include a test as well :)

@mpavlinov
Copy link
Contributor

@tkiryu I've communicated this issue with Satoru Yamaguchi. As he is escalating it we will take care of it.

@ChronosSF ChronosSF added ✅ status: resolved Applies to issues that have pending PRs resolving them, or PRs that have already merged. and removed 🛠️ status: in-development Issues and PRs with active development on them labels Dec 18, 2018
@tkiryu
Copy link

tkiryu commented Dec 19, 2018

@mpavlinov , thank you so much!

mpavlinov pushed a commit that referenced this issue Dec 20, 2018
* test(forof): adding failing test for scrollNext wraparound #3365

* fix(forof): fixing break clause for scrollTo #3365

* chore(*): removing left-over fit

* test(forof): fixing some tests for better passability #3365

* test(filtering): Fix the logic calculating test results (#2915)
zdrawku added a commit that referenced this issue Jan 8, 2019
* refactor(displayDensity): Code cleanup in display density base class

Cleaned host bindings in child components.
The displayDensity getter cannot retrun undefined anymore.

* refactor(displayDensity): Address code review suggestions

* chore(*): Added itemSize to width calculations - forOf.

* refactor(displayDensity): Fix header group

* refactor(linear-progress): modify styles and template for indeterminate state

* refactor(circular-bar): add indeterminate state and animation

* refactor(progressbar): apply type classes to the host and refactor the tests

* fix(slider): prevent snapping of maxValue to minValue

Closes #2610

* test(slider): add some tests about the exceeding bounds

Closes #2610

* test(slider): run all and modify some tests

Closes #2610

* fix(slider.spec): fix some lint errors

Closes #2610

* fix(progress): fix progress bars to work in IE11

* chore(changelog, readme): update to reflect the new indeterminate property

* refactor(progressbar): update circular progress when not in indeterminate

* test(progressbar): fix circularbar tests

Closes #1997 #1986

* test(progress): fix failing tests after binding test to host

* fix(progressbar): prevent value update when indeterminate mode is on

Closes #1997 #1986

* refactor(avatar): allow for more robust styling of the avatar

* Update avatar.component.spec.ts

* test(transaction): deleting w/ transactions + paging in grid, #3425

* fix(transaction): check for transactions when commiting delete, #3425

* fix(transaction): hier trans getAggregatedChanges uses state copy instead, #3425

* chore(*): Changed the way to get the item size.

* Update avatar.component.spec.ts

* chore(*): Added test for bug 3087.

* fix(grid): proper check for paging w/ transactions in place, #3425

* chore(*): Improved test about width for_of.

* chore(*): Fixed identation change.

* fix(grid): can no longer select deleted rows, #3424

* refactor(grid): move deleted checks to API, remove extra loop, #3424

* refactor(treeGrid): row_deleted_parent is now private, remove imports, #3424

* test(treeGrid): add row selection + transaction tests, #3424

* refactor(treeGrid): remove isRowDeleted, get deleted; use api service, #3424

* refactor(grid): remove unnecessary assignment, #3424

* fix(IgxGridCell): focus input when enter cell in edit mode #2801

* fix(igx-grid): Scroll filtered column in view, #3451

* refactor(grid): add comment to row delete+paging, change check for page, #3425

* test(forof): adding failing test for scrollNext wraparound #3365

* chore(*): fix tests using avatar #3444

* fix(forof): fixing break clause for scrollTo #3365

* chore(*): removing left-over fit

* chore(ng-add): bump Ignite UI CLI version

* test(forof): fixing some tests for better passability #3365

* refactor(*): refactor some comments and exports

hide GroupedRecords class from typedoc API doc and refactor
igx-drop-down-theme param comment

Closes #3483 #3484

* test(grid): #3047 igxGrid isn't displayed properly in IE11 when in igxTabs

* chore(*): Fixing lint errors

* fix(grid): igxGrid isn't displayed properly in IE11 in igxTabs #3047

* Include grid's unpinnedWidth and totalWidth in cell width calculation (#3465)

* test(grid): add test for summary alignment #3462

* fix(grid): include grid widths in cell width calculation #3462

* fix(summary): convert getCellWidth from getter to method #3462

* Derive possible heights after markForCheck() is called #3467 (#3479)

* fix(grid): add pipeTrigger in the AfterViewInit event #3467

* test(grid): add general test for treegrid default rendering #8347

* fix(grid): calling pipeTrigger is not needed #3467

* test(grid): move general test to component test file #3467

* test(grid): remove f from test file #3467

*  docs(*): updating changelog for 7.1.x #3495

* chore(*): adding sections for 6.2.4 and 7.0.5 as well

* test(update): Modify firstMonth selector #3508

* Fix - Convert % column width to px when calculating default column width (#3319)

* test(grid): add test for a column width in % #1245

* fix(grid): convert % to px when calculating default width #1245

* test(grid): remove fit #1245

* fix(#3332): Exception when exporting more than 8 nested levels (#3501)

* fix(#3332): Exception when exporting more than 8 level

* fix(Exporter): #3332 Adding a test.

* fix(Exporter): #3332 Improve the fix and test

* fix(Exporter): #3332 Fix was braking the existing export

* fix(headers-api-docs): set header IG main page link depending on the lang

Closes #3516

* fix(*): build errors due to displayDensity changes #3310

* chore(*): more code optimizations #3310

* igxTimePicker - editable masked input + dropdown new mode (#3394)

* feat(time-picker): initial implementation of removing dialog #2337

* feat(time picker): spin on edit functionality #2337

* feat(time picker): editable input implementation #2337

* feat(time-picker): dropdown/dialog display rework #2337

* feat(time-picker): sync dropdwwon navigation and input display #2337

* feat(time picker): emit events when necessary #2337

* feat(time picker): code restructuring and demo rework #2337

* feat(time picker): fix broken sample #2337

* feat(time picker): fix test failures and styles #2337

* feat(time-picker): minor fixes and improvements #2337

* feat(time-picker): more fixes and improvements #2337

* feat(time-picker): cover corner cases with invalid value #2337

* refactor(theme): adjust time picker theme

* feat(time picker): hide/show overlay via hidden attribute #2337

* test(timePicker): Adding TimePicker DropDown initial Tests. #2337

* test(timePicker): Adding TimePicker DropDown Tests. #2337

* feat(time-picker): mask directive placeholder #2337

* test(timePicker): Fixing falling Vertical test. #2337

* feat(time picker): some code refactoring #2337

* feat(time picker): code refactoring and bug fixing #2337

* test(timePicker): Finalizing TimePicker DropDown Tests. #2337

* feat(time picker): tests refactoring and bug fixing #2337

* feat(time picker): code styling #2337

* feat(time picker): update README.md and CHANGELOG.md #2337

* feat(time picker): minor fixes/improvements #2337

* feat(time picker): some more little refinements #2337

* chore(*): mask demo enhancement #2337

* chore(*): address review comments #2337

* chore(*): more refinements #2337

* feat(time picker): address comments form review #2337

* feat(time picker): expose enum again in common #2337

* feat(time picker): cover some more corner cases #2337

* feat(time picker): some more minor bug fixes #2337

* feat(time picker): fix undesired input event firing in IE #2337

* fix(IgxColumnMovingDropDirective): focus last active cell on column moving #3407 (#3524)

* fix(igx-grid): Add function to localize summaries, #3533 (#3534)

* chore(*): Fix 7.1.1 duplicate section in Changelog

* chore(*): Update changelog
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
🐛 bug Any issue that describes a bug 📉 regression 🧨 severity: medium grid: general scroll version: 7.0.1 ✅ status: resolved Applies to issues that have pending PRs resolving them, or PRs that have already merged.
Projects
None yet
Development

Successfully merging a pull request may close this issue.

7 participants