2020-06-25 16:05:36 -07:00
|
|
|
/**
|
|
|
|
* Copyright (c) Microsoft Corporation.
|
|
|
|
*
|
|
|
|
* 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 { ElementHandle } from '../../dom';
|
|
|
|
import * as js from '../../javascript';
|
|
|
|
import * as types from '../../types';
|
2020-07-21 12:44:30 -07:00
|
|
|
import { ElementHandleChannel, FrameChannel, Binary, SerializedArgument, SerializedValue } from '../channels';
|
2020-06-30 22:21:17 -07:00
|
|
|
import { DispatcherScope, lookupNullableDispatcher } from './dispatcher';
|
2020-06-27 11:10:07 -07:00
|
|
|
import { JSHandleDispatcher, serializeResult, parseArgument } from './jsHandleDispatcher';
|
|
|
|
import { FrameDispatcher } from './frameDispatcher';
|
2020-06-25 16:05:36 -07:00
|
|
|
|
2020-06-30 21:30:39 -07:00
|
|
|
export function createHandle(scope: DispatcherScope, handle: js.JSHandle): JSHandleDispatcher {
|
2020-06-30 10:55:11 -07:00
|
|
|
return handle.asElement() ? new ElementHandleDispatcher(scope, handle.asElement()!) : new JSHandleDispatcher(scope, handle);
|
|
|
|
}
|
|
|
|
|
2020-06-25 16:05:36 -07:00
|
|
|
export class ElementHandleDispatcher extends JSHandleDispatcher implements ElementHandleChannel {
|
2020-06-26 11:51:47 -07:00
|
|
|
readonly _elementHandle: ElementHandle;
|
2020-06-25 16:05:36 -07:00
|
|
|
|
2020-07-20 17:38:06 -07:00
|
|
|
static createNullable(scope: DispatcherScope, handle: ElementHandle | null): ElementHandleDispatcher | undefined {
|
2020-06-25 16:05:36 -07:00
|
|
|
if (!handle)
|
2020-07-20 17:38:06 -07:00
|
|
|
return undefined;
|
2020-06-30 21:30:39 -07:00
|
|
|
return new ElementHandleDispatcher(scope, handle);
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
constructor(scope: DispatcherScope, elementHandle: ElementHandle) {
|
2020-06-26 12:28:27 -07:00
|
|
|
super(scope, elementHandle);
|
2020-06-25 16:05:36 -07:00
|
|
|
this._elementHandle = elementHandle;
|
|
|
|
}
|
|
|
|
|
2020-07-20 17:38:06 -07:00
|
|
|
async ownerFrame(): Promise<{ frame?: FrameChannel }> {
|
2020-07-14 18:26:50 -07:00
|
|
|
return { frame: lookupNullableDispatcher<FrameDispatcher>(await this._elementHandle.ownerFrame()) };
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
2020-07-20 17:38:06 -07:00
|
|
|
async contentFrame(): Promise<{ frame?: FrameChannel }> {
|
2020-07-14 18:26:50 -07:00
|
|
|
return { frame: lookupNullableDispatcher<FrameDispatcher>(await this._elementHandle.contentFrame()) };
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
2020-07-20 17:38:06 -07:00
|
|
|
async getAttribute(params: { name: string }): Promise<{ value?: string }> {
|
|
|
|
const value = await this._elementHandle.getAttribute(params.name);
|
|
|
|
return { value: value === null ? undefined : value };
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
2020-07-20 17:38:06 -07:00
|
|
|
async textContent(): Promise<{ value?: string }> {
|
|
|
|
const value = await this._elementHandle.textContent();
|
|
|
|
return { value: value === null ? undefined : value };
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
2020-07-14 18:26:50 -07:00
|
|
|
async innerText(): Promise<{ value: string }> {
|
|
|
|
return { value: await this._elementHandle.innerText() };
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
2020-07-14 18:26:50 -07:00
|
|
|
async innerHTML(): Promise<{ value: string }> {
|
|
|
|
return { value: await this._elementHandle.innerHTML() };
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
2020-07-17 09:53:13 -07:00
|
|
|
async dispatchEvent(params: { type: string, eventInit: SerializedArgument }) {
|
|
|
|
await this._elementHandle.dispatchEvent(params.type, parseArgument(params.eventInit));
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
2020-07-06 10:04:09 -07:00
|
|
|
async scrollIntoViewIfNeeded(params: types.TimeoutOptions) {
|
|
|
|
await this._elementHandle.scrollIntoViewIfNeeded(params);
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
2020-07-06 10:04:09 -07:00
|
|
|
async hover(params: types.PointerActionOptions & types.PointerActionWaitOptions) {
|
|
|
|
await this._elementHandle.hover(params);
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
2020-07-06 10:04:09 -07:00
|
|
|
async click(params: types.MouseClickOptions & types.PointerActionWaitOptions & types.NavigatingActionWaitOptions) {
|
|
|
|
await this._elementHandle.click(params);
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
2020-07-06 10:04:09 -07:00
|
|
|
async dblclick(params: types.MouseMultiClickOptions & types.PointerActionWaitOptions & types.NavigatingActionWaitOptions) {
|
|
|
|
await this._elementHandle.dblclick(params);
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
2020-07-14 18:26:50 -07:00
|
|
|
async selectOption(params: { elements?: ElementHandleChannel[], options?: types.SelectOption[] } & types.NavigatingActionWaitOptions): Promise<{ values: string[] }> {
|
2020-08-18 16:44:17 -07:00
|
|
|
const elements = (params.elements || []).map(e => (e as ElementHandleDispatcher)._elementHandle);
|
|
|
|
return { values: await this._elementHandle.selectOption(elements, params.options || [], params) };
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
2020-07-06 10:04:09 -07:00
|
|
|
async fill(params: { value: string } & types.NavigatingActionWaitOptions) {
|
|
|
|
await this._elementHandle.fill(params.value, params);
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
2020-07-06 10:04:09 -07:00
|
|
|
async selectText(params: types.TimeoutOptions) {
|
|
|
|
await this._elementHandle.selectText(params);
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
2020-07-10 15:39:11 -07:00
|
|
|
async setInputFiles(params: { files: { name: string, mimeType: string, buffer: string }[] } & types.NavigatingActionWaitOptions) {
|
|
|
|
await this._elementHandle.setInputFiles(convertInputFiles(params.files), params);
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
async focus() {
|
|
|
|
await this._elementHandle.focus();
|
|
|
|
}
|
|
|
|
|
2020-07-06 10:04:09 -07:00
|
|
|
async type(params: { text: string } & { delay?: number } & types.NavigatingActionWaitOptions) {
|
|
|
|
await this._elementHandle.type(params.text, params);
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
2020-07-06 10:04:09 -07:00
|
|
|
async press(params: { key: string } & { delay?: number } & types.NavigatingActionWaitOptions) {
|
|
|
|
await this._elementHandle.press(params.key, params);
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
2020-07-06 10:04:09 -07:00
|
|
|
async check(params: types.PointerActionWaitOptions & types.NavigatingActionWaitOptions) {
|
|
|
|
await this._elementHandle.check(params);
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
2020-07-06 10:04:09 -07:00
|
|
|
async uncheck(params: types.PointerActionWaitOptions & types.NavigatingActionWaitOptions) {
|
|
|
|
await this._elementHandle.uncheck(params);
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
2020-07-20 17:38:06 -07:00
|
|
|
async boundingBox(): Promise<{ value?: types.Rect }> {
|
|
|
|
const value = await this._elementHandle.boundingBox();
|
|
|
|
return { value: value || undefined };
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
2020-07-14 18:26:50 -07:00
|
|
|
async screenshot(params: types.ElementScreenshotOptions): Promise<{ binary: Binary }> {
|
|
|
|
return { binary: (await this._elementHandle.screenshot(params)).toString('base64') };
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
2020-07-20 17:38:06 -07:00
|
|
|
async querySelector(params: { selector: string }): Promise<{ element?: ElementHandleChannel }> {
|
2020-06-30 21:30:39 -07:00
|
|
|
const handle = await this._elementHandle.$(params.selector);
|
2020-07-20 17:38:06 -07:00
|
|
|
return { element: handle ? new ElementHandleDispatcher(this._scope, handle) : undefined };
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
2020-07-14 18:26:50 -07:00
|
|
|
async querySelectorAll(params: { selector: string }): Promise<{ elements: ElementHandleChannel[] }> {
|
2020-06-25 16:05:36 -07:00
|
|
|
const elements = await this._elementHandle.$$(params.selector);
|
2020-07-14 18:26:50 -07:00
|
|
|
return { elements: elements.map(e => new ElementHandleDispatcher(this._scope, e)) };
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
2020-07-17 09:53:13 -07:00
|
|
|
async evalOnSelector(params: { selector: string, expression: string, isFunction: boolean, arg: SerializedArgument }): Promise<{ value: SerializedValue }> {
|
2020-07-14 18:26:50 -07:00
|
|
|
return { value: serializeResult(await this._elementHandle._$evalExpression(params.selector, params.expression, params.isFunction, parseArgument(params.arg))) };
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
|
|
|
|
2020-07-17 09:53:13 -07:00
|
|
|
async evalOnSelectorAll(params: { selector: string, expression: string, isFunction: boolean, arg: SerializedArgument }): Promise<{ value: SerializedValue }> {
|
2020-07-14 18:26:50 -07:00
|
|
|
return { value: serializeResult(await this._elementHandle._$$evalExpression(params.selector, params.expression, params.isFunction, parseArgument(params.arg))) };
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
2020-08-14 14:47:24 -07:00
|
|
|
|
2020-08-17 16:22:34 -07:00
|
|
|
async waitForElementState(params: { state: 'visible' | 'hidden' | 'stable' | 'enabled' } & types.TimeoutOptions): Promise<void> {
|
|
|
|
await this._elementHandle.waitForElementState(params.state, params);
|
|
|
|
}
|
|
|
|
|
2020-08-14 14:47:24 -07:00
|
|
|
async waitForSelector(params: { selector: string } & types.WaitForElementOptions): Promise<{ element?: ElementHandleChannel }> {
|
|
|
|
return { element: ElementHandleDispatcher.createNullable(this._scope, await this._elementHandle.waitForSelector(params.selector, params)) };
|
|
|
|
}
|
2020-06-25 16:05:36 -07:00
|
|
|
}
|
2020-06-26 11:51:47 -07:00
|
|
|
|
2020-07-10 15:39:11 -07:00
|
|
|
export function convertInputFiles(files: { name: string, mimeType: string, buffer: string }[]): types.FilePayload[] {
|
|
|
|
return files.map(f => ({ name: f.name, mimeType: f.mimeType, buffer: Buffer.from(f.buffer, 'base64') }));
|
2020-06-26 11:51:47 -07:00
|
|
|
}
|