@stablyai/internal-playwright-core 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +202 -0
- package/NOTICE +5 -0
- package/README.md +3 -0
- package/ThirdPartyNotices.txt +1134 -0
- package/bin/install_media_pack.ps1 +5 -0
- package/bin/install_webkit_wsl.ps1 +35 -0
- package/bin/reinstall_chrome_beta_linux.sh +42 -0
- package/bin/reinstall_chrome_beta_mac.sh +13 -0
- package/bin/reinstall_chrome_beta_win.ps1 +24 -0
- package/bin/reinstall_chrome_stable_linux.sh +42 -0
- package/bin/reinstall_chrome_stable_mac.sh +12 -0
- package/bin/reinstall_chrome_stable_win.ps1 +24 -0
- package/bin/reinstall_msedge_beta_linux.sh +48 -0
- package/bin/reinstall_msedge_beta_mac.sh +11 -0
- package/bin/reinstall_msedge_beta_win.ps1 +23 -0
- package/bin/reinstall_msedge_dev_linux.sh +48 -0
- package/bin/reinstall_msedge_dev_mac.sh +11 -0
- package/bin/reinstall_msedge_dev_win.ps1 +23 -0
- package/bin/reinstall_msedge_stable_linux.sh +48 -0
- package/bin/reinstall_msedge_stable_mac.sh +11 -0
- package/bin/reinstall_msedge_stable_win.ps1 +24 -0
- package/browsers.json +80 -0
- package/cli.js +18 -0
- package/index.d.ts +17 -0
- package/index.js +32 -0
- package/index.mjs +28 -0
- package/lib/androidServerImpl.js +65 -0
- package/lib/browserServerImpl.js +120 -0
- package/lib/cli/cli.js +58 -0
- package/lib/cli/driver.js +97 -0
- package/lib/cli/program.js +634 -0
- package/lib/cli/programWithTestStub.js +74 -0
- package/lib/client/accessibility.js +49 -0
- package/lib/client/android.js +361 -0
- package/lib/client/api.js +137 -0
- package/lib/client/artifact.js +79 -0
- package/lib/client/browser.js +163 -0
- package/lib/client/browserContext.js +529 -0
- package/lib/client/browserType.js +184 -0
- package/lib/client/cdpSession.js +51 -0
- package/lib/client/channelOwner.js +194 -0
- package/lib/client/clientHelper.js +64 -0
- package/lib/client/clientInstrumentation.js +55 -0
- package/lib/client/clientStackTrace.js +69 -0
- package/lib/client/clock.js +68 -0
- package/lib/client/connection.js +314 -0
- package/lib/client/consoleMessage.js +54 -0
- package/lib/client/coverage.js +44 -0
- package/lib/client/dialog.js +56 -0
- package/lib/client/download.js +62 -0
- package/lib/client/electron.js +138 -0
- package/lib/client/elementHandle.js +281 -0
- package/lib/client/errors.js +77 -0
- package/lib/client/eventEmitter.js +314 -0
- package/lib/client/events.js +99 -0
- package/lib/client/fetch.js +369 -0
- package/lib/client/fileChooser.js +46 -0
- package/lib/client/fileUtils.js +34 -0
- package/lib/client/frame.js +408 -0
- package/lib/client/harRouter.js +87 -0
- package/lib/client/input.js +84 -0
- package/lib/client/jsHandle.js +109 -0
- package/lib/client/jsonPipe.js +39 -0
- package/lib/client/localUtils.js +60 -0
- package/lib/client/locator.js +368 -0
- package/lib/client/network.js +747 -0
- package/lib/client/page.js +721 -0
- package/lib/client/platform.js +74 -0
- package/lib/client/playwright.js +71 -0
- package/lib/client/selectors.js +55 -0
- package/lib/client/stream.js +39 -0
- package/lib/client/timeoutSettings.js +79 -0
- package/lib/client/tracing.js +117 -0
- package/lib/client/types.js +28 -0
- package/lib/client/video.js +59 -0
- package/lib/client/waiter.js +142 -0
- package/lib/client/webError.js +39 -0
- package/lib/client/webSocket.js +93 -0
- package/lib/client/worker.js +63 -0
- package/lib/client/writableStream.js +39 -0
- package/lib/common/debugLogger.js +90 -0
- package/lib/common/socksProxy.js +569 -0
- package/lib/common/timeoutSettings.js +73 -0
- package/lib/common/types.js +5 -0
- package/lib/generated/bindingsControllerSource.js +28 -0
- package/lib/generated/clockSource.js +28 -0
- package/lib/generated/consoleApiSource.js +28 -0
- package/lib/generated/injectedScriptSource.js +28 -0
- package/lib/generated/pollingRecorderSource.js +28 -0
- package/lib/generated/recorderSource.js +28 -0
- package/lib/generated/storageScriptSource.js +28 -0
- package/lib/generated/utilityScriptSource.js +28 -0
- package/lib/generated/webSocketMockSource.js +336 -0
- package/lib/image_tools/colorUtils.js +98 -0
- package/lib/image_tools/compare.js +108 -0
- package/lib/image_tools/imageChannel.js +70 -0
- package/lib/image_tools/stats.js +102 -0
- package/lib/inProcessFactory.js +60 -0
- package/lib/index.js +19 -0
- package/lib/inprocess.js +3 -0
- package/lib/outofprocess.js +76 -0
- package/lib/protocol/debug.js +27 -0
- package/lib/protocol/serializers.js +192 -0
- package/lib/protocol/transport.js +82 -0
- package/lib/protocol/validator.js +2919 -0
- package/lib/protocol/validatorPrimitives.js +193 -0
- package/lib/remote/playwrightConnection.js +129 -0
- package/lib/remote/playwrightServer.js +335 -0
- package/lib/server/accessibility.js +69 -0
- package/lib/server/android/android.js +465 -0
- package/lib/server/android/backendAdb.js +177 -0
- package/lib/server/artifact.js +127 -0
- package/lib/server/bidi/bidiBrowser.js +490 -0
- package/lib/server/bidi/bidiChromium.js +153 -0
- package/lib/server/bidi/bidiConnection.js +212 -0
- package/lib/server/bidi/bidiExecutionContext.js +221 -0
- package/lib/server/bidi/bidiFirefox.js +130 -0
- package/lib/server/bidi/bidiInput.js +146 -0
- package/lib/server/bidi/bidiNetworkManager.js +383 -0
- package/lib/server/bidi/bidiOverCdp.js +102 -0
- package/lib/server/bidi/bidiPage.js +552 -0
- package/lib/server/bidi/bidiPdf.js +106 -0
- package/lib/server/bidi/third_party/bidiCommands.d.js +22 -0
- package/lib/server/bidi/third_party/bidiDeserializer.js +98 -0
- package/lib/server/bidi/third_party/bidiKeyboard.js +256 -0
- package/lib/server/bidi/third_party/bidiProtocol.js +24 -0
- package/lib/server/bidi/third_party/bidiProtocolCore.js +179 -0
- package/lib/server/bidi/third_party/bidiProtocolPermissions.js +42 -0
- package/lib/server/bidi/third_party/bidiSerializer.js +148 -0
- package/lib/server/bidi/third_party/firefoxPrefs.js +259 -0
- package/lib/server/browser.js +149 -0
- package/lib/server/browserContext.js +695 -0
- package/lib/server/browserType.js +328 -0
- package/lib/server/callLog.js +82 -0
- package/lib/server/chromium/appIcon.png +0 -0
- package/lib/server/chromium/chromium.js +402 -0
- package/lib/server/chromium/chromiumSwitches.js +95 -0
- package/lib/server/chromium/crAccessibility.js +263 -0
- package/lib/server/chromium/crBrowser.js +501 -0
- package/lib/server/chromium/crConnection.js +202 -0
- package/lib/server/chromium/crCoverage.js +235 -0
- package/lib/server/chromium/crDevTools.js +113 -0
- package/lib/server/chromium/crDragDrop.js +131 -0
- package/lib/server/chromium/crExecutionContext.js +146 -0
- package/lib/server/chromium/crInput.js +187 -0
- package/lib/server/chromium/crNetworkManager.js +666 -0
- package/lib/server/chromium/crPage.js +1069 -0
- package/lib/server/chromium/crPdf.js +121 -0
- package/lib/server/chromium/crProtocolHelper.js +145 -0
- package/lib/server/chromium/crServiceWorker.js +123 -0
- package/lib/server/chromium/defaultFontFamilies.js +162 -0
- package/lib/server/chromium/protocol.d.js +16 -0
- package/lib/server/chromium/videoRecorder.js +113 -0
- package/lib/server/clock.js +149 -0
- package/lib/server/codegen/csharp.js +327 -0
- package/lib/server/codegen/java.js +274 -0
- package/lib/server/codegen/javascript.js +270 -0
- package/lib/server/codegen/jsonl.js +52 -0
- package/lib/server/codegen/language.js +132 -0
- package/lib/server/codegen/languages.js +68 -0
- package/lib/server/codegen/python.js +279 -0
- package/lib/server/codegen/types.js +16 -0
- package/lib/server/console.js +53 -0
- package/lib/server/cookieStore.js +206 -0
- package/lib/server/debugController.js +191 -0
- package/lib/server/debugger.js +119 -0
- package/lib/server/deviceDescriptors.js +39 -0
- package/lib/server/deviceDescriptorsSource.json +1779 -0
- package/lib/server/dialog.js +116 -0
- package/lib/server/dispatchers/androidDispatcher.js +325 -0
- package/lib/server/dispatchers/artifactDispatcher.js +118 -0
- package/lib/server/dispatchers/browserContextDispatcher.js +364 -0
- package/lib/server/dispatchers/browserDispatcher.js +118 -0
- package/lib/server/dispatchers/browserTypeDispatcher.js +64 -0
- package/lib/server/dispatchers/cdpSessionDispatcher.js +44 -0
- package/lib/server/dispatchers/debugControllerDispatcher.js +78 -0
- package/lib/server/dispatchers/dialogDispatcher.js +47 -0
- package/lib/server/dispatchers/dispatcher.js +371 -0
- package/lib/server/dispatchers/electronDispatcher.js +89 -0
- package/lib/server/dispatchers/elementHandlerDispatcher.js +181 -0
- package/lib/server/dispatchers/frameDispatcher.js +227 -0
- package/lib/server/dispatchers/jsHandleDispatcher.js +85 -0
- package/lib/server/dispatchers/jsonPipeDispatcher.js +58 -0
- package/lib/server/dispatchers/localUtilsDispatcher.js +149 -0
- package/lib/server/dispatchers/networkDispatchers.js +213 -0
- package/lib/server/dispatchers/pageDispatcher.js +401 -0
- package/lib/server/dispatchers/playwrightDispatcher.js +108 -0
- package/lib/server/dispatchers/selectorsDispatcher.js +36 -0
- package/lib/server/dispatchers/streamDispatcher.js +67 -0
- package/lib/server/dispatchers/tracingDispatcher.js +68 -0
- package/lib/server/dispatchers/webSocketRouteDispatcher.js +165 -0
- package/lib/server/dispatchers/writableStreamDispatcher.js +79 -0
- package/lib/server/dom.js +806 -0
- package/lib/server/download.js +70 -0
- package/lib/server/electron/electron.js +270 -0
- package/lib/server/electron/loader.js +29 -0
- package/lib/server/errors.js +69 -0
- package/lib/server/fetch.js +621 -0
- package/lib/server/fileChooser.js +43 -0
- package/lib/server/fileUploadUtils.js +84 -0
- package/lib/server/firefox/ffAccessibility.js +238 -0
- package/lib/server/firefox/ffBrowser.js +428 -0
- package/lib/server/firefox/ffConnection.js +147 -0
- package/lib/server/firefox/ffExecutionContext.js +150 -0
- package/lib/server/firefox/ffInput.js +159 -0
- package/lib/server/firefox/ffNetworkManager.js +256 -0
- package/lib/server/firefox/ffPage.js +503 -0
- package/lib/server/firefox/firefox.js +116 -0
- package/lib/server/firefox/protocol.d.js +16 -0
- package/lib/server/formData.js +147 -0
- package/lib/server/frameSelectors.js +156 -0
- package/lib/server/frames.js +1502 -0
- package/lib/server/har/harRecorder.js +147 -0
- package/lib/server/har/harTracer.js +607 -0
- package/lib/server/harBackend.js +157 -0
- package/lib/server/helper.js +96 -0
- package/lib/server/index.js +58 -0
- package/lib/server/input.js +273 -0
- package/lib/server/instrumentation.js +69 -0
- package/lib/server/isomorphic/utilityScriptSerializers.js +212 -0
- package/lib/server/javascript.js +291 -0
- package/lib/server/launchApp.js +128 -0
- package/lib/server/localUtils.js +218 -0
- package/lib/server/macEditingCommands.js +143 -0
- package/lib/server/network.js +629 -0
- package/lib/server/page.js +871 -0
- package/lib/server/pipeTransport.js +89 -0
- package/lib/server/playwright.js +69 -0
- package/lib/server/progress.js +112 -0
- package/lib/server/protocolError.js +52 -0
- package/lib/server/recorder/chat.js +161 -0
- package/lib/server/recorder/codeGenerator.js +153 -0
- package/lib/server/recorder/csharp.js +310 -0
- package/lib/server/recorder/java.js +248 -0
- package/lib/server/recorder/javascript.js +229 -0
- package/lib/server/recorder/jsonl.js +47 -0
- package/lib/server/recorder/language.js +44 -0
- package/lib/server/recorder/python.js +276 -0
- package/lib/server/recorder/recorderActions.js +5 -0
- package/lib/server/recorder/recorderApp.js +387 -0
- package/lib/server/recorder/recorderRunner.js +138 -0
- package/lib/server/recorder/recorderSignalProcessor.js +83 -0
- package/lib/server/recorder/recorderUtils.js +157 -0
- package/lib/server/recorder/throttledFile.js +57 -0
- package/lib/server/recorder/utils.js +45 -0
- package/lib/server/recorder.js +499 -0
- package/lib/server/registry/browserFetcher.js +175 -0
- package/lib/server/registry/dependencies.js +371 -0
- package/lib/server/registry/index.js +1331 -0
- package/lib/server/registry/nativeDeps.js +1280 -0
- package/lib/server/registry/oopDownloadBrowserMain.js +120 -0
- package/lib/server/screenshotter.js +333 -0
- package/lib/server/selectors.js +112 -0
- package/lib/server/socksClientCertificatesInterceptor.js +383 -0
- package/lib/server/socksInterceptor.js +95 -0
- package/lib/server/stably/ai-tools/http-request.js +70 -0
- package/lib/server/stably/ai-tools/stablyApiCaller.js +137 -0
- package/lib/server/stably/autohealing/elementHandleFromCoordinates.js +64 -0
- package/lib/server/stably/autohealing/healingService.js +228 -0
- package/lib/server/stably/autohealing/screenshotFrame.js +41 -0
- package/lib/server/stably/constants.js +31 -0
- package/lib/server/trace/recorder/snapshotter.js +147 -0
- package/lib/server/trace/recorder/snapshotterInjected.js +541 -0
- package/lib/server/trace/recorder/tracing.js +602 -0
- package/lib/server/trace/test/inMemorySnapshotter.js +87 -0
- package/lib/server/trace/viewer/traceViewer.js +240 -0
- package/lib/server/transport.js +181 -0
- package/lib/server/types.js +28 -0
- package/lib/server/usKeyboardLayout.js +145 -0
- package/lib/server/utils/ascii.js +44 -0
- package/lib/server/utils/comparators.js +161 -0
- package/lib/server/utils/crypto.js +216 -0
- package/lib/server/utils/debug.js +42 -0
- package/lib/server/utils/debugLogger.js +122 -0
- package/lib/server/utils/env.js +73 -0
- package/lib/server/utils/eventsHelper.js +39 -0
- package/lib/server/utils/expectUtils.js +38 -0
- package/lib/server/utils/fileUtils.js +191 -0
- package/lib/server/utils/happyEyeballs.js +207 -0
- package/lib/server/utils/hostPlatform.js +111 -0
- package/lib/server/utils/httpServer.js +218 -0
- package/lib/server/utils/image_tools/colorUtils.js +89 -0
- package/lib/server/utils/image_tools/compare.js +109 -0
- package/lib/server/utils/image_tools/imageChannel.js +78 -0
- package/lib/server/utils/image_tools/stats.js +102 -0
- package/lib/server/utils/linuxUtils.js +71 -0
- package/lib/server/utils/network.js +233 -0
- package/lib/server/utils/nodePlatform.js +148 -0
- package/lib/server/utils/pipeTransport.js +84 -0
- package/lib/server/utils/processLauncher.js +241 -0
- package/lib/server/utils/profiler.js +65 -0
- package/lib/server/utils/socksProxy.js +511 -0
- package/lib/server/utils/spawnAsync.js +41 -0
- package/lib/server/utils/task.js +51 -0
- package/lib/server/utils/userAgent.js +98 -0
- package/lib/server/utils/wsServer.js +121 -0
- package/lib/server/utils/zipFile.js +74 -0
- package/lib/server/utils/zones.js +57 -0
- package/lib/server/webkit/protocol.d.js +16 -0
- package/lib/server/webkit/webkit.js +119 -0
- package/lib/server/webkit/wkAccessibility.js +237 -0
- package/lib/server/webkit/wkBrowser.js +339 -0
- package/lib/server/webkit/wkConnection.js +149 -0
- package/lib/server/webkit/wkExecutionContext.js +154 -0
- package/lib/server/webkit/wkInput.js +181 -0
- package/lib/server/webkit/wkInterceptableRequest.js +169 -0
- package/lib/server/webkit/wkPage.js +1134 -0
- package/lib/server/webkit/wkProvisionalPage.js +83 -0
- package/lib/server/webkit/wkWorkers.js +104 -0
- package/lib/server/webkit/wsl/webkit-wsl-transport-client.js +74 -0
- package/lib/server/webkit/wsl/webkit-wsl-transport-server.js +113 -0
- package/lib/third_party/diff_match_patch.js +2222 -0
- package/lib/third_party/pixelmatch.js +255 -0
- package/lib/utils/ascii.js +31 -0
- package/lib/utils/comparators.js +171 -0
- package/lib/utils/crypto.js +33 -0
- package/lib/utils/debug.js +46 -0
- package/lib/utils/debugLogger.js +89 -0
- package/lib/utils/env.js +49 -0
- package/lib/utils/eventsHelper.js +38 -0
- package/lib/utils/fileUtils.js +205 -0
- package/lib/utils/glob.js +83 -0
- package/lib/utils/happy-eyeballs.js +160 -0
- package/lib/utils/headers.js +52 -0
- package/lib/utils/hostPlatform.js +128 -0
- package/lib/utils/httpServer.js +236 -0
- package/lib/utils/index.js +346 -0
- package/lib/utils/isomorphic/ariaSnapshot.js +392 -0
- package/lib/utils/isomorphic/assert.js +31 -0
- package/lib/utils/isomorphic/colors.js +72 -0
- package/lib/utils/isomorphic/cssParser.js +245 -0
- package/lib/utils/isomorphic/cssTokenizer.js +1051 -0
- package/lib/utils/isomorphic/headers.js +53 -0
- package/lib/utils/isomorphic/locatorGenerators.js +673 -0
- package/lib/utils/isomorphic/locatorParser.js +176 -0
- package/lib/utils/isomorphic/locatorUtils.js +81 -0
- package/lib/utils/isomorphic/manualPromise.js +114 -0
- package/lib/utils/isomorphic/mimeType.js +459 -0
- package/lib/utils/isomorphic/multimap.js +80 -0
- package/lib/utils/isomorphic/protocolFormatter.js +78 -0
- package/lib/utils/isomorphic/protocolMetainfo.js +321 -0
- package/lib/utils/isomorphic/rtti.js +43 -0
- package/lib/utils/isomorphic/selectorParser.js +386 -0
- package/lib/utils/isomorphic/semaphore.js +54 -0
- package/lib/utils/isomorphic/stackTrace.js +158 -0
- package/lib/utils/isomorphic/stringUtils.js +155 -0
- package/lib/utils/isomorphic/time.js +49 -0
- package/lib/utils/isomorphic/timeoutRunner.js +66 -0
- package/lib/utils/isomorphic/traceUtils.js +58 -0
- package/lib/utils/isomorphic/types.js +16 -0
- package/lib/utils/isomorphic/urlMatch.js +176 -0
- package/lib/utils/isomorphic/utilityScriptSerializers.js +251 -0
- package/lib/utils/linuxUtils.js +78 -0
- package/lib/utils/manualPromise.js +109 -0
- package/lib/utils/mimeType.js +29 -0
- package/lib/utils/multimap.js +75 -0
- package/lib/utils/network.js +188 -0
- package/lib/utils/processLauncher.js +248 -0
- package/lib/utils/profiler.js +53 -0
- package/lib/utils/rtti.js +44 -0
- package/lib/utils/semaphore.js +51 -0
- package/lib/utils/spawnAsync.js +45 -0
- package/lib/utils/stackTrace.js +121 -0
- package/lib/utils/task.js +58 -0
- package/lib/utils/time.js +37 -0
- package/lib/utils/timeoutRunner.js +66 -0
- package/lib/utils/traceUtils.js +44 -0
- package/lib/utils/userAgent.js +105 -0
- package/lib/utils/wsServer.js +127 -0
- package/lib/utils/zipFile.js +75 -0
- package/lib/utils/zones.js +62 -0
- package/lib/utils.js +107 -0
- package/lib/utilsBundle.js +109 -0
- package/lib/utilsBundleImpl/index.js +218 -0
- package/lib/utilsBundleImpl/xdg-open +1066 -0
- package/lib/vite/htmlReport/index.html +84 -0
- package/lib/vite/recorder/assets/codeMirrorModule-C3UTv-Ge.css +1 -0
- package/lib/vite/recorder/assets/codeMirrorModule-RJCXzfmE.js +24 -0
- package/lib/vite/recorder/assets/codicon-DCmgc-ay.ttf +0 -0
- package/lib/vite/recorder/assets/index-Ri0uHF7I.css +1 -0
- package/lib/vite/recorder/assets/index-Y-X2TGJv.js +193 -0
- package/lib/vite/recorder/index.html +29 -0
- package/lib/vite/recorder/playwright-logo.svg +9 -0
- package/lib/vite/traceViewer/assets/codeMirrorModule-Bhnc5o2x.js +24 -0
- package/lib/vite/traceViewer/assets/defaultSettingsView-ClwvkA2N.js +265 -0
- package/lib/vite/traceViewer/assets/xtermModule-CsJ4vdCR.js +9 -0
- package/lib/vite/traceViewer/codeMirrorModule.C3UTv-Ge.css +1 -0
- package/lib/vite/traceViewer/codicon.DCmgc-ay.ttf +0 -0
- package/lib/vite/traceViewer/defaultSettingsView.TQ8_7ybu.css +1 -0
- package/lib/vite/traceViewer/index.DFO9NNF5.js +2 -0
- package/lib/vite/traceViewer/index.I8N9v4jT.css +1 -0
- package/lib/vite/traceViewer/index.html +43 -0
- package/lib/vite/traceViewer/playwright-logo.svg +9 -0
- package/lib/vite/traceViewer/snapshot.html +21 -0
- package/lib/vite/traceViewer/sw.bundle.js +3 -0
- package/lib/vite/traceViewer/uiMode.Btcz36p_.css +1 -0
- package/lib/vite/traceViewer/uiMode.Shu3QS-1.js +5 -0
- package/lib/vite/traceViewer/uiMode.html +17 -0
- package/lib/vite/traceViewer/xtermModule.DYP7pi_n.css +32 -0
- package/lib/zipBundle.js +34 -0
- package/lib/zipBundleImpl.js +5 -0
- package/package.json +43 -0
- package/types/protocol.d.ts +23130 -0
- package/types/structs.d.ts +45 -0
- package/types/types.d.ts +22857 -0
@@ -0,0 +1,235 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __defProp = Object.defineProperty;
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
6
|
+
var __export = (target, all) => {
|
7
|
+
for (var name in all)
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
9
|
+
};
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
12
|
+
for (let key of __getOwnPropNames(from))
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
15
|
+
}
|
16
|
+
return to;
|
17
|
+
};
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
19
|
+
var crCoverage_exports = {};
|
20
|
+
__export(crCoverage_exports, {
|
21
|
+
CRCoverage: () => CRCoverage
|
22
|
+
});
|
23
|
+
module.exports = __toCommonJS(crCoverage_exports);
|
24
|
+
var import_utils = require("../../utils");
|
25
|
+
var import_eventsHelper = require("../utils/eventsHelper");
|
26
|
+
var import_progress = require("../progress");
|
27
|
+
class CRCoverage {
|
28
|
+
constructor(client) {
|
29
|
+
this._jsCoverage = new JSCoverage(client);
|
30
|
+
this._cssCoverage = new CSSCoverage(client);
|
31
|
+
}
|
32
|
+
async startJSCoverage(progress, options) {
|
33
|
+
await (0, import_progress.raceUncancellableOperationWithCleanup)(progress, () => this._jsCoverage.start(options), () => this._jsCoverage.stop());
|
34
|
+
}
|
35
|
+
async stopJSCoverage() {
|
36
|
+
return await this._jsCoverage.stop();
|
37
|
+
}
|
38
|
+
async startCSSCoverage(progress, options) {
|
39
|
+
await (0, import_progress.raceUncancellableOperationWithCleanup)(progress, () => this._cssCoverage.start(options), () => this._cssCoverage.stop());
|
40
|
+
}
|
41
|
+
async stopCSSCoverage() {
|
42
|
+
return await this._cssCoverage.stop();
|
43
|
+
}
|
44
|
+
}
|
45
|
+
class JSCoverage {
|
46
|
+
constructor(client) {
|
47
|
+
this._reportAnonymousScripts = false;
|
48
|
+
this._client = client;
|
49
|
+
this._enabled = false;
|
50
|
+
this._scriptIds = /* @__PURE__ */ new Set();
|
51
|
+
this._scriptSources = /* @__PURE__ */ new Map();
|
52
|
+
this._eventListeners = [];
|
53
|
+
this._resetOnNavigation = false;
|
54
|
+
}
|
55
|
+
async start(options) {
|
56
|
+
(0, import_utils.assert)(!this._enabled, "JSCoverage is already enabled");
|
57
|
+
const {
|
58
|
+
resetOnNavigation = true,
|
59
|
+
reportAnonymousScripts = false
|
60
|
+
} = options;
|
61
|
+
this._resetOnNavigation = resetOnNavigation;
|
62
|
+
this._reportAnonymousScripts = reportAnonymousScripts;
|
63
|
+
this._enabled = true;
|
64
|
+
this._scriptIds.clear();
|
65
|
+
this._scriptSources.clear();
|
66
|
+
this._eventListeners = [
|
67
|
+
import_eventsHelper.eventsHelper.addEventListener(this._client, "Debugger.scriptParsed", this._onScriptParsed.bind(this)),
|
68
|
+
import_eventsHelper.eventsHelper.addEventListener(this._client, "Runtime.executionContextsCleared", this._onExecutionContextsCleared.bind(this)),
|
69
|
+
import_eventsHelper.eventsHelper.addEventListener(this._client, "Debugger.paused", this._onDebuggerPaused.bind(this))
|
70
|
+
];
|
71
|
+
await Promise.all([
|
72
|
+
this._client.send("Profiler.enable"),
|
73
|
+
this._client.send("Profiler.startPreciseCoverage", { callCount: true, detailed: true }),
|
74
|
+
this._client.send("Debugger.enable"),
|
75
|
+
this._client.send("Debugger.setSkipAllPauses", { skip: true })
|
76
|
+
]);
|
77
|
+
}
|
78
|
+
_onDebuggerPaused() {
|
79
|
+
this._client.send("Debugger.resume");
|
80
|
+
}
|
81
|
+
_onExecutionContextsCleared() {
|
82
|
+
if (!this._resetOnNavigation)
|
83
|
+
return;
|
84
|
+
this._scriptIds.clear();
|
85
|
+
this._scriptSources.clear();
|
86
|
+
}
|
87
|
+
async _onScriptParsed(event) {
|
88
|
+
this._scriptIds.add(event.scriptId);
|
89
|
+
if (!event.url && !this._reportAnonymousScripts)
|
90
|
+
return;
|
91
|
+
const response = await this._client._sendMayFail("Debugger.getScriptSource", { scriptId: event.scriptId });
|
92
|
+
if (response)
|
93
|
+
this._scriptSources.set(event.scriptId, response.scriptSource);
|
94
|
+
}
|
95
|
+
async stop() {
|
96
|
+
if (!this._enabled)
|
97
|
+
return { entries: [] };
|
98
|
+
const [profileResponse] = await Promise.all([
|
99
|
+
this._client.send("Profiler.takePreciseCoverage"),
|
100
|
+
this._client.send("Profiler.stopPreciseCoverage"),
|
101
|
+
this._client.send("Profiler.disable"),
|
102
|
+
this._client.send("Debugger.disable")
|
103
|
+
]);
|
104
|
+
import_eventsHelper.eventsHelper.removeEventListeners(this._eventListeners);
|
105
|
+
this._enabled = false;
|
106
|
+
const coverage = { entries: [] };
|
107
|
+
for (const entry of profileResponse.result) {
|
108
|
+
if (!this._scriptIds.has(entry.scriptId))
|
109
|
+
continue;
|
110
|
+
if (!entry.url && !this._reportAnonymousScripts)
|
111
|
+
continue;
|
112
|
+
const source = this._scriptSources.get(entry.scriptId);
|
113
|
+
if (source)
|
114
|
+
coverage.entries.push({ ...entry, source });
|
115
|
+
else
|
116
|
+
coverage.entries.push(entry);
|
117
|
+
}
|
118
|
+
return coverage;
|
119
|
+
}
|
120
|
+
}
|
121
|
+
class CSSCoverage {
|
122
|
+
constructor(client) {
|
123
|
+
this._client = client;
|
124
|
+
this._enabled = false;
|
125
|
+
this._stylesheetURLs = /* @__PURE__ */ new Map();
|
126
|
+
this._stylesheetSources = /* @__PURE__ */ new Map();
|
127
|
+
this._eventListeners = [];
|
128
|
+
this._resetOnNavigation = false;
|
129
|
+
}
|
130
|
+
async start(options) {
|
131
|
+
(0, import_utils.assert)(!this._enabled, "CSSCoverage is already enabled");
|
132
|
+
const { resetOnNavigation = true } = options;
|
133
|
+
this._resetOnNavigation = resetOnNavigation;
|
134
|
+
this._enabled = true;
|
135
|
+
this._stylesheetURLs.clear();
|
136
|
+
this._stylesheetSources.clear();
|
137
|
+
this._eventListeners = [
|
138
|
+
import_eventsHelper.eventsHelper.addEventListener(this._client, "CSS.styleSheetAdded", this._onStyleSheet.bind(this)),
|
139
|
+
import_eventsHelper.eventsHelper.addEventListener(this._client, "Runtime.executionContextsCleared", this._onExecutionContextsCleared.bind(this))
|
140
|
+
];
|
141
|
+
await Promise.all([
|
142
|
+
this._client.send("DOM.enable"),
|
143
|
+
this._client.send("CSS.enable"),
|
144
|
+
this._client.send("CSS.startRuleUsageTracking")
|
145
|
+
]);
|
146
|
+
}
|
147
|
+
_onExecutionContextsCleared() {
|
148
|
+
if (!this._resetOnNavigation)
|
149
|
+
return;
|
150
|
+
this._stylesheetURLs.clear();
|
151
|
+
this._stylesheetSources.clear();
|
152
|
+
}
|
153
|
+
async _onStyleSheet(event) {
|
154
|
+
const header = event.header;
|
155
|
+
if (!header.sourceURL)
|
156
|
+
return;
|
157
|
+
const response = await this._client._sendMayFail("CSS.getStyleSheetText", { styleSheetId: header.styleSheetId });
|
158
|
+
if (response) {
|
159
|
+
this._stylesheetURLs.set(header.styleSheetId, header.sourceURL);
|
160
|
+
this._stylesheetSources.set(header.styleSheetId, response.text);
|
161
|
+
}
|
162
|
+
}
|
163
|
+
async stop() {
|
164
|
+
if (!this._enabled)
|
165
|
+
return { entries: [] };
|
166
|
+
const ruleTrackingResponse = await this._client.send("CSS.stopRuleUsageTracking");
|
167
|
+
await Promise.all([
|
168
|
+
this._client.send("CSS.disable"),
|
169
|
+
this._client.send("DOM.disable")
|
170
|
+
]);
|
171
|
+
import_eventsHelper.eventsHelper.removeEventListeners(this._eventListeners);
|
172
|
+
this._enabled = false;
|
173
|
+
const styleSheetIdToCoverage = /* @__PURE__ */ new Map();
|
174
|
+
for (const entry of ruleTrackingResponse.ruleUsage) {
|
175
|
+
let ranges = styleSheetIdToCoverage.get(entry.styleSheetId);
|
176
|
+
if (!ranges) {
|
177
|
+
ranges = [];
|
178
|
+
styleSheetIdToCoverage.set(entry.styleSheetId, ranges);
|
179
|
+
}
|
180
|
+
ranges.push({
|
181
|
+
startOffset: entry.startOffset,
|
182
|
+
endOffset: entry.endOffset,
|
183
|
+
count: entry.used ? 1 : 0
|
184
|
+
});
|
185
|
+
}
|
186
|
+
const coverage = { entries: [] };
|
187
|
+
for (const styleSheetId of this._stylesheetURLs.keys()) {
|
188
|
+
const url = this._stylesheetURLs.get(styleSheetId);
|
189
|
+
const text = this._stylesheetSources.get(styleSheetId);
|
190
|
+
const ranges = convertToDisjointRanges(styleSheetIdToCoverage.get(styleSheetId) || []);
|
191
|
+
coverage.entries.push({ url, ranges, text });
|
192
|
+
}
|
193
|
+
return coverage;
|
194
|
+
}
|
195
|
+
}
|
196
|
+
function convertToDisjointRanges(nestedRanges) {
|
197
|
+
const points = [];
|
198
|
+
for (const range of nestedRanges) {
|
199
|
+
points.push({ offset: range.startOffset, type: 0, range });
|
200
|
+
points.push({ offset: range.endOffset, type: 1, range });
|
201
|
+
}
|
202
|
+
points.sort((a, b) => {
|
203
|
+
if (a.offset !== b.offset)
|
204
|
+
return a.offset - b.offset;
|
205
|
+
if (a.type !== b.type)
|
206
|
+
return b.type - a.type;
|
207
|
+
const aLength = a.range.endOffset - a.range.startOffset;
|
208
|
+
const bLength = b.range.endOffset - b.range.startOffset;
|
209
|
+
if (a.type === 0)
|
210
|
+
return bLength - aLength;
|
211
|
+
return aLength - bLength;
|
212
|
+
});
|
213
|
+
const hitCountStack = [];
|
214
|
+
const results = [];
|
215
|
+
let lastOffset = 0;
|
216
|
+
for (const point of points) {
|
217
|
+
if (hitCountStack.length && lastOffset < point.offset && hitCountStack[hitCountStack.length - 1] > 0) {
|
218
|
+
const lastResult = results.length ? results[results.length - 1] : null;
|
219
|
+
if (lastResult && lastResult.end === lastOffset)
|
220
|
+
lastResult.end = point.offset;
|
221
|
+
else
|
222
|
+
results.push({ start: lastOffset, end: point.offset });
|
223
|
+
}
|
224
|
+
lastOffset = point.offset;
|
225
|
+
if (point.type === 0)
|
226
|
+
hitCountStack.push(point.range.count);
|
227
|
+
else
|
228
|
+
hitCountStack.pop();
|
229
|
+
}
|
230
|
+
return results.filter((range) => range.end - range.start > 1);
|
231
|
+
}
|
232
|
+
// Annotate the CommonJS export names for ESM import in node:
|
233
|
+
0 && (module.exports = {
|
234
|
+
CRCoverage
|
235
|
+
});
|
@@ -0,0 +1,113 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __create = Object.create;
|
3
|
+
var __defProp = Object.defineProperty;
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
8
|
+
var __export = (target, all) => {
|
9
|
+
for (var name in all)
|
10
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
11
|
+
};
|
12
|
+
var __copyProps = (to, from, except, desc) => {
|
13
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
14
|
+
for (let key of __getOwnPropNames(from))
|
15
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
16
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
17
|
+
}
|
18
|
+
return to;
|
19
|
+
};
|
20
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
21
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
22
|
+
// file that has been converted to a CommonJS file using a Babel-
|
23
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
24
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
25
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
26
|
+
mod
|
27
|
+
));
|
28
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
29
|
+
var crDevTools_exports = {};
|
30
|
+
__export(crDevTools_exports, {
|
31
|
+
CRDevTools: () => CRDevTools
|
32
|
+
});
|
33
|
+
module.exports = __toCommonJS(crDevTools_exports);
|
34
|
+
var import_fs = __toESM(require("fs"));
|
35
|
+
const kBindingName = "__pw_devtools__";
|
36
|
+
class CRDevTools {
|
37
|
+
constructor(preferencesPath) {
|
38
|
+
this._preferencesPath = preferencesPath;
|
39
|
+
this._savePromise = Promise.resolve();
|
40
|
+
}
|
41
|
+
install(session) {
|
42
|
+
session.on("Runtime.bindingCalled", async (event) => {
|
43
|
+
if (event.name !== kBindingName)
|
44
|
+
return;
|
45
|
+
const parsed = JSON.parse(event.payload);
|
46
|
+
let result = void 0;
|
47
|
+
if (this.__testHookOnBinding)
|
48
|
+
this.__testHookOnBinding(parsed);
|
49
|
+
if (parsed.method === "getPreferences") {
|
50
|
+
if (this._prefs === void 0) {
|
51
|
+
try {
|
52
|
+
const json = await import_fs.default.promises.readFile(this._preferencesPath, "utf8");
|
53
|
+
this._prefs = JSON.parse(json);
|
54
|
+
} catch (e) {
|
55
|
+
this._prefs = {};
|
56
|
+
}
|
57
|
+
}
|
58
|
+
result = this._prefs;
|
59
|
+
} else if (parsed.method === "setPreference") {
|
60
|
+
this._prefs[parsed.params[0]] = parsed.params[1];
|
61
|
+
this._save();
|
62
|
+
} else if (parsed.method === "removePreference") {
|
63
|
+
delete this._prefs[parsed.params[0]];
|
64
|
+
this._save();
|
65
|
+
} else if (parsed.method === "clearPreferences") {
|
66
|
+
this._prefs = {};
|
67
|
+
this._save();
|
68
|
+
}
|
69
|
+
session.send("Runtime.evaluate", {
|
70
|
+
expression: `window.DevToolsAPI.embedderMessageAck(${parsed.id}, ${JSON.stringify(result)})`,
|
71
|
+
contextId: event.executionContextId
|
72
|
+
}).catch((e) => null);
|
73
|
+
});
|
74
|
+
Promise.all([
|
75
|
+
session.send("Runtime.enable"),
|
76
|
+
session.send("Runtime.addBinding", { name: kBindingName }),
|
77
|
+
session.send("Page.enable"),
|
78
|
+
session.send("Page.addScriptToEvaluateOnNewDocument", { source: `
|
79
|
+
(() => {
|
80
|
+
const init = () => {
|
81
|
+
// Lazy init happens when InspectorFrontendHost is initialized.
|
82
|
+
// At this point DevToolsHost is ready to be used.
|
83
|
+
const host = window.DevToolsHost;
|
84
|
+
const old = host.sendMessageToEmbedder.bind(host);
|
85
|
+
host.sendMessageToEmbedder = message => {
|
86
|
+
if (['getPreferences', 'setPreference', 'removePreference', 'clearPreferences'].includes(JSON.parse(message).method))
|
87
|
+
window.${kBindingName}(message);
|
88
|
+
else
|
89
|
+
old(message);
|
90
|
+
};
|
91
|
+
};
|
92
|
+
let value;
|
93
|
+
Object.defineProperty(window, 'InspectorFrontendHost', {
|
94
|
+
configurable: true,
|
95
|
+
enumerable: true,
|
96
|
+
get() { return value; },
|
97
|
+
set(v) { value = v; init(); },
|
98
|
+
});
|
99
|
+
})()
|
100
|
+
` }),
|
101
|
+
session.send("Runtime.runIfWaitingForDebugger")
|
102
|
+
]).catch((e) => null);
|
103
|
+
}
|
104
|
+
_save() {
|
105
|
+
this._savePromise = this._savePromise.then(async () => {
|
106
|
+
await import_fs.default.promises.writeFile(this._preferencesPath, JSON.stringify(this._prefs)).catch((e) => null);
|
107
|
+
});
|
108
|
+
}
|
109
|
+
}
|
110
|
+
// Annotate the CommonJS export names for ESM import in node:
|
111
|
+
0 && (module.exports = {
|
112
|
+
CRDevTools
|
113
|
+
});
|
@@ -0,0 +1,131 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __defProp = Object.defineProperty;
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
6
|
+
var __export = (target, all) => {
|
7
|
+
for (var name in all)
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
9
|
+
};
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
12
|
+
for (let key of __getOwnPropNames(from))
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
15
|
+
}
|
16
|
+
return to;
|
17
|
+
};
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
19
|
+
var crDragDrop_exports = {};
|
20
|
+
__export(crDragDrop_exports, {
|
21
|
+
DragManager: () => DragManager
|
22
|
+
});
|
23
|
+
module.exports = __toCommonJS(crDragDrop_exports);
|
24
|
+
var import_crProtocolHelper = require("./crProtocolHelper");
|
25
|
+
var import_utils = require("../../utils");
|
26
|
+
class DragManager {
|
27
|
+
constructor(page) {
|
28
|
+
this._dragState = null;
|
29
|
+
this._lastPosition = { x: 0, y: 0 };
|
30
|
+
this._crPage = page;
|
31
|
+
}
|
32
|
+
async cancelDrag() {
|
33
|
+
if (!this._dragState)
|
34
|
+
return false;
|
35
|
+
await this._crPage._mainFrameSession._client.send("Input.dispatchDragEvent", {
|
36
|
+
type: "dragCancel",
|
37
|
+
x: this._lastPosition.x,
|
38
|
+
y: this._lastPosition.y,
|
39
|
+
data: {
|
40
|
+
items: [],
|
41
|
+
dragOperationsMask: 65535
|
42
|
+
}
|
43
|
+
});
|
44
|
+
this._dragState = null;
|
45
|
+
return true;
|
46
|
+
}
|
47
|
+
async interceptDragCausedByMove(progress, x, y, button, buttons, modifiers, moveCallback) {
|
48
|
+
this._lastPosition = { x, y };
|
49
|
+
if (this._dragState) {
|
50
|
+
await progress.race(this._crPage._mainFrameSession._client.send("Input.dispatchDragEvent", {
|
51
|
+
type: "dragOver",
|
52
|
+
x,
|
53
|
+
y,
|
54
|
+
data: this._dragState,
|
55
|
+
modifiers: (0, import_crProtocolHelper.toModifiersMask)(modifiers)
|
56
|
+
}));
|
57
|
+
return;
|
58
|
+
}
|
59
|
+
if (button !== "left")
|
60
|
+
return moveCallback();
|
61
|
+
const client = this._crPage._mainFrameSession._client;
|
62
|
+
let onDragIntercepted;
|
63
|
+
const dragInterceptedPromise = new Promise((x2) => onDragIntercepted = x2);
|
64
|
+
function setupDragListeners() {
|
65
|
+
let didStartDrag = Promise.resolve(false);
|
66
|
+
let dragEvent = null;
|
67
|
+
const dragListener = (event) => dragEvent = event;
|
68
|
+
const mouseListener = () => {
|
69
|
+
didStartDrag = new Promise((callback) => {
|
70
|
+
window.addEventListener("dragstart", dragListener, { once: true, capture: true });
|
71
|
+
setTimeout(() => callback(dragEvent ? !dragEvent.defaultPrevented : false), 0);
|
72
|
+
});
|
73
|
+
};
|
74
|
+
window.addEventListener("mousemove", mouseListener, { once: true, capture: true });
|
75
|
+
window.__cleanupDrag = async () => {
|
76
|
+
const val = await didStartDrag;
|
77
|
+
window.removeEventListener("mousemove", mouseListener, { capture: true });
|
78
|
+
window.removeEventListener("dragstart", dragListener, { capture: true });
|
79
|
+
delete window.__cleanupDrag;
|
80
|
+
return val;
|
81
|
+
};
|
82
|
+
}
|
83
|
+
try {
|
84
|
+
let expectingDrag = false;
|
85
|
+
await progress.race(this._crPage._page.safeNonStallingEvaluateInAllFrames(`(${setupDragListeners.toString()})()`, "utility"));
|
86
|
+
client.on("Input.dragIntercepted", onDragIntercepted);
|
87
|
+
await client.send("Input.setInterceptDrags", { enabled: true });
|
88
|
+
try {
|
89
|
+
await progress.race(moveCallback());
|
90
|
+
expectingDrag = (await Promise.all(this._crPage._page.frames().map(async (frame) => {
|
91
|
+
return frame.nonStallingEvaluateInExistingContext("window.__cleanupDrag?.()", "utility").catch(() => false);
|
92
|
+
}))).some((x2) => x2);
|
93
|
+
} finally {
|
94
|
+
client.off("Input.dragIntercepted", onDragIntercepted);
|
95
|
+
await client.send("Input.setInterceptDrags", { enabled: false });
|
96
|
+
}
|
97
|
+
this._dragState = expectingDrag ? (await dragInterceptedPromise).data : null;
|
98
|
+
} catch (error) {
|
99
|
+
this._crPage._page.safeNonStallingEvaluateInAllFrames("window.__cleanupDrag?.()", "utility").catch(() => {
|
100
|
+
});
|
101
|
+
throw error;
|
102
|
+
}
|
103
|
+
if (this._dragState) {
|
104
|
+
await progress.race(this._crPage._mainFrameSession._client.send("Input.dispatchDragEvent", {
|
105
|
+
type: "dragEnter",
|
106
|
+
x,
|
107
|
+
y,
|
108
|
+
data: this._dragState,
|
109
|
+
modifiers: (0, import_crProtocolHelper.toModifiersMask)(modifiers)
|
110
|
+
}));
|
111
|
+
}
|
112
|
+
}
|
113
|
+
isDragging() {
|
114
|
+
return !!this._dragState;
|
115
|
+
}
|
116
|
+
async drop(progress, x, y, modifiers) {
|
117
|
+
(0, import_utils.assert)(this._dragState, "missing drag state");
|
118
|
+
await progress.race(this._crPage._mainFrameSession._client.send("Input.dispatchDragEvent", {
|
119
|
+
type: "drop",
|
120
|
+
x,
|
121
|
+
y,
|
122
|
+
data: this._dragState,
|
123
|
+
modifiers: (0, import_crProtocolHelper.toModifiersMask)(modifiers)
|
124
|
+
}));
|
125
|
+
this._dragState = null;
|
126
|
+
}
|
127
|
+
}
|
128
|
+
// Annotate the CommonJS export names for ESM import in node:
|
129
|
+
0 && (module.exports = {
|
130
|
+
DragManager
|
131
|
+
});
|
@@ -0,0 +1,146 @@
|
|
1
|
+
"use strict";
|
2
|
+
var __create = Object.create;
|
3
|
+
var __defProp = Object.defineProperty;
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
8
|
+
var __export = (target, all) => {
|
9
|
+
for (var name in all)
|
10
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
11
|
+
};
|
12
|
+
var __copyProps = (to, from, except, desc) => {
|
13
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
14
|
+
for (let key of __getOwnPropNames(from))
|
15
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
16
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
17
|
+
}
|
18
|
+
return to;
|
19
|
+
};
|
20
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
21
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
22
|
+
// file that has been converted to a CommonJS file using a Babel-
|
23
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
24
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
25
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
26
|
+
mod
|
27
|
+
));
|
28
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
29
|
+
var crExecutionContext_exports = {};
|
30
|
+
__export(crExecutionContext_exports, {
|
31
|
+
CRExecutionContext: () => CRExecutionContext,
|
32
|
+
createHandle: () => createHandle
|
33
|
+
});
|
34
|
+
module.exports = __toCommonJS(crExecutionContext_exports);
|
35
|
+
var import_assert = require("../../utils/isomorphic/assert");
|
36
|
+
var import_crProtocolHelper = require("./crProtocolHelper");
|
37
|
+
var import_stackTrace = require("../../utils/isomorphic/stackTrace");
|
38
|
+
var import_utilityScriptSerializers = require("../../utils/isomorphic/utilityScriptSerializers");
|
39
|
+
var js = __toESM(require("../javascript"));
|
40
|
+
var dom = __toESM(require("../dom"));
|
41
|
+
var import_protocolError = require("../protocolError");
|
42
|
+
class CRExecutionContext {
|
43
|
+
constructor(client, contextPayload) {
|
44
|
+
this._client = client;
|
45
|
+
this._contextId = contextPayload.id;
|
46
|
+
}
|
47
|
+
async rawEvaluateJSON(expression) {
|
48
|
+
const { exceptionDetails, result: remoteObject } = await this._client.send("Runtime.evaluate", {
|
49
|
+
expression,
|
50
|
+
contextId: this._contextId,
|
51
|
+
returnByValue: true
|
52
|
+
}).catch(rewriteError);
|
53
|
+
if (exceptionDetails)
|
54
|
+
throw new js.JavaScriptErrorInEvaluate((0, import_crProtocolHelper.getExceptionMessage)(exceptionDetails));
|
55
|
+
return remoteObject.value;
|
56
|
+
}
|
57
|
+
async rawEvaluateHandle(context, expression) {
|
58
|
+
const { exceptionDetails, result: remoteObject } = await this._client.send("Runtime.evaluate", {
|
59
|
+
expression,
|
60
|
+
contextId: this._contextId
|
61
|
+
}).catch(rewriteError);
|
62
|
+
if (exceptionDetails)
|
63
|
+
throw new js.JavaScriptErrorInEvaluate((0, import_crProtocolHelper.getExceptionMessage)(exceptionDetails));
|
64
|
+
return createHandle(context, remoteObject);
|
65
|
+
}
|
66
|
+
async evaluateWithArguments(expression, returnByValue, utilityScript, values, handles) {
|
67
|
+
const { exceptionDetails, result: remoteObject } = await this._client.send("Runtime.callFunctionOn", {
|
68
|
+
functionDeclaration: expression,
|
69
|
+
objectId: utilityScript._objectId,
|
70
|
+
arguments: [
|
71
|
+
{ objectId: utilityScript._objectId },
|
72
|
+
...values.map((value) => ({ value })),
|
73
|
+
...handles.map((handle) => ({ objectId: handle._objectId }))
|
74
|
+
],
|
75
|
+
returnByValue,
|
76
|
+
awaitPromise: true,
|
77
|
+
userGesture: true
|
78
|
+
}).catch(rewriteError);
|
79
|
+
if (exceptionDetails)
|
80
|
+
throw new js.JavaScriptErrorInEvaluate((0, import_crProtocolHelper.getExceptionMessage)(exceptionDetails));
|
81
|
+
return returnByValue ? (0, import_utilityScriptSerializers.parseEvaluationResultValue)(remoteObject.value) : createHandle(utilityScript._context, remoteObject);
|
82
|
+
}
|
83
|
+
async getProperties(object) {
|
84
|
+
const response = await this._client.send("Runtime.getProperties", {
|
85
|
+
objectId: object._objectId,
|
86
|
+
ownProperties: true
|
87
|
+
});
|
88
|
+
const result = /* @__PURE__ */ new Map();
|
89
|
+
for (const property of response.result) {
|
90
|
+
if (!property.enumerable || !property.value)
|
91
|
+
continue;
|
92
|
+
result.set(property.name, createHandle(object._context, property.value));
|
93
|
+
}
|
94
|
+
return result;
|
95
|
+
}
|
96
|
+
async releaseHandle(handle) {
|
97
|
+
if (!handle._objectId)
|
98
|
+
return;
|
99
|
+
await (0, import_crProtocolHelper.releaseObject)(this._client, handle._objectId);
|
100
|
+
}
|
101
|
+
}
|
102
|
+
function rewriteError(error) {
|
103
|
+
if (error.message.includes("Object reference chain is too long"))
|
104
|
+
throw new Error("Cannot serialize result: object reference chain is too long.");
|
105
|
+
if (error.message.includes("Object couldn't be returned by value"))
|
106
|
+
return { result: { type: "undefined" } };
|
107
|
+
if (error instanceof TypeError && error.message.startsWith("Converting circular structure to JSON"))
|
108
|
+
(0, import_stackTrace.rewriteErrorMessage)(error, error.message + " Are you passing a nested JSHandle?");
|
109
|
+
if (!js.isJavaScriptErrorInEvaluate(error) && !(0, import_protocolError.isSessionClosedError)(error))
|
110
|
+
throw new Error("Execution context was destroyed, most likely because of a navigation.");
|
111
|
+
throw error;
|
112
|
+
}
|
113
|
+
function potentiallyUnserializableValue(remoteObject) {
|
114
|
+
const value = remoteObject.value;
|
115
|
+
const unserializableValue = remoteObject.unserializableValue;
|
116
|
+
return unserializableValue ? js.parseUnserializableValue(unserializableValue) : value;
|
117
|
+
}
|
118
|
+
function renderPreview(object) {
|
119
|
+
if (object.type === "undefined")
|
120
|
+
return "undefined";
|
121
|
+
if ("value" in object)
|
122
|
+
return String(object.value);
|
123
|
+
if (object.unserializableValue)
|
124
|
+
return String(object.unserializableValue);
|
125
|
+
if (object.description === "Object" && object.preview) {
|
126
|
+
const tokens = [];
|
127
|
+
for (const { name, value } of object.preview.properties)
|
128
|
+
tokens.push(`${name}: ${value}`);
|
129
|
+
return `{${tokens.join(", ")}}`;
|
130
|
+
}
|
131
|
+
if (object.subtype === "array" && object.preview)
|
132
|
+
return js.sparseArrayToString(object.preview.properties);
|
133
|
+
return object.description;
|
134
|
+
}
|
135
|
+
function createHandle(context, remoteObject) {
|
136
|
+
if (remoteObject.subtype === "node") {
|
137
|
+
(0, import_assert.assert)(context instanceof dom.FrameExecutionContext);
|
138
|
+
return new dom.ElementHandle(context, remoteObject.objectId);
|
139
|
+
}
|
140
|
+
return new js.JSHandle(context, remoteObject.subtype || remoteObject.type, renderPreview(remoteObject), remoteObject.objectId, potentiallyUnserializableValue(remoteObject));
|
141
|
+
}
|
142
|
+
// Annotate the CommonJS export names for ESM import in node:
|
143
|
+
0 && (module.exports = {
|
144
|
+
CRExecutionContext,
|
145
|
+
createHandle
|
146
|
+
});
|