...
The script follows the structure noted in this article - imports the main class from the SDK and exports an anonymous function for the app.js invocation.
Also imported is the configuration file (line 2)
The widget’s root elements are queried by a designated data attribute selector (line 5). In this case a search box and a results widget.
For each of the root elements, a configuration object is created based on the general default configuration object. Any specific settings are additionally updated based on the available data attributes (line 10 through 16)
The landing page is parsed, if available (line 19)
The data layer is fetched based on the index name. This is an optional step required for multiple widgets placed on the same page (line 22)
The basic initialization (line 32)
Code Block var widget = HawksearchVue.createWidget(component, { config });
creates the widget on top of the root element with the provided configuration object. This type of initialization can also be used when there is only one widget on the page (e.g. search box redirecting, single page application)
For the given example, it is presumed that there is more than one widget on this page (i.e. search box, results). For that reason, we save the newly created data layer (line 33)
If a widget is provided with the same index as another on the same page, the data layer is reused and this type of initialization is used (line 28)
Code Block var widget = HawksearchVue.createWidget(component, { config, store: widgetStore });
If the type of widget is results, it is preferable to make an initial search (line 37)
...