Merge "Update docs/hooks.txt for ShowSearchHitTitle"
[mediawiki.git] / tests / qunit / suites / resources / mediawiki / mediawiki.viewport.test.js
blobf40429421517d0059765a68f392cd4f09ecfd433
1 ( function ( mw, $ ) {
3         // Simulate square element with 20px long edges placed at (20, 20) on the page
4         var
5                 DEFAULT_VIEWPORT = {
6                         top: 0,
7                         left: 0,
8                         right: 100,
9                         bottom: 100
10                 };
12         QUnit.module( 'mediawiki.viewport', QUnit.newMwEnvironment( {
13                 setup: function () {
14                         this.el = $( '<div />' )
15                                 .appendTo( '#qunit-fixture' )
16                                 .width( 20 )
17                                 .height( 20 )
18                                 .offset( {
19                                         top: 20,
20                                         left: 20
21                                 } )
22                                 .get( 0 );
23                         this.sandbox.stub( mw.viewport, 'makeViewportFromWindow' )
24                                 .returns( DEFAULT_VIEWPORT );
25                 }
26         } ) );
28         QUnit.test( 'isElementInViewport', 6, function ( assert ) {
29                 var viewport = $.extend( {}, DEFAULT_VIEWPORT );
30                 assert.ok( mw.viewport.isElementInViewport( this.el, viewport ),
31                         'It should return true when the element is fully enclosed in the viewport' );
33                 viewport.right = 20;
34                 viewport.bottom = 20;
35                 assert.ok( mw.viewport.isElementInViewport( this.el, viewport ),
36                         'It should return true when only the top-left of the element is within the viewport' );
38                 viewport.top = 40;
39                 viewport.left = 40;
40                 viewport.right = 50;
41                 viewport.bottom = 50;
42                 assert.ok( mw.viewport.isElementInViewport( this.el, viewport ),
43                         'It should return true when only the bottom-right is within the viewport' );
45                 viewport.top = 30;
46                 viewport.left = 30;
47                 viewport.right = 35;
48                 viewport.bottom = 35;
49                 assert.ok( mw.viewport.isElementInViewport( this.el, viewport ),
50                         'It should return true when the element encapsulates the viewport' );
52                 viewport.top = 0;
53                 viewport.left = 0;
54                 viewport.right = 19;
55                 viewport.bottom = 19;
56                 assert.notOk( mw.viewport.isElementInViewport( this.el, viewport ),
57                         'It should return false when the element is not within the viewport' );
59                 assert.ok( mw.viewport.isElementInViewport( this.el ),
60                         'It should default to the window object if no viewport is given' );
61         } );
63         QUnit.test( 'isElementInViewport with scrolled page', 1, function ( assert ) {
64                 var viewport = {
65                                 top: 2000,
66                                 left: 0,
67                                 right: 1000,
68                                 bottom: 2500
69                         },
70                         el = $( '<div />' )
71                                 .appendTo( '#qunit-fixture' )
72                                 .width( 20 )
73                                 .height( 20 )
74                                 .offset( {
75                                         top: 2300,
76                                         left: 20
77                                 } )
78                                 .get( 0 );
79                 window.scrollTo( viewport.left, viewport.top );
80                 assert.ok( mw.viewport.isElementInViewport( el, viewport ),
81                         'It should return true when the element is fully enclosed in the ' +
82                         'viewport even when the page is scrolled down' );
83                 window.scrollTo( 0, 0 );
84         } );
86         QUnit.test( 'isElementCloseToViewport', 3, function ( assert ) {
87                 var
88                         viewport = {
89                                 top: 90,
90                                 left: 90,
91                                 right: 100,
92                                 bottom: 100
93                         },
94                         distantElement = $( '<div />' )
95                                 .appendTo( '#qunit-fixture' )
96                                 .width( 20 )
97                                 .height( 20 )
98                                 .offset( {
99                                         top: 220,
100                                         left: 20
101                                 } )
102                                 .get( 0 );
104                 assert.ok( mw.viewport.isElementCloseToViewport( this.el, 60, viewport ),
105                         'It should return true when the element is within the given threshold away' );
106                 assert.notOk( mw.viewport.isElementCloseToViewport( this.el, 20, viewport ),
107                         'It should return false when the element is further than the given threshold away' );
108                 assert.notOk( mw.viewport.isElementCloseToViewport( distantElement ),
109                         'It should default to a threshold of 50px and the window\'s viewport' );
110         } );
112 }( mediaWiki, jQuery ) );