The Universal UI Library
๐ Overview
๐ฅฏPapanasi (pronunced pษpษnรฆส or papanash) is a UI library to use cross Frameworks. A set of components to use in Angular, Preact, Qwik, React, Solid, Svelte, Vue and Web Components. Is based on the Mitosis library and documented using Storybook.
๐ Platforms
Angular
|
Preact
|
Qwik
|
React
|
Solid
|
Svelte
|
Vue
|
Web Comps.
|
๐ฎ Demos
๐ฃ Manifesto
This library born as a pet project to create universal components, easy to extend in any project and easy to use with any framework, is based on the next principles:
A Component...
- ...should be cross-libraries but the code should be written once.
- ...should have a minimum style but easy to extend it via CSS by any dev.
- ...should provide some optional themes to make it easy to use.
- ...should be accessible (FUTURE RELEASES).
- ...should be made for developers not for non-coders, they will decide how to style most of the things.
- ...should be tree-shakable.
- ...should be compatible with StoryBook.
- ...should be inspired by other UI Libraries and don't reinvent the wheel.
- ...should be easy to create new variants.
๐งฉ Elements Showcase
Layout
|
Container
data:image/s3,"s3://crabby-images/3d1f5/3d1f5f23d58656c9c3e30cf03cde30ef319f4c93" alt="React status"
data:image/s3,"s3://crabby-images/48b31/48b31fc87a39b24390f94ef91ea527ebdafdfd40" alt="W3c status"
|
Row
data:image/s3,"s3://crabby-images/3d1f5/3d1f5f23d58656c9c3e30cf03cde30ef319f4c93" alt="React status"
data:image/s3,"s3://crabby-images/48b31/48b31fc87a39b24390f94ef91ea527ebdafdfd40" alt="W3c status"
|
Column
data:image/s3,"s3://crabby-images/3d1f5/3d1f5f23d58656c9c3e30cf03cde30ef319f4c93" alt="React status"
data:image/s3,"s3://crabby-images/48b31/48b31fc87a39b24390f94ef91ea527ebdafdfd40" alt="W3c status"
|
Grid
data:image/s3,"s3://crabby-images/3d1f5/3d1f5f23d58656c9c3e30cf03cde30ef319f4c93" alt="React status"
data:image/s3,"s3://crabby-images/48b31/48b31fc87a39b24390f94ef91ea527ebdafdfd40" alt="W3c status"
|
Components
|
Avatar
data:image/s3,"s3://crabby-images/3d1f5/3d1f5f23d58656c9c3e30cf03cde30ef319f4c93" alt="React status"
data:image/s3,"s3://crabby-images/48b31/48b31fc87a39b24390f94ef91ea527ebdafdfd40" alt="W3c status"
|
Button
data:image/s3,"s3://crabby-images/3d1f5/3d1f5f23d58656c9c3e30cf03cde30ef319f4c93" alt="React status"
data:image/s3,"s3://crabby-images/48b31/48b31fc87a39b24390f94ef91ea527ebdafdfd40" alt="W3c status"
|
Code
data:image/s3,"s3://crabby-images/3d1f5/3d1f5f23d58656c9c3e30cf03cde30ef319f4c93" alt="React status"
data:image/s3,"s3://crabby-images/dcdc3/dcdc3d8ab34f1506c44b8924492021e0d6535f28" alt="W3c status"
|
Pill
data:image/s3,"s3://crabby-images/3d1f5/3d1f5f23d58656c9c3e30cf03cde30ef319f4c93" alt="React status"
data:image/s3,"s3://crabby-images/48b31/48b31fc87a39b24390f94ef91ea527ebdafdfd40" alt="W3c status"
|
Spinner
data:image/s3,"s3://crabby-images/3d1f5/3d1f5f23d58656c9c3e30cf03cde30ef319f4c93" alt="React status"
data:image/s3,"s3://crabby-images/dcdc3/dcdc3d8ab34f1506c44b8924492021e0d6535f28" alt="W3c status"
|
Enterprise
|
Itchio
data:image/s3,"s3://crabby-images/3d1f5/3d1f5f23d58656c9c3e30cf03cde30ef319f4c93" alt="React status"
data:image/s3,"s3://crabby-images/6d6b4/6d6b4043ff5a4e16461c938a7de310411a1323b8" alt="W3c status"
|
Extensions
|
Tooltip
data:image/s3,"s3://crabby-images/3d1f5/3d1f5f23d58656c9c3e30cf03cde30ef319f4c93" alt="React status"
data:image/s3,"s3://crabby-images/dcdc3/dcdc3d8ab34f1506c44b8924492021e0d6535f28" alt="W3c status"
|
๐ Setup and scripts
With npm:
$ npm install @papanasi/preact
With yarn:
$ yarn add @papanasi/preact
๐ Documentation
To learn more about Papanasi, check the documentation.
๐ License
MIT
๐ Contributing
Contributing Guidelines
To build the project run:
> yarn compile
You can choose which frameworks to build by passing the --platforms
:
> yarn compile --platforms react vue
It is also possible to specify which components to build --elements
:
> yarn compile --elements avatar pill
If you want to disable the linting use --no-lint
:
> yarn compile --no-lint
To contribute and watch the changes in local environment just use:
> yarn dev
Finally, to launch storybook use:
> yarn start
Thanks to everyone who contributed:
data:image/s3,"s3://crabby-images/c02ab/c02abf1759c16755edd0640f7cce99ccfbf73df0" alt="Contributors"
Made with ๐ by Quique Fdez Guerra