"use strict"; /** * 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. */ Object.defineProperty(exports, "__esModule", { value: true }); exports.Realm = void 0; const WaitTask_js_1 = require("../common/WaitTask.js"); const disposable_js_1 = require("../util/disposable.js"); /** * @internal */ class Realm { timeoutSettings; taskManager = new WaitTask_js_1.TaskManager(); constructor(timeoutSettings) { this.timeoutSettings = timeoutSettings; } async waitForFunction(pageFunction, options = {}, ...args) { const { polling = 'raf', timeout = this.timeoutSettings.timeout(), root, signal, } = options; if (typeof polling === 'number' && polling < 0) { throw new Error('Cannot poll with non-positive interval'); } const waitTask = new WaitTask_js_1.WaitTask(this, { polling, root, timeout, signal, }, pageFunction, ...args); return await waitTask.result; } get disposed() { return this.#disposed; } #disposed = false; /** @internal */ [disposable_js_1.disposeSymbol]() { this.#disposed = true; this.taskManager.terminateAll(new Error('waitForFunction failed: frame got detached.')); } } exports.Realm = Realm; //# sourceMappingURL=Realm.js.map