2023-08-13 12:22:57 +00:00
|
|
|
/*
|
2024-02-13 15:50:11 +00:00
|
|
|
* SPDX-FileCopyrightText: syuilo and other misskey contributors
|
2023-08-13 12:22:57 +00:00
|
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
*/
|
|
|
|
|
|
|
|
import { describe, test, assert, afterEach } from 'vitest';
|
|
|
|
import { Window } from 'happy-dom';
|
2023-09-19 07:37:43 +00:00
|
|
|
import { onScrollBottom, onScrollTop } from '@/scripts/scroll.js';
|
2023-08-13 12:22:57 +00:00
|
|
|
|
|
|
|
describe('Scroll', () => {
|
|
|
|
describe('onScrollTop', () => {
|
|
|
|
test('Initial onScrollTop callback for connected elements', () => {
|
|
|
|
const { document } = new Window();
|
|
|
|
const div = document.createElement('div');
|
|
|
|
assert.strictEqual(div.scrollTop, 0);
|
|
|
|
|
|
|
|
document.body.append(div);
|
|
|
|
|
|
|
|
let called = false;
|
|
|
|
onScrollTop(div as any as HTMLElement, () => called = true);
|
|
|
|
|
|
|
|
assert.ok(called);
|
|
|
|
});
|
|
|
|
|
|
|
|
test('No onScrollTop callback for disconnected elements', () => {
|
|
|
|
const { document } = new Window();
|
|
|
|
const div = document.createElement('div');
|
|
|
|
assert.strictEqual(div.scrollTop, 0);
|
|
|
|
|
|
|
|
let called = false;
|
|
|
|
onScrollTop(div as any as HTMLElement, () => called = true);
|
|
|
|
|
|
|
|
assert.ok(!called);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('onScrollBottom', () => {
|
|
|
|
test('Initial onScrollBottom callback for connected elements', () => {
|
|
|
|
const { document } = new Window();
|
|
|
|
const div = document.createElement('div');
|
|
|
|
assert.strictEqual(div.scrollTop, 0);
|
|
|
|
(div as any).scrollHeight = 100; // happy-dom has no scrollHeight
|
|
|
|
|
|
|
|
document.body.append(div);
|
|
|
|
|
|
|
|
let called = false;
|
|
|
|
onScrollBottom(div as any as HTMLElement, () => called = true);
|
|
|
|
|
|
|
|
assert.ok(called);
|
|
|
|
});
|
|
|
|
|
|
|
|
test('No onScrollBottom callback for disconnected elements', () => {
|
|
|
|
const { document } = new Window();
|
|
|
|
const div = document.createElement('div');
|
|
|
|
assert.strictEqual(div.scrollTop, 0);
|
|
|
|
(div as any).scrollHeight = 100; // happy-dom has no scrollHeight
|
|
|
|
|
|
|
|
let called = false;
|
|
|
|
onScrollBottom(div as any as HTMLElement, () => called = true);
|
|
|
|
|
|
|
|
assert.ok(!called);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|