-
Notifications
You must be signed in to change notification settings - Fork 426
/
Copy pathinp.njk
128 lines (112 loc) · 4.49 KB
/
inp.njk
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
<!--
Copyright 2022 Google LLC
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
https://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
-->
{% extends 'layout.njk' %}
{% block content %}
<h1 elementtiming="main-heading">INP Test</h1>
<p>
<label><input type="number" value="0" id="mousedown-blocking-time">
<code>mousedown</code> blocking time</label>
</p>
<p>
<label><input type="number" value="0" id="mouseup-blocking-time">
<code>mouseup</code> blocking time</label>
</p>
<p>
<label><input type="number" value="0" id="pointerdown-blocking-time">
<code>pointerdown</code> blocking time</label>
</p>
<p>
<label><input type="number" value="0" id="pointerup-blocking-time">
<code>pointerup</code> blocking time</label>
</p>
<p>
<label><input type="number" value="0" id="keydown-blocking-time">
<code>keydown</code> blocking time</label>
</p>
<p>
<label><input type="number" value="0" id="keyup-blocking-time">
<code>keyup</code> blocking time</label>
</p>
<p>
<label><input type="number" value="0" id="click-blocking-time">
<code>click</code> blocking time</label>
</p>
<p>
<button id="reset">Reset blocking time to zero</button>
</p>
<p>
<textarea id="textarea" style="width:40em;height:5em"></textarea>
</p>
<script>
// Set the blocking values based on query params if present.
const params = new URLSearchParams(location.search);
for (const [key, value] of params) {
const el = document.getElementById(`${key}-blocking-time`);
if (el && el.nodeName.toLowerCase() === 'input') {
el.value = value;
}
}
function block(event) {
const blockingTime = Number(document.getElementById(`${event.type}-blocking-time`).value);
const startTime = performance.now();
while (performance.now() < startTime + blockingTime) {
// Block...
}
}
function onInput(event) {
const input = event.target;
const eventName = input.id.slice(0, input.id.indexOf('-'));
if (input.value > 0) {
addEventListener(eventName, block, true);
} else {
removeEventListener(eventName, block, true);
}
}
function addBlockingListeners() {
const eventNames = [
'mousedown',
'mouseup',
'pointerdown',
'pointerup',
'keydown',
'keyup',
'click',
];
for (const eventName of eventNames) {
const input = document.getElementById(`${eventName}-blocking-time`);
input.addEventListener('input', onInput, true);
if (input.value > 0) {
addEventListener(eventName, block, true);
}
}
}
document.getElementById('reset').addEventListener('click', () => {
[...document.querySelectorAll('label>input')].forEach((n) => n.value = 0);
});
addBlockingListeners();
</script>
<p><a id="navigate-away" href="https://example.com">Navigate away</a></p>
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Proin nec porta orci, ac sagittis augue. Nullam orci tellus, suscipit sed magna id, mattis iaculis ex. Etiam felis lectus, accumsan eu magna lacinia, lobortis tempus lacus. Donec nulla metus, blandit eget ullamcorper in, placerat eu massa. Curabitur vitae elementum orci, ac tincidunt neque. Maecenas accumsan odio sit amet arcu elementum, non vestibulum enim finibus. Phasellus malesuada lacinia suscipit. Cras ac gravida urna. In et mauris non tellus pretium ultrices. Fusce mattis a risus at tincidunt. Donec ac fringilla magna, nec suscipit lectus. Sed risus massa, rutrum ut leo quis, tempor dapibus dui. Proin in mauris non risus maximus tincidunt quis a mauris.</p>
<script type="module">
const {onINP} = await __testImport('{{ modulePath }}');
onINP((inp) => {
// Log for easier manual testing.
console.log(inp);
// Test sending the metric to an analytics endpoint.
navigator.sendBeacon(`/collect`, JSON.stringify(__toSafeObject(inp)));
}, {
reportAllChanges: self.__reportAllChanges,
durationThreshold: self.__durationThreshold,
});
</script>
{% endblock %}