/
Update facet to add a display rule

Update facet to add a display rule

This API allows you to update a facet in Hawksearch dashboard and manage the facet configurations.

Example use case: Add a display rule for the Price facet so that it is only visible when Brand is ‘Columbia Sportswear’.

Note: Please pass the FacetId in the PUT request below.

Request: PUT request to the API:

PUT /api/v9/facet/83284 HTTP/1.1 Host: dashboard-na.hawksearch.com X-HawkSearch-ApiKey: USE_YOUR_API_KEY Content-Type: application/json Cache-Control: no-cache { "SyncGuid": "e96a399a-f25b-4311-bf26-68c958f5bfl8", "FacetId": 83284, "Name": "Price", "FacetType": "checkbox", "FieldType": "numeric", "MaxCount": 30, "MinHitCount": 1, "Field": "price", "Param": "", "DisplayType": "default", "ScrollHeight": 0, "ScrollThreshold": 0, "TruncateThreshold": 0, "SearchThreshold": 0, "SortOrder": 20932, "ExpandSelection": false, "IsCurrency": true, "IsNumeric": true, "IsSearch": false, "IsVisible": true, "UBound": null, "LBound": null, "Increment": "0", "NofVisible": 10, "Height": 0, "DisplayRuleXML": "<?xml version=\"1.0\" encoding=\"utf-16\"?>\r\n<Rule xmlns:xsd=\"http://www.w3.org/2001/XMLSchema\" xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" Operator=\"Any\" RuleType=\"Group\">\r\n <Rules>\r\n <Rule Operator=\"None\" RuleType=\"Eval\">\r\n <Rules />\r\n <Field>facet:brand</Field>\r\n <Condition>is</Condition>\r\n <Value>Columbia Sportswear</Value>\r\n </Rule>\r\n </Rules>\r\n <Field />\r\n <Condition />\r\n <Value />\r\n</Rule>", "SortBy": "Ascending", "ParentId": 0, "IsCollapsible": true, "IsCollapsedDefault": false, "SwatchData": null, "FacetRangeDisplayType": 0, "PreloadChildren": false, "Tooltip": "Price", "ShowSliderInputs": true, "ShowFacetImageCount": true, "FacetRanges": [ { "RangeId": 72624, "Name": "$0 - $150.99\t", "LBound": "0", "UBound": "150.99", "SortOrder": 1, "AssetName": "", "AssetUrl": "" }, { "RangeId": 72625, "Name": "$151 - $200.99", "LBound": "151", "UBound": "200.99", "SortOrder": 2, "AssetName": "", "AssetUrl": "" }, { "RangeId": 72626, "Name": "$201 - $500", "LBound": "201", "UBound": "500", "SortOrder": 3, "AssetName": "", "AssetUrl": "" }, { "RangeId": 72627, "Name": "$501 - $750", "LBound": "501", "UBound": "750", "SortOrder": 4, "AssetName": "", "AssetUrl": "" }, { "RangeId": 72628, "Name": "$751 - $1000", "LBound": "751", "UBound": "1000", "SortOrder": 5, "AssetName": "", "AssetUrl": "" }, { "RangeId": 72629, "Name": "$1000 - $2000", "LBound": "1000", "UBound": "2000", "SortOrder": 6, "AssetName": "", "AssetUrl": "" }, { "RangeId": 72630, "Name": "$2000 - $3000", "LBound": "2000", "UBound": "3000", "SortOrder": 7, "AssetName": "", "AssetUrl": "" }, { "RangeId": 72631, "Name": "$3000 and Up", "LBound": "3000", "UBound": "999999999", "SortOrder": 8, "AssetName": "", "AssetUrl": "" } ], "Tags": "", "CreateDate": "01-01-0001", "ModifyDate": "04-12-2021", "BoostBury": { "BoostValues": [], "BuryValues": [] }, "ListName": "Price", "NumericPrecision": 0, "CurrencySymbol": null }

 

Response: The response is an array of facet objects, every facet object being a series of key-value pairs. Description of the data is as follows:

No

Key

Description

Value Type

No

Key

Description

Value Type

1

FacetId

The unique identifier of the facet (unique across the whole system)

Number

2

SyncGuid

Internal field

GUID

3

Name

This is the name of the facet displayed to the user on the search results page. This property corresponds to the display name of the facet in the workbench.

Alphanumeric string

4

FacetType

Indicates the mode in which the facet is displayed and configurable from the workbench. Possible values for this are:

  • checkbox (Checkbox List)

  • link (Link List)

  • nestedcheckbox (Nested Checkbox)

  • nestedlinklist (Nested Link List)

  • size (Size)

  • swatch (Swatch)

  • rating (Rating)

  • slider (Slider)

  • related (Related Searches)

  • recentsearches (Recent Searches)

  • search (Search Within)

One of the possible values -

checkbox (String, Numeric, Range, Tabs)

link (String, Numeric, Range, Tabs)

nestedcheckbox (String, Numeric, Tabs)

nestedlinklist (String, Numeric, Tabs)

size (String, Numeric, Tabs)

swatch (String, Numeric, Tabs)

rating (String, Numeric, Tabs)

slider (Numeric, Range)

related (Search)

recentsearches (Search)

search (Search)

5

FieldType

Datatype of the field

One of the 3 possible values -

Single
Numeric
String

Search

6

MaxCount

The integer value which indicates the maximum number of facet values which can be displayed inside the facet.

Numeric

7

MinHitCount

The integer value which indicates the minimum number of facet values the minimum count of filters the facet must possess in order to be displayed as an option.

Numeric

8

Field

The name of the field for the facet.

lowercase alphanumeric string with underscores allowed

9

Param

This is the parameter to be used if you need to apply filter using this facet. Example, if you need to filter by the brand "The North Face" then in send the parameter "brand=The North Face" in addition to the other filters.

Alphanumeric

10

DisplayType

This is the property which provides options to fine-tune the way the list of facet values will be displayed. In the JSON output, the three different choices that will determine what fields will need to be defined in lowercase:

  • scrolling

  • default

  • truncating

String

11

ScrollHeight

This is used when the facet's DisplayType is set to scroll. It sets the height of the facet in pixels.

Numeric

12

ScrollThreshold

This is used when the facet's DisplayType is set to scroll. It sets the minimum limit for the number of filters to be present in the facet for it to be displayed in a scrolling manner.

Numeric

13

TruncateThreshold

This is used when the facet's DisplayType is set to Truncating.The truncated facet shows only the first N values where N is the number set in the workbench, to load more values, user needs to click the "show more" link.

Numeric

14

SearchThreshold

It specifies the minimum number of filters to be present in the facet to make it search-able. The facet needs to have "Is Search Enabled?" set to on, in other words IsSearch property needs to be true.

Numeric

15

IsCurrency

Indicates if the facet needs to display the currency symbol. If the facet's FieldType is set as either numeric or range, and the display type is slider, then this option is displayed.

Boolean

16

IsNumeric

Indicator for range type of facets to show the slider. This property is hidden for all other facet types.

Boolean

17

IsSearch

This makes the facet searchable for its filters. This is useful for facets containing more than 15 values in general.

Boolean

18

IsVisible

Boolean switch to toggle the visibility of the facet

Boolean

19

UBound

Indicates the upper bound of the range facet.

Numeric

20

LBound

Indicates the lower bound of the range facet.

Numeric

21

Increment

Setting up the range facet slider value

Numeric

22

NofVisible

Number of Visible Facet values

Numeric

23

Height

Height of the scrollable facet values

Numeric

24

DisplayRuleXML

Display rule details of the facet in XML format

XML

25

SortBy

Indicates the default sort order of the facet.

Numeric

26

ParentId

ParentId of the facet for Hierarchial facets.

Numeric

27

IsCollapsible

Boolean value indicating whether the facet can be completely collapsed into a header

Boolean

28

IsCollapsedDefault

Boolean value indicating collapsible display

Boolean

29

SwatchData

A special type of facet is a swatch which displays images instead of the facet filters. The JSON output consists of the list of images. This is most useful for colors.

Alphanumeric

30

FacetRangeDisplayType

Numeric value to indicate the sub type of the facet when it is a range.

Numeric

31

PreloadChildren

Nested facets can load children filters either upon click event of the parent filter or automatically. This choice can be opted based on the value of this property.

Boolean

32

Tooltip

Quick help for the user available when hovered over the question mark next to the facet name

Alphanumeric

33

ShowSliderInputs

For slider facet, the user-entered inputs can be made visible using this property.

Boolean

34

ShowFacetImageCount

Boolean value to show or hide facet image count

Boolean

35

FacetRanges

It consistes of FacetRangeModel object.

FacetRangeModel Object

36

Tags

Tags assocaited with a facet

Alphanumeric

37

CreateDate

Facet Creation Date

Date string in MM-DD-YYYY format

38

ModifyDate

Facet Modification Date

Date string in MM-DD-YYYY format

39

BoostValues

Boost value of a facet

Numeric

40

BuryValues

Bury value of a facet

Numeric

41

ListName

Name of the facet which is not displayed to front end users.

Alphanumeric

42

NumericPrecision

Numeric

Numeric

43

CurrencySymbol

If facet type uses Currency

Alphanumeric

44

ExpandSelection

This field controls whether or not you will allow your customer to see additional filters after making their initial selection. All relevant sub departments will still be returned, but other filters not related to the initial selection will be hidden if this option is set to NO. If the option is set to YES, then the top level filters, and each layer of additional sub-departments, will be displayed. 

This is helpful if you have a department that has hundreds of sub-departments, for example. You can limit the number of filters that your customers can view so as not to overwhelm them.

Boolean

 

{ "SyncGuid": "e96a399a-f25b-4311-bf26-68c958f5bfb8", "FacetId": 83284, "Name": "Price", "FacetType": "checkbox", "FieldType": "numeric", "MaxCount": 30, "MinHitCount": 1, "Field": "price", "Param": "", "DisplayType": "default", "ScrollHeight": 0, "ScrollThreshold": 0, "TruncateThreshold": 0, "SearchThreshold": 0, "SortOrder": 20932, "ExpandSelection": false, "IsCurrency": true, "IsNumeric": true, "IsSearch": false, "IsVisible": true, "UBound": null, "LBound": null, "Increment": "0", "NofVisible": 10, "Height": 0, "DisplayRuleXML": "<?xml version=\"1.0\" encoding=\"utf-16\"?>\r\n<Rule xmlns:xsd=\"http://www.w3.org/2001/XMLSchema\" xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" Operator=\"Any\" RuleType=\"Group\">\r\n <Rules>\r\n <Rule Operator=\"None\" RuleType=\"Eval\">\r\n <Field>facet:brand</Field>\r\n <Condition>is</Condition>\r\n <Value>Columbia Sportswear</Value>\r\n </Rule>\r\n </Rules>\r\n</Rule>", "SortBy": "Ascending", "ParentId": 0, "IsCollapsible": true, "IsCollapsedDefault": false, "SwatchData": null, "FacetRangeDisplayType": 0, "PreloadChildren": false, "Tooltip": "Price", "ShowSliderInputs": true, "ShowFacetImageCount": true, "FacetRanges": [ { "RangeId": 1, "Name": "$0 - $150.99\t", "LBound": "0", "UBound": "150.99", "SortOrder": 1, "AssetName": "", "AssetUrl": "" }, { "RangeId": 2, "Name": "$151 - $200.99", "LBound": "151", "UBound": "200.99", "SortOrder": 2, "AssetName": "", "AssetUrl": "" }, { "RangeId": 3, "Name": "$201 - $500", "LBound": "201", "UBound": "500", "SortOrder": 3, "AssetName": "", "AssetUrl": "" }, { "RangeId": 4, "Name": "$501 - $750", "LBound": "501", "UBound": "750", "SortOrder": 4, "AssetName": "", "AssetUrl": "" }, { "RangeId": 5, "Name": "$751 - $1000", "LBound": "751", "UBound": "1000", "SortOrder": 5, "AssetName": "", "AssetUrl": "" }, { "RangeId": 6, "Name": "$1000 - $2000", "LBound": "1000", "UBound": "2000", "SortOrder": 6, "AssetName": "", "AssetUrl": "" }, { "RangeId": 7, "Name": "$2000 - $3000", "LBound": "2000", "UBound": "3000", "SortOrder": 7, "AssetName": "", "AssetUrl": "" }, { "RangeId": 8, "Name": "$3000 and Up", "LBound": "3000", "UBound": "999999999", "SortOrder": 8, "AssetName": "", "AssetUrl": "" } ], "Tags": "", "CreateDate": "01-01-0001", "ModifyDate": "04-12-2021", "BoostBury": { "BoostValues": [], "BuryValues": [] }, "ListName": "Price", "NumericPrecision": 0, "CurrencySymbol": null }

 

DisplayRuleXML Representation Example

If the condition set for the rules for selecting products is not linear and requires multiple clauses which cannot be accommodated by the attribute_name or the attribute_value structure, please specify the entire xml for the rule as shown below.

 

<?xml version="1.0" encoding="UTF-8"?> <Rule xmlns:xsd="https://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" RuleType="Group" Operator="All"> <Rules> <Rule RuleType="Eval" Operator="None"> <Field>facet:brand</Field> <Condition>is</Condition> <Value>Columbia Sportswear</Value> </Rule> <Rule RuleType="Eval" Operator="None"> <Field>facet:subdepartment</Field> <Condition>is</Condition> <Value>Socks</Value> </Rule> <Rule RuleType="Eval" Operator="None"> <Field>keyword:Keyword</Field> <Condition>contains</Condition> <Value>sock</Value> </Rule> </Rules> </Rule>

 

Rules node


Attributes:

  • RuleType attribute specifies if the rule must be processed for a result or treated as a group with rules nested inside it. If the rules node contains further rules, then the type must be set to “Group” for that rules node. For rules that need to be evaluated, please set this attribute to “Eval.”

  • Operator attribute specifies what the condition is for evaluation for rules with in a group. If all rules in the group need to be met to satisfy the group the value must be set to “All”. If at least one rule needs to be satisfied, please set the value to “Any”. For nested rules (not the parent rules node), if there is only one rule inside the group please set value to “None”.


Child Nodes:

  • Field: Specify the field name you want to use as part of condition

  • Condition: Specify the condition (is equal to, contains) so on

  • Value: This is the value to compare against