Script: Class dw.suggest.SuggestModel

Class SuggestModel

The Suggest model provides methods and functions to access search suggestions.

The search suggestion feature basically covers two functional areas. First is just to suggest words, based on the users input, utilizing spell correction or prediction (also known as auto completion). The second functional area is also often referred to as search-as-you-type, where, based on the users input, specific items are already looked up, before the user actually has completed typing a word or even fired up the search.

This model combines both functional areas and provides access to both - the suggested words and the items found while using the predicted words.

This model supports various types of items that are being suggested, like products, categories, brands, content pages as well merchant provided search phrases. For each type, there is a Suggestions implementation available and accessible through this model: ProductSuggestions, CategorySuggestions, BrandSuggestions, ContentSuggestions, and CustomSuggestions.

For each type of suggestions, the actual suggested items (like products) can by obtained, and, on the other hand, a list of terms is provided which were used to lookup the found items. The terms can be used to present a advanced user experience in the storefront, e.g. show auto completed words, spell corrections and so on. The SuggestModel script API will always create suggestions with Autocorrections regardless of the value of "Search Autocorrections" search preference.

Constants

MAX_SUGGESTIONS : Number=10

The maximum number of suggestions that can be obtain from this model: 10

Properties

brandSuggestions : BrandSuggestions Read Only

A BrandSuggestions container for the current search phrase. The BrandSuggestions container provides access to the found brands (if any) and the terms suggested by the system with respect to the known product brands in the catalog.

categorySuggestions : CategorySuggestions Read Only

A CategorySuggestions container for the current search phrase. The CategorySuggestions container provides access to the found categories (if any) and the terms suggested by the system with respect to the known categories in the catalog.

contentSuggestions : ContentSuggestions Read Only

A ContentSuggestions container for the current search phrase. The ContentSuggestions container provides access to the found content pages (if any) and the terms suggested by the system with respect to the known content in the library.

customSuggestions : CustomSuggestions Read Only

A CustomSuggestions container for the current search phrase. The CustomSuggestions container provides access to matching custom phrases (if any) and the terms suggested by the system with respect to the merchant provided custom phrases.

filteredByFolder : boolean

The method returns true, if the search suggestions are filtered by the folder. If this returns true it is not possible for search suggestions to contain Page Designer content as it belongs to no folder.

popularSearchPhrases : Iterator Read Only

Use this method to obtain a list of search phrases that currently are very popular among all users across the Site. The search phrases are specific to the region (based on user's IP address), language (locale) and the user's browser type (agent).

productSuggestions : ProductSuggestions Read Only

A ProductSuggestions container for the current search phrase. The ProductSuggestions container provides access to the found products (if any) and the terms suggested by the system with respect to the known products in the catalog.

recentSearchPhrases : Iterator Read Only

Use this method to obtain a list of personalized search phrases that the current user entered recently. The user is being identified by the CQuotient tracking cookie.

Constructor Summary

SuggestModel()

Constructs a new SuggestModel.

Method Summary

addRefinementValues(attributeID : String, values : String) : void

Adds a refinement for product suggestions.

getBrandSuggestions() : BrandSuggestions

Returns a BrandSuggestions container for the current search phrase.

getCategorySuggestions() : CategorySuggestions

Returns a CategorySuggestions container for the current search phrase.

getContentSuggestions() : ContentSuggestions

Returns a ContentSuggestions container for the current search phrase.

getCustomSuggestions() : CustomSuggestions

Returns a CustomSuggestions container for the current search phrase.

getPopularSearchPhrases() : Iterator

Use this method to obtain a list of search phrases that currently are very popular among all users across the Site.

getProductSuggestions() : ProductSuggestions

Returns a ProductSuggestions container for the current search phrase.

getRecentSearchPhrases() : Iterator

Use this method to obtain a list of personalized search phrases that the current user entered recently.

isFilteredByFolder() : boolean

The method returns true, if the search suggestions are filtered by the folder.

removeRefinementValues(attributeID : String, values : String) : void

Removes a refinement.

setCategoryID(categoryID : String) : void

Apply a category ID to filter product, brand and category suggestions.

setFilteredByFolder(filteredByFolder : boolean) : void

Set a flag to indicate if the search suggestions filter for elements that do not belong to a folder.

setMaxSuggestions(maxSuggestions : Number) : void

Use this method to setup the maximum number of returned suggested items.

setRefinementValues(attributeID : String, values : String) : void

Sets product suggestion refinement values for an attribute.

setSearchPhrase(searchPhrase : String) : void

Sets the user input search phrase.

Methods inherited from class Object

assign, create, create, defineProperties, defineProperty, entries, freeze, fromEntries, getOwnPropertyDescriptor, getOwnPropertyNames, getOwnPropertySymbols, getPrototypeOf, hasOwnProperty, is, isExtensible, isFrozen, isPrototypeOf, isSealed, keys, preventExtensions, propertyIsEnumerable, seal, setPrototypeOf, toLocaleString, toString, valueOf, values

Constructor Detail

SuggestModel

publicSuggestModel()

Constructs a new SuggestModel.


Method Detail

addRefinementValues

addRefinementValues(attributeID : String, values : String) : void

Adds a refinement for product suggestions. The method can be called to add an additional query parameter specified as name-value pair. The values string may encode multiple values delimited by the pipe symbol ('|').

Parameters:

attributeID - The ID of the refinement attribute.

values - the refinement value to set

getBrandSuggestions

getBrandSuggestions() : BrandSuggestions

Returns a BrandSuggestions container for the current search phrase. The BrandSuggestions container provides access to the found brands (if any) and the terms suggested by the system with respect to the known product brands in the catalog.

Returns:

a brand suggestions container for the current search phrase, returns null for insufficient search input

See Also:

setMaxSuggestions(Number)

setSearchPhrase(String)


getCategorySuggestions

getCategorySuggestions() : CategorySuggestions

Returns a CategorySuggestions container for the current search phrase. The CategorySuggestions container provides access to the found categories (if any) and the terms suggested by the system with respect to the known categories in the catalog.

Returns:

a category suggestions container for the current search phrase, returns null for insufficient search input

See Also:

setMaxSuggestions(Number)

setSearchPhrase(String)


getContentSuggestions

getContentSuggestions() : ContentSuggestions

Returns a ContentSuggestions container for the current search phrase. The ContentSuggestions container provides access to the found content pages (if any) and the terms suggested by the system with respect to the known content in the library.

Returns:

a content suggestions container for the current search phrase, returns null for insufficient search input

See Also:

setMaxSuggestions(Number)

setSearchPhrase(String)


getCustomSuggestions

getCustomSuggestions() : CustomSuggestions

Returns a CustomSuggestions container for the current search phrase. The CustomSuggestions container provides access to matching custom phrases (if any) and the terms suggested by the system with respect to the merchant provided custom phrases.

Returns:

a custom suggestions container for the current search phrase, returns null for insufficient search input

See Also:

setMaxSuggestions(Number)

setSearchPhrase(String)


getPopularSearchPhrases() : Iterator

Use this method to obtain a list of search phrases that currently are very popular among all users across the Site. The search phrases are specific to the region (based on user's IP address), language (locale) and the user's browser type (agent).

Returns:

a list of personalized popular search phrases


getProductSuggestions

getProductSuggestions() : ProductSuggestions

Returns a ProductSuggestions container for the current search phrase. The ProductSuggestions container provides access to the found products (if any) and the terms suggested by the system with respect to the known products in the catalog.

Returns:

a product suggestions container for the current search phrase, returns null for insufficient search input

See Also:

setMaxSuggestions(Number)

setSearchPhrase(String)


getRecentSearchPhrases

getRecentSearchPhrases() : Iterator

Use this method to obtain a list of personalized search phrases that the current user entered recently. The user is being identified by the CQuotient tracking cookie.

Returns:

a list of recent search phrases of the current user


isFilteredByFolder

isFilteredByFolder() : boolean

The method returns true, if the search suggestions are filtered by the folder. If this returns true it is not possible for search suggestions to contain Page Designer content as it belongs to no folder.

Returns:

True if search suggestions are filtered by the folder of the content asset.


removeRefinementValues

removeRefinementValues(attributeID : String, values : String) : void

Removes a refinement. The method can be called to remove previously added refinement values. The values string may encode multiple values delimited by the pipe symbol ('|').

Parameters:

attributeID - The ID of the refinement attribute.

values - the refinement value to remove or null to remove all values


setCategoryID

setCategoryID(categoryID : String) : void

Apply a category ID to filter product, brand and category suggestions.

Suggested products, brands and categories, as well as corrected and completed terms are specific to the given category or one of it's sub categories.

For example, in the specified category "television", the search term "pla" will be auto completed to "plasma" (instead of e.g. "player") and only televisions will be included in the list of suggested products.

Parameters:

categoryID - the category to filter suggestions for


setFilteredByFolder

setFilteredByFolder(filteredByFolder : boolean) : void

Set a flag to indicate if the search suggestions filter for elements that do not belong to a folder. Must be set to false to return content assets that do not belong to any folder.

Parameters:

filteredByFolder - filter the search suggestions by folder


setMaxSuggestions

setMaxSuggestions(maxSuggestions : Number) : void

Use this method to setup the maximum number of returned suggested items. For example, set this to 3 in order to only retrieve the 3 most relevant suggested products.

The maximum number of suggestions that can be queried are defined as MAX_SUGGESTIONS.

Parameters:

maxSuggestions - the number of suggested items to be returned by this model instance


setRefinementValues

setRefinementValues(attributeID : String, values : String) : void

Sets product suggestion refinement values for an attribute. The method can be called to set an additional query parameter specified as name-value pair. The value string may encode multiple values delimited by the pipe symbol ('|'). Existing refinement values for the attribute will be removed.

Parameters:

attributeID - The ID of the refinement attribute.

values - the refinement values to set (delimited by '|') or null to remove all values


setSearchPhrase

setSearchPhrase(searchPhrase : String) : void

Sets the user input search phrase. This search phrase is being processed by applying auto completion, spell correction and enhancement with alternative similar search terms.

The resulting search phrase is used to lookup the actual items, like products or categories (search-as-you-type).

In order to access the processed terms, one can use the SearchPhraseSuggestions.getSuggestedTerms() method of each of the respective results returned by the methods in this model.

Parameters:

searchPhrase - the user input search phrase

See Also:

SearchPhraseSuggestions.getSuggestedTerms()