@progress/sitefinity-nextjs-sdk
Version:
Provides OOB widgets developed using the Next.js framework, which includes an abstraction layer for Sitefinity communication. Additionally, it offers an expanded API, typings, and tools for further development and integration.
78 lines (77 loc) • 4.53 kB
JavaScript
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
import { StyleGenerator } from '../styling/style-generator.service';
import { StylingConfig } from '../styling/styling-config';
import { VisibilityStyle } from '../styling/visibility-style';
import { SearchBoxClient } from './search-box-client';
import { classNames } from '../../editor/utils/classNames';
import { getCustomAttributes, htmlAttributes } from '../../editor/widget-framework/attributes';
import { getMinimumWidgetContext } from '../../editor/widget-framework/widget-context';
import { RestSdkTypes } from '../../rest-sdk/rest-client';
import { RootUrlService } from '../../rest-sdk/root-url.service';
import { RestClientForContext } from '../../services/rest-client-for-context';
import { RenderView } from '../common/render-view';
import { Tracer } from '@progress/sitefinity-nextjs-sdk/diagnostics/empty';
import { ODataFilterSerializer } from '../../rest-sdk/services/odata-filter-serializer';
import { SearchFilterMetadataProvider } from '../../rest-sdk/services/search-filter-metadata-provider';
import { FilterConverterService } from '../../rest-sdk';
export async function SearchBox(props) {
const { span, ctx } = Tracer.traceWidget(props, true);
const entity = props.model.Properties;
const requestContext = props.requestContext;
const dataAttributes = htmlAttributes(props);
const defaultClass = entity.CssClass;
const marginClass = entity.Margins && StyleGenerator.getMarginClasses(entity.Margins);
dataAttributes['className'] = classNames('position-relative', defaultClass, marginClass);
const customAttributes = getCustomAttributes(entity.Attributes, 'SearchBox');
let scoringProfile = {
scoringSetting: entity.ScoringProfile || '',
scoringParameters: entity.ScoringParameters?.length ? entity.ScoringParameters.join(';') : ''
};
let searchResultsPageUrl = null;
if (entity.SearchResultsPage?.Content?.length && entity.SearchResultsPage.Content[0].Variations?.length) {
try {
const searchResultsPage = await RestClientForContext.getItem(entity.SearchResultsPage, { type: RestSdkTypes.Pages, culture: requestContext.culture, traceContext: ctx });
if (searchResultsPage) {
searchResultsPageUrl = searchResultsPage['ViewUrl'];
}
}
catch (error) { /* empty */ }
}
let filterExpression = null;
if (entity.FilterExpression) {
// handle invalid json in filter expression by wrapping in try catch and logging error, but not breaking the widget
try {
JSON.parse(JSON.stringify(entity.FilterExpression));
const filter = FilterConverterService.parseComplexFilter(entity.FilterExpression);
filterExpression = new ODataFilterSerializer(new SearchFilterMetadataProvider()).serialize({
Type: 'search', Filter: filter
});
}
catch (error) {
console.error('Error serializing filter expression', error);
}
}
const viewProps = {
activeClass: StylingConfig.ActiveClass,
culture: requestContext.culture,
scoringProfile: scoringProfile,
suggestionsTriggerCharCount: entity.SuggestionsTriggerCharCount || 0,
searchBoxPlaceholder: entity.SearchBoxPlaceholder,
searchButtonLabel: entity.SearchButtonLabel,
searchIndex: entity.SearchIndex,
webServicePath: `${RootUrlService.getClientCmsUrl()}/${RootUrlService.getSearchWebServicePath()}/`,
siteId: requestContext.layout.SiteId,
suggestionFields: entity.SuggestionFields,
searchResultsPageUrl: searchResultsPageUrl,
visibilityClassHidden: StylingConfig.VisibilityClasses[VisibilityStyle.Hidden],
searchAutocompleteItemClass: StylingConfig.SearchAutocompleteItemClass,
showResultsForAllIndexedSites: entity.ShowResultsForAllIndexedSites || 0,
isEdit: requestContext.isEdit,
webserviceApiKey: requestContext.webserviceApiKey,
attributes: { ...dataAttributes, ...customAttributes },
widgetContext: getMinimumWidgetContext(props),
filterExpression: filterExpression
};
const viewName = props.model.Properties.SfViewName;
return (_jsxs(RenderView, { viewName: viewName, widgetKey: props.model.Name, traceSpan: span, viewProps: viewProps, children: [entity.SearchIndex && _jsx(SearchBoxClient, { ...viewProps }), !entity.SearchIndex && _jsx("div", { ...viewProps.attributes })] }));
}