UNPKG

@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.

28 lines (27 loc) 1.43 kB
import { jsx as _jsx, Fragment as _Fragment } from "react/jsx-runtime"; import { DetailPageSelectionMode } from '../../content-lists-common/detail-page-selection-mode'; import { KnownContentTypes } from '@progress/sitefinity-widget-designers-sdk'; export function OpenDetailsAnchor(props) { const item = props.item; let url = undefined; if (item.Original?.ItemDefaultUrl && props.detailPageUrl) { url = props.detailPageUrl + item.Original?.ItemDefaultUrl; } else if (props.type && props.type === KnownContentTypes.ListItems && props.item.Original?.Parent) { const listItemUrlName = props.item.Original.UrlName; const parentUrlName = props.item.Original.Parent.UrlName; url = `${props.detailPageUrl}/lists/${parentUrlName}/${listItemUrlName}`; } if (url && props.detailPageMode === DetailPageSelectionMode.SamePage) { if (props.requestContext && props.requestContext.searchParams && Object.keys(props.requestContext.searchParams).length) { url += '?' + new URLSearchParams(props.requestContext.searchParams).toString(); } } function getItemTitle(item) { return item.Title?.Value || item.Original['Title']; } return url ? (_jsx("a", { href: url, className: props.className, children: props.text || getItemTitle(item) })) : (_jsx(_Fragment, { children: props.text || getItemTitle(item) })); }