blob: c6f786c8a9b9a579e8fe926d097f58c2e9b00469 [file] [log] [blame]
// Copyright 2017 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 'alert.dart';
import '../alert.dart';
import '../common.dart';
import '../target_locator.dart';
import '../web_driver.dart';
import '../window.dart';
class JsonWireTargetLocator implements TargetLocator {
final WebDriver _driver;
final Resolver _resolver;
JsonWireTargetLocator(this._driver) : _resolver = new Resolver(_driver, '');
/// Change focus to another frame on the page.
/// If [frame] is a:
/// [int]: select by its zero-based index
/// [String]: select frame by the name of the frame window or the id of the
/// frame or iframe tag.
/// [WebElement]: select the frame for a previously found frame or iframe
/// element.
/// not provided: selects the first frame on the page or the main document.
///
/// Throws [NoSuchFrameException] if the specified frame can't be found.
@override
void frame([frame]) {
_resolver.post('frame', {'id': frame});
}
/// Switch the focus of void commands for this driver to the window with the
/// given name/handle.
///
/// Throws [NoSuchWindowException] if the specified window can't be found.
@Deprecated('Use "Window.setAsActive()". '
'Selecting by name is not supported by the current W3C spec.')
@override
void window(dynamic window) {
if (window is Window) {
window.setAsActive();
} else if (window is String) {
_resolver.post('window', {'name': window});
} else {
throw 'Unsupported type: ${window.runtimeType}';
}
}
/// Switches to the currently active modal dialog for this particular driver
/// instance.
@override
Alert get alert => new JsonWireAlert(_driver);
@override
String toString() => '$_driver.switchTo';
@override
int get hashCode => _driver.hashCode;
@override
bool operator ==(other) =>
other is JsonWireTargetLocator && other._driver == _driver;
}