Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
@plone/components
Advanced tools
This package contains ReactJS components for using Plone as a headless CMS.
The purpose of this package is to provide an agnostic set of baseline components to build sites upon.
You can find the self-documented Storybook in:
https://plone-components.netlify.app/
@plone/components
is based on React Aria Components, the documentation there applies also to all the components in this package.
This package provides a set of simple, ready to use components with the following features:
Since we are using RAC as the base, the styling of this package components are done via the RAC styling options.
See the react-aria-components
section below for more information about RAC.
This package provides a simple and basic set of CSS rules to build upon.
Alternatively, you can bring your own styles, removing the basic styling or complementing it, and build on top of it.
You can even use RAC to use other CSS utility libraries, like TailwindCSS.
This package provide a basic set of CSS rules. You should add them to your project build to make the components properly styled.
You can bring your own styles, but the CSS you provide should replace what the basic stylying does and style the bare components from scratch.
You can use the CSS bundled for all components in a single file, or use the specific files for your components.
They are distributed along with the components code in the dist
folder of the library.
import '@plone/components/dist/basic.css';
or selectively:
import '@plone/components/src/styles/basic/TextField.css';
You can use the basic styles as a baseline while building the theme of your site.
You can take advantage of them, as they are very thin and basic (almost vanilla CSS for the components).
Using them as a baseline will allow you to quickly build your theme around them.
@plone/components
basic styles provide a simple, yet powerful, set of tokenized custom CSS properties that will help you customize your own styles on the top of the basic styling.
You can override them in your classes while maintaining them for others.
This package uses CSS layers to style the components in a more flexible way.
It uses the plone-components
layer name to scope all the CSS declarations in the package.
The basic styling uses the nested plone-components.base
named layer.
You can use the plone-components
layer to override the basic styling, or use the plone-components.base
layer to override the basic styling in a more specific way.
This package also features the Quanta components.
These components use the basic styling as a baseline, extending them to achieve the Quanta look and feel.
They also extend the basic React components in a composable way.
The Quanta styling is scoped in the plone-components.quanta
named layer.
Quanta is built upon the basic styles in an additive way. The use of the Quanta CSS implies using it upon basic styling. You could take Quanta as example to build your own layer of styles over basic styling for your theme.
To use a theme built upon the basic styling, you need to import both the basic and the theme CSS, in this order:
import '@plone/components/dist/basic.css';
import '@plone/components/dist/quanta.css';
You have the option of doing it selectively per component, too:
import '@plone/components/src/styles/basic/TextField.css';
import '@plone/components/src/styles/quanta/TextField.css';
Take a look at the implementation of the Quanta components, using the basic ones as baseline in the quanta
folders.
Alternatively, as RAC allows, you can also drop your own basic set of styles. You can take the basic styles as reference. You can even remove the basic styling completely and bring your own CSS framework and push a new styling from scratch in there using the utilities of your choice, targeting the default RAC class names. It's even possible to use TailwindCSS for styling the components in this package, using the RAC styling approach.
This package provides an implementation of the Quanta Icon set in React components. They can be used directly in your components as:
import { ChevronupIcon, ChevrondownIcon, Button } from '@plone/components';
const MyComponent = (props) => (
<Button aria-label="Unfold/Collapse">
{props.isOpen ? <ChevronupIcon /> : <ChevrondownIcon />}
</Button>
)
flattenToAppURL
This provider allows you to pass down to your components a flattenToAppURL
helper.
This helper can be different across platforms or frameworks, since the way to provide configuration can also be different.
import { FlattenToAppURLProvider } from '@plone/components';
import { flattenToAppURL } from './utils';
const rootApp = (
<FlattenToAppURLProvider flattenToAppURL={flattenToAppURL}>
{children}
</FlattenToAppURLProvider>
)
Then from your components:
import { useFlattenToAppURL } from '@plone/components';
import { Link as RACLink } from 'react-aria-components';
const Link = (props: LinkProps, ref: ForwardedRef<HTMLAnchorElement>) => {
const { flattenToAppURL } = useFlattenToAppURL();
const flattenedURL = flattenToAppURL(props.href);
return (
<RACLink {...props} href={flattenedURL}>
{props.children}
</RACLink>
);
};
This package follows a style guide (Storybook) driven development. The components are developed in isolation, given their own Storybook stories.
The components are expected to be data-driven-less. They won't rely internally on any data retrieval facility or utilities (as in i18n). They are expected to receive all the necessary data as props from the parent components. In that regard, they should be "dumb" components that only take care of rendering.
This package has the form of a headless UI component library. A headless UI component library provides "white label" components that you can later style with your own styles. It is not tied to any heavy, specific styling, nor to any CSS framework. The vanilla CSS provided allows you to "drop-in" your own CSS framework, and build existing styling into the components.
This post explains extensively its benefits:
react-aria-components
@plone/components
is based on Adobe's react-aria-components
library.
React Aria Components is a library of unstyled components built on top of the React Aria library.
It provides a simpler way to build accessible components with custom styles, while offering the flexibility to drop down to hooks for even more customizability where needed.
The release policy for this package follows a quick 1.0.0 release, as opposed to have an excessively long-lasting alpha/beta road to 1.0.0. This is because the development of this package is expected to happen over the next few years.
Breaking changes will be stated properly using semantic versioning. However, an upgrade guide won't be supplied until the package is considered "ready for production". The Volto Team will communicate this state properly when the moment comes.
This package is the result of the execution of the Plone Improvement Proposal #4352.
FAQs
ReactJS components for Plone
We found that @plone/components demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 12 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.