o
    OTh                     @   s6   d dl mZ ddlmZ ddlmZ G dd dZdS )	    )md5   )By   )Commandc                   @   s   e Zd ZdddZdefddZdefddZdefd	d
Z	e
defddZejdfdedefddZejdfdedefddZdddZdS )
ShadowRootreturnNc                 C   s   || _ || _d S N)session_id)selfr
   id_ r   e/home/air/segue/gemini/back/venv/lib/python3.10/site-packages/selenium/webdriver/remote/shadowroot.py__init__   s   
zShadowRoot.__init__c                 C   s   | j |j kS r	   r   )r   other_shadowrootr   r   r   __eq__   s   zShadowRoot.__eq__c                 C   s   t t| jd dS )Nzutf-8   )intmd5_hashr   encode	hexdigestr   r   r   r   __hash__"   s   zShadowRoot.__hash__c                 C   s   d t| | jj| jS )Nz<<{0.__module__}.{0.__name__} (session="{1}", element="{2}")>)formattyper
   
session_idr   r   r   r   r   __repr__%   s   zShadowRoot.__repr__c                 C   s   | j S r	   r   r   r   r   r   id*   s   zShadowRoot.idbyvaluec                 C   n   |t jkrt j}d| d}n|t jkrt j}d| }n|t jkr+t j}d| d}| tj||dd S )a  Find an element inside a shadow root given a By strategy and
        locator.

        Parameters:
        -----------
        by : selenium.webdriver.common.by.By
            The locating strategy to use. Default is `By.ID`. Supported values include:
            - By.ID: Locate by element ID.
            - By.NAME: Locate by the `name` attribute.
            - By.XPATH: Locate by an XPath expression.
            - By.CSS_SELECTOR: Locate by a CSS selector.
            - By.CLASS_NAME: Locate by the `class` attribute.
            - By.TAG_NAME: Locate by the tag name (e.g., "input", "button").
            - By.LINK_TEXT: Locate a link element by its exact text.
            - By.PARTIAL_LINK_TEXT: Locate a link element by partial text match.
            - RelativeBy: Locate elements relative to a specified root element.

        Example:
        --------
        element = driver.find_element(By.ID, 'foo')

        Returns:
        -------
        WebElement
            The first matching `WebElement` found on the page.
        [id=""].[name="usingr!   r!   )r   IDCSS_SELECTOR
CLASS_NAMENAME_executer   FIND_ELEMENT_FROM_SHADOW_ROOTr   r    r!   r   r   r   find_element.   s   


zShadowRoot.find_elementc                 C   r"   )a  Find elements inside a shadow root given a By strategy and locator.

        Parameters:
        -----------
        by : selenium.webdriver.common.by.By
            The locating strategy to use. Default is `By.ID`. Supported values include:
            - By.ID: Locate by element ID.
            - By.NAME: Locate by the `name` attribute.
            - By.XPATH: Locate by an XPath expression.
            - By.CSS_SELECTOR: Locate by a CSS selector.
            - By.CLASS_NAME: Locate by the `class` attribute.
            - By.TAG_NAME: Locate by the tag name (e.g., "input", "button").
            - By.LINK_TEXT: Locate a link element by its exact text.
            - By.PARTIAL_LINK_TEXT: Locate a link element by partial text match.
            - RelativeBy: Locate elements relative to a specified root element.

        Example:
        --------
        element = driver.find_elements(By.ID, 'foo')

        Returns:
        -------
        List[WebElement]
            list of `WebElements` matching locator strategy found on the page.
        r#   r$   r%   r&   r'   r!   )r   r)   r*   r+   r,   r-   r   FIND_ELEMENTS_FROM_SHADOW_ROOTr/   r   r   r   find_elementsU   s   


zShadowRoot.find_elementsc                 C   s    |si }| j |d< | j||S )a9  Executes a command against the underlying HTML element.

        Args:
          command: The name of the command to _execute as a string.
          params: A dictionary of named parameters to send with the command.

        Returns:
          The command's JSON response loaded into a dictionary object.
        shadowId)r   r
   execute)r   commandparamsr   r   r   r-   |   s   

zShadowRoot._execute)r   Nr	   )__name__
__module____qualname__r   boolr   r   r   strr   propertyr   r   r)   r0   r2   r-   r   r   r   r   r      s    
''r   N)hashlibr   r   	common.byr   r5   r   r   r   r   r   r   <module>   s   