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: manage.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 |
---|---|---|---|
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:
| 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 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:
| 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