@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.
59 lines (58 loc) • 2.57 kB
JavaScript
import { jsx as _jsx, Fragment as _Fragment } from "react/jsx-runtime";
import { RenderWidgetService } from '../services/render-widget-service';
import { RestClient } from '../rest-sdk/rest-client';
import { cookies, headers } from 'next/headers';
import { setHostServerContext } from '../services/server-context';
import { initServerSideRestSdk } from '../rest-sdk/init';
import { widgetRegistry } from '@widgetregistry';
import { initRegistry } from '../editor/widget-framework/widget-registry';
export async function RenderLazyWidgets({ searchParams }) {
const hostHeader = headers().get('host') || '';
setHostServerContext(hostHeader);
if (!RenderWidgetService.widgetRegistry) {
RenderWidgetService.widgetRegistry = initRegistry(widgetRegistry);
}
const pageUrl = searchParams['pageUrl'];
let cookie = cookies().toString();
const lazyWidgets = await RestClient.getLazyWidgets({
url: pageUrl,
correlationId: searchParams['correlationId'],
referrer: searchParams['referrer'],
cookie: cookie
});
lazyWidgets.forEach(x => x.Lazy = false);
let path = pageUrl;
let query = '';
const questionMarkIndex = pageUrl.indexOf('?');
if (questionMarkIndex > -1) {
path = pageUrl.substring(0, questionMarkIndex);
query = pageUrl.substring(questionMarkIndex);
}
let params = new URLSearchParams(query);
const paramsAsObject = Object.fromEntries(params);
const layoutResponse = await RestClient.getPageLayout({
pagePath: path,
queryParams: paramsAsObject,
cookie: cookie,
followRedirects: true
});
const layout = layoutResponse.layout;
await initServerSideRestSdk({ metadataHash: layout.MetadataHash });
const requestContext = {
layout: layout,
searchParams: searchParams,
isEdit: false,
isPreview: false,
isLive: true,
culture: layout.Culture,
url: path,
pageNode: layout.Fields
};
return (_jsx("div", { id: "widgetPlaceholder", children: _jsx(_Fragment, { children: lazyWidgets.map((lazy) => {
const widgetEntry = RenderWidgetService.widgetRegistry.widgets[lazy.Name];
if (widgetEntry && !widgetEntry.ssr) {
return (_jsx("div", { id: lazy.Id, "data-sfmodel": true, children: JSON.stringify(lazy) }, lazy.Id));
}
return (_jsx("div", { id: lazy.Id, children: RenderWidgetService.createComponent(lazy, requestContext) }, lazy.Id));
}) }) }));
}