-
Notifications
You must be signed in to change notification settings - Fork 276
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
[sitecore-jss-react] [Editing Integration] Add support for chrome hydration for Placeholders #1776
[sitecore-jss-react] [Editing Integration] Add support for chrome hydration for Placeholders #1776
Conversation
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.
A good start, and the implementation can be made even better, ensuring we get it as right as possible. I've left some comments for current implementation but perhaps it can go the slightly other way.
Something you can consider for the overall design: we have logic in PlaceholderCommon for the traditional way of rendering components and a bunch of conditions in main Placeholder that calls that logic.
We can use a separate component to add "placeholder" code blocks, or it can be a function in PlaceholderCommon, or (perhaps better) an HOC that wraps placeholders (I think Yavor does something similar for fields in his PR).
HOC that outputs chrome code blocks for components (chrometype: rendering) can also be added and used to wrap components in componentBuilder - ensuring every registered component has code blocks added.
packages/sitecore-jss-react/src/components/PlaceholderCommon.tsx
Outdated
Show resolved
Hide resolved
packages/sitecore-jss-react/src/components/PlaceholderMetadata.tsx
Outdated
Show resolved
Hide resolved
packages/sitecore-jss-react/src/components/PlaceholderMetadata.test.tsx
Outdated
Show resolved
Hide resolved
packages/sitecore-jss-react/src/components/PlaceholderCommon.tsx
Outdated
Show resolved
Hide resolved
packages/sitecore-jss-react/src/components/PlaceholderMetadata.test.tsx
Outdated
Show resolved
Hide resolved
packages/sitecore-jss-react/src/components/PlaceholderMetadata.tsx
Outdated
Show resolved
Hide resolved
packages/sitecore-jss-react/src/components/PlaceholderMetadata.tsx
Outdated
Show resolved
Hide resolved
packages/sitecore-jss-react/src/components/PlaceholderMetadata.tsx
Outdated
Show resolved
Hide resolved
packages/sitecore-jss-react/src/components/PlaceholderMetadata.tsx
Outdated
Show resolved
Hide resolved
packages/sitecore-jss-react/src/components/PlaceholderMetadata.tsx
Outdated
Show resolved
Hide resolved
packages/sitecore-jss-react/src/components/PlaceholderCommon.tsx
Outdated
Show resolved
Hide resolved
Co-authored-by: Illia Kovalenko <[email protected]>
….tsx Co-authored-by: Illia Kovalenko <[email protected]>
….tsx Co-authored-by: Illia Kovalenko <[email protected]>
….tsx Co-authored-by: Illia Kovalenko <[email protected]>
Co-authored-by: Illia Kovalenko <[email protected]>
…thub.com:Sitecore/jss into feature/jss-1828-editing-integration-placeholder
packages/sitecore-jss-react/src/components/PlaceholderMetadata.test.tsx
Outdated
Show resolved
Hide resolved
packages/sitecore-jss-react/src/components/PlaceholderMetadata.test.tsx
Outdated
Show resolved
Hide resolved
packages/sitecore-jss-react/src/components/PlaceholderCommon.tsx
Outdated
Show resolved
Hide resolved
packages/sitecore-jss-react/src/components/PlaceholderMetadata.test.tsx
Outdated
Show resolved
Hide resolved
packages/sitecore-jss-react/src/components/Placeholder.test.tsx
Outdated
Show resolved
Hide resolved
packages/sitecore-jss-react/src/components/PlaceholderCommon.tsx
Outdated
Show resolved
Hide resolved
packages/sitecore-jss-react/src/components/PlaceholderMetadata.test.tsx
Outdated
Show resolved
Hide resolved
packages/sitecore-jss-react/src/components/PlaceholderCommon.tsx
Outdated
Show resolved
Hide resolved
packages/sitecore-jss-react/src/components/PlaceholderCommon.tsx
Outdated
Show resolved
Hide resolved
packages/sitecore-jss-react/src/components/PlaceholderMetadata.tsx
Outdated
Show resolved
Hide resolved
packages/sitecore-jss-react/src/components/PlaceholderMetadata.tsx
Outdated
Show resolved
Hide resolved
packages/sitecore-jss-react/src/components/PlaceholderMetadata.test.tsx
Outdated
Show resolved
Hide resolved
packages/sitecore-jss-react/src/components/Placeholder.test.tsx
Outdated
Show resolved
Hide resolved
packages/sitecore-jss-react/src/components/PlaceholderMetadata.tsx
Outdated
Show resolved
Hide resolved
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.
Good work!
Let's figure out the purpose of WithSitecoreContextHocProps type and remove it if needed, and then merge
* [sitecore-jss-react] [sitecore-jss-nextjs] Add support for chrome's hydration for fields (#1773) * render field metadata for Text field component; introduce field metadata component - wip * rename FieldMetadata module, add unit test for Text component, add comments * add field metadata component to Date, Image and File field components; include unit tests * add field metadata component to link and richtext field components, include unit tests * update FieldMetadata interfaces to prevent build errors in sitecore-jss-nextjs; component update * export fieldmetadata component and interfaces from sitecore-jss-react * add metadata component for nextjs link field component; include unit test * add field metadata component to nextimage component; small fix in link field component * unit tests for FieldMetadata * update unit test * introduce getFieldMetadataMarkup function and used in the field components; add unit test * update changelog * react - use higher order component to wrap metadata around field components * update nextjs components to use metadata wrapper hoc; aadjust unit tests * adjust unit tests and fix File component * adjust image field tests; include check for media property in metadata wrapper * some types updates * some unit tests adjustments and metadata wrapper component update * some FieldMetadata related renamings * add unit test for RichText nextjs component * update changelog * update changelog pull request * some type updates * reenable file tests * update function description Co-authored-by: Illia Kovalenko <[email protected]> * minor variable renaming Co-authored-by: Illia Kovalenko <[email protected]> * remove unnecessary commented line * remove unnecessary undefined check * move FieldMetada interfaces to base package; extract metadata proptypes * move FieldMetadata under enchancments * added some descriptions * move and rename FieldMetadata to layout submodule of base package * rename FieldMetadata component * add tsdoc description for fieldmetadata component * conditionally forwardRef in fieldMetadata * two separate withFieldMetadata functions based on if used with forwardRef * single withFieldMetadata function with forwardref parameter * update with metadata unit test to test the whole structure of markup * withMetadata refactoring wip * Adjusted withFieldMetadata generic type * update unit test * wip - refactor field metadata hoc * Updates * Updated unit tests, simplified types * Update * Expose withFieldMetadata as a part of nextjs sdk * Updated PropTypes * Removed extra asserts * remove media property from propTypes --------- Co-authored-by: Illia Kovalenko <[email protected]> Co-authored-by: illiakovalenko <[email protected]> * [sitecore-jss-react] [Editing Integration] Add support for chrome hydration for Placeholders (#1776) * conditinally emit edit chromes metadata for placeholders, rendering * refactor PlaceholderWithMetadata component * update tests * update changelog * remove extra lines * remove editMode mock data * update unit test, change code tag chrometype * remove only * refactor as per new requirements * Update packages/sitecore-jss/src/layout/models.ts Co-authored-by: Illia Kovalenko <[email protected]> * Update packages/sitecore-jss-react/src/components/PlaceholderMetadata.tsx Co-authored-by: Illia Kovalenko <[email protected]> * Update packages/sitecore-jss-react/src/components/PlaceholderMetadata.tsx Co-authored-by: Illia Kovalenko <[email protected]> * Update packages/sitecore-jss-react/src/components/PlaceholderMetadata.tsx Co-authored-by: Illia Kovalenko <[email protected]> * Update CHANGELOG.md Co-authored-by: Illia Kovalenko <[email protected]> * refactor unit test * change naming of props and types * add test for placeholder * update PlaceholderMetadata to render a component * add test for missing component * fix nextjs placeholder * remove context * reset nextjs placeholder * update changelog * update test data * change PlaceholderMetadata implmentation * Placeholder metadata refactor - wip * update tests, refactor Placeholder component * remove redundant data * update unit test - wip * move tests to placeholder, refactor placeholder * refactor tests * refactor placeholdermetadata component, update tests * refactor placeholder tests, update jsdoc * update nextjs types * remove keys from code * fix nextjs placeholder props * change deprecated statement * update deprecated 2 --------- Co-authored-by: Illia Kovalenko <[email protected]> Co-authored-by: yavorsk <[email protected]> * [templates/nextjs-sxa] SXA components has been reworked with supporting metadata (#1788) * [templates/nextjs-sxa] SXA components has been reworked with supporting metadata approach --------- Co-authored-by: Ruslan Matkovsky <[email protected]> * [Editing Integration] Placeholder chromes hydration (Update - Part 2) (#1792) * fix unit tests, update upgrade guide * update changelog * update missing component test * remove only * update changelog, upgrade guide * remove only * Update CHANGELOG.md Co-authored-by: Illia Kovalenko <[email protected]> * Update CHANGELOG.md Co-authored-by: Illia Kovalenko <[email protected]> * Update CHANGELOG.md Co-authored-by: Illia Kovalenko <[email protected]> * refactor placeholder tests * update changelog --------- Co-authored-by: Illia Kovalenko <[email protected]> * [sitecore-jss-react] [sitecore-jss-nextjs] Reconciled withSitecoreContext and Placeholder types (#1797) * [sitecore-jss-react] [sitecore-jss-nextjs] Reconciled withSitecoreContext and Placeholder types * Reuse default _editable_ value in withFieldMetadata component * Updated CHANGELOG * Updated props param * Remove extra type * Remove generic in Styleguide-Layout-Tabs * [Editing Integration] Render clientScripts / clientData (#1800) * [Editing Integration] Render clientScripts / clientData * Updated upgrade guide, changelog --------- Co-authored-by: Illia Kovalenko <[email protected]> Co-authored-by: illiakovalenko <[email protected]> Co-authored-by: Addy Pathania <[email protected]> Co-authored-by: Ruslan Matkovskyi <[email protected]> Co-authored-by: Ruslan Matkovsky <[email protected]>
Description / Motivation
To enable Chrome's hydration process in Pages, we need to modify the JSS Placeholder component in the sitecore-jss-react SDKs. We need to emit shallow chromes and required data for placeholders and renderings.
PlaceholderMetadata
component to emit shallow chromes.sitecoreContext
to accesseditMode: "chromes" | "metadata"
property from Layout Service.Testing Details
Types of changes