-
Notifications
You must be signed in to change notification settings - Fork 40
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
fix: apostrophe-issue-richtext #1314
base: main
Are you sure you want to change the base?
Conversation
- Introduced a new utility function `decodeHtmlEntities` to decode HTML entities in strings. - Updated `convertAttributesInElement` to handle string children by decoding HTML entities before processing. - Enhanced the handling of text nodes to ensure proper rendering of HTML content in React elements.
commit: |
import React from 'react'; | ||
import { BrowserRouter, Link, Route, Routes } from 'react-router'; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not sure we want to make our React playground dependent on react-router
honestly, is this needed?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Why not? It's just a playground, otherwise I will need to change the index page whenever I want to test the rich text in isolation.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@@ -11,7 +11,7 @@ import { apiPlugin, storyblokInit } from '@storyblok/react'; | |||
import IFrameEmbed from './components/iframe-embed'; | |||
|
|||
storyblokInit({ | |||
accessToken: 'd6IKUtAUDiKyAhpJtrLFcwtt', | |||
accessToken: 'OurklwV5XsDJTIE1NJaD2wtt', |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think we need to document which space is associated with these demo token, or it would be a mess to test them later
@@ -1,5 +1,11 @@ | |||
import React from 'react'; | |||
|
|||
function decodeHtmlEntities(text: string): string { | |||
const textarea = document.createElement('textarea'); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this would break in SSR because of the use of document
on the server
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is there an SSR-friendly way to decodeHTML
entities on React? Maybe the textarea hack is not the best option here
decodeHtmlEntities
to decode HTML entities in strings.convertAttributesInElement
to handle string children by decoding HTML entities before processing.Closes #1315