a
    &h                     @   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dZedddZedddZedd	d
Z	e
edddZejdfeedddZejdfeedddZdddZdS )
ShadowRootN)returnc                 C   s   || _ || _d S N)session_id)selfr
   id_ r   i/var/www/html/swiplay.fr/scambot/venv/lib/python3.9/site-packages/selenium/webdriver/remote/shadowroot.py__init__   s    zShadowRoot.__init__c                 C   s   | j |j kS r	   r   )r   Z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   sn   |t jkrt j}d| d}n8|t jkr:t j}d| }n|t jkrVt 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   sn   |t jkrt j}d| d}n8|t jkr:t j}d| }n|t jkrVt j}d| d}| tj||dd S )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.
        ZshadowId)r   r
   execute)r   commandparamsr   r   r   r+   |   s    

zShadowRoot._execute)N)__name__
__module____qualname__r   boolr   r   r   strr   propertyr   r   r'   r.   r0   r+   r   r   r   r   r      s   ''r   N)hashlibr   r   Z	common.byr   r2   r   r   r   r   r   r   <module>   s   