163 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			163 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| // Copyright 2004-present Facebook. 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.
 | |
| 
 | |
| namespace Facebook\WebDriver;
 | |
| 
 | |
| use Facebook\WebDriver\Exception\IndexOutOfBoundsException;
 | |
| use Facebook\WebDriver\Remote\DriverCommand;
 | |
| use Facebook\WebDriver\Remote\ExecuteMethod;
 | |
| 
 | |
| /**
 | |
|  * An abstraction allowing the driver to manipulate the browser's window
 | |
|  */
 | |
| class WebDriverWindow
 | |
| {
 | |
|     /**
 | |
|      * @var ExecuteMethod
 | |
|      */
 | |
|     protected $executor;
 | |
| 
 | |
|     public function __construct(ExecuteMethod $executor)
 | |
|     {
 | |
|         $this->executor = $executor;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the position of the current window, relative to the upper left corner
 | |
|      * of the screen.
 | |
|      *
 | |
|      * @return WebDriverPoint The current window position.
 | |
|      */
 | |
|     public function getPosition()
 | |
|     {
 | |
|         $position = $this->executor->execute(
 | |
|             DriverCommand::GET_WINDOW_POSITION,
 | |
|             [':windowHandle' => 'current']
 | |
|         );
 | |
| 
 | |
|         return new WebDriverPoint(
 | |
|             $position['x'],
 | |
|             $position['y']
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the size of the current window. This will return the outer window
 | |
|      * dimension, not just the view port.
 | |
|      *
 | |
|      * @return WebDriverDimension The current window size.
 | |
|      */
 | |
|     public function getSize()
 | |
|     {
 | |
|         $size = $this->executor->execute(
 | |
|             DriverCommand::GET_WINDOW_SIZE,
 | |
|             [':windowHandle' => 'current']
 | |
|         );
 | |
| 
 | |
|         return new WebDriverDimension(
 | |
|             $size['width'],
 | |
|             $size['height']
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Maximizes the current window if it is not already maximized
 | |
|      *
 | |
|      * @return WebDriverWindow The instance.
 | |
|      */
 | |
|     public function maximize()
 | |
|     {
 | |
|         $this->executor->execute(
 | |
|             DriverCommand::MAXIMIZE_WINDOW,
 | |
|             [':windowHandle' => 'current']
 | |
|         );
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Set the size of the current window. This will change the outer window
 | |
|      * dimension, not just the view port.
 | |
|      *
 | |
|      * @param WebDriverDimension $size
 | |
|      * @return WebDriverWindow The instance.
 | |
|      */
 | |
|     public function setSize(WebDriverDimension $size)
 | |
|     {
 | |
|         $params = [
 | |
|             'width' => $size->getWidth(),
 | |
|             'height' => $size->getHeight(),
 | |
|             ':windowHandle' => 'current',
 | |
|         ];
 | |
|         $this->executor->execute(DriverCommand::SET_WINDOW_SIZE, $params);
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Set the position of the current window. This is relative to the upper left
 | |
|      * corner of the screen.
 | |
|      *
 | |
|      * @param WebDriverPoint $position
 | |
|      * @return WebDriverWindow The instance.
 | |
|      */
 | |
|     public function setPosition(WebDriverPoint $position)
 | |
|     {
 | |
|         $params = [
 | |
|             'x' => $position->getX(),
 | |
|             'y' => $position->getY(),
 | |
|             ':windowHandle' => 'current',
 | |
|         ];
 | |
|         $this->executor->execute(DriverCommand::SET_WINDOW_POSITION, $params);
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the current browser orientation.
 | |
|      *
 | |
|      * @return string Either LANDSCAPE|PORTRAIT
 | |
|      */
 | |
|     public function getScreenOrientation()
 | |
|     {
 | |
|         return $this->executor->execute(DriverCommand::GET_SCREEN_ORIENTATION);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Set the browser orientation. The orientation should either
 | |
|      * LANDSCAPE|PORTRAIT
 | |
|      *
 | |
|      * @param string $orientation
 | |
|      * @throws IndexOutOfBoundsException
 | |
|      * @return WebDriverWindow The instance.
 | |
|      */
 | |
|     public function setScreenOrientation($orientation)
 | |
|     {
 | |
|         $orientation = mb_strtoupper($orientation);
 | |
|         if (!in_array($orientation, ['PORTRAIT', 'LANDSCAPE'])) {
 | |
|             throw new IndexOutOfBoundsException(
 | |
|                 'Orientation must be either PORTRAIT, or LANDSCAPE'
 | |
|             );
 | |
|         }
 | |
| 
 | |
|         $this->executor->execute(
 | |
|             DriverCommand::SET_SCREEN_ORIENTATION,
 | |
|             ['orientation' => $orientation]
 | |
|         );
 | |
| 
 | |
|         return $this;
 | |
|     }
 | |
| }
 |