Skip to content

Commit

Permalink
CTC-2582 update portable text examples (#90)
Browse files Browse the repository at this point in the history
* CTC-2582 update portable text examples

* CTC-2582 Extend rich text resolver samples

Added comments and changed return values

---------

Co-authored-by: Jan Cerman <[email protected]>
  • Loading branch information
pokornyd and jancerman authored Oct 23, 2024
1 parent 289363d commit 6528dbe
Show file tree
Hide file tree
Showing 7 changed files with 142 additions and 182 deletions.
35 changes: 0 additions & 35 deletions ts/structure-in-rte/resolve_rich_text_components_items.ts

This file was deleted.

35 changes: 35 additions & 0 deletions ts/structure-in-rte/resolve_rich_text_components_items.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
import { Elements } from "@kontent-ai/delivery-sdk";
import { PortableTextComponent } from "@kontent-ai/rich-text-resolver";
import { PortableTextComponents, PortableTextTypeComponentProps, } from "@portabletext/react";
import { React } from 'react';

import { CalloutComponent } from "../components/shared/richText/Callout";
import { contentTypes } from "../models";

const createRichTextResolver = (element: Elements.RichTextElement): Partial<PortableTextComponents> => ({
types: {
// Components and content items inserted in rich text
component: ({
value,
}: PortableTextTypeComponentProps<PortableTextComponent>) => {
// Checks if the inserted content item is included in the response
// Kontent.ai components are always included in the response
const componentOrItem = element.linkedItems.find(
(i) => i.system.codename === value.component._ref
);

if (!componentOrItem) {
return (<div>The referenced content item '{componentOrItem.system.codename}' wasn't found.</div>);
}

// Renders the component or content item based on its type
switch (componentOrItem.system.type) {
// Tip: Generate models at https://kontent.ai/learn/strongly-typed-models
case contentTypes.callout.codename:
return <CalloutComponent item={componentOrItem} />;
default:
return (<div>Content based on the type '{componentOrItem.system.type}' couldn't be resolved.</div>);
}
},
},
});
35 changes: 0 additions & 35 deletions ts/structure-in-rte/resolve_rich_text_flow.ts

This file was deleted.

55 changes: 55 additions & 0 deletions ts/structure-in-rte/resolve_rich_text_flow.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,55 @@
import { Elements } from "@kontent-ai/delivery-sdk";
import { nodeParse, transformToPortableText, } from "@kontent-ai/rich-text-resolver";
import { PortableText, PortableTextComponents } from "@portabletext/react";
import { React } from "react";

// Defines how to transform Kontent.ai-specific portable text components, as well as default blocks
const createRichTextResolver = (element: Elements.RichTextElement): Partial<PortableTextComponents> => ({
// The logic for individual portable text components is explained later in the lesson
types: {
// Resolution for components and content items inserted in rich text
component: undefined,
// Resolution for tables in rich text
table: undefined,
// Resolution for assets in rich text
image: undefined,
},
marks: {
// Resolution for links to external URLs
link: undefined,
// Resolution for links to content items
internalLink: undefined,
},
block: {
// Exmamples of custom resolution for default blocks
h1: undefined, // h1 headings
p: undefined, // paragraphs
},
});

type RichTextComponentProps = {
richTextElement: Elements.RichTextElement;
};

// Custom React component that renders your rich text element
export const RichTextComponent: React.FC<RichTextComponentProps> = (props) => {
// Converts a Kontent.ai rich text element value to a JSON tree
const parsedTree = nodeParse(props.richTextElement.value);
// Converts the JSON tree to portable text
const portableText = transformToPortableText(parsedTree);
// Renders content based on the specified transformations
return (
<PortableText
value={portableText}
components={createRichTextResolver(props.richTextElement)}
/>
);
};

// In your application code, get a content item and retrieve its rich text element.
// Get familiar with retrieving content in https://kontent.ai/learn/develop/hello-world
// const richTextElement: Elements.RichTextElement = response.data.item.elements.richtext;
// Example: using 'MyComponent' to render your rich text element in a <div>
// <div>
// <MyComponent value={richTextElement} />
// </div>
26 changes: 0 additions & 26 deletions ts/structure-in-rte/resolve_rich_text_links_to_items.ts

This file was deleted.

52 changes: 52 additions & 0 deletions ts/structure-in-rte/resolve_rich_text_links_to_items.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
import { Elements, ILink } from "@kontent-ai/delivery-sdk";
import { PortableTextInternalLink } from "@kontent-ai/rich-text-resolver";
import { PortableTextComponents, PortableTextMarkComponentProps } from "@portabletext/react";
import { React, ReactNode } from "react";

import { ProductLink } from "../components";
import { contentTypes } from "../models";

type ContentItemLinkProps = {
link: ILink;
children: ReactNode;
};

// Custom React component for rendering links to content items
const ContentItemLink: React.FC<ContentItemLinkProps> = (props) => {
// Use different resolution logic based on the content type
switch (props.link.type) {
case contentTypes.product.codename:
return (
<ProductLink
itemCodename={props.link.codename}
urlSlug={props.link.urlSlug}
>
{props.children}
</ProductLink>
);
default:
return (<div>Link to the content item '{props.link.codename}' couldn't be resolved.</div>);
}
};

type ProductLinkProps = {};
const ProductLink: React.FC<ProductLinkProps> = (props) => {
// Based on your app routing, resolve links to products
};

const createRichTextResolver = (element: Elements.RichTextElement): Partial<PortableTextComponents> => ({
marks: {
// Links to content items
internalLink: ({
value, // The linked item's metadata
children, // Link text that might include text formatting
}: PortableTextMarkComponentProps<PortableTextInternalLink>) => {
// Gets content item link metadata from the response
const link = element.links.find(
(l) => l.linkId === value?.reference._ref
);

return <ContentItemLink link={link!}>{children}</ContentItemLink>;
},
},
});
86 changes: 0 additions & 86 deletions ts/structure-in-rte/structure_in_rte_use_standalone_resolver.tsx

This file was deleted.

0 comments on commit 6528dbe

Please sign in to comment.