All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.sphere.sdk.search.model.FacetSearchModel Maven / Gradle / Ivy

There is a newer version: 1.0.0-M26
Show newest version
package io.sphere.sdk.search.model;

import io.sphere.sdk.search.*;

import javax.annotation.Nullable;

import java.util.function.Function;

import static java.util.Collections.singletonList;

abstract class FacetSearchModel extends SearchModelImpl {
    @Nullable
    protected final String alias;
    protected final Function typeSerializer;

    FacetSearchModel(@Nullable final SearchModel parent, final Function typeSerializer, final String alias) {
        super(parent, null);
        this.typeSerializer = typeSerializer;
        this.alias = alias;
    }

    FacetSearchModel(@Nullable final SearchModel parent, final Function typeSerializer) {
        super(parent, null);
        this.typeSerializer = typeSerializer;
        this.alias = null;
    }

    @Nullable
    public String getAlias() {
        return alias;
    }

    /**
     * Allows to set an alias to identify the facet.
     * @param alias the identifier to use for the facet
     * @return a new facet search model identical to the current one, but with the given alias
     */
    public abstract FacetSearchModel withAlias(final String alias);

    /**
     * Generates an expression to obtain the facets of the attribute for all values.
     * For example: a possible faceted classification could be ["red": 4, "yellow": 2, "blue": 1].
     * @return a facet expression for all values
     */
    public TermFacetExpression allTerms() {
        return new TermFacetExpressionImpl<>(this, typeSerializer, alias);
    }

    /**
     * Generates an expression to obtain the facet of the attribute for only the given value.
     * For example: a possible faceted classification for "red" could be ["red": 4].
     * @param value the value from which to obtain the facet
     * @return a facet expression for only the given value
     */
    public FilteredFacetExpression onlyTerm(final V value) {
        return onlyTerm(singletonList(value));
    }

    /**
     * Generates an expression to obtain the facets of the attribute for only the given values.
     * For example: a possible faceted classification for ["red", "blue"] could be ["red": 4, "blue": 1].
     * @param values the values from which to obtain the facets
     * @return a facet expression for only the given values
     */
    public FilteredFacetExpression onlyTerm(final Iterable values) {
        return new FilteredFacetExpressionImpl<>(this, typeSerializer, values, alias);
    }

    /**
     * Generates an expression to obtain the facets of the attribute for only the given values.
     * For example: a possible faceted classification for ["red", "blue"] could be ["red": 4, "blue": 1].
     * @param values the values from which to obtain the facets
     * @return a facet expression for only the given values
     */
    public FilteredFacetExpression onlyTermAsString(final Iterable values) {
        return new FilteredFacetExpressionImpl<>(this, TypeSerializer.ofString(), values, alias);
    }

    /**
     * Generates an expression to obtain the facets of the attribute for all values.
     * For example: a possible faceted classification could be ["red": 4, "yellow": 2, "blue": 1].
     * @return a facet expression for all values
     * @deprecated use {@link #allTerms()} instead
     */
    @Deprecated
    public TermFacetExpression byAllTerms() {
        return new TermFacetExpressionImpl<>(this, typeSerializer, alias);
    }

    /**
     * Generates an expression to obtain the facet of the attribute for only the given value.
     * For example: a possible faceted classification for "red" could be ["red": 4].
     * @param value the value from which to obtain the facet
     * @return a facet expression for only the given value
     * @deprecated use {@link #onlyTerm(Object)}
     */
    @Deprecated
    public FilteredFacetExpression byTerm(final V value) {
        return onlyTerm(singletonList(value));
    }

    /**
     * Generates an expression to obtain the facets of the attribute for only the given values.
     * For example: a possible faceted classification for ["red", "blue"] could be ["red": 4, "blue": 1].
     * @param values the values from which to obtain the facets
     * @return a facet expression for only the given values
     * @deprecated use {@link #onlyTerm(Iterable)}
     */
    @Deprecated
    public FilteredFacetExpression byTerm(final Iterable values) {
        return new FilteredFacetExpressionImpl<>(this, typeSerializer, values, alias);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy