# -*- coding: utf-8 -*-
# This Source Code Form is subject to the terms of the Mozilla Public
# License, v. 2.0. If a copy of the MPL was not distributed with this
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
from __future__ import absolute_import
from marionette_driver.marionette import Actions, errors
class CaretActions(Actions):
def __init__(self, marionette):
super(CaretActions, self).__init__(marionette)
self._reset_action_chain()
def _reset_action_chain(self):
self.mouse_chain = self.sequence(
"pointer", "pointer_id", {"pointerType": "mouse"}
)
self.key_chain = self.sequence("key", "keyboard_id")
def flick(self, element, x1, y1, x2, y2, duration=200):
"""Perform a flick gesture on the target element.
:param element: The element to perform the flick gesture on.
:param x1: Starting x-coordinate of flick, relative to the top left
corner of the element.
:param y1: Starting y-coordinate of flick, relative to the top left
corner of the element.
:param x2: Ending x-coordinate of flick, relative to the top left
corner of the element.
:param y2: Ending y-coordinate of flick, relative to the top left
corner of the element.
"""
rect = element.rect
el_x, el_y = rect["x"], rect["y"]
# Add element's (x, y) to make the coordinate relative to the viewport.
from_x, from_y = int(el_x + x1), int(el_y + y1)
to_x, to_y = int(el_x + x2), int(el_y + y2)
self.mouse_chain.pointer_move(from_x, from_y).pointer_down().pointer_move(
to_x, to_y, duration=duration
).pointer_up()
return self
def send_keys(self, keys):
"""Perform a keyDown and keyUp action for each character in `keys`.
:param keys: String of keys to perform key actions with.
"""
self.key_chain.send_keys(keys)
return self
def perform(self):
"""Perform the action chain built so far to the server side for execution
and clears the current chain of actions.
Warning: This method performs all the mouse actions before all the key
actions!
"""
self.mouse_chain.perform()
self.key_chain.perform()
self._reset_action_chain()
class SelectionManager(object):
"""Interface for manipulating the selection and carets of the element.
We call the blinking cursor (nsCaret) as cursor, and call AccessibleCaret as
caret for short.
Simple usage example:
::
element = marionette.find_element(By.ID, 'input')
sel = SelectionManager(element)
sel.move_caret_to_front()
"""
def __init__(self, element):
self.element = element
def _input_or_textarea(self):
"""Return True if element is either or