2019-03-28 18:00:51 -04:00
|
|
|
/**
|
|
|
|
* @license
|
2020-05-19 15:08:49 -04:00
|
|
|
* Copyright Google LLC All Rights Reserved.
|
2019-03-28 18:00:51 -04:00
|
|
|
*
|
|
|
|
* Use of this source code is governed by an MIT-style license that can be
|
|
|
|
* found in the LICENSE file at https://angular.io/license
|
|
|
|
*/
|
|
|
|
|
|
|
|
import {describe, expect, it} from '@angular/core/testing/src/testing_internal';
|
|
|
|
import {BrowserViewportScroller, ViewportScroller} from '../src/viewport_scroller';
|
|
|
|
|
2020-07-16 04:58:17 -04:00
|
|
|
describe('BrowserViewportScroller', () => {
|
2020-12-22 15:50:51 -05:00
|
|
|
describe('setHistoryScrollRestoration', () => {
|
|
|
|
let scroller: ViewportScroller;
|
|
|
|
let windowSpy: any;
|
2019-05-23 08:44:46 -04:00
|
|
|
|
2020-12-22 15:50:51 -05:00
|
|
|
beforeEach(() => {
|
|
|
|
windowSpy =
|
|
|
|
jasmine.createSpyObj('window', ['history', 'scrollTo', 'pageXOffset', 'pageYOffset']);
|
|
|
|
windowSpy.history.scrollRestoration = 'auto';
|
|
|
|
scroller = new BrowserViewportScroller(document, windowSpy);
|
|
|
|
});
|
2019-05-23 08:44:46 -04:00
|
|
|
|
2020-08-14 13:32:55 -04:00
|
|
|
function createNonWritableScrollRestoration() {
|
2019-05-23 08:44:46 -04:00
|
|
|
Object.defineProperty(windowSpy.history, 'scrollRestoration', {
|
|
|
|
value: 'auto',
|
|
|
|
configurable: true,
|
|
|
|
});
|
2020-08-14 13:32:55 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
it('should not crash when scrollRestoration is not writable', () => {
|
|
|
|
createNonWritableScrollRestoration();
|
2019-05-23 08:44:46 -04:00
|
|
|
expect(() => scroller.setHistoryScrollRestoration('manual')).not.toThrow();
|
|
|
|
});
|
2020-08-14 13:32:55 -04:00
|
|
|
|
|
|
|
it('should still allow scrolling if scrollRestoration is not writable', () => {
|
|
|
|
createNonWritableScrollRestoration();
|
|
|
|
scroller.scrollToPosition([10, 10]);
|
|
|
|
expect(windowSpy.scrollTo as jasmine.Spy).toHaveBeenCalledWith(10, 10);
|
|
|
|
});
|
2020-07-16 04:58:17 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
describe('scrollToAnchor', () => {
|
2020-12-22 15:50:51 -05:00
|
|
|
// Testing scroll behavior does not make sense outside a browser
|
|
|
|
if (isNode) return;
|
2020-07-16 04:58:17 -04:00
|
|
|
const anchor = 'anchor';
|
2020-12-22 15:50:51 -05:00
|
|
|
let tallItem: HTMLDivElement;
|
|
|
|
let el: HTMLAnchorElement;
|
|
|
|
let scroller: BrowserViewportScroller;
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
scroller = new BrowserViewportScroller(document, window);
|
|
|
|
scroller.scrollToPosition([0, 0]);
|
|
|
|
|
|
|
|
tallItem = document.createElement('div');
|
|
|
|
tallItem.style.height = '3000px';
|
|
|
|
document.body.appendChild(tallItem);
|
|
|
|
|
|
|
|
el = document.createElement('a');
|
|
|
|
el.innerText = 'some link';
|
|
|
|
el.href = '#';
|
|
|
|
document.body.appendChild(el);
|
|
|
|
});
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
document.body.removeChild(tallItem);
|
|
|
|
document.body.removeChild(el);
|
|
|
|
});
|
2020-07-16 04:58:17 -04:00
|
|
|
|
2020-12-22 15:50:51 -05:00
|
|
|
it('should scroll when element with matching id is found', () => {
|
|
|
|
el.id = anchor;
|
2020-07-16 04:58:17 -04:00
|
|
|
scroller.scrollToAnchor(anchor);
|
2020-12-22 15:50:51 -05:00
|
|
|
expect(scroller.getScrollPosition()[1]).not.toEqual(0);
|
2020-07-16 04:58:17 -04:00
|
|
|
});
|
|
|
|
|
2020-12-22 15:50:51 -05:00
|
|
|
it('should scroll when anchor with matching name is found', () => {
|
|
|
|
el.name = anchor;
|
2020-07-16 04:58:17 -04:00
|
|
|
scroller.scrollToAnchor(anchor);
|
2020-12-22 15:50:51 -05:00
|
|
|
expect(scroller.getScrollPosition()[1]).not.toEqual(0);
|
2020-07-16 04:58:17 -04:00
|
|
|
});
|
2019-05-23 08:44:46 -04:00
|
|
|
|
2020-12-22 15:50:51 -05:00
|
|
|
it('should not scroll when no matching element is found', () => {
|
2020-07-16 04:58:17 -04:00
|
|
|
scroller.scrollToAnchor(anchor);
|
2020-12-22 15:50:51 -05:00
|
|
|
expect(scroller.getScrollPosition()[1]).toEqual(0);
|
2019-03-28 18:00:51 -04:00
|
|
|
});
|
|
|
|
});
|
2020-07-16 04:58:17 -04:00
|
|
|
});
|