pointerevent_touch-action-inherit_highest-parent-none_touch.html (6894B)
1 <!doctype html> 2 <html> 3 <head> 4 <title>touch-action: parent: none + two embedded children</title> 5 <meta name="viewport" content="width=device-width"> 6 <link rel="stylesheet" type="text/css" href="pointerevent_styles.css"> 7 <script src="/resources/testharness.js"></script> 8 <script src="/resources/testharnessreport.js"></script> 9 <script src="/resources/testdriver.js"></script> 10 <script src="/resources/testdriver-actions.js"></script> 11 <script src="/resources/testdriver-vendor.js"></script> 12 <script src="pointerevent_support.js"></script> 13 <style> 14 #divParent { 15 touch-action: none; 16 } 17 </style> 18 </head> 19 <body onload="run()"> 20 <h1>Pointer Events touch-action attribute support</h1> 21 <h4 id="desc">Test Description: Try to scroll text DOWN inside blue rectangle. Wait for description update. Expected: pan enabled</h4> 22 <p>Note: this test is for touch-devices only</p> 23 <div id="divParent"> 24 <div class="scroller" id="target0"> 25 <div id="scrollTarget"> 26 <p> 27 Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diem 28 nonummy nibh euismod tincidunt ut lacreet dolore magna aliguam erat volutpat. 29 Ut wisis enim ad minim veniam, quis nostrud exerci tution ullamcorper suscipit 30 lobortis nisl ut aliquip ex ea commodo consequat. 31 </p> 32 <p>Lorem ipsum dolor sit amet...</p> 33 <p>Lorem ipsum dolor sit amet...</p> 34 <p>Lorem ipsum dolor sit amet...</p> 35 <p>Lorem ipsum dolor sit amet...</p> 36 <p>Lorem ipsum dolor sit amet...</p> 37 <p>Lorem ipsum dolor sit amet...</p> 38 <p>Lorem ipsum dolor sit amet...</p> 39 <p> 40 Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diem 41 nonummy nibh euismod tincidunt ut lacreet dolore magna aliguam erat volutpat. 42 Ut wisis enim ad minim veniam, quis nostrud exerci tution ullamcorper suscipit 43 lobortis nisl ut aliquip ex ea commodo consequat. 44 </p> 45 <p>Lorem ipsum dolor sit amet...</p> 46 <p>Lorem ipsum dolor sit amet...</p> 47 <p>Lorem ipsum dolor sit amet...</p> 48 <p>Lorem ipsum dolor sit amet...</p> 49 <p>Lorem ipsum dolor sit amet...</p> 50 <p>Lorem ipsum dolor sit amet...</p> 51 <p>Lorem ipsum dolor sit amet...</p> 52 <p> 53 Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diem 54 nonummy nibh euismod tincidunt ut lacreet dolore magna aliguam erat volutpat. 55 Ut wisis enim ad minim veniam, quis nostrud exerci tution ullamcorper suscipit 56 lobortis nisl ut aliquip ex ea commodo consequat. 57 </p> 58 <p>Lorem ipsum dolor sit amet...</p> 59 <p>Lorem ipsum dolor sit amet...</p> 60 <p>Lorem ipsum dolor sit amet...</p> 61 <p>Lorem ipsum dolor sit amet...</p> 62 <p>Lorem ipsum dolor sit amet...</p> 63 <p>Lorem ipsum dolor sit amet...</p> 64 <p>Lorem ipsum dolor sit amet...</p> 65 <p> 66 Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diem 67 nonummy nibh euismod tincidunt ut lacreet dolore magna aliguam erat volutpat. 68 Ut wisis enim ad minim veniam, quis nostrud exerci tution ullamcorper suscipit 69 lobortis nisl ut aliquip ex ea commodo consequat. 70 </p> 71 <p>Lorem ipsum dolor sit amet...</p> 72 <p>Lorem ipsum dolor sit amet...</p> 73 <p>Lorem ipsum dolor sit amet...</p> 74 <p>Lorem ipsum dolor sit amet...</p> 75 <p>Lorem ipsum dolor sit amet...</p> 76 <p>Lorem ipsum dolor sit amet...</p> 77 <p>Lorem ipsum dolor sit amet...</p> 78 </div> 79 </div> 80 </div> 81 <script type='text/javascript'> 82 var detected_pointertypes = {}; 83 84 var xScrollIsReceived = false; 85 var yScrollIsReceived = false; 86 var xScr0, yScr0, xScr1, yScr1; 87 88 add_completion_callback(showPointerTypes); 89 add_completion_callback(enableScrolling); 90 91 function run() { 92 var target0 = document.getElementById("target0"); 93 94 var test_touchaction = async_test("touch-action attribute test"); 95 var actions_promise; 96 97 xScr0 = target0.scrollLeft; 98 yScr0 = target0.scrollTop; 99 100 on_event(target0, 'pointerdown', function(event) { 101 detected_pointertypes[event.pointerType] = true; 102 }); 103 104 // Check if touch-action attribute works properly for embedded divs 105 // 106 // TA: 15. 107 on_event(target0, 'scroll', function(event) { 108 xScr1 = target0.scrollLeft; 109 yScr1 = target0.scrollTop; 110 111 if(xScr1 != xScr0) { 112 xScrollIsReceived = true; 113 } 114 115 if(yScr1 != yScr0) { 116 yScrollIsReceived = true; 117 updateDescriptionNextStep(); 118 } 119 120 if(xScrollIsReceived && yScrollIsReceived) { 121 // Make sure the test finishes after all the input actions are completed. 122 actions_promise.then( () => { 123 test_touchaction.done(); 124 }); 125 updateDescriptionComplete(); 126 } 127 }); 128 129 // Inject touch inputs and wait for all the actions finish to end the test. 130 actions_promise = touchScrollInTarget(target0, 'down').then(function() { 131 return touchScrollInTarget(target0, 'right'); 132 }); 133 } 134 135 function enableScrolling() { 136 document.getElementById('divParent').setAttribute('style', 'touch-action: auto'); 137 } 138 </script> 139 <h1>behaviour: auto</h1> 140 <div id="complete-notice"> 141 <p>The following pointer types were detected: <span id="pointertype-log"></span>.</p> 142 </div> 143 <div id="log"></div> 144 </body> 145 </html>