-
-
Notifications
You must be signed in to change notification settings - Fork 718
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
Update @plone/* packages info #6521
Changes from 2 commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,17 +2,37 @@ | |
|
||
This document describes the packages that come with Volto, the default frontend for Plone 6. | ||
|
||
These packages are part of Plone's API-first story. | ||
Most of them are experimental and are marked in their respective `README` files. | ||
Plone 6.1.x (Volto 18) depends on: | ||
- `@plone/registry` | ||
- `@plone/scripts` | ||
- `@plone/volto-slate` | ||
|
||
and as a development dependency: | ||
- `@plone/types` | ||
|
||
Plone 6.0.x (Volto 17 and below) does not use any of them. | ||
|
||
These packages are expected to be used and become part of Plone 7. | ||
Some of them might become part of Plone 6.1.x minor versions. | ||
|
||
The packages are divided into three categories or types: | ||
|
||
- core | ||
- utilities | ||
- add-ons | ||
|
||
|
||
## `@plone/types` | ||
|
||
Plone types is a special development package. | ||
It contains the Plone typings for TypeScript. | ||
It's considered a core package, and it's the only package that the other core packages can rely on as | ||
a `devDependency` in your project configuration. | ||
It's considered a core package, and it's the only package that the other core packages can rely on as a `devDependency` in your project configuration. | ||
|
||
This package contains `.d.ts` typing definitions, curated by hand. | ||
Due to the nature of this package, it does not need bundling. | ||
It's published "as is", so you can import the type definitions from anywhere in your code. | ||
Due to the nature of this package, it does not need to be built nor bundled. | ||
It is published "as is", so you can import the type definitions from anywhere in your code. | ||
|
||
|
||
## Core packages | ||
|
@@ -29,11 +49,11 @@ They must be published and bundled in a traditional (transpiled) way. | |
The bundle of these packages must work on both CommonJS and ECMAScript Module (ESM) environments. | ||
|
||
|
||
## Utility packages | ||
## Utilities packages | ||
|
||
- `@plone/drivers` | ||
- `@plone/helpers` | ||
- `@plone/providers` | ||
- `@plone/helpers` | ||
- `@plone/drivers` | ||
- `@plone/rsc` | ||
|
||
|
||
|
@@ -44,19 +64,22 @@ They must be published in the traditional way, as a bundle. | |
This bundle must work on both CommonJS and ESM environments. | ||
|
||
|
||
## Feature packages | ||
## Add-on packages | ||
|
||
- `@plone/blocks` | ||
- `@plone/contents` | ||
- `@plone/slots` | ||
- `@plone/theming` | ||
- `@plone/contents` | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Can you leave these sorted alphabetically? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Same as above, but if you think it's valuable, let's do it. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yeah, relevance is arbitrary to the developer. Alpha also makes it easier to find in a list. |
||
|
||
|
||
### Rules | ||
|
||
Feature packages, or add-on packages, can depend on any other package. | ||
Add-on or feature packages, can depend on any other package. | ||
You must distribute them as source code, and not transpile them. | ||
They must provide a default configuration registry loader as the default main entry point export. | ||
They must be loadable as any other add-on. | ||
Unlike Volto add-ons, do *NOT* place the code in the `src` folder. | ||
If you do not transpile the package, the direct resolution must work out of the box, where both the bundler and TypeScript resolution are direct. | ||
They must be loadable as any other add-on, and contain an add-on registry compatible `install`-able default export. | ||
|
||
|
||
## Development utility packages | ||
|
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.
Can you leave these sorted alphabetically?
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've ordered by relevance to me, due to the current state of things (drivers and rsc are not a thing yet). It just occurred to me that if they do not exist yet, let's remove them.