Package 

Class ComponentQuery

  • All Implemented Interfaces:

    
    public class ComponentQuery<T extends Component>
    
                        

    Query class used for finding a component inside a given search context. The search context is either the current com.vaadin.flow.component.UI instance which searches through the whole component tree, or a com.vaadin.flow.component.Component instance, which limits the search to the component subtree.

    • Constructor Detail

      • ComponentQuery

        ComponentQuery(Class<T> componentType)
        Creates a new instance of ComponentQuery to search for components of given type.
        Parameters:
        componentType - the type of the component(s) to search for
    • Method Detail

      • withPropertyValue

         <V> ComponentQuery<T> withPropertyValue(Function<T, V> getter, V expectedValue)

        Requires the given property to have expected value.

        Parameters:
        getter - the function to get the value of the property of the field, not null
        expectedValue - value to be compared with the one obtained by applying the getter function to a component instance
      • withValue

         <V> ComponentQuery<T> withValue(V expectedValue)

        Requires the component to be an implementation of com.vaadin.flow.component.HasValue interface and to have exactly the given value. Providing a null value as expectedValue has no effects since the filter will not be applied.

        Parameters:
        expectedValue - value to be compared with the one obtained by getValue
      • withCondition

         ComponentQuery<T> withCondition(Predicate<T> condition)

        Requires the components to satisfy the given condition.

        Parameters:
        condition - the condition to check against the components.
      • withoutClassName

         ComponentQuery<T> withoutClassName(Array<String> className)

        Requires the components to have none of the given CSS class names

        Parameters:
        className - CSS class names that component should not have, not null
      • withTheme

         ComponentQuery<T> withTheme(String theme)

        Add theme that should be set on the target component.

        Parameters:
        theme - theme that should exist on the component.
      • withoutTheme

         ComponentQuery<T> withoutTheme(String theme)

        Add theme that should not be available on the target component.

        Parameters:
        theme - theme that should not exist on the component.
      • withCaption

         ComponentQuery<T> withCaption(String caption)

        Requires the component to have a caption equal to the given text Concept of caption vary based on the component type. The check is usually made against the com.vaadin.flow.dom.Elementlabel property, but for some component (e.g. Button) the text content may be used.

        Parameters:
        caption - the text the component is expected to have as its caption
      • withCaptionContaining

         ComponentQuery<T> withCaptionContaining(String text)

        Requires the component to have a caption containing the given text Concept of caption vary based on the component type. The check is usually made against the com.vaadin.flow.dom.Elementlabel property, but for some component (e.g. Button) the text content may be used.

        Parameters:
        text - the text the component is expected to have as its caption
      • withText

         ComponentQuery<T> withText(String text)

        Requires the text content of the component to be equal to the given text

        Parameters:
        text - the text the component is expected to have as its content
      • withTextContaining

         ComponentQuery<T> withTextContaining(String text)

        Requires the text content of the component to contain the given text

        Parameters:
        text - the text the component is expected to have as its caption
      • withResultsSize

         ComponentQuery<T> withResultsSize(int count)

        Requires the search to find exactly the given number of components

        Parameters:
        count - the expected number of component retrieved by the search
      • withResultsSize

         ComponentQuery<T> withResultsSize(int min, int max)

        Requires the search to find a number of components within given range

        Parameters:
        min - minimum number of components that should be found (inclusive)
        max - maximum number of components that should be found (inclusive)
      • withMinResults

         ComponentQuery<T> withMinResults(int min)

        Requires the search to find at least the given number of components

        Parameters:
        min - minimum number of components that should be found (inclusive)
      • withMaxResults

         ComponentQuery<T> withMaxResults(int max)

        Requires the search to find at most the given number of components

        Parameters:
        max - maximum number of components that should be found (inclusive)
      • withAttribute

         ComponentQuery<T> withAttribute(String attribute)

        Requires the search to find components with the given attribute set, independently of its value.

        Parameters:
        attribute - the name of the attribute, not null
      • withAttribute

         ComponentQuery<T> withAttribute(String attribute, String value)

        Requires the search to find components having the given attribute with exactly the expected value.

        Parameters:
        attribute - the name of the attribute, not null
        value - value expected to be set on attribute, not null
      • withoutAttribute

         ComponentQuery<T> withoutAttribute(String attribute)

        Requires the search to find components without the given attribute.

        Parameters:
        attribute - the name of the attribute, not null
      • withoutAttribute

         ComponentQuery<T> withoutAttribute(String attribute, String value)

        Requires the search to find components having the given attribute value different from the provided one, or to not have the attribute at all.

        Parameters:
        attribute - the name of the attribute, not null
        value - value expected not to be set on attribute, not null
      • thenOnFirst

         <E extends Component> ComponentQuery<E> thenOnFirst(Class<E> componentType)

        Gets a new ComponentQuery to search for given component type on the context of first matching component for current query.

        Parameters:
        componentType - the type of the component(s) to search for
      • thenOn

         <E extends Component> ComponentQuery<E> thenOn(int index, Class<E> componentType)

        Gets a new ComponentQuery to search for given component type on the context of the matching component at given index for current query. Index is 1-based. Given a zero or negative index or an index higher than the actual number of components found results in an IndexOutOfBoundsException.

        Parameters:
        componentType - the type of the component(s) to search for
      • single

         T single()

        Executes the search against current context and returns the component, expecting to find exactly one. Exceptions are thrown if the search produces zero or more than one result.

      • first

         T first()

        Executes the search against current context and returns the first result.

      • last

         T last()

        Executes the search against current context and returns the last result.

      • atIndex

         T atIndex(int index)

        Executes the search against current context and returns the component at given index. Index is 1-based. Given a zero or negative index or an index higher than the actual number of components found results in an IndexOutOfBoundsException.

      • id

         T id(String id)

        Executes a search for a component with the given id.

        Parameters:
        id - the id to look up
      • all

         List<T> all()

        Executes the search against current context and returns a list of matching components.

      • from

         ComponentQuery<T> from(Component context)

        Sets the context to search inside. If a null value is given, the search will be performed againt the UI.

        Parameters:
        context - a component used as starting element for search.