Important
This fork builds on the Stencil framework adapters, offering full compatibility with the original while introducing an enhanced feature: tag name adapters. This complements the Stencil compiler's tagNameTransform option, providing greater flexibility for customizing tag names. It is particularly useful for integrating multiple Stencil-based libraries seamlessly in micro frontend architectures.
Project | Package | Version | Documentation |
---|---|---|---|
React Output Target | @public-ui/stencil-react-output-target |
README | |
Angular Output Target | @public-ui/stencil-angular-output-target |
README | |
Vue Output Target | @public-ui/stencil-vue-output-target |
README | |
Solid Output Target | @public-ui/stencil-solid-output-target |
README |
Integrating web components into existing framework applications can be difficult at times. More about this can be read at https://custom-elements-everywhere.com/. To accommodate the various issues, the Stencil team has created new output target plugins to make the process simpler.
The plugins add additional output targets for each framework binding that is included.
Here is an example project using the plugins for reference: https://github.com/ionic-team/stencil-ds-output-targets/blob/main/packages/example-project/component-library
Detailed information for each output target can be found in each package's README.
This project is currently maintained for the purposes of supporting the Ionic Framework. At this time, only new issues & pull requests that support the Ionic Framework will be prioritized.
To set up this project and prepare the example project to be used in your own projects run the following commands.
npm install
npm run bootstrap
npm run build
This will generate all necessary builds in the example projects. You can then either publish the packages to npm or a private package manager, or use npm pack
to start using the builds in a local project for testing purposes where you manually place the package in the project node_modules
folder.
For example, if you have an Angular project, run npm pack
in packages/example-project/component-library
and packages/example-project/component-library-angular
. Since the framework component libraries depend on the Stencil project, you will need to provide the component-library
package in your project node_modules
folder.
This project uses Volta to automatically manage what npm and node versions are used when developing. If you don't use Volta, don't worry about it... just check the root package.json
for what version of node and npm is currently being used.
There is a manual workflow task called "Production Release" within the GitHub Actions workflows directory. We currently do not release all packages that have been changed at once. You will need to deploy each package (vue, react, angular) individually.
You'll need to fill out a few bits of information when you submit the deploy workflow:
- Which package should be published (Currently
vue
,react
, orangular
). - What version should be published.
- What npm tag it should be published under (
next
orlatest
) - Any preid, like
alpha
orrc