isomorfeus-puppetmaster 0.5.5 → 0.5.6

Sign up to get free protection for your applications and to get access to all the features.
Files changed (710) hide show
  1. checksums.yaml +4 -4
  2. data/lib/isomorfeus/puppetmaster/console_message.rb +18 -18
  3. data/lib/isomorfeus/puppetmaster/cookie.rb +46 -46
  4. data/lib/isomorfeus/puppetmaster/driver/puppeteer.rb +413 -415
  5. data/lib/isomorfeus/puppetmaster/driver/puppeteer_document.rb +953 -953
  6. data/lib/isomorfeus/puppetmaster/driver/puppeteer_node.rb +851 -851
  7. data/lib/isomorfeus/puppetmaster/errors.rb +90 -90
  8. data/lib/isomorfeus/puppetmaster/iframe.rb +16 -16
  9. data/lib/isomorfeus/puppetmaster/node/content_editable.rb +17 -17
  10. data/lib/isomorfeus/puppetmaster/node/input.rb +20 -20
  11. data/lib/isomorfeus/puppetmaster/node/select.rb +35 -35
  12. data/lib/isomorfeus/puppetmaster/node.rb +279 -279
  13. data/lib/isomorfeus/puppetmaster/request.rb +16 -16
  14. data/lib/isomorfeus/puppetmaster/response.rb +25 -25
  15. data/lib/isomorfeus/puppetmaster/self_forwardable.rb +38 -38
  16. data/lib/isomorfeus/puppetmaster/version.rb +3 -3
  17. data/lib/isomorfeus/puppetmaster.rb +85 -85
  18. data/lib/isomorfeus-puppetmaster.rb +1 -0
  19. data/node_modules/.bin/extract-zip +12 -12
  20. data/node_modules/.bin/extract-zip.ps1 +28 -28
  21. data/node_modules/.bin/rimraf +12 -12
  22. data/node_modules/.bin/rimraf.ps1 +28 -28
  23. data/node_modules/.package-lock.json +530 -585
  24. data/node_modules/@types/node/LICENSE +21 -21
  25. data/node_modules/@types/node/assert/strict.d.ts +8 -8
  26. data/node_modules/@types/node/assert.d.ts +912 -912
  27. data/node_modules/@types/node/async_hooks.d.ts +497 -497
  28. data/node_modules/@types/node/buffer.d.ts +2142 -2142
  29. data/node_modules/@types/node/child_process.d.ts +1355 -1355
  30. data/node_modules/@types/node/cluster.d.ts +414 -414
  31. data/node_modules/@types/node/console.d.ts +407 -407
  32. data/node_modules/@types/node/constants.d.ts +18 -18
  33. data/node_modules/@types/node/crypto.d.ts +3224 -3224
  34. data/node_modules/@types/node/dgram.d.ts +545 -545
  35. data/node_modules/@types/node/diagnostics_channel.d.ts +128 -128
  36. data/node_modules/@types/node/dns/promises.d.ts +357 -357
  37. data/node_modules/@types/node/dns.d.ts +643 -643
  38. data/node_modules/@types/node/domain.d.ts +169 -169
  39. data/node_modules/@types/node/events.d.ts +623 -623
  40. data/node_modules/@types/node/fs/promises.d.ts +997 -997
  41. data/node_modules/@types/node/fs.d.ts +3723 -3723
  42. data/node_modules/@types/node/globals.d.ts +285 -285
  43. data/node_modules/@types/node/globals.global.d.ts +1 -1
  44. data/node_modules/@types/node/http.d.ts +1358 -1358
  45. data/node_modules/@types/node/http2.d.ts +2100 -2100
  46. data/node_modules/@types/node/https.d.ts +391 -391
  47. data/node_modules/@types/node/index.d.ts +131 -131
  48. data/node_modules/@types/node/inspector.d.ts +2738 -2738
  49. data/node_modules/@types/node/module.d.ts +114 -114
  50. data/node_modules/@types/node/net.d.ts +783 -783
  51. data/node_modules/@types/node/os.d.ts +455 -455
  52. data/node_modules/@types/node/package.json +229 -229
  53. data/node_modules/@types/node/path.d.ts +172 -172
  54. data/node_modules/@types/node/perf_hooks.d.ts +555 -555
  55. data/node_modules/@types/node/process.d.ts +1477 -1477
  56. data/node_modules/@types/node/punycode.d.ts +117 -117
  57. data/node_modules/@types/node/querystring.d.ts +131 -131
  58. data/node_modules/@types/node/readline.d.ts +542 -542
  59. data/node_modules/@types/node/repl.d.ts +424 -424
  60. data/node_modules/@types/node/stream/consumers.d.ts +24 -24
  61. data/node_modules/@types/node/stream/promises.d.ts +42 -42
  62. data/node_modules/@types/node/stream/web.d.ts +6 -6
  63. data/node_modules/@types/node/stream.d.ts +1181 -1181
  64. data/node_modules/@types/node/string_decoder.d.ts +67 -67
  65. data/node_modules/@types/node/timers/promises.d.ts +68 -68
  66. data/node_modules/@types/node/timers.d.ts +94 -94
  67. data/node_modules/@types/node/tls.d.ts +1019 -1019
  68. data/node_modules/@types/node/trace_events.d.ts +161 -161
  69. data/node_modules/@types/node/tty.d.ts +206 -206
  70. data/node_modules/@types/node/url.d.ts +798 -798
  71. data/node_modules/@types/node/util.d.ts +1556 -1556
  72. data/node_modules/@types/node/v8.d.ts +378 -378
  73. data/node_modules/@types/node/vm.d.ts +504 -504
  74. data/node_modules/@types/node/wasi.d.ts +153 -153
  75. data/node_modules/@types/node/worker_threads.d.ts +649 -649
  76. data/node_modules/@types/node/zlib.d.ts +517 -517
  77. data/node_modules/@types/yauzl/LICENSE +21 -21
  78. data/node_modules/@types/yauzl/index.d.ts +98 -98
  79. data/node_modules/@types/yauzl/package.json +26 -26
  80. data/node_modules/agent-base/README.md +145 -145
  81. data/node_modules/agent-base/dist/src/index.d.ts +78 -78
  82. data/node_modules/agent-base/dist/src/index.js +202 -202
  83. data/node_modules/agent-base/dist/src/promisify.d.ts +4 -4
  84. data/node_modules/agent-base/dist/src/promisify.js +17 -17
  85. data/node_modules/agent-base/package.json +64 -64
  86. data/node_modules/agent-base/src/index.ts +345 -345
  87. data/node_modules/agent-base/src/promisify.ts +33 -33
  88. data/node_modules/balanced-match/.github/FUNDING.yml +2 -2
  89. data/node_modules/balanced-match/LICENSE.md +21 -21
  90. data/node_modules/balanced-match/README.md +97 -97
  91. data/node_modules/balanced-match/index.js +62 -62
  92. data/node_modules/balanced-match/package.json +48 -48
  93. data/node_modules/base64-js/LICENSE +21 -21
  94. data/node_modules/base64-js/README.md +34 -34
  95. data/node_modules/base64-js/index.d.ts +3 -3
  96. data/node_modules/base64-js/index.js +150 -150
  97. data/node_modules/base64-js/package.json +47 -47
  98. data/node_modules/bl/.travis.yml +17 -17
  99. data/node_modules/bl/BufferList.js +396 -396
  100. data/node_modules/bl/LICENSE.md +13 -13
  101. data/node_modules/bl/README.md +247 -247
  102. data/node_modules/bl/bl.js +84 -84
  103. data/node_modules/bl/package.json +37 -37
  104. data/node_modules/bl/test/convert.js +21 -21
  105. data/node_modules/bl/test/indexOf.js +492 -492
  106. data/node_modules/bl/test/isBufferList.js +32 -32
  107. data/node_modules/bl/test/test.js +869 -869
  108. data/node_modules/brace-expansion/LICENSE +21 -21
  109. data/node_modules/brace-expansion/README.md +129 -129
  110. data/node_modules/brace-expansion/index.js +201 -201
  111. data/node_modules/brace-expansion/package.json +47 -47
  112. data/node_modules/buffer/AUTHORS.md +70 -70
  113. data/node_modules/buffer/LICENSE +21 -21
  114. data/node_modules/buffer/README.md +410 -410
  115. data/node_modules/buffer/index.d.ts +186 -186
  116. data/node_modules/buffer/index.js +1817 -1817
  117. data/node_modules/buffer/package.json +96 -96
  118. data/node_modules/buffer-crc32/LICENSE +19 -19
  119. data/node_modules/buffer-crc32/README.md +47 -47
  120. data/node_modules/buffer-crc32/index.js +111 -111
  121. data/node_modules/buffer-crc32/package.json +39 -39
  122. data/node_modules/chownr/LICENSE +15 -15
  123. data/node_modules/chownr/README.md +3 -3
  124. data/node_modules/chownr/chownr.js +167 -167
  125. data/node_modules/chownr/package.json +29 -29
  126. data/node_modules/concat-map/.travis.yml +4 -4
  127. data/node_modules/concat-map/LICENSE +18 -18
  128. data/node_modules/concat-map/README.markdown +62 -62
  129. data/node_modules/concat-map/example/map.js +6 -6
  130. data/node_modules/concat-map/index.js +13 -13
  131. data/node_modules/concat-map/package.json +43 -43
  132. data/node_modules/concat-map/test/map.js +39 -39
  133. data/node_modules/debug/LICENSE +19 -19
  134. data/node_modules/debug/README.md +455 -455
  135. data/node_modules/debug/package.json +59 -59
  136. data/node_modules/debug/src/browser.js +269 -269
  137. data/node_modules/debug/src/common.js +274 -274
  138. data/node_modules/debug/src/index.js +10 -10
  139. data/node_modules/debug/src/node.js +263 -263
  140. data/node_modules/devtools-protocol/LICENSE +27 -27
  141. data/node_modules/devtools-protocol/README.md +12 -12
  142. data/node_modules/devtools-protocol/json/browser_protocol.json +20985 -20640
  143. data/node_modules/devtools-protocol/json/js_protocol.json +3531 -3580
  144. data/node_modules/devtools-protocol/package.json +17 -18
  145. data/node_modules/devtools-protocol/pdl/browser_protocol.pdl +9849 -9637
  146. data/node_modules/devtools-protocol/pdl/js_protocol.pdl +1653 -1678
  147. data/node_modules/devtools-protocol/types/protocol-mapping.d.ts +4333 -4321
  148. data/node_modules/devtools-protocol/types/protocol-proxy-api.d.ts +3695 -3683
  149. data/node_modules/devtools-protocol/types/protocol.d.ts +15714 -15538
  150. data/node_modules/end-of-stream/LICENSE +20 -20
  151. data/node_modules/end-of-stream/README.md +54 -54
  152. data/node_modules/end-of-stream/index.js +94 -94
  153. data/node_modules/end-of-stream/package.json +37 -37
  154. data/node_modules/extract-zip/LICENSE +23 -23
  155. data/node_modules/extract-zip/cli.js +19 -19
  156. data/node_modules/extract-zip/index.d.ts +21 -21
  157. data/node_modules/extract-zip/index.js +173 -173
  158. data/node_modules/extract-zip/package.json +80 -80
  159. data/node_modules/extract-zip/readme.md +57 -57
  160. data/node_modules/fd-slicer/.npmignore +2 -2
  161. data/node_modules/fd-slicer/.travis.yml +7 -7
  162. data/node_modules/fd-slicer/CHANGELOG.md +49 -49
  163. data/node_modules/fd-slicer/LICENSE +21 -21
  164. data/node_modules/fd-slicer/README.md +199 -199
  165. data/node_modules/fd-slicer/index.js +296 -296
  166. data/node_modules/fd-slicer/package.json +36 -36
  167. data/node_modules/fd-slicer/test/test.js +350 -350
  168. data/node_modules/find-up/index.d.ts +137 -137
  169. data/node_modules/find-up/index.js +89 -89
  170. data/node_modules/find-up/license +9 -9
  171. data/node_modules/find-up/package.json +53 -53
  172. data/node_modules/find-up/readme.md +156 -156
  173. data/node_modules/fs-constants/LICENSE +21 -21
  174. data/node_modules/fs-constants/README.md +26 -26
  175. data/node_modules/fs-constants/browser.js +1 -1
  176. data/node_modules/fs-constants/index.js +1 -1
  177. data/node_modules/fs-constants/package.json +19 -19
  178. data/node_modules/fs.realpath/LICENSE +43 -43
  179. data/node_modules/fs.realpath/README.md +33 -33
  180. data/node_modules/fs.realpath/index.js +66 -66
  181. data/node_modules/fs.realpath/old.js +303 -303
  182. data/node_modules/fs.realpath/package.json +26 -26
  183. data/node_modules/get-stream/buffer-stream.js +52 -52
  184. data/node_modules/get-stream/index.d.ts +108 -108
  185. data/node_modules/get-stream/index.js +60 -60
  186. data/node_modules/get-stream/license +9 -9
  187. data/node_modules/get-stream/package.json +50 -50
  188. data/node_modules/get-stream/readme.md +124 -124
  189. data/node_modules/glob/LICENSE +21 -21
  190. data/node_modules/glob/README.md +375 -375
  191. data/node_modules/glob/changelog.md +67 -67
  192. data/node_modules/glob/common.js +234 -234
  193. data/node_modules/glob/glob.js +788 -788
  194. data/node_modules/glob/package.json +51 -51
  195. data/node_modules/glob/sync.js +484 -484
  196. data/node_modules/https-proxy-agent/README.md +137 -137
  197. data/node_modules/https-proxy-agent/dist/agent.d.ts +30 -30
  198. data/node_modules/https-proxy-agent/dist/agent.js +179 -179
  199. data/node_modules/https-proxy-agent/dist/index.d.ts +23 -23
  200. data/node_modules/https-proxy-agent/dist/index.js +13 -13
  201. data/node_modules/https-proxy-agent/dist/parse-proxy-response.d.ts +7 -7
  202. data/node_modules/https-proxy-agent/dist/parse-proxy-response.js +65 -65
  203. data/node_modules/https-proxy-agent/package.json +56 -56
  204. data/node_modules/ieee754/LICENSE +11 -11
  205. data/node_modules/ieee754/README.md +51 -51
  206. data/node_modules/ieee754/index.d.ts +9 -9
  207. data/node_modules/ieee754/index.js +85 -85
  208. data/node_modules/ieee754/package.json +52 -52
  209. data/node_modules/inflight/LICENSE +15 -15
  210. data/node_modules/inflight/README.md +37 -37
  211. data/node_modules/inflight/inflight.js +54 -54
  212. data/node_modules/inflight/package.json +29 -29
  213. data/node_modules/inherits/LICENSE +16 -16
  214. data/node_modules/inherits/README.md +42 -42
  215. data/node_modules/inherits/inherits.js +9 -9
  216. data/node_modules/inherits/inherits_browser.js +27 -27
  217. data/node_modules/inherits/package.json +29 -29
  218. data/node_modules/locate-path/index.d.ts +83 -83
  219. data/node_modules/locate-path/index.js +65 -65
  220. data/node_modules/locate-path/license +9 -9
  221. data/node_modules/locate-path/package.json +45 -45
  222. data/node_modules/locate-path/readme.md +122 -122
  223. data/node_modules/minimatch/LICENSE +15 -15
  224. data/node_modules/minimatch/README.md +209 -209
  225. data/node_modules/minimatch/minimatch.js +923 -923
  226. data/node_modules/minimatch/package.json +30 -30
  227. data/node_modules/mkdirp-classic/LICENSE +21 -21
  228. data/node_modules/mkdirp-classic/README.md +18 -18
  229. data/node_modules/mkdirp-classic/index.js +98 -98
  230. data/node_modules/mkdirp-classic/package.json +18 -18
  231. data/node_modules/ms/index.js +162 -162
  232. data/node_modules/ms/license.md +21 -21
  233. data/node_modules/ms/package.json +37 -37
  234. data/node_modules/ms/readme.md +60 -60
  235. data/node_modules/node-fetch/LICENSE.md +22 -22
  236. data/node_modules/node-fetch/README.md +590 -590
  237. data/node_modules/node-fetch/browser.js +24 -24
  238. data/node_modules/node-fetch/lib/index.es.js +1662 -1662
  239. data/node_modules/node-fetch/lib/index.js +1671 -1671
  240. data/node_modules/node-fetch/lib/index.mjs +1660 -1660
  241. data/node_modules/node-fetch/package.json +68 -68
  242. data/node_modules/once/LICENSE +15 -15
  243. data/node_modules/once/README.md +79 -79
  244. data/node_modules/once/once.js +42 -42
  245. data/node_modules/once/package.json +33 -33
  246. data/node_modules/p-limit/index.d.ts +38 -38
  247. data/node_modules/p-limit/index.js +57 -57
  248. data/node_modules/p-limit/license +9 -9
  249. data/node_modules/p-limit/package.json +52 -52
  250. data/node_modules/p-limit/readme.md +101 -101
  251. data/node_modules/p-locate/index.d.ts +64 -64
  252. data/node_modules/p-locate/index.js +52 -52
  253. data/node_modules/p-locate/license +9 -9
  254. data/node_modules/p-locate/package.json +53 -53
  255. data/node_modules/p-locate/readme.md +90 -90
  256. data/node_modules/p-try/index.d.ts +39 -39
  257. data/node_modules/p-try/index.js +9 -9
  258. data/node_modules/p-try/license +9 -9
  259. data/node_modules/p-try/package.json +42 -42
  260. data/node_modules/p-try/readme.md +58 -58
  261. data/node_modules/path-exists/index.d.ts +28 -28
  262. data/node_modules/path-exists/index.js +23 -23
  263. data/node_modules/path-exists/license +9 -9
  264. data/node_modules/path-exists/package.json +39 -39
  265. data/node_modules/path-exists/readme.md +52 -52
  266. data/node_modules/path-is-absolute/index.js +20 -20
  267. data/node_modules/path-is-absolute/license +21 -21
  268. data/node_modules/path-is-absolute/package.json +43 -43
  269. data/node_modules/path-is-absolute/readme.md +59 -59
  270. data/node_modules/pend/LICENSE +23 -23
  271. data/node_modules/pend/README.md +41 -41
  272. data/node_modules/pend/index.js +55 -55
  273. data/node_modules/pend/package.json +18 -18
  274. data/node_modules/pend/test.js +137 -137
  275. data/node_modules/pkg-dir/index.d.ts +44 -44
  276. data/node_modules/pkg-dir/index.js +17 -17
  277. data/node_modules/pkg-dir/license +9 -9
  278. data/node_modules/pkg-dir/package.json +56 -56
  279. data/node_modules/pkg-dir/readme.md +66 -66
  280. data/node_modules/progress/CHANGELOG.md +115 -115
  281. data/node_modules/progress/LICENSE +22 -22
  282. data/node_modules/progress/Makefile +8 -8
  283. data/node_modules/progress/Readme.md +146 -146
  284. data/node_modules/progress/index.js +1 -1
  285. data/node_modules/progress/lib/node-progress.js +236 -236
  286. data/node_modules/progress/package.json +26 -26
  287. data/node_modules/proxy-from-env/.eslintrc +29 -29
  288. data/node_modules/proxy-from-env/.travis.yml +10 -10
  289. data/node_modules/proxy-from-env/LICENSE +20 -20
  290. data/node_modules/proxy-from-env/README.md +131 -131
  291. data/node_modules/proxy-from-env/index.js +108 -108
  292. data/node_modules/proxy-from-env/package.json +34 -34
  293. data/node_modules/proxy-from-env/test.js +483 -483
  294. data/node_modules/pump/.travis.yml +5 -5
  295. data/node_modules/pump/LICENSE +20 -20
  296. data/node_modules/pump/README.md +65 -65
  297. data/node_modules/pump/index.js +82 -82
  298. data/node_modules/pump/package.json +24 -24
  299. data/node_modules/pump/test-browser.js +66 -66
  300. data/node_modules/pump/test-node.js +53 -53
  301. data/node_modules/puppeteer-core/CHANGELOG.md +319 -290
  302. data/node_modules/puppeteer-core/LICENSE +202 -202
  303. data/node_modules/puppeteer-core/README.md +481 -481
  304. data/node_modules/puppeteer-core/cjs-entry-core.js +29 -29
  305. data/node_modules/puppeteer-core/cjs-entry.js +29 -29
  306. data/node_modules/puppeteer-core/install.js +89 -89
  307. data/node_modules/puppeteer-core/lib/cjs/puppeteer/api-docs-entry.d.ts +110 -110
  308. data/node_modules/puppeteer-core/lib/cjs/puppeteer/api-docs-entry.js +80 -80
  309. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Accessibility.d.ts +175 -175
  310. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Accessibility.js +360 -360
  311. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/AriaQueryHandler.d.ts +20 -20
  312. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/AriaQueryHandler.js +84 -84
  313. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/AriaQueryHandler.js.map +1 -1
  314. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Browser.d.ts +455 -455
  315. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Browser.js +540 -540
  316. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/BrowserConnector.d.ts +53 -53
  317. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/BrowserConnector.js +97 -97
  318. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/BrowserWebSocketTransport.d.ts +25 -25
  319. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/BrowserWebSocketTransport.js +34 -34
  320. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Connection.d.ts +135 -135
  321. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Connection.js +298 -298
  322. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/ConnectionTransport.d.ts +24 -24
  323. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/ConnectionTransport.js +17 -17
  324. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/ConsoleMessage.d.ts +72 -72
  325. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/ConsoleMessage.js +64 -64
  326. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Coverage.d.ts +204 -204
  327. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Coverage.js +335 -335
  328. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/DOMWorld.d.ts +175 -175
  329. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/DOMWorld.js +662 -662
  330. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Debug.d.ts +52 -52
  331. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Debug.js +81 -81
  332. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/DeviceDescriptors.d.ts +40 -40
  333. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/DeviceDescriptors.js +1070 -1070
  334. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Dialog.d.ts +74 -74
  335. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Dialog.js +97 -97
  336. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/EmulationManager.d.ts +24 -24
  337. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/EmulationManager.js +37 -37
  338. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Errors.d.ts +50 -50
  339. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Errors.js +56 -56
  340. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/EvalTypes.d.ts +60 -60
  341. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/EvalTypes.js +17 -17
  342. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/EventEmitter.d.ts +92 -92
  343. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/EventEmitter.js +116 -116
  344. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Events.d.ts +81 -81
  345. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Events.js +86 -86
  346. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/ExecutionContext.d.ts +193 -193
  347. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/ExecutionContext.js +321 -321
  348. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/FileChooser.d.ts +58 -58
  349. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/FileChooser.js +71 -71
  350. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/FrameManager.d.ts +744 -744
  351. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/FrameManager.js +1047 -1047
  352. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/FrameManager.js.map +1 -1
  353. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/HTTPRequest.d.ts +350 -345
  354. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/HTTPRequest.d.ts.map +1 -1
  355. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/HTTPRequest.js +549 -549
  356. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/HTTPRequest.js.map +1 -1
  357. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/HTTPResponse.d.ts +134 -125
  358. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/HTTPResponse.d.ts.map +1 -1
  359. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/HTTPResponse.js +184 -164
  360. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/HTTPResponse.js.map +1 -1
  361. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Input.d.ts +358 -358
  362. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Input.js +543 -543
  363. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/JSHandle.d.ts +490 -490
  364. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/JSHandle.js +827 -827
  365. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/LifecycleWatcher.d.ts +65 -65
  366. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/LifecycleWatcher.d.ts.map +1 -1
  367. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/LifecycleWatcher.js +149 -148
  368. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/LifecycleWatcher.js.map +1 -1
  369. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/NetworkConditions.d.ts +26 -26
  370. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/NetworkConditions.js +33 -33
  371. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/NetworkManager.d.ts +126 -97
  372. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/NetworkManager.d.ts.map +1 -1
  373. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/NetworkManager.js +467 -342
  374. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/NetworkManager.js.map +1 -1
  375. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/PDFOptions.d.ts +161 -161
  376. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/PDFOptions.js +34 -34
  377. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Page.d.ts +2055 -2055
  378. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Page.js +2533 -2533
  379. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Product.d.ts +20 -20
  380. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Product.js +17 -17
  381. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Puppeteer.d.ts +159 -159
  382. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Puppeteer.js +161 -161
  383. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/PuppeteerViewport.d.ts +51 -51
  384. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/PuppeteerViewport.js +2 -2
  385. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/QueryHandler.d.ts +64 -64
  386. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/QueryHandler.js +165 -165
  387. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/SecurityDetails.d.ts +60 -60
  388. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/SecurityDetails.js +76 -76
  389. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Target.d.ts +100 -100
  390. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Target.js +145 -145
  391. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/TaskQueue.d.ts +20 -20
  392. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/TaskQueue.js +29 -29
  393. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/TimeoutSettings.d.ts +27 -27
  394. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/TimeoutSettings.js +47 -47
  395. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Tracing.d.ts +46 -46
  396. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/Tracing.js +109 -109
  397. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/USKeyboardLayout.d.ts +39 -39
  398. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/USKeyboardLayout.js +406 -406
  399. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/WebWorker.d.ts +98 -98
  400. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/WebWorker.js +112 -112
  401. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/assert.d.ts +22 -22
  402. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/assert.js +33 -33
  403. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/fetch.d.ts +16 -16
  404. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/fetch.js +43 -43
  405. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/helper.d.ts +84 -84
  406. data/node_modules/puppeteer-core/lib/cjs/puppeteer/common/helper.js +327 -327
  407. data/node_modules/puppeteer-core/lib/cjs/puppeteer/environment.d.ts +16 -16
  408. data/node_modules/puppeteer-core/lib/cjs/puppeteer/environment.js +19 -19
  409. data/node_modules/puppeteer-core/lib/cjs/puppeteer/global.d.ts +16 -16
  410. data/node_modules/puppeteer-core/lib/cjs/puppeteer/global.js +2 -2
  411. data/node_modules/puppeteer-core/lib/cjs/puppeteer/initialize-node.d.ts +17 -17
  412. data/node_modules/puppeteer-core/lib/cjs/puppeteer/initialize-node.js +44 -44
  413. data/node_modules/puppeteer-core/lib/cjs/puppeteer/initialize-web.d.ts +17 -17
  414. data/node_modules/puppeteer-core/lib/cjs/puppeteer/initialize-web.js +26 -26
  415. data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/BrowserFetcher.d.ts +133 -133
  416. data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/BrowserFetcher.js +500 -500
  417. data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/BrowserRunner.d.ts +40 -39
  418. data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/BrowserRunner.d.ts.map +1 -1
  419. data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/BrowserRunner.js +256 -230
  420. data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/BrowserRunner.js.map +1 -1
  421. data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/LaunchOptions.d.ts +134 -134
  422. data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/LaunchOptions.js +17 -17
  423. data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/Launcher.d.ts +16 -16
  424. data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/Launcher.d.ts.map +1 -1
  425. data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/Launcher.js +655 -588
  426. data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/Launcher.js.map +1 -1
  427. data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/NodeWebSocketTransport.d.ts +26 -26
  428. data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/NodeWebSocketTransport.js +47 -47
  429. data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/PipeTransport.d.ts +29 -29
  430. data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/PipeTransport.js +64 -64
  431. data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/Puppeteer.d.ts +153 -153
  432. data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/Puppeteer.js +188 -188
  433. data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/install.d.ts +17 -17
  434. data/node_modules/puppeteer-core/lib/cjs/puppeteer/node/install.js +173 -173
  435. data/node_modules/puppeteer-core/lib/cjs/puppeteer/node-puppeteer-core.d.ts +17 -17
  436. data/node_modules/puppeteer-core/lib/cjs/puppeteer/node-puppeteer-core.js +24 -24
  437. data/node_modules/puppeteer-core/lib/cjs/puppeteer/node.d.ts +17 -17
  438. data/node_modules/puppeteer-core/lib/cjs/puppeteer/node.js +23 -23
  439. data/node_modules/puppeteer-core/lib/cjs/puppeteer/revisions.d.ts +21 -21
  440. data/node_modules/puppeteer-core/lib/cjs/puppeteer/revisions.js +22 -22
  441. data/node_modules/puppeteer-core/lib/cjs/puppeteer/web.d.ts +17 -17
  442. data/node_modules/puppeteer-core/lib/cjs/puppeteer/web.js +23 -23
  443. data/node_modules/puppeteer-core/lib/cjs/vendor/mitt/src/index.d.ts +27 -27
  444. data/node_modules/puppeteer-core/lib/cjs/vendor/mitt/src/index.js +56 -56
  445. data/node_modules/puppeteer-core/lib/esm/puppeteer/api-docs-entry.d.ts +110 -110
  446. data/node_modules/puppeteer-core/lib/esm/puppeteer/api-docs-entry.js +80 -80
  447. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Accessibility.d.ts +175 -175
  448. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Accessibility.js +356 -356
  449. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/AriaQueryHandler.d.ts +20 -20
  450. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/AriaQueryHandler.js +81 -81
  451. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/AriaQueryHandler.js.map +1 -1
  452. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Browser.d.ts +455 -455
  453. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Browser.js +535 -535
  454. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/BrowserConnector.d.ts +53 -53
  455. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/BrowserConnector.js +74 -74
  456. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/BrowserWebSocketTransport.d.ts +25 -25
  457. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/BrowserWebSocketTransport.js +30 -30
  458. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Connection.d.ts +135 -135
  459. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Connection.js +293 -293
  460. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/ConnectionTransport.d.ts +24 -24
  461. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/ConnectionTransport.js +16 -16
  462. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/ConsoleMessage.d.ts +72 -72
  463. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/ConsoleMessage.js +60 -60
  464. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Coverage.d.ts +204 -204
  465. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Coverage.js +329 -329
  466. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/DOMWorld.d.ts +175 -175
  467. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/DOMWorld.js +657 -657
  468. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Debug.d.ts +52 -52
  469. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Debug.js +77 -77
  470. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/DeviceDescriptors.d.ts +40 -40
  471. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/DeviceDescriptors.js +1067 -1067
  472. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Dialog.d.ts +74 -74
  473. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Dialog.js +93 -93
  474. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/EmulationManager.d.ts +24 -24
  475. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/EmulationManager.js +33 -33
  476. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Errors.d.ts +50 -50
  477. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Errors.js +50 -50
  478. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/EvalTypes.d.ts +60 -60
  479. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/EvalTypes.js +16 -16
  480. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/EventEmitter.d.ts +92 -92
  481. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/EventEmitter.js +109 -109
  482. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Events.d.ts +81 -81
  483. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Events.js +83 -83
  484. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/ExecutionContext.d.ts +193 -193
  485. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/ExecutionContext.js +317 -317
  486. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/FileChooser.d.ts +58 -58
  487. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/FileChooser.js +67 -67
  488. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/FrameManager.d.ts +744 -744
  489. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/FrameManager.js +1042 -1042
  490. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/FrameManager.js.map +1 -1
  491. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/HTTPRequest.d.ts +350 -345
  492. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/HTTPRequest.d.ts.map +1 -1
  493. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/HTTPRequest.js +545 -545
  494. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/HTTPRequest.js.map +1 -1
  495. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/HTTPResponse.d.ts +134 -125
  496. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/HTTPResponse.d.ts.map +1 -1
  497. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/HTTPResponse.js +180 -160
  498. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/HTTPResponse.js.map +1 -1
  499. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Input.d.ts +358 -358
  500. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Input.js +537 -537
  501. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/JSHandle.d.ts +490 -490
  502. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/JSHandle.js +802 -802
  503. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/LifecycleWatcher.d.ts +65 -65
  504. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/LifecycleWatcher.d.ts.map +1 -1
  505. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/LifecycleWatcher.js +145 -144
  506. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/LifecycleWatcher.js.map +1 -1
  507. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/NetworkConditions.d.ts +26 -26
  508. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/NetworkConditions.js +30 -30
  509. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/NetworkManager.d.ts +126 -97
  510. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/NetworkManager.d.ts.map +1 -1
  511. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/NetworkManager.js +463 -338
  512. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/NetworkManager.js.map +1 -1
  513. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/PDFOptions.d.ts +161 -161
  514. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/PDFOptions.js +31 -31
  515. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Page.d.ts +2055 -2055
  516. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Page.js +2529 -2529
  517. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Product.d.ts +20 -20
  518. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Product.js +16 -16
  519. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Puppeteer.d.ts +159 -159
  520. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Puppeteer.js +157 -157
  521. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/PuppeteerViewport.d.ts +51 -51
  522. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/PuppeteerViewport.js +1 -1
  523. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/QueryHandler.d.ts +64 -64
  524. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/QueryHandler.js +157 -157
  525. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/SecurityDetails.d.ts +60 -60
  526. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/SecurityDetails.js +72 -72
  527. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Target.d.ts +100 -100
  528. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Target.js +141 -141
  529. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/TaskQueue.d.ts +20 -20
  530. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/TaskQueue.js +25 -25
  531. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/TimeoutSettings.d.ts +27 -27
  532. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/TimeoutSettings.js +43 -43
  533. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Tracing.d.ts +46 -46
  534. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/Tracing.js +105 -105
  535. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/USKeyboardLayout.d.ts +39 -39
  536. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/USKeyboardLayout.js +403 -403
  537. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/WebWorker.d.ts +98 -98
  538. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/WebWorker.js +108 -108
  539. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/assert.d.ts +22 -22
  540. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/assert.js +28 -28
  541. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/fetch.d.ts +16 -16
  542. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/fetch.js +20 -20
  543. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/helper.d.ts +84 -84
  544. data/node_modules/puppeteer-core/lib/esm/puppeteer/common/helper.js +305 -305
  545. data/node_modules/puppeteer-core/lib/esm/puppeteer/environment.d.ts +16 -16
  546. data/node_modules/puppeteer-core/lib/esm/puppeteer/environment.js +16 -16
  547. data/node_modules/puppeteer-core/lib/esm/puppeteer/global.d.ts +16 -16
  548. data/node_modules/puppeteer-core/lib/esm/puppeteer/global.js +1 -1
  549. data/node_modules/puppeteer-core/lib/esm/puppeteer/initialize-node.d.ts +17 -17
  550. data/node_modules/puppeteer-core/lib/esm/puppeteer/initialize-node.js +37 -37
  551. data/node_modules/puppeteer-core/lib/esm/puppeteer/initialize-web.d.ts +17 -17
  552. data/node_modules/puppeteer-core/lib/esm/puppeteer/initialize-web.js +22 -22
  553. data/node_modules/puppeteer-core/lib/esm/puppeteer/node/BrowserFetcher.d.ts +133 -133
  554. data/node_modules/puppeteer-core/lib/esm/puppeteer/node/BrowserFetcher.js +474 -474
  555. data/node_modules/puppeteer-core/lib/esm/puppeteer/node/BrowserRunner.d.ts +40 -39
  556. data/node_modules/puppeteer-core/lib/esm/puppeteer/node/BrowserRunner.d.ts.map +1 -1
  557. data/node_modules/puppeteer-core/lib/esm/puppeteer/node/BrowserRunner.js +230 -204
  558. data/node_modules/puppeteer-core/lib/esm/puppeteer/node/BrowserRunner.js.map +1 -1
  559. data/node_modules/puppeteer-core/lib/esm/puppeteer/node/LaunchOptions.d.ts +134 -134
  560. data/node_modules/puppeteer-core/lib/esm/puppeteer/node/LaunchOptions.js +16 -16
  561. data/node_modules/puppeteer-core/lib/esm/puppeteer/node/Launcher.d.ts +16 -16
  562. data/node_modules/puppeteer-core/lib/esm/puppeteer/node/Launcher.d.ts.map +1 -1
  563. data/node_modules/puppeteer-core/lib/esm/puppeteer/node/Launcher.js +633 -566
  564. data/node_modules/puppeteer-core/lib/esm/puppeteer/node/Launcher.js.map +1 -1
  565. data/node_modules/puppeteer-core/lib/esm/puppeteer/node/NodeWebSocketTransport.d.ts +26 -26
  566. data/node_modules/puppeteer-core/lib/esm/puppeteer/node/NodeWebSocketTransport.js +40 -40
  567. data/node_modules/puppeteer-core/lib/esm/puppeteer/node/PipeTransport.d.ts +29 -29
  568. data/node_modules/puppeteer-core/lib/esm/puppeteer/node/PipeTransport.js +60 -60
  569. data/node_modules/puppeteer-core/lib/esm/puppeteer/node/Puppeteer.d.ts +153 -153
  570. data/node_modules/puppeteer-core/lib/esm/puppeteer/node/Puppeteer.js +181 -181
  571. data/node_modules/puppeteer-core/lib/esm/puppeteer/node/install.d.ts +17 -17
  572. data/node_modules/puppeteer-core/lib/esm/puppeteer/node/install.js +165 -165
  573. data/node_modules/puppeteer-core/lib/esm/puppeteer/node-puppeteer-core.d.ts +17 -17
  574. data/node_modules/puppeteer-core/lib/esm/puppeteer/node-puppeteer-core.js +22 -22
  575. data/node_modules/puppeteer-core/lib/esm/puppeteer/node.d.ts +17 -17
  576. data/node_modules/puppeteer-core/lib/esm/puppeteer/node.js +21 -21
  577. data/node_modules/puppeteer-core/lib/esm/puppeteer/revisions.d.ts +21 -21
  578. data/node_modules/puppeteer-core/lib/esm/puppeteer/revisions.js +19 -19
  579. data/node_modules/puppeteer-core/lib/esm/puppeteer/web.d.ts +17 -17
  580. data/node_modules/puppeteer-core/lib/esm/puppeteer/web.js +21 -21
  581. data/node_modules/puppeteer-core/lib/esm/vendor/mitt/src/index.d.ts +27 -27
  582. data/node_modules/puppeteer-core/lib/esm/vendor/mitt/src/index.js +53 -53
  583. data/node_modules/puppeteer-core/lib/types.d.ts +67 -25
  584. data/node_modules/puppeteer-core/package.json +115 -115
  585. data/node_modules/puppeteer-core/typescript-if-required.js +61 -61
  586. data/node_modules/readable-stream/CONTRIBUTING.md +38 -38
  587. data/node_modules/readable-stream/GOVERNANCE.md +136 -136
  588. data/node_modules/readable-stream/LICENSE +47 -47
  589. data/node_modules/readable-stream/README.md +106 -106
  590. data/node_modules/readable-stream/errors-browser.js +127 -127
  591. data/node_modules/readable-stream/errors.js +116 -116
  592. data/node_modules/readable-stream/experimentalWarning.js +17 -17
  593. data/node_modules/readable-stream/lib/_stream_duplex.js +138 -138
  594. data/node_modules/readable-stream/lib/_stream_passthrough.js +38 -38
  595. data/node_modules/readable-stream/lib/_stream_readable.js +1123 -1123
  596. data/node_modules/readable-stream/lib/_stream_transform.js +200 -200
  597. data/node_modules/readable-stream/lib/_stream_writable.js +696 -696
  598. data/node_modules/readable-stream/lib/internal/streams/async_iterator.js +206 -206
  599. data/node_modules/readable-stream/lib/internal/streams/buffer_list.js +209 -209
  600. data/node_modules/readable-stream/lib/internal/streams/destroy.js +104 -104
  601. data/node_modules/readable-stream/lib/internal/streams/end-of-stream.js +103 -103
  602. data/node_modules/readable-stream/lib/internal/streams/from-browser.js +3 -3
  603. data/node_modules/readable-stream/lib/internal/streams/from.js +63 -63
  604. data/node_modules/readable-stream/lib/internal/streams/pipeline.js +96 -96
  605. data/node_modules/readable-stream/lib/internal/streams/state.js +26 -26
  606. data/node_modules/readable-stream/lib/internal/streams/stream-browser.js +1 -1
  607. data/node_modules/readable-stream/lib/internal/streams/stream.js +1 -1
  608. data/node_modules/readable-stream/package.json +68 -68
  609. data/node_modules/readable-stream/readable-browser.js +9 -9
  610. data/node_modules/readable-stream/readable.js +16 -16
  611. data/node_modules/rimraf/CHANGELOG.md +65 -65
  612. data/node_modules/rimraf/LICENSE +15 -15
  613. data/node_modules/rimraf/README.md +101 -101
  614. data/node_modules/rimraf/bin.js +68 -68
  615. data/node_modules/rimraf/package.json +32 -32
  616. data/node_modules/rimraf/rimraf.js +360 -360
  617. data/node_modules/safe-buffer/LICENSE +21 -21
  618. data/node_modules/safe-buffer/README.md +584 -584
  619. data/node_modules/safe-buffer/index.d.ts +186 -186
  620. data/node_modules/safe-buffer/index.js +65 -65
  621. data/node_modules/safe-buffer/package.json +51 -51
  622. data/node_modules/string_decoder/LICENSE +48 -48
  623. data/node_modules/string_decoder/README.md +47 -47
  624. data/node_modules/string_decoder/lib/string_decoder.js +295 -295
  625. data/node_modules/string_decoder/package.json +34 -34
  626. data/node_modules/tar-fs/.travis.yml +6 -6
  627. data/node_modules/tar-fs/LICENSE +20 -20
  628. data/node_modules/tar-fs/README.md +165 -165
  629. data/node_modules/tar-fs/index.js +351 -351
  630. data/node_modules/tar-fs/package.json +41 -41
  631. data/node_modules/tar-fs/test/fixtures/a/hello.txt +1 -1
  632. data/node_modules/tar-fs/test/fixtures/b/a/test.txt +1 -1
  633. data/node_modules/tar-fs/test/index.js +346 -346
  634. data/node_modules/tar-stream/LICENSE +20 -20
  635. data/node_modules/tar-stream/README.md +168 -168
  636. data/node_modules/tar-stream/extract.js +257 -257
  637. data/node_modules/tar-stream/headers.js +295 -295
  638. data/node_modules/tar-stream/index.js +2 -2
  639. data/node_modules/tar-stream/pack.js +255 -255
  640. data/node_modules/tar-stream/package.json +58 -58
  641. data/node_modules/tar-stream/sandbox.js +11 -11
  642. data/node_modules/through/.travis.yml +5 -5
  643. data/node_modules/through/LICENSE.APACHE2 +15 -15
  644. data/node_modules/through/LICENSE.MIT +24 -24
  645. data/node_modules/through/index.js +108 -108
  646. data/node_modules/through/package.json +36 -36
  647. data/node_modules/through/readme.markdown +64 -64
  648. data/node_modules/through/test/async.js +28 -28
  649. data/node_modules/through/test/auto-destroy.js +30 -30
  650. data/node_modules/through/test/buffering.js +71 -71
  651. data/node_modules/through/test/end.js +45 -45
  652. data/node_modules/through/test/index.js +133 -133
  653. data/node_modules/tr46/.npmignore +4 -4
  654. data/node_modules/tr46/index.js +193 -193
  655. data/node_modules/tr46/package.json +31 -31
  656. data/node_modules/unbzip2-stream/LICENSE +24 -24
  657. data/node_modules/unbzip2-stream/README.md +59 -59
  658. data/node_modules/unbzip2-stream/dist/unbzip2-stream.min.js +1 -1
  659. data/node_modules/unbzip2-stream/index.js +93 -93
  660. data/node_modules/unbzip2-stream/lib/bit_iterator.js +39 -39
  661. data/node_modules/unbzip2-stream/lib/bzip2.js +365 -365
  662. data/node_modules/unbzip2-stream/package.json +51 -51
  663. data/node_modules/util-deprecate/History.md +16 -16
  664. data/node_modules/util-deprecate/LICENSE +24 -24
  665. data/node_modules/util-deprecate/README.md +53 -53
  666. data/node_modules/util-deprecate/browser.js +67 -67
  667. data/node_modules/util-deprecate/node.js +6 -6
  668. data/node_modules/util-deprecate/package.json +27 -27
  669. data/node_modules/webidl-conversions/LICENSE.md +12 -12
  670. data/node_modules/webidl-conversions/README.md +53 -53
  671. data/node_modules/webidl-conversions/lib/index.js +189 -189
  672. data/node_modules/webidl-conversions/package.json +23 -23
  673. data/node_modules/whatwg-url/LICENSE.txt +21 -21
  674. data/node_modules/whatwg-url/README.md +67 -67
  675. data/node_modules/whatwg-url/lib/URL-impl.js +200 -200
  676. data/node_modules/whatwg-url/lib/URL.js +196 -196
  677. data/node_modules/whatwg-url/lib/public-api.js +11 -11
  678. data/node_modules/whatwg-url/lib/utils.js +20 -20
  679. data/node_modules/whatwg-url/package.json +32 -32
  680. data/node_modules/wrappy/LICENSE +15 -15
  681. data/node_modules/wrappy/README.md +36 -36
  682. data/node_modules/wrappy/package.json +29 -29
  683. data/node_modules/wrappy/wrappy.js +33 -33
  684. data/node_modules/ws/LICENSE +19 -19
  685. data/node_modules/ws/README.md +493 -493
  686. data/node_modules/ws/browser.js +8 -8
  687. data/node_modules/ws/index.js +13 -13
  688. data/node_modules/ws/lib/buffer-util.js +126 -126
  689. data/node_modules/ws/lib/constants.js +12 -12
  690. data/node_modules/ws/lib/event-target.js +266 -266
  691. data/node_modules/ws/lib/extension.js +203 -203
  692. data/node_modules/ws/lib/limiter.js +55 -55
  693. data/node_modules/ws/lib/permessage-deflate.js +511 -511
  694. data/node_modules/ws/lib/receiver.js +612 -612
  695. data/node_modules/ws/lib/sender.js +422 -422
  696. data/node_modules/ws/lib/stream.js +180 -180
  697. data/node_modules/ws/lib/subprotocol.js +62 -62
  698. data/node_modules/ws/lib/validation.js +124 -124
  699. data/node_modules/ws/lib/websocket-server.js +485 -485
  700. data/node_modules/ws/lib/websocket.js +1149 -1149
  701. data/node_modules/ws/package.json +61 -61
  702. data/node_modules/ws/wrapper.mjs +8 -8
  703. data/node_modules/yauzl/LICENSE +21 -21
  704. data/node_modules/yauzl/README.md +658 -658
  705. data/node_modules/yauzl/index.js +796 -796
  706. data/node_modules/yauzl/package.json +40 -40
  707. data/package.json +1 -1
  708. metadata +23 -25
  709. data/node_modules/devtools-protocol/changelog.md +0 -10491
  710. data/node_modules/devtools-protocol/externs/protocol_externs.js +0 -9734
@@ -1,803 +1,803 @@
1
- /**
2
- * Copyright 2019 Google Inc. All rights reserved.
3
- *
4
- * Licensed under the Apache License, Version 2.0 (the "License");
5
- * you may not use this file except in compliance with the License.
6
- * You may obtain a copy of the License at
7
- *
8
- * http://www.apache.org/licenses/LICENSE-2.0
9
- *
10
- * Unless required by applicable law or agreed to in writing, software
11
- * distributed under the License is distributed on an "AS IS" BASIS,
12
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
- * See the License for the specific language governing permissions and
14
- * limitations under the License.
15
- */
16
- import { assert } from './assert.js';
17
- import { helper, debugError } from './helper.js';
18
- import { getQueryHandlerAndSelector } from './QueryHandler.js';
19
- import { isNode } from '../environment.js';
20
- /**
21
- * @internal
22
- */
23
- export function createJSHandle(context, remoteObject) {
24
- const frame = context.frame();
25
- if (remoteObject.subtype === 'node' && frame) {
26
- const frameManager = frame._frameManager;
27
- return new ElementHandle(context, context._client, remoteObject, frameManager.page(), frameManager);
28
- }
29
- return new JSHandle(context, context._client, remoteObject);
30
- }
31
- /**
32
- * Represents an in-page JavaScript object. JSHandles can be created with the
33
- * {@link Page.evaluateHandle | page.evaluateHandle} method.
34
- *
35
- * @example
36
- * ```js
37
- * const windowHandle = await page.evaluateHandle(() => window);
38
- * ```
39
- *
40
- * JSHandle prevents the referenced JavaScript object from being garbage-collected
41
- * unless the handle is {@link JSHandle.dispose | disposed}. JSHandles are auto-
42
- * disposed when their origin frame gets navigated or the parent context gets destroyed.
43
- *
44
- * JSHandle instances can be used as arguments for {@link Page.$eval},
45
- * {@link Page.evaluate}, and {@link Page.evaluateHandle}.
46
- *
47
- * @public
48
- */
49
- export class JSHandle {
50
- /**
51
- * @internal
52
- */
53
- constructor(context, client, remoteObject) {
54
- /**
55
- * @internal
56
- */
57
- this._disposed = false;
58
- this._context = context;
59
- this._client = client;
60
- this._remoteObject = remoteObject;
61
- }
62
- /** Returns the execution context the handle belongs to.
63
- */
64
- executionContext() {
65
- return this._context;
66
- }
67
- /**
68
- * This method passes this handle as the first argument to `pageFunction`.
69
- * If `pageFunction` returns a Promise, then `handle.evaluate` would wait
70
- * for the promise to resolve and return its value.
71
- *
72
- * @example
73
- * ```js
74
- * const tweetHandle = await page.$('.tweet .retweets');
75
- * expect(await tweetHandle.evaluate(node => node.innerText)).toBe('10');
76
- * ```
77
- */
78
- async evaluate(pageFunction, ...args) {
79
- return await this.executionContext().evaluate(pageFunction, this, ...args);
80
- }
81
- /**
82
- * This method passes this handle as the first argument to `pageFunction`.
83
- *
84
- * @remarks
85
- *
86
- * The only difference between `jsHandle.evaluate` and
87
- * `jsHandle.evaluateHandle` is that `jsHandle.evaluateHandle`
88
- * returns an in-page object (JSHandle).
89
- *
90
- * If the function passed to `jsHandle.evaluateHandle` returns a Promise,
91
- * then `evaluateHandle.evaluateHandle` waits for the promise to resolve and
92
- * returns its value.
93
- *
94
- * See {@link Page.evaluateHandle} for more details.
95
- */
96
- async evaluateHandle(pageFunction, ...args) {
97
- return await this.executionContext().evaluateHandle(pageFunction, this, ...args);
98
- }
99
- /** Fetches a single property from the referenced object.
100
- */
101
- async getProperty(propertyName) {
102
- const objectHandle = await this.evaluateHandle((object, propertyName) => {
103
- const result = { __proto__: null };
104
- result[propertyName] = object[propertyName];
105
- return result;
106
- }, propertyName);
107
- const properties = await objectHandle.getProperties();
108
- const result = properties.get(propertyName);
109
- assert(result instanceof JSHandle);
110
- await objectHandle.dispose();
111
- return result;
112
- }
113
- /**
114
- * The method returns a map with property names as keys and JSHandle
115
- * instances for the property values.
116
- *
117
- * @example
118
- * ```js
119
- * const listHandle = await page.evaluateHandle(() => document.body.children);
120
- * const properties = await listHandle.getProperties();
121
- * const children = [];
122
- * for (const property of properties.values()) {
123
- * const element = property.asElement();
124
- * if (element)
125
- * children.push(element);
126
- * }
127
- * children; // holds elementHandles to all children of document.body
128
- * ```
129
- */
130
- async getProperties() {
131
- const response = await this._client.send('Runtime.getProperties', {
132
- objectId: this._remoteObject.objectId,
133
- ownProperties: true,
134
- });
135
- const result = new Map();
136
- for (const property of response.result) {
137
- if (!property.enumerable)
138
- continue;
139
- result.set(property.name, createJSHandle(this._context, property.value));
140
- }
141
- return result;
142
- }
143
- /**
144
- * @returns Returns a JSON representation of the object.If the object has a
145
- * `toJSON` function, it will not be called.
146
- * @remarks
147
- *
148
- * The JSON is generated by running {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify | JSON.stringify}
149
- * on the object in page and consequent {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/parse | JSON.parse} in puppeteer.
150
- * **NOTE** The method throws if the referenced object is not stringifiable.
151
- */
152
- async jsonValue() {
153
- if (this._remoteObject.objectId) {
154
- const response = await this._client.send('Runtime.callFunctionOn', {
155
- functionDeclaration: 'function() { return this; }',
156
- objectId: this._remoteObject.objectId,
157
- returnByValue: true,
158
- awaitPromise: true,
159
- });
160
- return helper.valueFromRemoteObject(response.result);
161
- }
162
- return helper.valueFromRemoteObject(this._remoteObject);
163
- }
164
- /**
165
- * @returns Either `null` or the object handle itself, if the object
166
- * handle is an instance of {@link ElementHandle}.
167
- */
168
- asElement() {
169
- /* This always returns null, but subclasses can override this and return an
170
- ElementHandle.
171
- */
172
- return null;
173
- }
174
- /**
175
- * Stops referencing the element handle, and resolves when the object handle is
176
- * successfully disposed of.
177
- */
178
- async dispose() {
179
- if (this._disposed)
180
- return;
181
- this._disposed = true;
182
- await helper.releaseObject(this._client, this._remoteObject);
183
- }
184
- /**
185
- * Returns a string representation of the JSHandle.
186
- *
187
- * @remarks Useful during debugging.
188
- */
189
- toString() {
190
- if (this._remoteObject.objectId) {
191
- const type = this._remoteObject.subtype || this._remoteObject.type;
192
- return 'JSHandle@' + type;
193
- }
194
- return 'JSHandle:' + helper.valueFromRemoteObject(this._remoteObject);
195
- }
196
- }
197
- /**
198
- * ElementHandle represents an in-page DOM element.
199
- *
200
- * @remarks
201
- *
202
- * ElementHandles can be created with the {@link Page.$} method.
203
- *
204
- * ```js
205
- * const puppeteer = require('puppeteer');
206
- *
207
- * (async () => {
208
- * const browser = await puppeteer.launch();
209
- * const page = await browser.newPage();
210
- * await page.goto('https://example.com');
211
- * const hrefElement = await page.$('a');
212
- * await hrefElement.click();
213
- * // ...
214
- * })();
215
- * ```
216
- *
217
- * ElementHandle prevents the DOM element from being garbage-collected unless the
218
- * handle is {@link JSHandle.dispose | disposed}. ElementHandles are auto-disposed
219
- * when their origin frame gets navigated.
220
- *
221
- * ElementHandle instances can be used as arguments in {@link Page.$eval} and
222
- * {@link Page.evaluate} methods.
223
- *
224
- * If you're using TypeScript, ElementHandle takes a generic argument that
225
- * denotes the type of element the handle is holding within. For example, if you
226
- * have a handle to a `<select>` element, you can type it as
227
- * `ElementHandle<HTMLSelectElement>` and you get some nicer type checks.
228
- *
229
- * @public
230
- */
231
- export class ElementHandle extends JSHandle {
232
- /**
233
- * @internal
234
- */
235
- constructor(context, client, remoteObject, page, frameManager) {
236
- super(context, client, remoteObject);
237
- this._client = client;
238
- this._remoteObject = remoteObject;
239
- this._page = page;
240
- this._frameManager = frameManager;
241
- }
242
- asElement() {
243
- return this;
244
- }
245
- /**
246
- * Resolves to the content frame for element handles referencing
247
- * iframe nodes, or null otherwise
248
- */
249
- async contentFrame() {
250
- const nodeInfo = await this._client.send('DOM.describeNode', {
251
- objectId: this._remoteObject.objectId,
252
- });
253
- if (typeof nodeInfo.node.frameId !== 'string')
254
- return null;
255
- return this._frameManager.frame(nodeInfo.node.frameId);
256
- }
257
- async _scrollIntoViewIfNeeded() {
258
- const error = await this.evaluate(async (element, pageJavascriptEnabled) => {
259
- if (!element.isConnected)
260
- return 'Node is detached from document';
261
- if (element.nodeType !== Node.ELEMENT_NODE)
262
- return 'Node is not of type HTMLElement';
263
- // force-scroll if page's javascript is disabled.
264
- if (!pageJavascriptEnabled) {
265
- element.scrollIntoView({
266
- block: 'center',
267
- inline: 'center',
268
- // @ts-expect-error Chrome still supports behavior: instant but
269
- // it's not in the spec so TS shouts We don't want to make this
270
- // breaking change in Puppeteer yet so we'll ignore the line.
271
- behavior: 'instant',
272
- });
273
- return false;
274
- }
275
- const visibleRatio = await new Promise((resolve) => {
276
- const observer = new IntersectionObserver((entries) => {
277
- resolve(entries[0].intersectionRatio);
278
- observer.disconnect();
279
- });
280
- observer.observe(element);
281
- });
282
- if (visibleRatio !== 1.0) {
283
- element.scrollIntoView({
284
- block: 'center',
285
- inline: 'center',
286
- // @ts-expect-error Chrome still supports behavior: instant but
287
- // it's not in the spec so TS shouts We don't want to make this
288
- // breaking change in Puppeteer yet so we'll ignore the line.
289
- behavior: 'instant',
290
- });
291
- }
292
- return false;
293
- }, this._page.isJavaScriptEnabled());
294
- if (error)
295
- throw new Error(error);
296
- }
297
- /**
298
- * Returns the middle point within an element unless a specific offset is provided.
299
- */
300
- async clickablePoint(offset) {
301
- const [result, layoutMetrics] = await Promise.all([
302
- this._client
303
- .send('DOM.getContentQuads', {
304
- objectId: this._remoteObject.objectId,
305
- })
306
- .catch(debugError),
307
- this._client.send('Page.getLayoutMetrics'),
308
- ]);
309
- if (!result || !result.quads.length)
310
- throw new Error('Node is either not clickable or not an HTMLElement');
311
- // Filter out quads that have too small area to click into.
312
- // Fallback to `layoutViewport` in case of using Firefox.
313
- const { clientWidth, clientHeight } = layoutMetrics.cssLayoutViewport || layoutMetrics.layoutViewport;
314
- const quads = result.quads
315
- .map((quad) => this._fromProtocolQuad(quad))
316
- .map((quad) => this._intersectQuadWithViewport(quad, clientWidth, clientHeight))
317
- .filter((quad) => computeQuadArea(quad) > 1);
318
- if (!quads.length)
319
- throw new Error('Node is either not clickable or not an HTMLElement');
320
- const quad = quads[0];
321
- if (offset) {
322
- // Return the point of the first quad identified by offset.
323
- let minX = Number.MAX_SAFE_INTEGER;
324
- let minY = Number.MAX_SAFE_INTEGER;
325
- for (const point of quad) {
326
- if (point.x < minX) {
327
- minX = point.x;
328
- }
329
- if (point.y < minY) {
330
- minY = point.y;
331
- }
332
- }
333
- if (minX !== Number.MAX_SAFE_INTEGER &&
334
- minY !== Number.MAX_SAFE_INTEGER) {
335
- return {
336
- x: minX + offset.x,
337
- y: minY + offset.y,
338
- };
339
- }
340
- }
341
- // Return the middle point of the first quad.
342
- let x = 0;
343
- let y = 0;
344
- for (const point of quad) {
345
- x += point.x;
346
- y += point.y;
347
- }
348
- return {
349
- x: x / 4,
350
- y: y / 4,
351
- };
352
- }
353
- _getBoxModel() {
354
- const params = {
355
- objectId: this._remoteObject.objectId,
356
- };
357
- return this._client
358
- .send('DOM.getBoxModel', params)
359
- .catch((error) => debugError(error));
360
- }
361
- _fromProtocolQuad(quad) {
362
- return [
363
- { x: quad[0], y: quad[1] },
364
- { x: quad[2], y: quad[3] },
365
- { x: quad[4], y: quad[5] },
366
- { x: quad[6], y: quad[7] },
367
- ];
368
- }
369
- _intersectQuadWithViewport(quad, width, height) {
370
- return quad.map((point) => ({
371
- x: Math.min(Math.max(point.x, 0), width),
372
- y: Math.min(Math.max(point.y, 0), height),
373
- }));
374
- }
375
- /**
376
- * This method scrolls element into view if needed, and then
377
- * uses {@link Page.mouse} to hover over the center of the element.
378
- * If the element is detached from DOM, the method throws an error.
379
- */
380
- async hover() {
381
- await this._scrollIntoViewIfNeeded();
382
- const { x, y } = await this.clickablePoint();
383
- await this._page.mouse.move(x, y);
384
- }
385
- /**
386
- * This method scrolls element into view if needed, and then
387
- * uses {@link Page.mouse} to click in the center of the element.
388
- * If the element is detached from DOM, the method throws an error.
389
- */
390
- async click(options = {}) {
391
- await this._scrollIntoViewIfNeeded();
392
- const { x, y } = await this.clickablePoint(options.offset);
393
- await this._page.mouse.click(x, y, options);
394
- }
395
- /**
396
- * This method creates and captures a dragevent from the element.
397
- */
398
- async drag(target) {
399
- assert(this._page.isDragInterceptionEnabled(), 'Drag Interception is not enabled!');
400
- await this._scrollIntoViewIfNeeded();
401
- const start = await this.clickablePoint();
402
- return await this._page.mouse.drag(start, target);
403
- }
404
- /**
405
- * This method creates a `dragenter` event on the element.
406
- */
407
- async dragEnter(data = { items: [], dragOperationsMask: 1 }) {
408
- await this._scrollIntoViewIfNeeded();
409
- const target = await this.clickablePoint();
410
- await this._page.mouse.dragEnter(target, data);
411
- }
412
- /**
413
- * This method creates a `dragover` event on the element.
414
- */
415
- async dragOver(data = { items: [], dragOperationsMask: 1 }) {
416
- await this._scrollIntoViewIfNeeded();
417
- const target = await this.clickablePoint();
418
- await this._page.mouse.dragOver(target, data);
419
- }
420
- /**
421
- * This method triggers a drop on the element.
422
- */
423
- async drop(data = { items: [], dragOperationsMask: 1 }) {
424
- await this._scrollIntoViewIfNeeded();
425
- const destination = await this.clickablePoint();
426
- await this._page.mouse.drop(destination, data);
427
- }
428
- /**
429
- * This method triggers a dragenter, dragover, and drop on the element.
430
- */
431
- async dragAndDrop(target, options) {
432
- await this._scrollIntoViewIfNeeded();
433
- const startPoint = await this.clickablePoint();
434
- const targetPoint = await target.clickablePoint();
435
- await this._page.mouse.dragAndDrop(startPoint, targetPoint, options);
436
- }
437
- /**
438
- * Triggers a `change` and `input` event once all the provided options have been
439
- * selected. If there's no `<select>` element matching `selector`, the method
440
- * throws an error.
441
- *
442
- * @example
443
- * ```js
444
- * handle.select('blue'); // single selection
445
- * handle.select('red', 'green', 'blue'); // multiple selections
446
- * ```
447
- * @param values - Values of options to select. If the `<select>` has the
448
- * `multiple` attribute, all values are considered, otherwise only the first
449
- * one is taken into account.
450
- */
451
- async select(...values) {
452
- for (const value of values)
453
- assert(helper.isString(value), 'Values must be strings. Found value "' +
454
- value +
455
- '" of type "' +
456
- typeof value +
457
- '"');
458
- return this.evaluate((element, values) => {
459
- if (!(element instanceof HTMLSelectElement))
460
- throw new Error('Element is not a <select> element.');
461
- const options = Array.from(element.options);
462
- element.value = undefined;
463
- for (const option of options) {
464
- option.selected = values.includes(option.value);
465
- if (option.selected && !element.multiple)
466
- break;
467
- }
468
- element.dispatchEvent(new Event('input', { bubbles: true }));
469
- element.dispatchEvent(new Event('change', { bubbles: true }));
470
- return options
471
- .filter((option) => option.selected)
472
- .map((option) => option.value);
473
- }, values);
474
- }
475
- /**
476
- * This method expects `elementHandle` to point to an
477
- * {@link https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input | input element}.
478
- * @param filePaths - Sets the value of the file input to these paths.
479
- * If some of the `filePaths` are relative paths, then they are resolved
480
- * relative to the {@link https://nodejs.org/api/process.html#process_process_cwd | current working directory}
481
- */
482
- async uploadFile(...filePaths) {
483
- const isMultiple = await this.evaluate((element) => {
484
- if (!(element instanceof HTMLInputElement)) {
485
- throw new Error('uploadFile can only be called on an input element.');
486
- }
487
- return element.multiple;
488
- });
489
- assert(filePaths.length <= 1 || isMultiple, 'Multiple file uploads only work with <input type=file multiple>');
490
- if (!isNode) {
491
- throw new Error(`JSHandle#uploadFile can only be used in Node environments.`);
492
- }
493
- /*
494
- This import is only needed for `uploadFile`, so keep it scoped here to
495
- avoid paying the cost unnecessarily.
496
- */
497
- const path = await import('path');
498
- const fs = await helper.importFSModule();
499
- // Locate all files and confirm that they exist.
500
- const files = await Promise.all(filePaths.map(async (filePath) => {
501
- const resolvedPath = path.resolve(filePath);
502
- try {
503
- await fs.promises.access(resolvedPath, fs.constants.R_OK);
504
- }
505
- catch (error) {
506
- if (error.code === 'ENOENT')
507
- throw new Error(`${filePath} does not exist or is not readable`);
508
- }
509
- return resolvedPath;
510
- }));
511
- const { objectId } = this._remoteObject;
512
- const { node } = await this._client.send('DOM.describeNode', { objectId });
513
- const { backendNodeId } = node;
514
- /* The zero-length array is a special case, it seems that
515
- DOM.setFileInputFiles does not actually update the files in that case,
516
- so the solution is to eval the element value to a new FileList directly.
517
- */
518
- if (files.length === 0) {
519
- await this.evaluate((element) => {
520
- element.files = new DataTransfer().files;
521
- // Dispatch events for this case because it should behave akin to a user action.
522
- element.dispatchEvent(new Event('input', { bubbles: true }));
523
- element.dispatchEvent(new Event('change', { bubbles: true }));
524
- });
525
- }
526
- else {
527
- await this._client.send('DOM.setFileInputFiles', {
528
- objectId,
529
- files,
530
- backendNodeId,
531
- });
532
- }
533
- }
534
- /**
535
- * This method scrolls element into view if needed, and then uses
536
- * {@link Touchscreen.tap} to tap in the center of the element.
537
- * If the element is detached from DOM, the method throws an error.
538
- */
539
- async tap() {
540
- await this._scrollIntoViewIfNeeded();
541
- const { x, y } = await this.clickablePoint();
542
- await this._page.touchscreen.tap(x, y);
543
- }
544
- /**
545
- * Calls {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement/focus | focus} on the element.
546
- */
547
- async focus() {
548
- await this.evaluate((element) => element.focus());
549
- }
550
- /**
551
- * Focuses the element, and then sends a `keydown`, `keypress`/`input`, and
552
- * `keyup` event for each character in the text.
553
- *
554
- * To press a special key, like `Control` or `ArrowDown`,
555
- * use {@link ElementHandle.press}.
556
- *
557
- * @example
558
- * ```js
559
- * await elementHandle.type('Hello'); // Types instantly
560
- * await elementHandle.type('World', {delay: 100}); // Types slower, like a user
561
- * ```
562
- *
563
- * @example
564
- * An example of typing into a text field and then submitting the form:
565
- *
566
- * ```js
567
- * const elementHandle = await page.$('input');
568
- * await elementHandle.type('some text');
569
- * await elementHandle.press('Enter');
570
- * ```
571
- */
572
- async type(text, options) {
573
- await this.focus();
574
- await this._page.keyboard.type(text, options);
575
- }
576
- /**
577
- * Focuses the element, and then uses {@link Keyboard.down} and {@link Keyboard.up}.
578
- *
579
- * @remarks
580
- * If `key` is a single character and no modifier keys besides `Shift`
581
- * are being held down, a `keypress`/`input` event will also be generated.
582
- * The `text` option can be specified to force an input event to be generated.
583
- *
584
- * **NOTE** Modifier keys DO affect `elementHandle.press`. Holding down `Shift`
585
- * will type the text in upper case.
586
- *
587
- * @param key - Name of key to press, such as `ArrowLeft`.
588
- * See {@link KeyInput} for a list of all key names.
589
- */
590
- async press(key, options) {
591
- await this.focus();
592
- await this._page.keyboard.press(key, options);
593
- }
594
- /**
595
- * This method returns the bounding box of the element (relative to the main frame),
596
- * or `null` if the element is not visible.
597
- */
598
- async boundingBox() {
599
- const result = await this._getBoxModel();
600
- if (!result)
601
- return null;
602
- const quad = result.model.border;
603
- const x = Math.min(quad[0], quad[2], quad[4], quad[6]);
604
- const y = Math.min(quad[1], quad[3], quad[5], quad[7]);
605
- const width = Math.max(quad[0], quad[2], quad[4], quad[6]) - x;
606
- const height = Math.max(quad[1], quad[3], quad[5], quad[7]) - y;
607
- return { x, y, width, height };
608
- }
609
- /**
610
- * This method returns boxes of the element, or `null` if the element is not visible.
611
- *
612
- * @remarks
613
- *
614
- * Boxes are represented as an array of points;
615
- * Each Point is an object `{x, y}`. Box points are sorted clock-wise.
616
- */
617
- async boxModel() {
618
- const result = await this._getBoxModel();
619
- if (!result)
620
- return null;
621
- const { content, padding, border, margin, width, height } = result.model;
622
- return {
623
- content: this._fromProtocolQuad(content),
624
- padding: this._fromProtocolQuad(padding),
625
- border: this._fromProtocolQuad(border),
626
- margin: this._fromProtocolQuad(margin),
627
- width,
628
- height,
629
- };
630
- }
631
- /**
632
- * This method scrolls element into view if needed, and then uses
633
- * {@link Page.screenshot} to take a screenshot of the element.
634
- * If the element is detached from DOM, the method throws an error.
635
- */
636
- async screenshot(options = {}) {
637
- let needsViewportReset = false;
638
- let boundingBox = await this.boundingBox();
639
- assert(boundingBox, 'Node is either not visible or not an HTMLElement');
640
- const viewport = this._page.viewport();
641
- if (viewport &&
642
- (boundingBox.width > viewport.width ||
643
- boundingBox.height > viewport.height)) {
644
- const newViewport = {
645
- width: Math.max(viewport.width, Math.ceil(boundingBox.width)),
646
- height: Math.max(viewport.height, Math.ceil(boundingBox.height)),
647
- };
648
- await this._page.setViewport(Object.assign({}, viewport, newViewport));
649
- needsViewportReset = true;
650
- }
651
- await this._scrollIntoViewIfNeeded();
652
- boundingBox = await this.boundingBox();
653
- assert(boundingBox, 'Node is either not visible or not an HTMLElement');
654
- assert(boundingBox.width !== 0, 'Node has 0 width.');
655
- assert(boundingBox.height !== 0, 'Node has 0 height.');
656
- const layoutMetrics = await this._client.send('Page.getLayoutMetrics');
657
- // Fallback to `layoutViewport` in case of using Firefox.
658
- const { pageX, pageY } = layoutMetrics.cssLayoutViewport || layoutMetrics.layoutViewport;
659
- const clip = Object.assign({}, boundingBox);
660
- clip.x += pageX;
661
- clip.y += pageY;
662
- const imageData = await this._page.screenshot(Object.assign({}, {
663
- clip,
664
- }, options));
665
- if (needsViewportReset)
666
- await this._page.setViewport(viewport);
667
- return imageData;
668
- }
669
- /**
670
- * Runs `element.querySelector` within the page. If no element matches the selector,
671
- * the return value resolves to `null`.
672
- */
673
- async $(selector) {
674
- const { updatedSelector, queryHandler } = getQueryHandlerAndSelector(selector);
675
- return queryHandler.queryOne(this, updatedSelector);
676
- }
677
- /**
678
- * Runs `element.querySelectorAll` within the page. If no elements match the selector,
679
- * the return value resolves to `[]`.
680
- */
681
- async $$(selector) {
682
- const { updatedSelector, queryHandler } = getQueryHandlerAndSelector(selector);
683
- return queryHandler.queryAll(this, updatedSelector);
684
- }
685
- /**
686
- * This method runs `document.querySelector` within the element and passes it as
687
- * the first argument to `pageFunction`. If there's no element matching `selector`,
688
- * the method throws an error.
689
- *
690
- * If `pageFunction` returns a Promise, then `frame.$eval` would wait for the promise
691
- * to resolve and return its value.
692
- *
693
- * @example
694
- * ```js
695
- * const tweetHandle = await page.$('.tweet');
696
- * expect(await tweetHandle.$eval('.like', node => node.innerText)).toBe('100');
697
- * expect(await tweetHandle.$eval('.retweets', node => node.innerText)).toBe('10');
698
- * ```
699
- */
700
- async $eval(selector, pageFunction, ...args) {
701
- const elementHandle = await this.$(selector);
702
- if (!elementHandle)
703
- throw new Error(`Error: failed to find element matching selector "${selector}"`);
704
- const result = await elementHandle.evaluate(pageFunction, ...args);
705
- await elementHandle.dispose();
706
- /**
707
- * This `as` is a little unfortunate but helps TS understand the behavior of
708
- * `elementHandle.evaluate`. If evaluate returns an element it will return an
709
- * ElementHandle instance, rather than the plain object. All the
710
- * WrapElementHandle type does is wrap ReturnType into
711
- * ElementHandle<ReturnType> if it is an ElementHandle, or leave it alone as
712
- * ReturnType if it isn't.
713
- */
714
- return result;
715
- }
716
- /**
717
- * This method runs `document.querySelectorAll` within the element and passes it as
718
- * the first argument to `pageFunction`. If there's no element matching `selector`,
719
- * the method throws an error.
720
- *
721
- * If `pageFunction` returns a Promise, then `frame.$$eval` would wait for the
722
- * promise to resolve and return its value.
723
- *
724
- * @example
725
- * ```html
726
- * <div class="feed">
727
- * <div class="tweet">Hello!</div>
728
- * <div class="tweet">Hi!</div>
729
- * </div>
730
- * ```
731
- *
732
- * @example
733
- * ```js
734
- * const feedHandle = await page.$('.feed');
735
- * expect(await feedHandle.$$eval('.tweet', nodes => nodes.map(n => n.innerText)))
736
- * .toEqual(['Hello!', 'Hi!']);
737
- * ```
738
- */
739
- async $$eval(selector, pageFunction, ...args) {
740
- const { updatedSelector, queryHandler } = getQueryHandlerAndSelector(selector);
741
- const arrayHandle = await queryHandler.queryAllArray(this, updatedSelector);
742
- const result = await arrayHandle.evaluate(pageFunction, ...args);
743
- await arrayHandle.dispose();
744
- /* This `as` exists for the same reason as the `as` in $eval above.
745
- * See the comment there for a full explanation.
746
- */
747
- return result;
748
- }
749
- /**
750
- * The method evaluates the XPath expression relative to the elementHandle.
751
- * If there are no such elements, the method will resolve to an empty array.
752
- * @param expression - Expression to {@link https://developer.mozilla.org/en-US/docs/Web/API/Document/evaluate | evaluate}
753
- */
754
- async $x(expression) {
755
- const arrayHandle = await this.evaluateHandle((element, expression) => {
756
- const document = element.ownerDocument || element;
757
- const iterator = document.evaluate(expression, element, null, XPathResult.ORDERED_NODE_ITERATOR_TYPE);
758
- const array = [];
759
- let item;
760
- while ((item = iterator.iterateNext()))
761
- array.push(item);
762
- return array;
763
- }, expression);
764
- const properties = await arrayHandle.getProperties();
765
- await arrayHandle.dispose();
766
- const result = [];
767
- for (const property of properties.values()) {
768
- const elementHandle = property.asElement();
769
- if (elementHandle)
770
- result.push(elementHandle);
771
- }
772
- return result;
773
- }
774
- /**
775
- * Resolves to true if the element is visible in the current viewport.
776
- */
777
- async isIntersectingViewport(options) {
778
- const { threshold = 0 } = options || {};
779
- return await this.evaluate(async (element, threshold) => {
780
- const visibleRatio = await new Promise((resolve) => {
781
- const observer = new IntersectionObserver((entries) => {
782
- resolve(entries[0].intersectionRatio);
783
- observer.disconnect();
784
- });
785
- observer.observe(element);
786
- });
787
- return threshold === 1 ? visibleRatio === 1 : visibleRatio > threshold;
788
- }, threshold);
789
- }
790
- }
791
- function computeQuadArea(quad) {
792
- /* Compute sum of all directed areas of adjacent triangles
793
- https://en.wikipedia.org/wiki/Polygon#Simple_polygons
794
- */
795
- let area = 0;
796
- for (let i = 0; i < quad.length; ++i) {
797
- const p1 = quad[i];
798
- const p2 = quad[(i + 1) % quad.length];
799
- area += (p1.x * p2.y - p2.x * p1.y) / 2;
800
- }
801
- return Math.abs(area);
802
- }
1
+ /**
2
+ * Copyright 2019 Google Inc. All rights reserved.
3
+ *
4
+ * Licensed under the Apache License, Version 2.0 (the "License");
5
+ * you may not use this file except in compliance with the License.
6
+ * You may obtain a copy of the License at
7
+ *
8
+ * http://www.apache.org/licenses/LICENSE-2.0
9
+ *
10
+ * Unless required by applicable law or agreed to in writing, software
11
+ * distributed under the License is distributed on an "AS IS" BASIS,
12
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ * See the License for the specific language governing permissions and
14
+ * limitations under the License.
15
+ */
16
+ import { assert } from './assert.js';
17
+ import { helper, debugError } from './helper.js';
18
+ import { getQueryHandlerAndSelector } from './QueryHandler.js';
19
+ import { isNode } from '../environment.js';
20
+ /**
21
+ * @internal
22
+ */
23
+ export function createJSHandle(context, remoteObject) {
24
+ const frame = context.frame();
25
+ if (remoteObject.subtype === 'node' && frame) {
26
+ const frameManager = frame._frameManager;
27
+ return new ElementHandle(context, context._client, remoteObject, frameManager.page(), frameManager);
28
+ }
29
+ return new JSHandle(context, context._client, remoteObject);
30
+ }
31
+ /**
32
+ * Represents an in-page JavaScript object. JSHandles can be created with the
33
+ * {@link Page.evaluateHandle | page.evaluateHandle} method.
34
+ *
35
+ * @example
36
+ * ```js
37
+ * const windowHandle = await page.evaluateHandle(() => window);
38
+ * ```
39
+ *
40
+ * JSHandle prevents the referenced JavaScript object from being garbage-collected
41
+ * unless the handle is {@link JSHandle.dispose | disposed}. JSHandles are auto-
42
+ * disposed when their origin frame gets navigated or the parent context gets destroyed.
43
+ *
44
+ * JSHandle instances can be used as arguments for {@link Page.$eval},
45
+ * {@link Page.evaluate}, and {@link Page.evaluateHandle}.
46
+ *
47
+ * @public
48
+ */
49
+ export class JSHandle {
50
+ /**
51
+ * @internal
52
+ */
53
+ constructor(context, client, remoteObject) {
54
+ /**
55
+ * @internal
56
+ */
57
+ this._disposed = false;
58
+ this._context = context;
59
+ this._client = client;
60
+ this._remoteObject = remoteObject;
61
+ }
62
+ /** Returns the execution context the handle belongs to.
63
+ */
64
+ executionContext() {
65
+ return this._context;
66
+ }
67
+ /**
68
+ * This method passes this handle as the first argument to `pageFunction`.
69
+ * If `pageFunction` returns a Promise, then `handle.evaluate` would wait
70
+ * for the promise to resolve and return its value.
71
+ *
72
+ * @example
73
+ * ```js
74
+ * const tweetHandle = await page.$('.tweet .retweets');
75
+ * expect(await tweetHandle.evaluate(node => node.innerText)).toBe('10');
76
+ * ```
77
+ */
78
+ async evaluate(pageFunction, ...args) {
79
+ return await this.executionContext().evaluate(pageFunction, this, ...args);
80
+ }
81
+ /**
82
+ * This method passes this handle as the first argument to `pageFunction`.
83
+ *
84
+ * @remarks
85
+ *
86
+ * The only difference between `jsHandle.evaluate` and
87
+ * `jsHandle.evaluateHandle` is that `jsHandle.evaluateHandle`
88
+ * returns an in-page object (JSHandle).
89
+ *
90
+ * If the function passed to `jsHandle.evaluateHandle` returns a Promise,
91
+ * then `evaluateHandle.evaluateHandle` waits for the promise to resolve and
92
+ * returns its value.
93
+ *
94
+ * See {@link Page.evaluateHandle} for more details.
95
+ */
96
+ async evaluateHandle(pageFunction, ...args) {
97
+ return await this.executionContext().evaluateHandle(pageFunction, this, ...args);
98
+ }
99
+ /** Fetches a single property from the referenced object.
100
+ */
101
+ async getProperty(propertyName) {
102
+ const objectHandle = await this.evaluateHandle((object, propertyName) => {
103
+ const result = { __proto__: null };
104
+ result[propertyName] = object[propertyName];
105
+ return result;
106
+ }, propertyName);
107
+ const properties = await objectHandle.getProperties();
108
+ const result = properties.get(propertyName);
109
+ assert(result instanceof JSHandle);
110
+ await objectHandle.dispose();
111
+ return result;
112
+ }
113
+ /**
114
+ * The method returns a map with property names as keys and JSHandle
115
+ * instances for the property values.
116
+ *
117
+ * @example
118
+ * ```js
119
+ * const listHandle = await page.evaluateHandle(() => document.body.children);
120
+ * const properties = await listHandle.getProperties();
121
+ * const children = [];
122
+ * for (const property of properties.values()) {
123
+ * const element = property.asElement();
124
+ * if (element)
125
+ * children.push(element);
126
+ * }
127
+ * children; // holds elementHandles to all children of document.body
128
+ * ```
129
+ */
130
+ async getProperties() {
131
+ const response = await this._client.send('Runtime.getProperties', {
132
+ objectId: this._remoteObject.objectId,
133
+ ownProperties: true,
134
+ });
135
+ const result = new Map();
136
+ for (const property of response.result) {
137
+ if (!property.enumerable)
138
+ continue;
139
+ result.set(property.name, createJSHandle(this._context, property.value));
140
+ }
141
+ return result;
142
+ }
143
+ /**
144
+ * @returns Returns a JSON representation of the object.If the object has a
145
+ * `toJSON` function, it will not be called.
146
+ * @remarks
147
+ *
148
+ * The JSON is generated by running {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify | JSON.stringify}
149
+ * on the object in page and consequent {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/parse | JSON.parse} in puppeteer.
150
+ * **NOTE** The method throws if the referenced object is not stringifiable.
151
+ */
152
+ async jsonValue() {
153
+ if (this._remoteObject.objectId) {
154
+ const response = await this._client.send('Runtime.callFunctionOn', {
155
+ functionDeclaration: 'function() { return this; }',
156
+ objectId: this._remoteObject.objectId,
157
+ returnByValue: true,
158
+ awaitPromise: true,
159
+ });
160
+ return helper.valueFromRemoteObject(response.result);
161
+ }
162
+ return helper.valueFromRemoteObject(this._remoteObject);
163
+ }
164
+ /**
165
+ * @returns Either `null` or the object handle itself, if the object
166
+ * handle is an instance of {@link ElementHandle}.
167
+ */
168
+ asElement() {
169
+ /* This always returns null, but subclasses can override this and return an
170
+ ElementHandle.
171
+ */
172
+ return null;
173
+ }
174
+ /**
175
+ * Stops referencing the element handle, and resolves when the object handle is
176
+ * successfully disposed of.
177
+ */
178
+ async dispose() {
179
+ if (this._disposed)
180
+ return;
181
+ this._disposed = true;
182
+ await helper.releaseObject(this._client, this._remoteObject);
183
+ }
184
+ /**
185
+ * Returns a string representation of the JSHandle.
186
+ *
187
+ * @remarks Useful during debugging.
188
+ */
189
+ toString() {
190
+ if (this._remoteObject.objectId) {
191
+ const type = this._remoteObject.subtype || this._remoteObject.type;
192
+ return 'JSHandle@' + type;
193
+ }
194
+ return 'JSHandle:' + helper.valueFromRemoteObject(this._remoteObject);
195
+ }
196
+ }
197
+ /**
198
+ * ElementHandle represents an in-page DOM element.
199
+ *
200
+ * @remarks
201
+ *
202
+ * ElementHandles can be created with the {@link Page.$} method.
203
+ *
204
+ * ```js
205
+ * const puppeteer = require('puppeteer');
206
+ *
207
+ * (async () => {
208
+ * const browser = await puppeteer.launch();
209
+ * const page = await browser.newPage();
210
+ * await page.goto('https://example.com');
211
+ * const hrefElement = await page.$('a');
212
+ * await hrefElement.click();
213
+ * // ...
214
+ * })();
215
+ * ```
216
+ *
217
+ * ElementHandle prevents the DOM element from being garbage-collected unless the
218
+ * handle is {@link JSHandle.dispose | disposed}. ElementHandles are auto-disposed
219
+ * when their origin frame gets navigated.
220
+ *
221
+ * ElementHandle instances can be used as arguments in {@link Page.$eval} and
222
+ * {@link Page.evaluate} methods.
223
+ *
224
+ * If you're using TypeScript, ElementHandle takes a generic argument that
225
+ * denotes the type of element the handle is holding within. For example, if you
226
+ * have a handle to a `<select>` element, you can type it as
227
+ * `ElementHandle<HTMLSelectElement>` and you get some nicer type checks.
228
+ *
229
+ * @public
230
+ */
231
+ export class ElementHandle extends JSHandle {
232
+ /**
233
+ * @internal
234
+ */
235
+ constructor(context, client, remoteObject, page, frameManager) {
236
+ super(context, client, remoteObject);
237
+ this._client = client;
238
+ this._remoteObject = remoteObject;
239
+ this._page = page;
240
+ this._frameManager = frameManager;
241
+ }
242
+ asElement() {
243
+ return this;
244
+ }
245
+ /**
246
+ * Resolves to the content frame for element handles referencing
247
+ * iframe nodes, or null otherwise
248
+ */
249
+ async contentFrame() {
250
+ const nodeInfo = await this._client.send('DOM.describeNode', {
251
+ objectId: this._remoteObject.objectId,
252
+ });
253
+ if (typeof nodeInfo.node.frameId !== 'string')
254
+ return null;
255
+ return this._frameManager.frame(nodeInfo.node.frameId);
256
+ }
257
+ async _scrollIntoViewIfNeeded() {
258
+ const error = await this.evaluate(async (element, pageJavascriptEnabled) => {
259
+ if (!element.isConnected)
260
+ return 'Node is detached from document';
261
+ if (element.nodeType !== Node.ELEMENT_NODE)
262
+ return 'Node is not of type HTMLElement';
263
+ // force-scroll if page's javascript is disabled.
264
+ if (!pageJavascriptEnabled) {
265
+ element.scrollIntoView({
266
+ block: 'center',
267
+ inline: 'center',
268
+ // @ts-expect-error Chrome still supports behavior: instant but
269
+ // it's not in the spec so TS shouts We don't want to make this
270
+ // breaking change in Puppeteer yet so we'll ignore the line.
271
+ behavior: 'instant',
272
+ });
273
+ return false;
274
+ }
275
+ const visibleRatio = await new Promise((resolve) => {
276
+ const observer = new IntersectionObserver((entries) => {
277
+ resolve(entries[0].intersectionRatio);
278
+ observer.disconnect();
279
+ });
280
+ observer.observe(element);
281
+ });
282
+ if (visibleRatio !== 1.0) {
283
+ element.scrollIntoView({
284
+ block: 'center',
285
+ inline: 'center',
286
+ // @ts-expect-error Chrome still supports behavior: instant but
287
+ // it's not in the spec so TS shouts We don't want to make this
288
+ // breaking change in Puppeteer yet so we'll ignore the line.
289
+ behavior: 'instant',
290
+ });
291
+ }
292
+ return false;
293
+ }, this._page.isJavaScriptEnabled());
294
+ if (error)
295
+ throw new Error(error);
296
+ }
297
+ /**
298
+ * Returns the middle point within an element unless a specific offset is provided.
299
+ */
300
+ async clickablePoint(offset) {
301
+ const [result, layoutMetrics] = await Promise.all([
302
+ this._client
303
+ .send('DOM.getContentQuads', {
304
+ objectId: this._remoteObject.objectId,
305
+ })
306
+ .catch(debugError),
307
+ this._client.send('Page.getLayoutMetrics'),
308
+ ]);
309
+ if (!result || !result.quads.length)
310
+ throw new Error('Node is either not clickable or not an HTMLElement');
311
+ // Filter out quads that have too small area to click into.
312
+ // Fallback to `layoutViewport` in case of using Firefox.
313
+ const { clientWidth, clientHeight } = layoutMetrics.cssLayoutViewport || layoutMetrics.layoutViewport;
314
+ const quads = result.quads
315
+ .map((quad) => this._fromProtocolQuad(quad))
316
+ .map((quad) => this._intersectQuadWithViewport(quad, clientWidth, clientHeight))
317
+ .filter((quad) => computeQuadArea(quad) > 1);
318
+ if (!quads.length)
319
+ throw new Error('Node is either not clickable or not an HTMLElement');
320
+ const quad = quads[0];
321
+ if (offset) {
322
+ // Return the point of the first quad identified by offset.
323
+ let minX = Number.MAX_SAFE_INTEGER;
324
+ let minY = Number.MAX_SAFE_INTEGER;
325
+ for (const point of quad) {
326
+ if (point.x < minX) {
327
+ minX = point.x;
328
+ }
329
+ if (point.y < minY) {
330
+ minY = point.y;
331
+ }
332
+ }
333
+ if (minX !== Number.MAX_SAFE_INTEGER &&
334
+ minY !== Number.MAX_SAFE_INTEGER) {
335
+ return {
336
+ x: minX + offset.x,
337
+ y: minY + offset.y,
338
+ };
339
+ }
340
+ }
341
+ // Return the middle point of the first quad.
342
+ let x = 0;
343
+ let y = 0;
344
+ for (const point of quad) {
345
+ x += point.x;
346
+ y += point.y;
347
+ }
348
+ return {
349
+ x: x / 4,
350
+ y: y / 4,
351
+ };
352
+ }
353
+ _getBoxModel() {
354
+ const params = {
355
+ objectId: this._remoteObject.objectId,
356
+ };
357
+ return this._client
358
+ .send('DOM.getBoxModel', params)
359
+ .catch((error) => debugError(error));
360
+ }
361
+ _fromProtocolQuad(quad) {
362
+ return [
363
+ { x: quad[0], y: quad[1] },
364
+ { x: quad[2], y: quad[3] },
365
+ { x: quad[4], y: quad[5] },
366
+ { x: quad[6], y: quad[7] },
367
+ ];
368
+ }
369
+ _intersectQuadWithViewport(quad, width, height) {
370
+ return quad.map((point) => ({
371
+ x: Math.min(Math.max(point.x, 0), width),
372
+ y: Math.min(Math.max(point.y, 0), height),
373
+ }));
374
+ }
375
+ /**
376
+ * This method scrolls element into view if needed, and then
377
+ * uses {@link Page.mouse} to hover over the center of the element.
378
+ * If the element is detached from DOM, the method throws an error.
379
+ */
380
+ async hover() {
381
+ await this._scrollIntoViewIfNeeded();
382
+ const { x, y } = await this.clickablePoint();
383
+ await this._page.mouse.move(x, y);
384
+ }
385
+ /**
386
+ * This method scrolls element into view if needed, and then
387
+ * uses {@link Page.mouse} to click in the center of the element.
388
+ * If the element is detached from DOM, the method throws an error.
389
+ */
390
+ async click(options = {}) {
391
+ await this._scrollIntoViewIfNeeded();
392
+ const { x, y } = await this.clickablePoint(options.offset);
393
+ await this._page.mouse.click(x, y, options);
394
+ }
395
+ /**
396
+ * This method creates and captures a dragevent from the element.
397
+ */
398
+ async drag(target) {
399
+ assert(this._page.isDragInterceptionEnabled(), 'Drag Interception is not enabled!');
400
+ await this._scrollIntoViewIfNeeded();
401
+ const start = await this.clickablePoint();
402
+ return await this._page.mouse.drag(start, target);
403
+ }
404
+ /**
405
+ * This method creates a `dragenter` event on the element.
406
+ */
407
+ async dragEnter(data = { items: [], dragOperationsMask: 1 }) {
408
+ await this._scrollIntoViewIfNeeded();
409
+ const target = await this.clickablePoint();
410
+ await this._page.mouse.dragEnter(target, data);
411
+ }
412
+ /**
413
+ * This method creates a `dragover` event on the element.
414
+ */
415
+ async dragOver(data = { items: [], dragOperationsMask: 1 }) {
416
+ await this._scrollIntoViewIfNeeded();
417
+ const target = await this.clickablePoint();
418
+ await this._page.mouse.dragOver(target, data);
419
+ }
420
+ /**
421
+ * This method triggers a drop on the element.
422
+ */
423
+ async drop(data = { items: [], dragOperationsMask: 1 }) {
424
+ await this._scrollIntoViewIfNeeded();
425
+ const destination = await this.clickablePoint();
426
+ await this._page.mouse.drop(destination, data);
427
+ }
428
+ /**
429
+ * This method triggers a dragenter, dragover, and drop on the element.
430
+ */
431
+ async dragAndDrop(target, options) {
432
+ await this._scrollIntoViewIfNeeded();
433
+ const startPoint = await this.clickablePoint();
434
+ const targetPoint = await target.clickablePoint();
435
+ await this._page.mouse.dragAndDrop(startPoint, targetPoint, options);
436
+ }
437
+ /**
438
+ * Triggers a `change` and `input` event once all the provided options have been
439
+ * selected. If there's no `<select>` element matching `selector`, the method
440
+ * throws an error.
441
+ *
442
+ * @example
443
+ * ```js
444
+ * handle.select('blue'); // single selection
445
+ * handle.select('red', 'green', 'blue'); // multiple selections
446
+ * ```
447
+ * @param values - Values of options to select. If the `<select>` has the
448
+ * `multiple` attribute, all values are considered, otherwise only the first
449
+ * one is taken into account.
450
+ */
451
+ async select(...values) {
452
+ for (const value of values)
453
+ assert(helper.isString(value), 'Values must be strings. Found value "' +
454
+ value +
455
+ '" of type "' +
456
+ typeof value +
457
+ '"');
458
+ return this.evaluate((element, values) => {
459
+ if (!(element instanceof HTMLSelectElement))
460
+ throw new Error('Element is not a <select> element.');
461
+ const options = Array.from(element.options);
462
+ element.value = undefined;
463
+ for (const option of options) {
464
+ option.selected = values.includes(option.value);
465
+ if (option.selected && !element.multiple)
466
+ break;
467
+ }
468
+ element.dispatchEvent(new Event('input', { bubbles: true }));
469
+ element.dispatchEvent(new Event('change', { bubbles: true }));
470
+ return options
471
+ .filter((option) => option.selected)
472
+ .map((option) => option.value);
473
+ }, values);
474
+ }
475
+ /**
476
+ * This method expects `elementHandle` to point to an
477
+ * {@link https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input | input element}.
478
+ * @param filePaths - Sets the value of the file input to these paths.
479
+ * If some of the `filePaths` are relative paths, then they are resolved
480
+ * relative to the {@link https://nodejs.org/api/process.html#process_process_cwd | current working directory}
481
+ */
482
+ async uploadFile(...filePaths) {
483
+ const isMultiple = await this.evaluate((element) => {
484
+ if (!(element instanceof HTMLInputElement)) {
485
+ throw new Error('uploadFile can only be called on an input element.');
486
+ }
487
+ return element.multiple;
488
+ });
489
+ assert(filePaths.length <= 1 || isMultiple, 'Multiple file uploads only work with <input type=file multiple>');
490
+ if (!isNode) {
491
+ throw new Error(`JSHandle#uploadFile can only be used in Node environments.`);
492
+ }
493
+ /*
494
+ This import is only needed for `uploadFile`, so keep it scoped here to
495
+ avoid paying the cost unnecessarily.
496
+ */
497
+ const path = await import('path');
498
+ const fs = await helper.importFSModule();
499
+ // Locate all files and confirm that they exist.
500
+ const files = await Promise.all(filePaths.map(async (filePath) => {
501
+ const resolvedPath = path.resolve(filePath);
502
+ try {
503
+ await fs.promises.access(resolvedPath, fs.constants.R_OK);
504
+ }
505
+ catch (error) {
506
+ if (error.code === 'ENOENT')
507
+ throw new Error(`${filePath} does not exist or is not readable`);
508
+ }
509
+ return resolvedPath;
510
+ }));
511
+ const { objectId } = this._remoteObject;
512
+ const { node } = await this._client.send('DOM.describeNode', { objectId });
513
+ const { backendNodeId } = node;
514
+ /* The zero-length array is a special case, it seems that
515
+ DOM.setFileInputFiles does not actually update the files in that case,
516
+ so the solution is to eval the element value to a new FileList directly.
517
+ */
518
+ if (files.length === 0) {
519
+ await this.evaluate((element) => {
520
+ element.files = new DataTransfer().files;
521
+ // Dispatch events for this case because it should behave akin to a user action.
522
+ element.dispatchEvent(new Event('input', { bubbles: true }));
523
+ element.dispatchEvent(new Event('change', { bubbles: true }));
524
+ });
525
+ }
526
+ else {
527
+ await this._client.send('DOM.setFileInputFiles', {
528
+ objectId,
529
+ files,
530
+ backendNodeId,
531
+ });
532
+ }
533
+ }
534
+ /**
535
+ * This method scrolls element into view if needed, and then uses
536
+ * {@link Touchscreen.tap} to tap in the center of the element.
537
+ * If the element is detached from DOM, the method throws an error.
538
+ */
539
+ async tap() {
540
+ await this._scrollIntoViewIfNeeded();
541
+ const { x, y } = await this.clickablePoint();
542
+ await this._page.touchscreen.tap(x, y);
543
+ }
544
+ /**
545
+ * Calls {@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement/focus | focus} on the element.
546
+ */
547
+ async focus() {
548
+ await this.evaluate((element) => element.focus());
549
+ }
550
+ /**
551
+ * Focuses the element, and then sends a `keydown`, `keypress`/`input`, and
552
+ * `keyup` event for each character in the text.
553
+ *
554
+ * To press a special key, like `Control` or `ArrowDown`,
555
+ * use {@link ElementHandle.press}.
556
+ *
557
+ * @example
558
+ * ```js
559
+ * await elementHandle.type('Hello'); // Types instantly
560
+ * await elementHandle.type('World', {delay: 100}); // Types slower, like a user
561
+ * ```
562
+ *
563
+ * @example
564
+ * An example of typing into a text field and then submitting the form:
565
+ *
566
+ * ```js
567
+ * const elementHandle = await page.$('input');
568
+ * await elementHandle.type('some text');
569
+ * await elementHandle.press('Enter');
570
+ * ```
571
+ */
572
+ async type(text, options) {
573
+ await this.focus();
574
+ await this._page.keyboard.type(text, options);
575
+ }
576
+ /**
577
+ * Focuses the element, and then uses {@link Keyboard.down} and {@link Keyboard.up}.
578
+ *
579
+ * @remarks
580
+ * If `key` is a single character and no modifier keys besides `Shift`
581
+ * are being held down, a `keypress`/`input` event will also be generated.
582
+ * The `text` option can be specified to force an input event to be generated.
583
+ *
584
+ * **NOTE** Modifier keys DO affect `elementHandle.press`. Holding down `Shift`
585
+ * will type the text in upper case.
586
+ *
587
+ * @param key - Name of key to press, such as `ArrowLeft`.
588
+ * See {@link KeyInput} for a list of all key names.
589
+ */
590
+ async press(key, options) {
591
+ await this.focus();
592
+ await this._page.keyboard.press(key, options);
593
+ }
594
+ /**
595
+ * This method returns the bounding box of the element (relative to the main frame),
596
+ * or `null` if the element is not visible.
597
+ */
598
+ async boundingBox() {
599
+ const result = await this._getBoxModel();
600
+ if (!result)
601
+ return null;
602
+ const quad = result.model.border;
603
+ const x = Math.min(quad[0], quad[2], quad[4], quad[6]);
604
+ const y = Math.min(quad[1], quad[3], quad[5], quad[7]);
605
+ const width = Math.max(quad[0], quad[2], quad[4], quad[6]) - x;
606
+ const height = Math.max(quad[1], quad[3], quad[5], quad[7]) - y;
607
+ return { x, y, width, height };
608
+ }
609
+ /**
610
+ * This method returns boxes of the element, or `null` if the element is not visible.
611
+ *
612
+ * @remarks
613
+ *
614
+ * Boxes are represented as an array of points;
615
+ * Each Point is an object `{x, y}`. Box points are sorted clock-wise.
616
+ */
617
+ async boxModel() {
618
+ const result = await this._getBoxModel();
619
+ if (!result)
620
+ return null;
621
+ const { content, padding, border, margin, width, height } = result.model;
622
+ return {
623
+ content: this._fromProtocolQuad(content),
624
+ padding: this._fromProtocolQuad(padding),
625
+ border: this._fromProtocolQuad(border),
626
+ margin: this._fromProtocolQuad(margin),
627
+ width,
628
+ height,
629
+ };
630
+ }
631
+ /**
632
+ * This method scrolls element into view if needed, and then uses
633
+ * {@link Page.screenshot} to take a screenshot of the element.
634
+ * If the element is detached from DOM, the method throws an error.
635
+ */
636
+ async screenshot(options = {}) {
637
+ let needsViewportReset = false;
638
+ let boundingBox = await this.boundingBox();
639
+ assert(boundingBox, 'Node is either not visible or not an HTMLElement');
640
+ const viewport = this._page.viewport();
641
+ if (viewport &&
642
+ (boundingBox.width > viewport.width ||
643
+ boundingBox.height > viewport.height)) {
644
+ const newViewport = {
645
+ width: Math.max(viewport.width, Math.ceil(boundingBox.width)),
646
+ height: Math.max(viewport.height, Math.ceil(boundingBox.height)),
647
+ };
648
+ await this._page.setViewport(Object.assign({}, viewport, newViewport));
649
+ needsViewportReset = true;
650
+ }
651
+ await this._scrollIntoViewIfNeeded();
652
+ boundingBox = await this.boundingBox();
653
+ assert(boundingBox, 'Node is either not visible or not an HTMLElement');
654
+ assert(boundingBox.width !== 0, 'Node has 0 width.');
655
+ assert(boundingBox.height !== 0, 'Node has 0 height.');
656
+ const layoutMetrics = await this._client.send('Page.getLayoutMetrics');
657
+ // Fallback to `layoutViewport` in case of using Firefox.
658
+ const { pageX, pageY } = layoutMetrics.cssLayoutViewport || layoutMetrics.layoutViewport;
659
+ const clip = Object.assign({}, boundingBox);
660
+ clip.x += pageX;
661
+ clip.y += pageY;
662
+ const imageData = await this._page.screenshot(Object.assign({}, {
663
+ clip,
664
+ }, options));
665
+ if (needsViewportReset)
666
+ await this._page.setViewport(viewport);
667
+ return imageData;
668
+ }
669
+ /**
670
+ * Runs `element.querySelector` within the page. If no element matches the selector,
671
+ * the return value resolves to `null`.
672
+ */
673
+ async $(selector) {
674
+ const { updatedSelector, queryHandler } = getQueryHandlerAndSelector(selector);
675
+ return queryHandler.queryOne(this, updatedSelector);
676
+ }
677
+ /**
678
+ * Runs `element.querySelectorAll` within the page. If no elements match the selector,
679
+ * the return value resolves to `[]`.
680
+ */
681
+ async $$(selector) {
682
+ const { updatedSelector, queryHandler } = getQueryHandlerAndSelector(selector);
683
+ return queryHandler.queryAll(this, updatedSelector);
684
+ }
685
+ /**
686
+ * This method runs `document.querySelector` within the element and passes it as
687
+ * the first argument to `pageFunction`. If there's no element matching `selector`,
688
+ * the method throws an error.
689
+ *
690
+ * If `pageFunction` returns a Promise, then `frame.$eval` would wait for the promise
691
+ * to resolve and return its value.
692
+ *
693
+ * @example
694
+ * ```js
695
+ * const tweetHandle = await page.$('.tweet');
696
+ * expect(await tweetHandle.$eval('.like', node => node.innerText)).toBe('100');
697
+ * expect(await tweetHandle.$eval('.retweets', node => node.innerText)).toBe('10');
698
+ * ```
699
+ */
700
+ async $eval(selector, pageFunction, ...args) {
701
+ const elementHandle = await this.$(selector);
702
+ if (!elementHandle)
703
+ throw new Error(`Error: failed to find element matching selector "${selector}"`);
704
+ const result = await elementHandle.evaluate(pageFunction, ...args);
705
+ await elementHandle.dispose();
706
+ /**
707
+ * This `as` is a little unfortunate but helps TS understand the behavior of
708
+ * `elementHandle.evaluate`. If evaluate returns an element it will return an
709
+ * ElementHandle instance, rather than the plain object. All the
710
+ * WrapElementHandle type does is wrap ReturnType into
711
+ * ElementHandle<ReturnType> if it is an ElementHandle, or leave it alone as
712
+ * ReturnType if it isn't.
713
+ */
714
+ return result;
715
+ }
716
+ /**
717
+ * This method runs `document.querySelectorAll` within the element and passes it as
718
+ * the first argument to `pageFunction`. If there's no element matching `selector`,
719
+ * the method throws an error.
720
+ *
721
+ * If `pageFunction` returns a Promise, then `frame.$$eval` would wait for the
722
+ * promise to resolve and return its value.
723
+ *
724
+ * @example
725
+ * ```html
726
+ * <div class="feed">
727
+ * <div class="tweet">Hello!</div>
728
+ * <div class="tweet">Hi!</div>
729
+ * </div>
730
+ * ```
731
+ *
732
+ * @example
733
+ * ```js
734
+ * const feedHandle = await page.$('.feed');
735
+ * expect(await feedHandle.$$eval('.tweet', nodes => nodes.map(n => n.innerText)))
736
+ * .toEqual(['Hello!', 'Hi!']);
737
+ * ```
738
+ */
739
+ async $$eval(selector, pageFunction, ...args) {
740
+ const { updatedSelector, queryHandler } = getQueryHandlerAndSelector(selector);
741
+ const arrayHandle = await queryHandler.queryAllArray(this, updatedSelector);
742
+ const result = await arrayHandle.evaluate(pageFunction, ...args);
743
+ await arrayHandle.dispose();
744
+ /* This `as` exists for the same reason as the `as` in $eval above.
745
+ * See the comment there for a full explanation.
746
+ */
747
+ return result;
748
+ }
749
+ /**
750
+ * The method evaluates the XPath expression relative to the elementHandle.
751
+ * If there are no such elements, the method will resolve to an empty array.
752
+ * @param expression - Expression to {@link https://developer.mozilla.org/en-US/docs/Web/API/Document/evaluate | evaluate}
753
+ */
754
+ async $x(expression) {
755
+ const arrayHandle = await this.evaluateHandle((element, expression) => {
756
+ const document = element.ownerDocument || element;
757
+ const iterator = document.evaluate(expression, element, null, XPathResult.ORDERED_NODE_ITERATOR_TYPE);
758
+ const array = [];
759
+ let item;
760
+ while ((item = iterator.iterateNext()))
761
+ array.push(item);
762
+ return array;
763
+ }, expression);
764
+ const properties = await arrayHandle.getProperties();
765
+ await arrayHandle.dispose();
766
+ const result = [];
767
+ for (const property of properties.values()) {
768
+ const elementHandle = property.asElement();
769
+ if (elementHandle)
770
+ result.push(elementHandle);
771
+ }
772
+ return result;
773
+ }
774
+ /**
775
+ * Resolves to true if the element is visible in the current viewport.
776
+ */
777
+ async isIntersectingViewport(options) {
778
+ const { threshold = 0 } = options || {};
779
+ return await this.evaluate(async (element, threshold) => {
780
+ const visibleRatio = await new Promise((resolve) => {
781
+ const observer = new IntersectionObserver((entries) => {
782
+ resolve(entries[0].intersectionRatio);
783
+ observer.disconnect();
784
+ });
785
+ observer.observe(element);
786
+ });
787
+ return threshold === 1 ? visibleRatio === 1 : visibleRatio > threshold;
788
+ }, threshold);
789
+ }
790
+ }
791
+ function computeQuadArea(quad) {
792
+ /* Compute sum of all directed areas of adjacent triangles
793
+ https://en.wikipedia.org/wiki/Polygon#Simple_polygons
794
+ */
795
+ let area = 0;
796
+ for (let i = 0; i < quad.length; ++i) {
797
+ const p1 = quad[i];
798
+ const p2 = quad[(i + 1) % quad.length];
799
+ area += (p1.x * p2.y - p2.x * p1.y) / 2;
800
+ }
801
+ return Math.abs(area);
802
+ }
803
803
  //# sourceMappingURL=JSHandle.js.map