@saasquatch/squatch-js 2.6.0-1 → 2.6.0-11

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 (52) hide show
  1. package/.github/workflows/size-limit.yml +14 -14
  2. package/.github/workflows/static.yml +89 -0
  3. package/CHANGELOG.md +329 -326
  4. package/LICENSE +20 -20
  5. package/README.md +208 -199
  6. package/babel.config.js +7 -7
  7. package/coverage/clover.xml +2 -2
  8. package/cucumber.js +45 -45
  9. package/demo/sandbox.ts +124 -124
  10. package/demo/toolbar.tsx +526 -526
  11. package/dist/api/WidgetApi.d.ts +3 -2
  12. package/dist/async.d.ts +5 -0
  13. package/dist/globals.d.ts +4 -0
  14. package/dist/squatch.d.ts +28 -16
  15. package/dist/squatch.esm.js +464 -249
  16. package/dist/squatch.esm.js.map +1 -1
  17. package/dist/squatch.js +463 -249
  18. package/dist/squatch.js.map +1 -1
  19. package/dist/squatch.min.js +1 -1
  20. package/dist/squatch.min.js.br +0 -0
  21. package/dist/squatch.min.js.map +1 -1
  22. package/dist/squatch.modern.js +1 -1
  23. package/dist/squatch.modern.js.map +1 -1
  24. package/dist/stats.html +1 -1
  25. package/dist/types.d.ts +8 -6
  26. package/dist/utils/decodeJwt.d.ts +1 -0
  27. package/dist/utils/validate.d.ts +2 -2
  28. package/dist/widgets/EmbedWidget.d.ts +9 -0
  29. package/dist/widgets/PopupWidget.d.ts +8 -3
  30. package/dist/widgets/Widgets.d.ts +21 -8
  31. package/dist/widgets/declarative/DeclarativeWidget.d.ts +72 -2
  32. package/dist/widgets/declarative/DeclarativeWidgets.d.ts +22 -0
  33. package/jest.config.ts +200 -202
  34. package/package.json +123 -123
  35. package/tsconfig.json +23 -23
  36. package/coverage/lcov-report/WidgetApi.ts.html +0 -631
  37. package/coverage/lcov-report/api/AnalyticsApi.ts.html +0 -304
  38. package/coverage/lcov-report/api/WidgetApi.ts.html +0 -631
  39. package/coverage/lcov-report/api/graphql.ts.html +0 -130
  40. package/coverage/lcov-report/utils/cookieUtils.ts.html +0 -415
  41. package/coverage/lcov-report/utils/decodeUserJwt.ts.html +0 -133
  42. package/coverage/lcov-report/utils/domready.ts.html +0 -160
  43. package/coverage/lcov-report/utils/io.ts.html +0 -400
  44. package/coverage/lcov-report/utils/utmUtils.ts.html +0 -277
  45. package/coverage/lcov-report/utils/validate.ts.html +0 -268
  46. package/coverage/lcov-report/validate.ts.html +0 -268
  47. package/coverage/lcov-report/widgets/EmbedWidget.ts.html +0 -433
  48. package/coverage/lcov-report/widgets/PopupWidget.ts.html +0 -670
  49. package/coverage/lcov-report/widgets/Widget.ts.html +0 -1165
  50. package/coverage/lcov-report/widgets/Widgets.ts.html +0 -1060
  51. package/coverage/lcov-report/widgets/declarative/DeclarativeWidget.ts.html +0 -499
  52. package/stats.json +0 -1
@@ -1,670 +0,0 @@
1
-
2
- <!doctype html>
3
- <html lang="en">
4
-
5
- <head>
6
- <title>Code coverage report for widgets/PopupWidget.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">widgets</a> PopupWidget.ts</h1>
23
- <div class='clearfix'>
24
-
25
- <div class='fl pad1y space-right2'>
26
- <span class="strong">6.45% </span>
27
- <span class="quiet">Statements</span>
28
- <span class='fraction'>6/93</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/31</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/14</span>
43
- </div>
44
-
45
-
46
- <div class='fl pad1y space-right2'>
47
- <span class="strong">6.89% </span>
48
- <span class="quiet">Lines</span>
49
- <span class='fraction'>6/87</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></td><td class="line-coverage quiet"><span class="cline-any cline-neutral">&nbsp;</span>
262
- <span class="cline-any cline-neutral">&nbsp;</span>
263
- <span class="cline-any cline-yes">1x</span>
264
- <span class="cline-any cline-yes">1x</span>
265
- <span class="cline-any cline-yes">1x</span>
266
- <span class="cline-any cline-neutral">&nbsp;</span>
267
- <span class="cline-any cline-neutral">&nbsp;</span>
268
- <span class="cline-any cline-yes">1x</span>
269
- <span class="cline-any cline-neutral">&nbsp;</span>
270
- <span class="cline-any cline-yes">1x</span>
271
- <span class="cline-any cline-neutral">&nbsp;</span>
272
- <span class="cline-any cline-neutral">&nbsp;</span>
273
- <span class="cline-any cline-neutral">&nbsp;</span>
274
- <span class="cline-any cline-neutral">&nbsp;</span>
275
- <span class="cline-any cline-neutral">&nbsp;</span>
276
- <span class="cline-any cline-neutral">&nbsp;</span>
277
- <span class="cline-any cline-neutral">&nbsp;</span>
278
- <span class="cline-any cline-yes">1x</span>
279
- <span class="cline-any cline-neutral">&nbsp;</span>
280
- <span class="cline-any cline-neutral">&nbsp;</span>
281
- <span class="cline-any cline-neutral">&nbsp;</span>
282
- <span class="cline-any cline-neutral">&nbsp;</span>
283
- <span class="cline-any cline-no">&nbsp;</span>
284
- <span class="cline-any cline-neutral">&nbsp;</span>
285
- <span class="cline-any cline-no">&nbsp;</span>
286
- <span class="cline-any cline-neutral">&nbsp;</span>
287
- <span class="cline-any cline-no">&nbsp;</span>
288
- <span class="cline-any cline-no">&nbsp;</span>
289
- <span class="cline-any cline-neutral">&nbsp;</span>
290
- <span class="cline-any cline-no">&nbsp;</span>
291
- <span class="cline-any cline-no">&nbsp;</span>
292
- <span class="cline-any cline-neutral">&nbsp;</span>
293
- <span class="cline-any cline-neutral">&nbsp;</span>
294
- <span class="cline-any cline-no">&nbsp;</span>
295
- <span class="cline-any cline-neutral">&nbsp;</span>
296
- <span class="cline-any cline-neutral">&nbsp;</span>
297
- <span class="cline-any cline-neutral">&nbsp;</span>
298
- <span class="cline-any cline-neutral">&nbsp;</span>
299
- <span class="cline-any cline-neutral">&nbsp;</span>
300
- <span class="cline-any cline-neutral">&nbsp;</span>
301
- <span class="cline-any cline-no">&nbsp;</span>
302
- <span class="cline-any cline-neutral">&nbsp;</span>
303
- <span class="cline-any cline-neutral">&nbsp;</span>
304
- <span class="cline-any cline-no">&nbsp;</span>
305
- <span class="cline-any cline-no">&nbsp;</span>
306
- <span class="cline-any cline-no">&nbsp;</span>
307
- <span class="cline-any cline-no">&nbsp;</span>
308
- <span class="cline-any cline-neutral">&nbsp;</span>
309
- <span class="cline-any cline-no">&nbsp;</span>
310
- <span class="cline-any cline-neutral">&nbsp;</span>
311
- <span class="cline-any cline-neutral">&nbsp;</span>
312
- <span class="cline-any cline-neutral">&nbsp;</span>
313
- <span class="cline-any cline-no">&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-neutral">&nbsp;</span>
317
- <span class="cline-any cline-neutral">&nbsp;</span>
318
- <span class="cline-any cline-neutral">&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-neutral">&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-neutral">&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-no">&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-no">&nbsp;</span>
339
- <span class="cline-any cline-no">&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-no">&nbsp;</span>
343
- <span class="cline-any cline-neutral">&nbsp;</span>
344
- <span class="cline-any cline-no">&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-no">&nbsp;</span>
349
- <span class="cline-any cline-no">&nbsp;</span>
350
- <span class="cline-any cline-neutral">&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-no">&nbsp;</span>
355
- <span class="cline-any cline-no">&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-neutral">&nbsp;</span>
359
- <span class="cline-any cline-no">&nbsp;</span>
360
- <span class="cline-any cline-neutral">&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-neutral">&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-neutral">&nbsp;</span>
369
- <span class="cline-any cline-neutral">&nbsp;</span>
370
- <span class="cline-any cline-no">&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-neutral">&nbsp;</span>
375
- <span class="cline-any cline-neutral">&nbsp;</span>
376
- <span class="cline-any cline-no">&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-neutral">&nbsp;</span>
381
- <span class="cline-any cline-neutral">&nbsp;</span>
382
- <span class="cline-any cline-no">&nbsp;</span>
383
- <span class="cline-any cline-neutral">&nbsp;</span>
384
- <span class="cline-any cline-no">&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-no">&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-no">&nbsp;</span>
392
- <span class="cline-any cline-no">&nbsp;</span>
393
- <span class="cline-any cline-no">&nbsp;</span>
394
- <span class="cline-any cline-neutral">&nbsp;</span>
395
- <span class="cline-any cline-no">&nbsp;</span>
396
- <span class="cline-any cline-no">&nbsp;</span>
397
- <span class="cline-any cline-no">&nbsp;</span>
398
- <span class="cline-any cline-neutral">&nbsp;</span>
399
- <span class="cline-any cline-no">&nbsp;</span>
400
- <span class="cline-any cline-no">&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-no">&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-no">&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-no">&nbsp;</span>
412
- <span class="cline-any cline-no">&nbsp;</span>
413
- <span class="cline-any cline-no">&nbsp;</span>
414
- <span class="cline-any cline-no">&nbsp;</span>
415
- <span class="cline-any cline-neutral">&nbsp;</span>
416
- <span class="cline-any cline-no">&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-no">&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-neutral">&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-no">&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-neutral">&nbsp;</span>
431
- <span class="cline-any cline-neutral">&nbsp;</span>
432
- <span class="cline-any cline-neutral">&nbsp;</span>
433
- <span class="cline-any cline-neutral">&nbsp;</span>
434
- <span class="cline-any cline-no">&nbsp;</span>
435
- <span class="cline-any cline-no">&nbsp;</span>
436
- <span class="cline-any cline-no">&nbsp;</span>
437
- <span class="cline-any cline-no">&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-neutral">&nbsp;</span>
441
- <span class="cline-any cline-no">&nbsp;</span>
442
- <span class="cline-any cline-neutral">&nbsp;</span>
443
- <span class="cline-any cline-neutral">&nbsp;</span>
444
- <span class="cline-any cline-neutral">&nbsp;</span>
445
- <span class="cline-any cline-neutral">&nbsp;</span>
446
- <span class="cline-any cline-neutral">&nbsp;</span>
447
- <span class="cline-any cline-neutral">&nbsp;</span>
448
- <span class="cline-any cline-no">&nbsp;</span>
449
- <span class="cline-any cline-neutral">&nbsp;</span>
450
- <span class="cline-any cline-no">&nbsp;</span>
451
- <span class="cline-any cline-neutral">&nbsp;</span>
452
- <span class="cline-any cline-neutral">&nbsp;</span>
453
- <span class="cline-any cline-no">&nbsp;</span>
454
- <span class="cline-any cline-no">&nbsp;</span>
455
- <span class="cline-any cline-neutral">&nbsp;</span>
456
- <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js">// @ts-check
457
- &nbsp;
458
- import { debug } from "debug";
459
- import { domready } from "../utils/domready";
460
- import Widget, { Params } from "./Widget";
461
- import DeclarativeWidget from "./declarative/DeclarativeWidget";
462
- &nbsp;
463
- const _log = debug("squatch-js:POPUPwidget");
464
- &nbsp;
465
- let popupId = 0;
466
- /**
467
- * The PopupWidget is used to display popups (also known as "Modals").
468
- * Popups widgets are rendered on top of other elements in a page.
469
- *
470
- * To create a PopupWidget use {@link Widgets}
471
- *
472
- */
473
- export default class PopupWidget extends Widget {
474
- trigger: string | null;
475
- id: string;
476
- &nbsp;
477
- <span class="fstat-no" title="function not covered" > constructor(p</span>arams: Params, trigger: string | null = <span class="branch-0 cbranch-no" title="branch not covered" >".squatchpop")</span> {
478
- <span class="cstat-no" title="statement not covered" > super(params);</span>
479
- &nbsp;
480
- <span class="cstat-no" title="statement not covered" > this.trigger = trigger;</span>
481
- &nbsp;
482
- <span class="cstat-no" title="statement not covered" > if (this.container) {</span>
483
- <span class="cstat-no" title="statement not covered" > this.id = "squatchModal";</span>
484
- } else {
485
- <span class="cstat-no" title="statement not covered" > this.id = popupId === 0 ? `squatchModal` : `squatchModal__${popupId}`;</span>
486
- <span class="cstat-no" title="statement not covered" > popupId = popupId + 1;</span>
487
- }
488
- &nbsp;
489
- <span class="cstat-no" title="statement not covered" > document.head.insertAdjacentHTML(</span>
490
- "beforeend",
491
- `&lt;style&gt;#${this.id}::-webkit-scrollbar { display: none; }&lt;/style&gt;`
492
- );
493
- }
494
- &nbsp;
495
- <span class="fstat-no" title="function not covered" > _initialiseCTA(</span>frame: HTMLIFrameElement) {
496
- <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (!this.trigger) <span class="cstat-no" title="statement not covered" >return;</span></span>
497
- &nbsp;
498
- let triggerElement;
499
- <span class="cstat-no" title="statement not covered" > try {</span>
500
- <span class="cstat-no" title="statement not covered" > triggerElement /* HTMLButton */ = document.querySelector(this.trigger);</span>
501
- <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (this.trigger &amp;&amp; !triggerElement)</span>
502
- <span class="cstat-no" title="statement not covered" > _log("No element found with trigger selector", this.trigger);</span>
503
- } catch {
504
- <span class="cstat-no" title="statement not covered" > _log("Not a valid selector", this.trigger);</span>
505
- }
506
- &nbsp;
507
- // Trigger is optional
508
- <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (triggerElement) {</span>
509
- <span class="cstat-no" title="statement not covered" > triggerElement.onclick = <span class="fstat-no" title="function not covered" >() =</span>&gt; {</span>
510
- <span class="cstat-no" title="statement not covered" > this.open();</span>
511
- };
512
- }
513
- &nbsp;
514
- // const element = this._findElement();
515
- // If widget is loaded with CTA, look for a 'squatchpop' element to use
516
- // that element as a trigger as well.
517
- // const triggerWhenCTA = element.querySelector(".squatchpop") as HTMLElement;
518
- &nbsp;
519
- // if (this.trigger === "#cta" &amp;&amp; triggerWhenCTA) {
520
- // triggerWhenCTA.onclick = () =&gt; {
521
- // this.open(frame);
522
- // };
523
- // }
524
- }
525
- &nbsp;
526
- <span class="fstat-no" title="function not covered" > _createPopupDialog(</span>): HTMLDialogElement {
527
- const dialog = <span class="cstat-no" title="statement not covered" >document.createElement("dialog");</span>
528
- <span class="cstat-no" title="statement not covered" > dialog.id = this.id;</span>
529
- <span class="cstat-no" title="statement not covered" > dialog.setAttribute(</span>
530
- "style",
531
- "width: 100%; max-width: 500px; border: none; padding: 0;"
532
- );
533
- const onClick = <span class="cstat-no" title="statement not covered" ><span class="fstat-no" title="function not covered" >(e</span>) =&gt; {</span>
534
- <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (e.target === dialog) <span class="cstat-no" title="statement not covered" >dialog.close();</span></span>
535
- };
536
- &nbsp;
537
- <span class="cstat-no" title="statement not covered" > dialog.addEventListener("click", onClick);</span>
538
- &nbsp;
539
- <span class="cstat-no" title="statement not covered" > return dialog;</span>
540
- }
541
- &nbsp;
542
- <span class="fstat-no" title="function not covered" > load(</span>) {
543
- const frame = <span class="cstat-no" title="statement not covered" >this._createFrame();</span>
544
- <span class="cstat-no" title="statement not covered" > this._initialiseCTA(frame);</span>
545
- &nbsp;
546
- const element = <span class="cstat-no" title="statement not covered" >this._findElement();</span>
547
- &nbsp;
548
- const dialogParent = <span class="cstat-no" title="statement not covered" >element.shadowRoot || element;</span>
549
- const dialog = <span class="cstat-no" title="statement not covered" >this._createPopupDialog();</span>
550
- <span class="cstat-no" title="statement not covered" > dialog.appendChild(frame);</span>
551
- &nbsp;
552
- <span class="cstat-no" title="statement not covered" > if (dialogParent.lastChild?.nodeName === "DIALOG") {</span>
553
- // Was reloaded
554
- <span class="cstat-no" title="statement not covered" > dialogParent.replaceChild(dialog, dialogParent.lastChild);</span>
555
- } else {
556
- // First time rendering
557
- <span class="cstat-no" title="statement not covered" > dialogParent.appendChild(dialog);</span>
558
- }
559
- &nbsp;
560
- const { contentWindow } = <span class="cstat-no" title="statement not covered" >frame;</span>
561
- <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (!contentWindow) {</span>
562
- <span class="cstat-no" title="statement not covered" > throw new Error("Frame needs a content window");</span>
563
- }
564
- &nbsp;
565
- const frameDoc = <span class="cstat-no" title="statement not covered" >contentWindow.document;</span>
566
- <span class="cstat-no" title="statement not covered" > frameDoc.open();</span>
567
- <span class="cstat-no" title="statement not covered" > frameDoc.write(this.content);</span>
568
- <span class="cstat-no" title="statement not covered" > frameDoc.write(</span>
569
- `&lt;script src="${this.npmCdn}/resize-observer-polyfill@1.5.x"&gt;&lt;/script&gt;`
570
- );
571
- <span class="cstat-no" title="statement not covered" > frameDoc.close();</span>
572
- <span class="cstat-no" title="statement not covered" > _log("Popup template loaded into iframe");</span>
573
- <span class="cstat-no" title="statement not covered" > this._setupResizeHandler(frame);</span>
574
- }
575
- &nbsp;
576
- protected <span class="fstat-no" title="function not covered" >_setupResizeHandler(</span>frame: HTMLIFrameElement) {
577
- const { contentWindow } = <span class="cstat-no" title="statement not covered" >frame;</span>
578
- &nbsp;
579
- <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (!contentWindow) {</span>
580
- <span class="cstat-no" title="statement not covered" > throw new Error("Frame needs a content window");</span>
581
- }
582
- &nbsp;
583
- const frameDoc = <span class="cstat-no" title="statement not covered" >contentWindow.document;</span>
584
- &nbsp;
585
- // Adjust frame height when size of body changes
586
- <span class="cstat-no" title="statement not covered" > domready(frameDoc, <span class="fstat-no" title="function not covered" >async </span>() =&gt; {</span>
587
- <span class="cstat-no" title="statement not covered" > frameDoc.body.style.overflowY = "hidden";</span>
588
- <span class="cstat-no" title="statement not covered" > frame.height = `${frameDoc.body.offsetHeight}px`;</span>
589
- // Adjust frame height when size of body changes
590
- const ro = <span class="cstat-no" title="statement not covered" >new contentWindow["ResizeObserver"](<span class="fstat-no" title="function not covered" >(e</span>ntries) =&gt; {</span>
591
- <span class="cstat-no" title="statement not covered" > for (const entry of entries) {</span>
592
- const { top, bottom } = <span class="cstat-no" title="statement not covered" >entry.contentRect;</span>
593
- &nbsp;
594
- const computedHeight = <span class="cstat-no" title="statement not covered" >bottom + top;</span>
595
- <span class="cstat-no" title="statement not covered" > frame.height = computedHeight + "";</span>
596
- &nbsp;
597
- // Don't let anything else set the height of this element
598
- <span class="cstat-no" title="statement not covered" > entry.target.style = ``;</span>
599
- }
600
- });
601
- <span class="cstat-no" title="statement not covered" > ro.observe(await this._findInnerContainer(frame));</span>
602
- });
603
- }
604
- &nbsp;
605
- <span class="fstat-no" title="function not covered" > open(</span>) {
606
- const element = <span class="cstat-no" title="statement not covered" >this._findElement();</span>
607
- const parent = <span class="cstat-no" title="statement not covered" >element.shadowRoot || element;</span>
608
- const dialog = <span class="cstat-no" title="statement not covered" >parent.querySelector(`#${this.id}`) as HTMLDialogElement;</span>
609
- <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (!dialog) <span class="cstat-no" title="statement not covered" >throw new Error("Could not determine container div");</span></span>
610
- &nbsp;
611
- <span class="cstat-no" title="statement not covered" > dialog.showModal();</span>
612
- &nbsp;
613
- const frame = <span class="cstat-no" title="statement not covered" >this._findFrame();</span>
614
- <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (!frame) <span class="cstat-no" title="statement not covered" >throw new Error("Could not find iframe");</span></span>
615
- const { contentWindow } = <span class="cstat-no" title="statement not covered" >frame;</span>
616
- <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (!contentWindow) <span class="cstat-no" title="statement not covered" >throw new Error("Squatch.js has an empty iframe");</span></span>
617
- const frameDoc = <span class="cstat-no" title="statement not covered" >contentWindow.document;</span>
618
- &nbsp;
619
- // Adjust frame height when size of body changes
620
- <span class="cstat-no" title="statement not covered" > domready(frameDoc, <span class="fstat-no" title="function not covered" >() =</span>&gt; {</span>
621
- const _sqh = <span class="cstat-no" title="statement not covered" >contentWindow.squatch || contentWindow.widgetIdent;</span>
622
- <span class="cstat-no" title="statement not covered" > frame.contentDocument?.dispatchEvent(new CustomEvent("sq:refresh"));</span>
623
- <span class="cstat-no" title="statement not covered" > this._loadEvent(_sqh);</span>
624
- <span class="cstat-no" title="statement not covered" > _log("Popup opened");</span>
625
- });
626
- }
627
- &nbsp;
628
- <span class="fstat-no" title="function not covered" > close(</span>) {
629
- const element = <span class="cstat-no" title="statement not covered" >this._findElement();</span>
630
- const parent = <span class="cstat-no" title="statement not covered" >element.shadowRoot || element;</span>
631
- const dialog = <span class="cstat-no" title="statement not covered" >parent.querySelector(`#${this.id}`) as HTMLDialogElement;</span>
632
- <span class="cstat-no" title="statement not covered" > <span class="missing-if-branch" title="if path not taken" >I</span>if (!dialog) <span class="cstat-no" title="statement not covered" >throw new Error("Could not determine container div");</span></span>
633
- &nbsp;
634
- <span class="cstat-no" title="statement not covered" > dialog.close();</span>
635
- &nbsp;
636
- <span class="cstat-no" title="statement not covered" > _log("Popup closed");</span>
637
- }
638
- &nbsp;
639
- protected <span class="fstat-no" title="function not covered" >_clickedOutside(</span>{ target }) {}
640
- &nbsp;
641
- protected <span class="fstat-no" title="function not covered" >_error(</span>rs, mode = <span class="branch-0 cbranch-no" title="branch not covered" >"modal",</span> style = <span class="branch-0 cbranch-no" title="branch not covered" >"")</span> {
642
- const _style =
643
- <span class="cstat-no" title="statement not covered" > "body { margin: 0; } .modal { box-shadow: none; border: 0; }";</span>
644
- &nbsp;
645
- <span class="cstat-no" title="statement not covered" > return super._error(rs, mode, style || _style);</span>
646
- }
647
- &nbsp;
648
- show = <span class="cstat-no" title="statement not covered" >this.open;</span>
649
- hide = <span class="cstat-no" title="statement not covered" >this.close;</span>
650
- }
651
- &nbsp;</pre></td></tr></table></pre>
652
-
653
- <div class='push'></div><!-- for sticky footer -->
654
- </div><!-- /wrapper -->
655
- <div class='footer quiet pad2 space-top1 center small'>
656
- Code coverage generated by
657
- <a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
658
- at 2023-07-18T18:05:44.533Z
659
- </div>
660
- <script src="../prettify.js"></script>
661
- <script>
662
- window.onload = function () {
663
- prettyPrint();
664
- };
665
- </script>
666
- <script src="../sorter.js"></script>
667
- <script src="../block-navigation.js"></script>
668
- </body>
669
- </html>
670
-