2018-04-24 14:09:16 +02:00
|
|
|
zrequire('scroll_util');
|
2019-03-01 01:40:05 +01:00
|
|
|
set_global('ui', {
|
|
|
|
get_scroll_element: element => element,
|
|
|
|
});
|
2018-04-24 14:09:16 +02:00
|
|
|
|
2018-05-15 12:40:07 +02:00
|
|
|
run_test('scroll_delta', () => {
|
2018-04-24 14:09:16 +02:00
|
|
|
// If we are entirely on-screen, don't scroll
|
|
|
|
assert.equal(0, scroll_util.scroll_delta({
|
|
|
|
elem_top: 1,
|
|
|
|
elem_bottom: 9,
|
|
|
|
container_height: 10,
|
|
|
|
}));
|
|
|
|
|
|
|
|
assert.equal(0, scroll_util.scroll_delta({
|
|
|
|
elem_top: -5,
|
|
|
|
elem_bottom: 15,
|
|
|
|
container_height: 10,
|
|
|
|
}));
|
|
|
|
|
|
|
|
// The top is offscreen.
|
|
|
|
assert.equal(-3, scroll_util.scroll_delta({
|
|
|
|
elem_top: -3,
|
|
|
|
elem_bottom: 5,
|
|
|
|
container_height: 10,
|
|
|
|
}));
|
|
|
|
|
|
|
|
assert.equal(-3, scroll_util.scroll_delta({
|
|
|
|
elem_top: -3,
|
|
|
|
elem_bottom: -1,
|
|
|
|
container_height: 10,
|
|
|
|
}));
|
|
|
|
|
|
|
|
assert.equal(-11, scroll_util.scroll_delta({
|
|
|
|
elem_top: -150,
|
|
|
|
elem_bottom: -1,
|
|
|
|
container_height: 10,
|
|
|
|
}));
|
|
|
|
|
|
|
|
// The bottom is offscreen.
|
|
|
|
assert.equal(3, scroll_util.scroll_delta({
|
|
|
|
elem_top: 7,
|
|
|
|
elem_bottom: 13,
|
|
|
|
container_height: 10,
|
|
|
|
}));
|
|
|
|
|
|
|
|
assert.equal(3, scroll_util.scroll_delta({
|
|
|
|
elem_top: 11,
|
|
|
|
elem_bottom: 13,
|
|
|
|
container_height: 10,
|
|
|
|
}));
|
|
|
|
|
|
|
|
assert.equal(11, scroll_util.scroll_delta({
|
|
|
|
elem_top: 11,
|
|
|
|
elem_bottom: 99,
|
|
|
|
container_height: 10,
|
|
|
|
}));
|
|
|
|
|
2018-05-15 12:40:07 +02:00
|
|
|
});
|
2018-04-24 14:28:24 +02:00
|
|
|
|
2018-05-15 12:40:07 +02:00
|
|
|
run_test('scroll_element_into_container', () => {
|
2018-04-24 14:28:24 +02:00
|
|
|
const container = (function () {
|
2019-11-02 00:06:25 +01:00
|
|
|
let top = 3;
|
2018-04-24 14:28:24 +02:00
|
|
|
return {
|
|
|
|
height: () => 100,
|
|
|
|
scrollTop: (arg) => {
|
|
|
|
if (arg === undefined) {
|
|
|
|
return top;
|
|
|
|
}
|
|
|
|
top = arg;
|
|
|
|
},
|
|
|
|
};
|
|
|
|
}());
|
|
|
|
|
|
|
|
const elem1 = {
|
2018-07-22 06:03:57 +02:00
|
|
|
innerHeight: () => 25,
|
2018-04-24 14:28:24 +02:00
|
|
|
position: () => {
|
|
|
|
return {
|
|
|
|
top: 0,
|
|
|
|
};
|
|
|
|
},
|
|
|
|
};
|
|
|
|
scroll_util.scroll_element_into_container(elem1, container);
|
|
|
|
assert.equal(container.scrollTop(), 3);
|
|
|
|
|
|
|
|
const elem2 = {
|
2018-07-22 06:03:57 +02:00
|
|
|
innerHeight: () => 15,
|
2018-04-24 14:28:24 +02:00
|
|
|
position: () => {
|
|
|
|
return {
|
|
|
|
top: 250,
|
|
|
|
};
|
|
|
|
},
|
|
|
|
};
|
|
|
|
scroll_util.scroll_element_into_container(elem2, container);
|
|
|
|
assert.equal(container.scrollTop(), 250 - 100 + 3 + 15);
|
2018-05-15 12:40:07 +02:00
|
|
|
});
|
2020-04-13 13:52:07 +02:00
|
|
|
|
|
|
|
run_test('get_list_scrolling_container error', () => {
|
|
|
|
const body = {
|
|
|
|
length: 1,
|
|
|
|
is: (sel) => {
|
|
|
|
assert.equal(sel, 'body, html');
|
|
|
|
return true;
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
blueslip.expect(
|
|
|
|
'error',
|
|
|
|
"Please wrap lists in an element with " +
|
|
|
|
"'max-height' attribute."
|
|
|
|
);
|
|
|
|
|
|
|
|
scroll_util.get_list_scrolling_container(body);
|
|
|
|
|
|
|
|
blueslip.reset();
|
|
|
|
});
|