/** * Copyright 2023 Google Inc. All rights reserved. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import {ClickOptions, ElementHandle} from '../api/ElementHandle.js'; import {HTTPResponse} from '../api/HTTPResponse.js'; import {Page, WaitTimeoutOptions} from '../api/Page.js'; import {CDPSession} from '../common/Connection.js'; import {DeviceRequestPrompt} from '../common/DeviceRequestPrompt.js'; import {EventEmitter} from '../common/EventEmitter.js'; import {ExecutionContext} from '../common/ExecutionContext.js'; import {getQueryHandlerAndSelector} from '../common/GetQueryHandler.js'; import {transposeIterableHandle} from '../common/HandleIterator.js'; import { IsolatedWorldChart, WaitForSelectorOptions, } from '../common/IsolatedWorld.js'; import {LazyArg} from '../common/LazyArg.js'; import {PuppeteerLifeCycleEvent} from '../common/LifecycleWatcher.js'; import { Awaitable, EvaluateFunc, EvaluateFuncWith, HandleFor, InnerLazyParams, NodeFor, } from '../common/types.js'; import {importFSPromises} from '../common/util.js'; import {TaskManager} from '../common/WaitTask.js'; import {KeyboardTypeOptions} from './Input.js'; import {JSHandle} from './JSHandle.js'; import {FunctionLocator, Locator, NodeLocator} from './locators/locators.js'; /** * @internal */ export interface Realm { taskManager: TaskManager; waitForFunction< Params extends unknown[], Func extends EvaluateFunc> = EvaluateFunc< InnerLazyParams >, >( pageFunction: Func | string, options: { polling?: 'raf' | 'mutation' | number; timeout?: number; root?: ElementHandle; signal?: AbortSignal; }, ...args: Params ): Promise>>>; adoptHandle>(handle: T): Promise; transferHandle>(handle: T): Promise; evaluateHandle< Params extends unknown[], Func extends EvaluateFunc = EvaluateFunc, >( pageFunction: Func | string, ...args: Params ): Promise>>>; evaluate< Params extends unknown[], Func extends EvaluateFunc = EvaluateFunc, >( pageFunction: Func | string, ...args: Params ): Promise>>; click(selector: string, options: Readonly): Promise; focus(selector: string): Promise; hover(selector: string): Promise; select(selector: string, ...values: string[]): Promise; tap(selector: string): Promise; type( selector: string, text: string, options?: Readonly ): Promise; } /** * @public */ export interface FrameWaitForFunctionOptions { /** * An interval at which the `pageFunction` is executed, defaults to `raf`. If * `polling` is a number, then it is treated as an interval in milliseconds at * which the function would be executed. If `polling` is a string, then it can * be one of the following values: * * - `raf` - to constantly execute `pageFunction` in `requestAnimationFrame` * callback. This is the tightest polling mode which is suitable to observe * styling changes. * * - `mutation` - to execute `pageFunction` on every DOM mutation. */ polling?: 'raf' | 'mutation' | number; /** * Maximum time to wait in milliseconds. Defaults to `30000` (30 seconds). * Pass `0` to disable the timeout. Puppeteer's default timeout can be changed * using {@link Page.setDefaultTimeout}. */ timeout?: number; /** * A signal object that allows you to cancel a waitForFunction call. */ signal?: AbortSignal; } /** * @public */ export interface FrameAddScriptTagOptions { /** * URL of the script to be added. */ url?: string; /** * Path to a JavaScript file to be injected into the frame. * * @remarks * If `path` is a relative path, it is resolved relative to the current * working directory (`process.cwd()` in Node.js). */ path?: string; /** * JavaScript to be injected into the frame. */ content?: string; /** * Sets the `type` of the script. Use `module` in order to load an ES2015 module. */ type?: string; /** * Sets the `id` of the script. */ id?: string; } /** * @public */ export interface FrameAddStyleTagOptions { /** * the URL of the CSS file to be added. */ url?: string; /** * The path to a CSS file to be injected into the frame. * @remarks * If `path` is a relative path, it is resolved relative to the current * working directory (`process.cwd()` in Node.js). */ path?: string; /** * Raw CSS content to be injected into the frame. */ content?: string; } /** * Represents a DOM frame. * * To understand frames, you can think of frames as `