
    ,h                     <    d dl mZ ddlmZ ddlmZ  G d d      Zy)	    )md5   )By   )Commandc                       e Zd ZddZdefdZdefdZdefdZ	e
j                  dfdedefd	Ze
j                  dfdedefd
ZddZy)
ShadowRootreturnNc                      || _         || _        y N)session_id)selfr   id_s      f/var/www/html/Resume-Scraper/venv/lib/python3.12/site-packages/selenium/webdriver/remote/shadowroot.py__init__zShadowRoot.__init__   s        c                 4    | j                   |j                   k(  S r   )r   )r   other_shadowroots     r   __eq__zShadowRoot.__eq__   s    xx+////r   c                 z    t        t        | j                  j                  d            j	                         d      S )Nzutf-8   )intmd5_hashr   encode	hexdigestr   s    r   __hash__zShadowRoot.__hash__"   s*    8DHHOOG45??A2FFr   c                 v    dj                  t        |       | j                  j                  | j                        S )Nz<<{0.__module__}.{0.__name__} (session="{1}", element="{2}")>)formattyper   
session_idr   r   s    r   __repr__zShadowRoot.__repr__%   s.    MTTJ//
 	
r   byvaluec                 F   |t         j                  k(  rt         j                  }d| d}nR|t         j                  k(  rt         j                  }d| }n)|t         j                  k(  rt         j                  }d| d}| j                  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%   s      r   find_elementzShadowRoot.find_element*   s    6 ;BE7"%E2== BwKE277]BeWB'E}}WBBb[`Dabcjkkr   c                 F   |t         j                  k(  rt         j                  }d| d}nR|t         j                  k(  rt         j                  }d| }n)|t         j                  k(  rt         j                  }d| d}| j                  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/   r0   r1   r   FIND_ELEMENTS_FROM_SHADOW_ROOTr3   s      r   find_elementszShadowRoot.find_elementsQ   s    4 ;BE7"%E2== BwKE277]BeWB'E}}WCCr\aEbcdkllr   c                 `    |si }| j                   |d<   | j                  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paramss      r   r1   zShadowRoot._executex   s1     F!XXz||##GV44r   )r
   Nr   )__name__
__module____qualname__r   boolr   r   r   strr#   r   r-   r4   r7   r1    r   r   r	   r	      sv    0$ 0G# G
# 

 &(UU %ls %l3 %lN ')ee$ $m $mC $mN5r   r	   N)hashlibr   r   	common.byr   r;   r   r	   rB   r   r   <module>rE      s   $ $  m5 m5r   