@openreplay/tracker 9.0.8 → 9.0.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (79) hide show
  1. package/CHANGELOG.md +8 -0
  2. package/cjs/app/index.js +1 -1
  3. package/cjs/index.js +1 -1
  4. package/cjs/modules/attributeSender.js +10 -8
  5. package/cjs/modules/timing.d.ts +1 -0
  6. package/cjs/modules/timing.js +7 -0
  7. package/coverage/clover.xml +3426 -0
  8. package/coverage/coverage-final.json +50 -0
  9. package/coverage/lcov-report/base.css +224 -0
  10. package/coverage/lcov-report/block-navigation.js +87 -0
  11. package/coverage/lcov-report/favicon.png +0 -0
  12. package/coverage/lcov-report/index.html +206 -0
  13. package/coverage/lcov-report/main/app/guards.ts.html +229 -0
  14. package/coverage/lcov-report/main/app/index.html +221 -0
  15. package/coverage/lcov-report/main/app/index.ts.html +2182 -0
  16. package/coverage/lcov-report/main/app/logger.ts.html +277 -0
  17. package/coverage/lcov-report/main/app/messages.gen.ts.html +2827 -0
  18. package/coverage/lcov-report/main/app/nodes.ts.html +385 -0
  19. package/coverage/lcov-report/main/app/observer/iframe_observer.ts.html +148 -0
  20. package/coverage/lcov-report/main/app/observer/iframe_offsets.ts.html +289 -0
  21. package/coverage/lcov-report/main/app/observer/index.html +161 -0
  22. package/coverage/lcov-report/main/app/observer/shadow_root_observer.ts.html +142 -0
  23. package/coverage/lcov-report/main/app/observer/top_observer.ts.html +538 -0
  24. package/coverage/lcov-report/main/app/sanitizer.ts.html +394 -0
  25. package/coverage/lcov-report/main/app/session.ts.html +601 -0
  26. package/coverage/lcov-report/main/app/ticker.ts.html +250 -0
  27. package/coverage/lcov-report/main/index.html +131 -0
  28. package/coverage/lcov-report/main/index.ts.html +1213 -0
  29. package/coverage/lcov-report/main/modules/Network/beaconProxy.ts.html +391 -0
  30. package/coverage/lcov-report/main/modules/Network/fetchProxy.ts.html +1027 -0
  31. package/coverage/lcov-report/main/modules/Network/index.html +191 -0
  32. package/coverage/lcov-report/main/modules/Network/index.ts.html +244 -0
  33. package/coverage/lcov-report/main/modules/Network/networkMessage.ts.html +385 -0
  34. package/coverage/lcov-report/main/modules/Network/utils.ts.html +700 -0
  35. package/coverage/lcov-report/main/modules/Network/xhrProxy.ts.html +850 -0
  36. package/coverage/lcov-report/main/modules/attributeSender.ts.html +232 -0
  37. package/coverage/lcov-report/main/modules/axiosSpy.ts.html +709 -0
  38. package/coverage/lcov-report/main/modules/connection.ts.html +160 -0
  39. package/coverage/lcov-report/main/modules/console.ts.html +541 -0
  40. package/coverage/lcov-report/main/modules/constructedStyleSheets.ts.html +559 -0
  41. package/coverage/lcov-report/main/modules/cssrules.ts.html +418 -0
  42. package/coverage/lcov-report/main/modules/exception.ts.html +385 -0
  43. package/coverage/lcov-report/main/modules/featureFlags.ts.html +412 -0
  44. package/coverage/lcov-report/main/modules/focus.ts.html +220 -0
  45. package/coverage/lcov-report/main/modules/fonts.ts.html +289 -0
  46. package/coverage/lcov-report/main/modules/img.ts.html +433 -0
  47. package/coverage/lcov-report/main/modules/index.html +401 -0
  48. package/coverage/lcov-report/main/modules/input.ts.html +826 -0
  49. package/coverage/lcov-report/main/modules/mouse.ts.html +826 -0
  50. package/coverage/lcov-report/main/modules/network.ts.html +1123 -0
  51. package/coverage/lcov-report/main/modules/performance.ts.html +367 -0
  52. package/coverage/lcov-report/main/modules/scroll.ts.html +364 -0
  53. package/coverage/lcov-report/main/modules/selection.ts.html +202 -0
  54. package/coverage/lcov-report/main/modules/tabs.ts.html +124 -0
  55. package/coverage/lcov-report/main/modules/timing.ts.html +841 -0
  56. package/coverage/lcov-report/main/modules/userTesting/dnd.ts.html +232 -0
  57. package/coverage/lcov-report/main/modules/userTesting/index.html +161 -0
  58. package/coverage/lcov-report/main/modules/userTesting/index.ts.html +1210 -0
  59. package/coverage/lcov-report/main/modules/userTesting/recorder.ts.html +361 -0
  60. package/coverage/lcov-report/main/modules/userTesting/styles.ts.html +865 -0
  61. package/coverage/lcov-report/main/modules/viewport.ts.html +250 -0
  62. package/coverage/lcov-report/main/utils.ts.html +406 -0
  63. package/coverage/lcov-report/prettify.css +1 -0
  64. package/coverage/lcov-report/prettify.js +2 -0
  65. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  66. package/coverage/lcov-report/sorter.js +196 -0
  67. package/coverage/lcov-report/webworker/BatchWriter.ts.html +481 -0
  68. package/coverage/lcov-report/webworker/MessageEncoder.gen.ts.html +961 -0
  69. package/coverage/lcov-report/webworker/PrimitiveEncoder.ts.html +436 -0
  70. package/coverage/lcov-report/webworker/QueueSender.ts.html +505 -0
  71. package/coverage/lcov-report/webworker/index.html +176 -0
  72. package/coverage/lcov-report/webworker/index.ts.html +628 -0
  73. package/coverage/lcov.info +6631 -0
  74. package/lib/app/index.js +1 -1
  75. package/lib/index.js +1 -1
  76. package/lib/modules/attributeSender.js +10 -8
  77. package/lib/modules/timing.d.ts +1 -0
  78. package/lib/modules/timing.js +7 -0
  79. package/package.json +1 -1
@@ -0,0 +1,826 @@
1
+
2
+ <!doctype html>
3
+ <html lang="en">
4
+
5
+ <head>
6
+ <title>Code coverage report for main/modules/mouse.ts</title>
7
+ <meta charset="utf-8" />
8
+ <link rel="stylesheet" href="../../prettify.css" />
9
+ <link rel="stylesheet" href="../../base.css" />
10
+ <link rel="shortcut icon" type="image/x-icon" href="../../favicon.png" />
11
+ <meta name="viewport" content="width=device-width, initial-scale=1" />
12
+ <style type='text/css'>
13
+ .coverage-summary .sorter {
14
+ background-image: url(../../sort-arrow-sprite.png);
15
+ }
16
+ </style>
17
+ </head>
18
+
19
+ <body>
20
+ <div class='wrapper'>
21
+ <div class='pad1'>
22
+ <h1><a href="../../index.html">All files</a> / <a href="index.html">main/modules</a> mouse.ts</h1>
23
+ <div class='clearfix'>
24
+
25
+ <div class='fl pad1y space-right2'>
26
+ <span class="strong">0% </span>
27
+ <span class="quiet">Statements</span>
28
+ <span class='fraction'>0/116</span>
29
+ </div>
30
+
31
+
32
+ <div class='fl pad1y space-right2'>
33
+ <span class="strong">0% </span>
34
+ <span class="quiet">Branches</span>
35
+ <span class='fraction'>0/81</span>
36
+ </div>
37
+
38
+
39
+ <div class='fl pad1y space-right2'>
40
+ <span class="strong">0% </span>
41
+ <span class="quiet">Functions</span>
42
+ <span class='fraction'>0/17</span>
43
+ </div>
44
+
45
+
46
+ <div class='fl pad1y space-right2'>
47
+ <span class="strong">0% </span>
48
+ <span class="quiet">Lines</span>
49
+ <span class='fraction'>0/115</span>
50
+ </div>
51
+
52
+
53
+ </div>
54
+ <p class="quiet">
55
+ Press <em>n</em> or <em>j</em> to go to the next uncovered block, <em>b</em>, <em>p</em> or <em>k</em> for the previous block.
56
+ </p>
57
+ <template id="filterTemplate">
58
+ <div class="quiet">
59
+ Filter:
60
+ <input oninput="onInput()" type="search" id="fileSearch">
61
+ </div>
62
+ </template>
63
+ </div>
64
+ <div class='status-line low'></div>
65
+ <pre><table class="coverage">
66
+ <tr><td class="line-count quiet"><a name='L1'></a><a href='#L1'>1</a>
67
+ <a name='L2'></a><a href='#L2'>2</a>
68
+ <a name='L3'></a><a href='#L3'>3</a>
69
+ <a name='L4'></a><a href='#L4'>4</a>
70
+ <a name='L5'></a><a href='#L5'>5</a>
71
+ <a name='L6'></a><a href='#L6'>6</a>
72
+ <a name='L7'></a><a href='#L7'>7</a>
73
+ <a name='L8'></a><a href='#L8'>8</a>
74
+ <a name='L9'></a><a href='#L9'>9</a>
75
+ <a name='L10'></a><a href='#L10'>10</a>
76
+ <a name='L11'></a><a href='#L11'>11</a>
77
+ <a name='L12'></a><a href='#L12'>12</a>
78
+ <a name='L13'></a><a href='#L13'>13</a>
79
+ <a name='L14'></a><a href='#L14'>14</a>
80
+ <a name='L15'></a><a href='#L15'>15</a>
81
+ <a name='L16'></a><a href='#L16'>16</a>
82
+ <a name='L17'></a><a href='#L17'>17</a>
83
+ <a name='L18'></a><a href='#L18'>18</a>
84
+ <a name='L19'></a><a href='#L19'>19</a>
85
+ <a name='L20'></a><a href='#L20'>20</a>
86
+ <a name='L21'></a><a href='#L21'>21</a>
87
+ <a name='L22'></a><a href='#L22'>22</a>
88
+ <a name='L23'></a><a href='#L23'>23</a>
89
+ <a name='L24'></a><a href='#L24'>24</a>
90
+ <a name='L25'></a><a href='#L25'>25</a>
91
+ <a name='L26'></a><a href='#L26'>26</a>
92
+ <a name='L27'></a><a href='#L27'>27</a>
93
+ <a name='L28'></a><a href='#L28'>28</a>
94
+ <a name='L29'></a><a href='#L29'>29</a>
95
+ <a name='L30'></a><a href='#L30'>30</a>
96
+ <a name='L31'></a><a href='#L31'>31</a>
97
+ <a name='L32'></a><a href='#L32'>32</a>
98
+ <a name='L33'></a><a href='#L33'>33</a>
99
+ <a name='L34'></a><a href='#L34'>34</a>
100
+ <a name='L35'></a><a href='#L35'>35</a>
101
+ <a name='L36'></a><a href='#L36'>36</a>
102
+ <a name='L37'></a><a href='#L37'>37</a>
103
+ <a name='L38'></a><a href='#L38'>38</a>
104
+ <a name='L39'></a><a href='#L39'>39</a>
105
+ <a name='L40'></a><a href='#L40'>40</a>
106
+ <a name='L41'></a><a href='#L41'>41</a>
107
+ <a name='L42'></a><a href='#L42'>42</a>
108
+ <a name='L43'></a><a href='#L43'>43</a>
109
+ <a name='L44'></a><a href='#L44'>44</a>
110
+ <a name='L45'></a><a href='#L45'>45</a>
111
+ <a name='L46'></a><a href='#L46'>46</a>
112
+ <a name='L47'></a><a href='#L47'>47</a>
113
+ <a name='L48'></a><a href='#L48'>48</a>
114
+ <a name='L49'></a><a href='#L49'>49</a>
115
+ <a name='L50'></a><a href='#L50'>50</a>
116
+ <a name='L51'></a><a href='#L51'>51</a>
117
+ <a name='L52'></a><a href='#L52'>52</a>
118
+ <a name='L53'></a><a href='#L53'>53</a>
119
+ <a name='L54'></a><a href='#L54'>54</a>
120
+ <a name='L55'></a><a href='#L55'>55</a>
121
+ <a name='L56'></a><a href='#L56'>56</a>
122
+ <a name='L57'></a><a href='#L57'>57</a>
123
+ <a name='L58'></a><a href='#L58'>58</a>
124
+ <a name='L59'></a><a href='#L59'>59</a>
125
+ <a name='L60'></a><a href='#L60'>60</a>
126
+ <a name='L61'></a><a href='#L61'>61</a>
127
+ <a name='L62'></a><a href='#L62'>62</a>
128
+ <a name='L63'></a><a href='#L63'>63</a>
129
+ <a name='L64'></a><a href='#L64'>64</a>
130
+ <a name='L65'></a><a href='#L65'>65</a>
131
+ <a name='L66'></a><a href='#L66'>66</a>
132
+ <a name='L67'></a><a href='#L67'>67</a>
133
+ <a name='L68'></a><a href='#L68'>68</a>
134
+ <a name='L69'></a><a href='#L69'>69</a>
135
+ <a name='L70'></a><a href='#L70'>70</a>
136
+ <a name='L71'></a><a href='#L71'>71</a>
137
+ <a name='L72'></a><a href='#L72'>72</a>
138
+ <a name='L73'></a><a href='#L73'>73</a>
139
+ <a name='L74'></a><a href='#L74'>74</a>
140
+ <a name='L75'></a><a href='#L75'>75</a>
141
+ <a name='L76'></a><a href='#L76'>76</a>
142
+ <a name='L77'></a><a href='#L77'>77</a>
143
+ <a name='L78'></a><a href='#L78'>78</a>
144
+ <a name='L79'></a><a href='#L79'>79</a>
145
+ <a name='L80'></a><a href='#L80'>80</a>
146
+ <a name='L81'></a><a href='#L81'>81</a>
147
+ <a name='L82'></a><a href='#L82'>82</a>
148
+ <a name='L83'></a><a href='#L83'>83</a>
149
+ <a name='L84'></a><a href='#L84'>84</a>
150
+ <a name='L85'></a><a href='#L85'>85</a>
151
+ <a name='L86'></a><a href='#L86'>86</a>
152
+ <a name='L87'></a><a href='#L87'>87</a>
153
+ <a name='L88'></a><a href='#L88'>88</a>
154
+ <a name='L89'></a><a href='#L89'>89</a>
155
+ <a name='L90'></a><a href='#L90'>90</a>
156
+ <a name='L91'></a><a href='#L91'>91</a>
157
+ <a name='L92'></a><a href='#L92'>92</a>
158
+ <a name='L93'></a><a href='#L93'>93</a>
159
+ <a name='L94'></a><a href='#L94'>94</a>
160
+ <a name='L95'></a><a href='#L95'>95</a>
161
+ <a name='L96'></a><a href='#L96'>96</a>
162
+ <a name='L97'></a><a href='#L97'>97</a>
163
+ <a name='L98'></a><a href='#L98'>98</a>
164
+ <a name='L99'></a><a href='#L99'>99</a>
165
+ <a name='L100'></a><a href='#L100'>100</a>
166
+ <a name='L101'></a><a href='#L101'>101</a>
167
+ <a name='L102'></a><a href='#L102'>102</a>
168
+ <a name='L103'></a><a href='#L103'>103</a>
169
+ <a name='L104'></a><a href='#L104'>104</a>
170
+ <a name='L105'></a><a href='#L105'>105</a>
171
+ <a name='L106'></a><a href='#L106'>106</a>
172
+ <a name='L107'></a><a href='#L107'>107</a>
173
+ <a name='L108'></a><a href='#L108'>108</a>
174
+ <a name='L109'></a><a href='#L109'>109</a>
175
+ <a name='L110'></a><a href='#L110'>110</a>
176
+ <a name='L111'></a><a href='#L111'>111</a>
177
+ <a name='L112'></a><a href='#L112'>112</a>
178
+ <a name='L113'></a><a href='#L113'>113</a>
179
+ <a name='L114'></a><a href='#L114'>114</a>
180
+ <a name='L115'></a><a href='#L115'>115</a>
181
+ <a name='L116'></a><a href='#L116'>116</a>
182
+ <a name='L117'></a><a href='#L117'>117</a>
183
+ <a name='L118'></a><a href='#L118'>118</a>
184
+ <a name='L119'></a><a href='#L119'>119</a>
185
+ <a name='L120'></a><a href='#L120'>120</a>
186
+ <a name='L121'></a><a href='#L121'>121</a>
187
+ <a name='L122'></a><a href='#L122'>122</a>
188
+ <a name='L123'></a><a href='#L123'>123</a>
189
+ <a name='L124'></a><a href='#L124'>124</a>
190
+ <a name='L125'></a><a href='#L125'>125</a>
191
+ <a name='L126'></a><a href='#L126'>126</a>
192
+ <a name='L127'></a><a href='#L127'>127</a>
193
+ <a name='L128'></a><a href='#L128'>128</a>
194
+ <a name='L129'></a><a href='#L129'>129</a>
195
+ <a name='L130'></a><a href='#L130'>130</a>
196
+ <a name='L131'></a><a href='#L131'>131</a>
197
+ <a name='L132'></a><a href='#L132'>132</a>
198
+ <a name='L133'></a><a href='#L133'>133</a>
199
+ <a name='L134'></a><a href='#L134'>134</a>
200
+ <a name='L135'></a><a href='#L135'>135</a>
201
+ <a name='L136'></a><a href='#L136'>136</a>
202
+ <a name='L137'></a><a href='#L137'>137</a>
203
+ <a name='L138'></a><a href='#L138'>138</a>
204
+ <a name='L139'></a><a href='#L139'>139</a>
205
+ <a name='L140'></a><a href='#L140'>140</a>
206
+ <a name='L141'></a><a href='#L141'>141</a>
207
+ <a name='L142'></a><a href='#L142'>142</a>
208
+ <a name='L143'></a><a href='#L143'>143</a>
209
+ <a name='L144'></a><a href='#L144'>144</a>
210
+ <a name='L145'></a><a href='#L145'>145</a>
211
+ <a name='L146'></a><a href='#L146'>146</a>
212
+ <a name='L147'></a><a href='#L147'>147</a>
213
+ <a name='L148'></a><a href='#L148'>148</a>
214
+ <a name='L149'></a><a href='#L149'>149</a>
215
+ <a name='L150'></a><a href='#L150'>150</a>
216
+ <a name='L151'></a><a href='#L151'>151</a>
217
+ <a name='L152'></a><a href='#L152'>152</a>
218
+ <a name='L153'></a><a href='#L153'>153</a>
219
+ <a name='L154'></a><a href='#L154'>154</a>
220
+ <a name='L155'></a><a href='#L155'>155</a>
221
+ <a name='L156'></a><a href='#L156'>156</a>
222
+ <a name='L157'></a><a href='#L157'>157</a>
223
+ <a name='L158'></a><a href='#L158'>158</a>
224
+ <a name='L159'></a><a href='#L159'>159</a>
225
+ <a name='L160'></a><a href='#L160'>160</a>
226
+ <a name='L161'></a><a href='#L161'>161</a>
227
+ <a name='L162'></a><a href='#L162'>162</a>
228
+ <a name='L163'></a><a href='#L163'>163</a>
229
+ <a name='L164'></a><a href='#L164'>164</a>
230
+ <a name='L165'></a><a href='#L165'>165</a>
231
+ <a name='L166'></a><a href='#L166'>166</a>
232
+ <a name='L167'></a><a href='#L167'>167</a>
233
+ <a name='L168'></a><a href='#L168'>168</a>
234
+ <a name='L169'></a><a href='#L169'>169</a>
235
+ <a name='L170'></a><a href='#L170'>170</a>
236
+ <a name='L171'></a><a href='#L171'>171</a>
237
+ <a name='L172'></a><a href='#L172'>172</a>
238
+ <a name='L173'></a><a href='#L173'>173</a>
239
+ <a name='L174'></a><a href='#L174'>174</a>
240
+ <a name='L175'></a><a href='#L175'>175</a>
241
+ <a name='L176'></a><a href='#L176'>176</a>
242
+ <a name='L177'></a><a href='#L177'>177</a>
243
+ <a name='L178'></a><a href='#L178'>178</a>
244
+ <a name='L179'></a><a href='#L179'>179</a>
245
+ <a name='L180'></a><a href='#L180'>180</a>
246
+ <a name='L181'></a><a href='#L181'>181</a>
247
+ <a name='L182'></a><a href='#L182'>182</a>
248
+ <a name='L183'></a><a href='#L183'>183</a>
249
+ <a name='L184'></a><a href='#L184'>184</a>
250
+ <a name='L185'></a><a href='#L185'>185</a>
251
+ <a name='L186'></a><a href='#L186'>186</a>
252
+ <a name='L187'></a><a href='#L187'>187</a>
253
+ <a name='L188'></a><a href='#L188'>188</a>
254
+ <a name='L189'></a><a href='#L189'>189</a>
255
+ <a name='L190'></a><a href='#L190'>190</a>
256
+ <a name='L191'></a><a href='#L191'>191</a>
257
+ <a name='L192'></a><a href='#L192'>192</a>
258
+ <a name='L193'></a><a href='#L193'>193</a>
259
+ <a name='L194'></a><a href='#L194'>194</a>
260
+ <a name='L195'></a><a href='#L195'>195</a>
261
+ <a name='L196'></a><a href='#L196'>196</a>
262
+ <a name='L197'></a><a href='#L197'>197</a>
263
+ <a name='L198'></a><a href='#L198'>198</a>
264
+ <a name='L199'></a><a href='#L199'>199</a>
265
+ <a name='L200'></a><a href='#L200'>200</a>
266
+ <a name='L201'></a><a href='#L201'>201</a>
267
+ <a name='L202'></a><a href='#L202'>202</a>
268
+ <a name='L203'></a><a href='#L203'>203</a>
269
+ <a name='L204'></a><a href='#L204'>204</a>
270
+ <a name='L205'></a><a href='#L205'>205</a>
271
+ <a name='L206'></a><a href='#L206'>206</a>
272
+ <a name='L207'></a><a href='#L207'>207</a>
273
+ <a name='L208'></a><a href='#L208'>208</a>
274
+ <a name='L209'></a><a href='#L209'>209</a>
275
+ <a name='L210'></a><a href='#L210'>210</a>
276
+ <a name='L211'></a><a href='#L211'>211</a>
277
+ <a name='L212'></a><a href='#L212'>212</a>
278
+ <a name='L213'></a><a href='#L213'>213</a>
279
+ <a name='L214'></a><a href='#L214'>214</a>
280
+ <a name='L215'></a><a href='#L215'>215</a>
281
+ <a name='L216'></a><a href='#L216'>216</a>
282
+ <a name='L217'></a><a href='#L217'>217</a>
283
+ <a name='L218'></a><a href='#L218'>218</a>
284
+ <a name='L219'></a><a href='#L219'>219</a>
285
+ <a name='L220'></a><a href='#L220'>220</a>
286
+ <a name='L221'></a><a href='#L221'>221</a>
287
+ <a name='L222'></a><a href='#L222'>222</a>
288
+ <a name='L223'></a><a href='#L223'>223</a>
289
+ <a name='L224'></a><a href='#L224'>224</a>
290
+ <a name='L225'></a><a href='#L225'>225</a>
291
+ <a name='L226'></a><a href='#L226'>226</a>
292
+ <a name='L227'></a><a href='#L227'>227</a>
293
+ <a name='L228'></a><a href='#L228'>228</a>
294
+ <a name='L229'></a><a href='#L229'>229</a>
295
+ <a name='L230'></a><a href='#L230'>230</a>
296
+ <a name='L231'></a><a href='#L231'>231</a>
297
+ <a name='L232'></a><a href='#L232'>232</a>
298
+ <a name='L233'></a><a href='#L233'>233</a>
299
+ <a name='L234'></a><a href='#L234'>234</a>
300
+ <a name='L235'></a><a href='#L235'>235</a>
301
+ <a name='L236'></a><a href='#L236'>236</a>
302
+ <a name='L237'></a><a href='#L237'>237</a>
303
+ <a name='L238'></a><a href='#L238'>238</a>
304
+ <a name='L239'></a><a href='#L239'>239</a>
305
+ <a name='L240'></a><a href='#L240'>240</a>
306
+ <a name='L241'></a><a href='#L241'>241</a>
307
+ <a name='L242'></a><a href='#L242'>242</a>
308
+ <a name='L243'></a><a href='#L243'>243</a>
309
+ <a name='L244'></a><a href='#L244'>244</a>
310
+ <a name='L245'></a><a href='#L245'>245</a>
311
+ <a name='L246'></a><a href='#L246'>246</a>
312
+ <a name='L247'></a><a href='#L247'>247</a>
313
+ <a name='L248'></a><a href='#L248'>248</a></td><td class="line-coverage quiet"><span class="cline-any cline-neutral">&nbsp;</span>
314
+ <span class="cline-any cline-no">&nbsp;</span>
315
+ <span class="cline-any cline-no">&nbsp;</span>
316
+ <span class="cline-any cline-no">&nbsp;</span>
317
+ <span class="cline-any cline-no">&nbsp;</span>
318
+ <span class="cline-any cline-no">&nbsp;</span>
319
+ <span class="cline-any cline-neutral">&nbsp;</span>
320
+ <span class="cline-any cline-neutral">&nbsp;</span>
321
+ <span class="cline-any cline-no">&nbsp;</span>
322
+ <span class="cline-any cline-neutral">&nbsp;</span>
323
+ <span class="cline-any cline-neutral">&nbsp;</span>
324
+ <span class="cline-any cline-neutral">&nbsp;</span>
325
+ <span class="cline-any cline-neutral">&nbsp;</span>
326
+ <span class="cline-any cline-neutral">&nbsp;</span>
327
+ <span class="cline-any cline-neutral">&nbsp;</span>
328
+ <span class="cline-any cline-neutral">&nbsp;</span>
329
+ <span class="cline-any cline-no">&nbsp;</span>
330
+ <span class="cline-any cline-neutral">&nbsp;</span>
331
+ <span class="cline-any cline-neutral">&nbsp;</span>
332
+ <span class="cline-any cline-neutral">&nbsp;</span>
333
+ <span class="cline-any cline-no">&nbsp;</span>
334
+ <span class="cline-any cline-no">&nbsp;</span>
335
+ <span class="cline-any cline-neutral">&nbsp;</span>
336
+ <span class="cline-any cline-neutral">&nbsp;</span>
337
+ <span class="cline-any cline-neutral">&nbsp;</span>
338
+ <span class="cline-any cline-neutral">&nbsp;</span>
339
+ <span class="cline-any cline-neutral">&nbsp;</span>
340
+ <span class="cline-any cline-neutral">&nbsp;</span>
341
+ <span class="cline-any cline-neutral">&nbsp;</span>
342
+ <span class="cline-any cline-neutral">&nbsp;</span>
343
+ <span class="cline-any cline-neutral">&nbsp;</span>
344
+ <span class="cline-any cline-neutral">&nbsp;</span>
345
+ <span class="cline-any cline-neutral">&nbsp;</span>
346
+ <span class="cline-any cline-neutral">&nbsp;</span>
347
+ <span class="cline-any cline-neutral">&nbsp;</span>
348
+ <span class="cline-any cline-neutral">&nbsp;</span>
349
+ <span class="cline-any cline-neutral">&nbsp;</span>
350
+ <span class="cline-any cline-no">&nbsp;</span>
351
+ <span class="cline-any cline-no">&nbsp;</span>
352
+ <span class="cline-any cline-neutral">&nbsp;</span>
353
+ <span class="cline-any cline-no">&nbsp;</span>
354
+ <span class="cline-any cline-neutral">&nbsp;</span>
355
+ <span class="cline-any cline-neutral">&nbsp;</span>
356
+ <span class="cline-any cline-neutral">&nbsp;</span>
357
+ <span class="cline-any cline-no">&nbsp;</span>
358
+ <span class="cline-any cline-no">&nbsp;</span>
359
+ <span class="cline-any cline-no">&nbsp;</span>
360
+ <span class="cline-any cline-no">&nbsp;</span>
361
+ <span class="cline-any cline-neutral">&nbsp;</span>
362
+ <span class="cline-any cline-no">&nbsp;</span>
363
+ <span class="cline-any cline-neutral">&nbsp;</span>
364
+ <span class="cline-any cline-no">&nbsp;</span>
365
+ <span class="cline-any cline-no">&nbsp;</span>
366
+ <span class="cline-any cline-no">&nbsp;</span>
367
+ <span class="cline-any cline-no">&nbsp;</span>
368
+ <span class="cline-any cline-no">&nbsp;</span>
369
+ <span class="cline-any cline-neutral">&nbsp;</span>
370
+ <span class="cline-any cline-neutral">&nbsp;</span>
371
+ <span class="cline-any cline-no">&nbsp;</span>
372
+ <span class="cline-any cline-no">&nbsp;</span>
373
+ <span class="cline-any cline-no">&nbsp;</span>
374
+ <span class="cline-any cline-no">&nbsp;</span>
375
+ <span class="cline-any cline-no">&nbsp;</span>
376
+ <span class="cline-any cline-neutral">&nbsp;</span>
377
+ <span class="cline-any cline-no">&nbsp;</span>
378
+ <span class="cline-any cline-no">&nbsp;</span>
379
+ <span class="cline-any cline-neutral">&nbsp;</span>
380
+ <span class="cline-any cline-no">&nbsp;</span>
381
+ <span class="cline-any cline-no">&nbsp;</span>
382
+ <span class="cline-any cline-neutral">&nbsp;</span>
383
+ <span class="cline-any cline-no">&nbsp;</span>
384
+ <span class="cline-any cline-neutral">&nbsp;</span>
385
+ <span class="cline-any cline-no">&nbsp;</span>
386
+ <span class="cline-any cline-neutral">&nbsp;</span>
387
+ <span class="cline-any cline-neutral">&nbsp;</span>
388
+ <span class="cline-any cline-neutral">&nbsp;</span>
389
+ <span class="cline-any cline-neutral">&nbsp;</span>
390
+ <span class="cline-any cline-neutral">&nbsp;</span>
391
+ <span class="cline-any cline-neutral">&nbsp;</span>
392
+ <span class="cline-any cline-neutral">&nbsp;</span>
393
+ <span class="cline-any cline-neutral">&nbsp;</span>
394
+ <span class="cline-any cline-neutral">&nbsp;</span>
395
+ <span class="cline-any cline-neutral">&nbsp;</span>
396
+ <span class="cline-any cline-neutral">&nbsp;</span>
397
+ <span class="cline-any cline-neutral">&nbsp;</span>
398
+ <span class="cline-any cline-neutral">&nbsp;</span>
399
+ <span class="cline-any cline-neutral">&nbsp;</span>
400
+ <span class="cline-any cline-neutral">&nbsp;</span>
401
+ <span class="cline-any cline-neutral">&nbsp;</span>
402
+ <span class="cline-any cline-neutral">&nbsp;</span>
403
+ <span class="cline-any cline-neutral">&nbsp;</span>
404
+ <span class="cline-any cline-neutral">&nbsp;</span>
405
+ <span class="cline-any cline-neutral">&nbsp;</span>
406
+ <span class="cline-any cline-neutral">&nbsp;</span>
407
+ <span class="cline-any cline-neutral">&nbsp;</span>
408
+ <span class="cline-any cline-neutral">&nbsp;</span>
409
+ <span class="cline-any cline-neutral">&nbsp;</span>
410
+ <span class="cline-any cline-neutral">&nbsp;</span>
411
+ <span class="cline-any cline-neutral">&nbsp;</span>
412
+ <span class="cline-any cline-neutral">&nbsp;</span>
413
+ <span class="cline-any cline-neutral">&nbsp;</span>
414
+ <span class="cline-any cline-neutral">&nbsp;</span>
415
+ <span class="cline-any cline-neutral">&nbsp;</span>
416
+ <span class="cline-any cline-neutral">&nbsp;</span>
417
+ <span class="cline-any cline-neutral">&nbsp;</span>
418
+ <span class="cline-any cline-no">&nbsp;</span>
419
+ <span class="cline-any cline-no">&nbsp;</span>
420
+ <span class="cline-any cline-neutral">&nbsp;</span>
421
+ <span class="cline-any cline-no">&nbsp;</span>
422
+ <span class="cline-any cline-no">&nbsp;</span>
423
+ <span class="cline-any cline-no">&nbsp;</span>
424
+ <span class="cline-any cline-neutral">&nbsp;</span>
425
+ <span class="cline-any cline-no">&nbsp;</span>
426
+ <span class="cline-any cline-no">&nbsp;</span>
427
+ <span class="cline-any cline-neutral">&nbsp;</span>
428
+ <span class="cline-any cline-no">&nbsp;</span>
429
+ <span class="cline-any cline-no">&nbsp;</span>
430
+ <span class="cline-any cline-no">&nbsp;</span>
431
+ <span class="cline-any cline-no">&nbsp;</span>
432
+ <span class="cline-any cline-neutral">&nbsp;</span>
433
+ <span class="cline-any cline-no">&nbsp;</span>
434
+ <span class="cline-any cline-no">&nbsp;</span>
435
+ <span class="cline-any cline-neutral">&nbsp;</span>
436
+ <span class="cline-any cline-no">&nbsp;</span>
437
+ <span class="cline-any cline-neutral">&nbsp;</span>
438
+ <span class="cline-any cline-neutral">&nbsp;</span>
439
+ <span class="cline-any cline-no">&nbsp;</span>
440
+ <span class="cline-any cline-no">&nbsp;</span>
441
+ <span class="cline-any cline-no">&nbsp;</span>
442
+ <span class="cline-any cline-no">&nbsp;</span>
443
+ <span class="cline-any cline-no">&nbsp;</span>
444
+ <span class="cline-any cline-no">&nbsp;</span>
445
+ <span class="cline-any cline-neutral">&nbsp;</span>
446
+ <span class="cline-any cline-no">&nbsp;</span>
447
+ <span class="cline-any cline-no">&nbsp;</span>
448
+ <span class="cline-any cline-no">&nbsp;</span>
449
+ <span class="cline-any cline-no">&nbsp;</span>
450
+ <span class="cline-any cline-neutral">&nbsp;</span>
451
+ <span class="cline-any cline-no">&nbsp;</span>
452
+ <span class="cline-any cline-no">&nbsp;</span>
453
+ <span class="cline-any cline-neutral">&nbsp;</span>
454
+ <span class="cline-any cline-neutral">&nbsp;</span>
455
+ <span class="cline-any cline-no">&nbsp;</span>
456
+ <span class="cline-any cline-neutral">&nbsp;</span>
457
+ <span class="cline-any cline-no">&nbsp;</span>
458
+ <span class="cline-any cline-no">&nbsp;</span>
459
+ <span class="cline-any cline-no">&nbsp;</span>
460
+ <span class="cline-any cline-neutral">&nbsp;</span>
461
+ <span class="cline-any cline-neutral">&nbsp;</span>
462
+ <span class="cline-any cline-no">&nbsp;</span>
463
+ <span class="cline-any cline-no">&nbsp;</span>
464
+ <span class="cline-any cline-no">&nbsp;</span>
465
+ <span class="cline-any cline-neutral">&nbsp;</span>
466
+ <span class="cline-any cline-neutral">&nbsp;</span>
467
+ <span class="cline-any cline-no">&nbsp;</span>
468
+ <span class="cline-any cline-no">&nbsp;</span>
469
+ <span class="cline-any cline-no">&nbsp;</span>
470
+ <span class="cline-any cline-neutral">&nbsp;</span>
471
+ <span class="cline-any cline-neutral">&nbsp;</span>
472
+ <span class="cline-any cline-no">&nbsp;</span>
473
+ <span class="cline-any cline-no">&nbsp;</span>
474
+ <span class="cline-any cline-neutral">&nbsp;</span>
475
+ <span class="cline-any cline-neutral">&nbsp;</span>
476
+ <span class="cline-any cline-no">&nbsp;</span>
477
+ <span class="cline-any cline-no">&nbsp;</span>
478
+ <span class="cline-any cline-no">&nbsp;</span>
479
+ <span class="cline-any cline-no">&nbsp;</span>
480
+ <span class="cline-any cline-no">&nbsp;</span>
481
+ <span class="cline-any cline-no">&nbsp;</span>
482
+ <span class="cline-any cline-no">&nbsp;</span>
483
+ <span class="cline-any cline-no">&nbsp;</span>
484
+ <span class="cline-any cline-neutral">&nbsp;</span>
485
+ <span class="cline-any cline-neutral">&nbsp;</span>
486
+ <span class="cline-any cline-neutral">&nbsp;</span>
487
+ <span class="cline-any cline-no">&nbsp;</span>
488
+ <span class="cline-any cline-no">&nbsp;</span>
489
+ <span class="cline-any cline-no">&nbsp;</span>
490
+ <span class="cline-any cline-no">&nbsp;</span>
491
+ <span class="cline-any cline-neutral">&nbsp;</span>
492
+ <span class="cline-any cline-neutral">&nbsp;</span>
493
+ <span class="cline-any cline-neutral">&nbsp;</span>
494
+ <span class="cline-any cline-no">&nbsp;</span>
495
+ <span class="cline-any cline-neutral">&nbsp;</span>
496
+ <span class="cline-any cline-no">&nbsp;</span>
497
+ <span class="cline-any cline-neutral">&nbsp;</span>
498
+ <span class="cline-any cline-neutral">&nbsp;</span>
499
+ <span class="cline-any cline-no">&nbsp;</span>
500
+ <span class="cline-any cline-neutral">&nbsp;</span>
501
+ <span class="cline-any cline-neutral">&nbsp;</span>
502
+ <span class="cline-any cline-neutral">&nbsp;</span>
503
+ <span class="cline-any cline-no">&nbsp;</span>
504
+ <span class="cline-any cline-no">&nbsp;</span>
505
+ <span class="cline-any cline-no">&nbsp;</span>
506
+ <span class="cline-any cline-no">&nbsp;</span>
507
+ <span class="cline-any cline-no">&nbsp;</span>
508
+ <span class="cline-any cline-neutral">&nbsp;</span>
509
+ <span class="cline-any cline-neutral">&nbsp;</span>
510
+ <span class="cline-any cline-no">&nbsp;</span>
511
+ <span class="cline-any cline-neutral">&nbsp;</span>
512
+ <span class="cline-any cline-neutral">&nbsp;</span>
513
+ <span class="cline-any cline-neutral">&nbsp;</span>
514
+ <span class="cline-any cline-no">&nbsp;</span>
515
+ <span class="cline-any cline-no">&nbsp;</span>
516
+ <span class="cline-any cline-no">&nbsp;</span>
517
+ <span class="cline-any cline-no">&nbsp;</span>
518
+ <span class="cline-any cline-neutral">&nbsp;</span>
519
+ <span class="cline-any cline-no">&nbsp;</span>
520
+ <span class="cline-any cline-no">&nbsp;</span>
521
+ <span class="cline-any cline-neutral">&nbsp;</span>
522
+ <span class="cline-any cline-no">&nbsp;</span>
523
+ <span class="cline-any cline-no">&nbsp;</span>
524
+ <span class="cline-any cline-no">&nbsp;</span>
525
+ <span class="cline-any cline-neutral">&nbsp;</span>
526
+ <span class="cline-any cline-neutral">&nbsp;</span>
527
+ <span class="cline-any cline-neutral">&nbsp;</span>
528
+ <span class="cline-any cline-neutral">&nbsp;</span>
529
+ <span class="cline-any cline-no">&nbsp;</span>
530
+ <span class="cline-any cline-no">&nbsp;</span>
531
+ <span class="cline-any cline-no">&nbsp;</span>
532
+ <span class="cline-any cline-no">&nbsp;</span>
533
+ <span class="cline-any cline-neutral">&nbsp;</span>
534
+ <span class="cline-any cline-no">&nbsp;</span>
535
+ <span class="cline-any cline-no">&nbsp;</span>
536
+ <span class="cline-any cline-no">&nbsp;</span>
537
+ <span class="cline-any cline-no">&nbsp;</span>
538
+ <span class="cline-any cline-neutral">&nbsp;</span>
539
+ <span class="cline-any cline-neutral">&nbsp;</span>
540
+ <span class="cline-any cline-neutral">&nbsp;</span>
541
+ <span class="cline-any cline-neutral">&nbsp;</span>
542
+ <span class="cline-any cline-neutral">&nbsp;</span>
543
+ <span class="cline-any cline-neutral">&nbsp;</span>
544
+ <span class="cline-any cline-neutral">&nbsp;</span>
545
+ <span class="cline-any cline-neutral">&nbsp;</span>
546
+ <span class="cline-any cline-neutral">&nbsp;</span>
547
+ <span class="cline-any cline-no">&nbsp;</span>
548
+ <span class="cline-any cline-neutral">&nbsp;</span>
549
+ <span class="cline-any cline-neutral">&nbsp;</span>
550
+ <span class="cline-any cline-neutral">&nbsp;</span>
551
+ <span class="cline-any cline-no">&nbsp;</span>
552
+ <span class="cline-any cline-no">&nbsp;</span>
553
+ <span class="cline-any cline-no">&nbsp;</span>
554
+ <span class="cline-any cline-neutral">&nbsp;</span>
555
+ <span class="cline-any cline-neutral">&nbsp;</span>
556
+ <span class="cline-any cline-no">&nbsp;</span>
557
+ <span class="cline-any cline-neutral">&nbsp;</span>
558
+ <span class="cline-any cline-no">&nbsp;</span>
559
+ <span class="cline-any cline-neutral">&nbsp;</span>
560
+ <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js">import type App from '../app/index.js'
561
+ <span class="cstat-no" title="statement not covered" >import { hasTag, isSVGElement, isDocument } from '../app/guards.js'</span>
562
+ <span class="cstat-no" title="statement not covered" >import { normSpaces, hasOpenreplayAttribute, getLabelAttribute, now } from '../utils.js'</span>
563
+ <span class="cstat-no" title="statement not covered" >import { MouseMove, MouseClick, MouseThrashing } from '../app/messages.gen.js'</span>
564
+ <span class="cstat-no" title="statement not covered" >import { getInputLabel } from './input.js'</span>
565
+ <span class="cstat-no" title="statement not covered" >import { finder } from '@medv/finder'</span>
566
+ &nbsp;
567
+ function <span class="fstat-no" title="function not covered" >_getSelector(</span>target: Element, document: Document, options?: MouseHandlerOptions): string {
568
+ const selector = <span class="cstat-no" title="statement not covered" >finder(target, {</span>
569
+ root: document.body,
570
+ seedMinLength: 3,
571
+ optimizedMinLength: options?.minSelectorDepth || 2,
572
+ threshold: options?.nthThreshold || 1000,
573
+ maxNumberOfTries: options?.maxOptimiseTries || 10_000,
574
+ })
575
+ &nbsp;
576
+ <span class="cstat-no" title="statement not covered" > return selector</span>
577
+ }
578
+ &nbsp;
579
+ function <span class="fstat-no" title="function not covered" >isClickable(</span>element: Element): boolean {
580
+ const tag = <span class="cstat-no" title="statement not covered" >element.tagName.toUpperCase()</span>
581
+ <span class="cstat-no" title="statement not covered" > return (</span>
582
+ tag === 'BUTTON' ||
583
+ tag === 'A' ||
584
+ tag === 'LI' ||
585
+ tag === 'SELECT' ||
586
+ tag === 'TR' ||
587
+ tag === 'TH' ||
588
+ (element as HTMLElement).onclick != null ||
589
+ element.getAttribute('role') === 'button'
590
+ )
591
+ //|| element.className.includes("btn")
592
+ // MBTODO: intercept addEventListener
593
+ }
594
+ &nbsp;
595
+ //TODO: fix (typescript is not sure about target variable after assignation of svg)
596
+ function <span class="fstat-no" title="function not covered" >getTarget(</span>target: EventTarget | null, document: Document): Element | null {
597
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (target instanceof Element) {</span>
598
+ <span class="cstat-no" title="statement not covered" > return _getTarget(target, document)</span>
599
+ }
600
+ <span class="cstat-no" title="statement not covered" > return null</span>
601
+ }
602
+ &nbsp;
603
+ function <span class="fstat-no" title="function not covered" >_getTarget(</span>target: Element, document: Document): Element | null {
604
+ let element: Element | null = <span class="cstat-no" title="statement not covered" >target</span>
605
+ <span class="cstat-no" title="statement not covered" > while (element !== null &amp;&amp; element !== document.documentElement) {</span>
606
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (hasOpenreplayAttribute(element, 'masked')) {</span>
607
+ <span class="cstat-no" title="statement not covered" > return null</span>
608
+ }
609
+ <span class="cstat-no" title="statement not covered" > element = element.parentElement</span>
610
+ }
611
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (isSVGElement(target)) {</span>
612
+ let owner = <span class="cstat-no" title="statement not covered" >target.ownerSVGElement</span>
613
+ <span class="cstat-no" title="statement not covered" > while (owner !== null) {</span>
614
+ <span class="cstat-no" title="statement not covered" > target = owner</span>
615
+ <span class="cstat-no" title="statement not covered" > owner = owner.ownerSVGElement</span>
616
+ }
617
+ }
618
+ <span class="cstat-no" title="statement not covered" > element = target</span>
619
+ <span class="cstat-no" title="statement not covered" > while (element !== null &amp;&amp; element !== document.documentElement) {</span>
620
+ const tag = <span class="cstat-no" title="statement not covered" >element.tagName.toUpperCase()</span>
621
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (tag === 'LABEL') {</span>
622
+ <span class="cstat-no" title="statement not covered" > return null</span>
623
+ }
624
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (tag === 'INPUT') {</span>
625
+ <span class="cstat-no" title="statement not covered" > return element</span>
626
+ }
627
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (isClickable(element) || getLabelAttribute(element) !== null) {</span>
628
+ <span class="cstat-no" title="statement not covered" > return element</span>
629
+ }
630
+ <span class="cstat-no" title="statement not covered" > element = element.parentElement</span>
631
+ }
632
+ <span class="cstat-no" title="statement not covered" > return target === document.documentElement ? null : target</span>
633
+ }
634
+ &nbsp;
635
+ export interface MouseHandlerOptions {
636
+ disableClickmaps?: boolean
637
+ /** minimum length of an optimised selector.
638
+ *
639
+ * body &gt; div &gt; div &gt; p =&gt; body &gt; p for example
640
+ *
641
+ * default 2
642
+ * */
643
+ minSelectorDepth?: number
644
+ /** how many selectors to try before falling back to nth-child selectors
645
+ * performance expensive operation
646
+ *
647
+ * default 1000
648
+ * */
649
+ nthThreshold?: number
650
+ /**
651
+ * how many tries to optimise and shorten the selector
652
+ *
653
+ * default 10_000
654
+ * */
655
+ maxOptimiseTries?: number
656
+ /**
657
+ * how many ticks to wait before capturing mouse position
658
+ * (can affect performance)
659
+ * 1 tick = 30ms
660
+ * default 7
661
+ * */
662
+ trackingOffset?: number
663
+ }
664
+ &nbsp;
665
+ <span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" >export default function (a</span></span>pp: App, options?: MouseHandlerOptions): void {
666
+ const { disableClickmaps = <span class="branch-0 cbranch-no" title="branch not covered" >false </span>} = <span class="cstat-no" title="statement not covered" >options || {}</span>
667
+ function <span class="fstat-no" title="function not covered" >getTargetLabel(</span>target: Element): string {
668
+ const dl = <span class="cstat-no" title="statement not covered" >getLabelAttribute(target)</span>
669
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (dl !== null) {</span>
670
+ <span class="cstat-no" title="statement not covered" > return dl</span>
671
+ }
672
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (hasTag(target, 'input')) {</span>
673
+ <span class="cstat-no" title="statement not covered" > return getInputLabel(target)</span>
674
+ }
675
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (isClickable(target)) {</span>
676
+ let label = <span class="cstat-no" title="statement not covered" >''</span>
677
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (target instanceof HTMLElement) {</span>
678
+ <span class="cstat-no" title="statement not covered" > label = app.sanitizer.getInnerTextSecure(target)</span>
679
+ }
680
+ <span class="cstat-no" title="statement not covered" > label = label || target.id || target.className</span>
681
+ <span class="cstat-no" title="statement not covered" > return normSpaces(label).slice(0, 100)</span>
682
+ }
683
+ <span class="cstat-no" title="statement not covered" > return ''</span>
684
+ }
685
+ &nbsp;
686
+ let mousePositionX = <span class="cstat-no" title="statement not covered" >-1</span>
687
+ let mousePositionY = <span class="cstat-no" title="statement not covered" >-1</span>
688
+ let mousePositionChanged = <span class="cstat-no" title="statement not covered" >false</span>
689
+ let mouseTarget: Element | null = <span class="cstat-no" title="statement not covered" >null</span>
690
+ let mouseTargetTime = <span class="cstat-no" title="statement not covered" >0</span>
691
+ let selectorMap: { [id: number]: string } = <span class="cstat-no" title="statement not covered" >{}</span>
692
+ &nbsp;
693
+ let velocity = <span class="cstat-no" title="statement not covered" >0</span>
694
+ let direction = <span class="cstat-no" title="statement not covered" >0</span>
695
+ let directionChangeCount = <span class="cstat-no" title="statement not covered" >0</span>
696
+ let distance = <span class="cstat-no" title="statement not covered" >0</span>
697
+ let checkIntervalId: NodeJS.Timer
698
+ const shakeThreshold = <span class="cstat-no" title="statement not covered" >0.008</span>
699
+ const shakeCheckInterval = <span class="cstat-no" title="statement not covered" >225</span>
700
+ &nbsp;
701
+ function <span class="fstat-no" title="function not covered" >checkMouseShaking(</span>) {
702
+ const nextVelocity = <span class="cstat-no" title="statement not covered" >distance / shakeCheckInterval</span>
703
+ &nbsp;
704
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (!velocity) {</span>
705
+ <span class="cstat-no" title="statement not covered" > velocity = nextVelocity</span>
706
+ <span class="cstat-no" title="statement not covered" > return</span>
707
+ }
708
+ &nbsp;
709
+ const acceleration = <span class="cstat-no" title="statement not covered" >(nextVelocity - velocity) / shakeCheckInterval</span>
710
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (directionChangeCount &gt; 4 &amp;&amp; acceleration &gt; shakeThreshold) {</span>
711
+ <span class="cstat-no" title="statement not covered" > app.send(MouseThrashing(now()))</span>
712
+ }
713
+ &nbsp;
714
+ <span class="cstat-no" title="statement not covered" > distance = 0</span>
715
+ <span class="cstat-no" title="statement not covered" > directionChangeCount = 0</span>
716
+ <span class="cstat-no" title="statement not covered" > velocity = nextVelocity</span>
717
+ }
718
+ &nbsp;
719
+ <span class="cstat-no" title="statement not covered" > app.attachStartCallback(<span class="fstat-no" title="function not covered" >() =</span>&gt; {</span>
720
+ <span class="cstat-no" title="statement not covered" > checkIntervalId = setInterval(<span class="fstat-no" title="function not covered" >() =</span>&gt; <span class="cstat-no" title="statement not covered" >checkMouseShaking(),</span> shakeCheckInterval)</span>
721
+ })
722
+ &nbsp;
723
+ <span class="cstat-no" title="statement not covered" > app.attachStopCallback(<span class="fstat-no" title="function not covered" >() =</span>&gt; {</span>
724
+ <span class="cstat-no" title="statement not covered" > mousePositionX = -1</span>
725
+ <span class="cstat-no" title="statement not covered" > mousePositionY = -1</span>
726
+ <span class="cstat-no" title="statement not covered" > mousePositionChanged = false</span>
727
+ <span class="cstat-no" title="statement not covered" > mouseTarget = null</span>
728
+ <span class="cstat-no" title="statement not covered" > selectorMap = {}</span>
729
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (checkIntervalId) {</span>
730
+ <span class="cstat-no" title="statement not covered" > clearInterval(checkIntervalId as unknown as number)</span>
731
+ }
732
+ })
733
+ &nbsp;
734
+ const sendMouseMove = <span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" >(): void =</span>&gt; {</span>
735
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (mousePositionChanged) {</span>
736
+ <span class="cstat-no" title="statement not covered" > app.send(MouseMove(mousePositionX, mousePositionY))</span>
737
+ <span class="cstat-no" title="statement not covered" > mousePositionChanged = false</span>
738
+ }
739
+ }
740
+ &nbsp;
741
+ const patchDocument = <span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" >(d</span>ocument: Document, topframe = <span class="branch-0 cbranch-no" title="branch not covered" >false)</span> =&gt; {</span>
742
+ function <span class="fstat-no" title="function not covered" >getSelector(</span>id: number, target: Element, options?: MouseHandlerOptions): string {
743
+ <span class="cstat-no" title="statement not covered" > return (selectorMap[id] = selectorMap[id] || _getSelector(target, document, options))</span>
744
+ }
745
+ &nbsp;
746
+ const attachListener = <span class="cstat-no" title="statement not covered" >topframe</span>
747
+ ? app.attachEventListener.bind(app) // attached/removed on start/stop
748
+ : app.nodes.attachNodeListener.bind(app.nodes) // attached/removed on node register/unregister
749
+ &nbsp;
750
+ <span class="cstat-no" title="statement not covered" > attachListener(document.documentElement, 'mouseover', <span class="fstat-no" title="function not covered" >(e</span>: MouseEvent): void =&gt; {</span>
751
+ const target = <span class="cstat-no" title="statement not covered" >getTarget(e.target, document)</span>
752
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (target !== mouseTarget) {</span>
753
+ <span class="cstat-no" title="statement not covered" > mouseTarget = target</span>
754
+ <span class="cstat-no" title="statement not covered" > mouseTargetTime = performance.now()</span>
755
+ }
756
+ })
757
+ <span class="cstat-no" title="statement not covered" > attachListener(</span>
758
+ document,
759
+ 'mousemove',
760
+ <span class="fstat-no" title="function not covered" > (e</span>: MouseEvent): void =&gt; {
761
+ const [left, top] = <span class="cstat-no" title="statement not covered" >app.observer.getDocumentOffset(document) </span>// MBTODO?: document-id related message
762
+ <span class="cstat-no" title="statement not covered" > mousePositionX = e.clientX + left</span>
763
+ <span class="cstat-no" title="statement not covered" > mousePositionY = e.clientY + top</span>
764
+ <span class="cstat-no" title="statement not covered" > mousePositionChanged = true</span>
765
+ &nbsp;
766
+ const nextDirection = <span class="cstat-no" title="statement not covered" >Math.sign(e.movementX)</span>
767
+ <span class="cstat-no" title="statement not covered" > distance += Math.abs(e.movementX) + Math.abs(e.movementY)</span>
768
+ &nbsp;
769
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (nextDirection !== direction) {</span>
770
+ <span class="cstat-no" title="statement not covered" > direction = nextDirection</span>
771
+ <span class="cstat-no" title="statement not covered" > directionChangeCount++</span>
772
+ }
773
+ },
774
+ false,
775
+ )
776
+ <span class="cstat-no" title="statement not covered" > attachListener(document, 'click', <span class="fstat-no" title="function not covered" >(e</span>: MouseEvent): void =&gt; {</span>
777
+ const target = <span class="cstat-no" title="statement not covered" >getTarget(e.target, document)</span>
778
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if ((!e.clientX &amp;&amp; !e.clientY) || target === null) {</span>
779
+ <span class="cstat-no" title="statement not covered" > return</span>
780
+ }
781
+ const id = <span class="cstat-no" title="statement not covered" >app.nodes.getID(target)</span>
782
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (id !== undefined) {</span>
783
+ <span class="cstat-no" title="statement not covered" > sendMouseMove()</span>
784
+ <span class="cstat-no" title="statement not covered" > app.send(</span>
785
+ MouseClick(
786
+ id,
787
+ mouseTarget === target ? Math.round(performance.now() - mouseTargetTime) : 0,
788
+ getTargetLabel(target),
789
+ isClickable(target) &amp;&amp; !disableClickmaps ? getSelector(id, target, options) : '',
790
+ ),
791
+ true,
792
+ )
793
+ }
794
+ <span class="cstat-no" title="statement not covered" > mouseTarget = null</span>
795
+ })
796
+ }
797
+ &nbsp;
798
+ <span class="cstat-no" title="statement not covered" > app.nodes.attachNodeCallback(<span class="fstat-no" title="function not covered" >(n</span>ode) =&gt; {</span>
799
+ <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (isDocument(node)) {</span>
800
+ <span class="cstat-no" title="statement not covered" > patchDocument(node)</span>
801
+ }
802
+ })
803
+ <span class="cstat-no" title="statement not covered" > patchDocument(document, true)</span>
804
+ &nbsp;
805
+ <span class="cstat-no" title="statement not covered" > app.ticker.attach(sendMouseMove, options?.trackingOffset || 7)</span>
806
+ }
807
+ &nbsp;</pre></td></tr></table></pre>
808
+
809
+ <div class='push'></div><!-- for sticky footer -->
810
+ </div><!-- /wrapper -->
811
+ <div class='footer quiet pad2 space-top1 center small'>
812
+ Code coverage generated by
813
+ <a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
814
+ at 2023-10-17T13:37:58.420Z
815
+ </div>
816
+ <script src="../../prettify.js"></script>
817
+ <script>
818
+ window.onload = function () {
819
+ prettyPrint();
820
+ };
821
+ </script>
822
+ <script src="../../sorter.js"></script>
823
+ <script src="../../block-navigation.js"></script>
824
+ </body>
825
+ </html>
826
+