Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fovea-org/fovea
Fovea is a tool for generating tiny, incredibly powerful Web Components.
https://github.com/fovea-org/fovea
cli compiler customelements dom fovea shadowdom template ui-library webcomponents webdevelopment
Last synced: 4 months ago
JSON representation
Fovea is a tool for generating tiny, incredibly powerful Web Components.
- Host: GitHub
- URL: https://github.com/fovea-org/fovea
- Owner: fovea-org
- License: mit
- Created: 2018-06-30T13:59:59.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2018-11-30T10:59:38.000Z (about 6 years ago)
- Last Synced: 2024-10-05T12:54:03.427Z (4 months ago)
- Topics: cli, compiler, customelements, dom, fovea, shadowdom, template, ui-library, webcomponents, webdevelopment
- Language: TypeScript
- Size: 3.11 MB
- Stars: 9
- Watchers: 4
- Forks: 0
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.md
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
## Introduction
Fovea is a compiler for generating tiny and powerful Web Components, to use in building Web applications.
By shifting computations to compile-time, rather than run-time, Fovea enables you to do way more with way less overhead.
And, because components compiled with Fovea are just Web Components, they work in any framework you may choose - or with no framework at all.
Fovea also makes it super easy to build powerful Progressive Web Apps with the [`@fovea/cli`](https://github.com/fovea-org/fovea/blob/master/packages/cli/README.md).
There's so much we want to say, but let's take it bit by bit:## Install
- [Build Progressive Web Apps with Fovea] by leveraging the powerful `@fovea/cli`.
- [Build reusable Web Components with Fovea] with the `@fovea/compiler` and `@fovea/rollup-plugin-fovea`.## Examples
A Fovea component looks like a Custom Element - because it _is_ a Custom Element! And, your templates and styles are completely encapsulated within the Shadow DOM.
Here's a very simple example of a Fovea component:```typescript
@templateSrc("./my-component.html")
@styleSrc(["./my-component.scss"])
class MyComponent extends HTMLElement {}
```The decorators are just there to help Fovea understand what you want to achieve. They are gone in the compiled output!
Fovea enables you to write your styles in `.css` (or `.scss`) and your template in `.html`, - but it doesn't force you to!
If you're a fan of [React], [lit-html] or [Stencil], you can also declare both directly from the component with `template` and/or `styles` accessors, methods or property declarations.
Because Fovea is compiled, it doesn't matter how you provide your template and styles. Fovea will figure it out:```typescript
class MyComponent extends HTMLElement {
// You can also provide the template from a get accessor or from a method of the same name
// In this example, it is provided from a property.
template = `This is my component!
`;
}
```By design, Fovea let's you write as little as possible, and fills out the gaps for you as required. In this example:
- The `MyComponent` Custom Element is automatically registered with the selector `my-component`
- A Shadow Root is automatically attached to the element
- The template is compiled into a sequence of blazing fast, secure instructions and attached the Shadow root
- The styles are run through PostCSS and compiled with SASS if applicable, and attached to the Shadow root
But you can manually invoke `customElements.define(...)` if you want, or provide a different selector name. Fovea won't get in your way.Here's another example of a component that does a little more:
```typescript
@selector("clickey-thingey")
class MyComponent extends HTMLElement {
@prop @setOnHost clickAmount: number = 0;template = `
I've been clicked ${this.clickAmount} ${this.clickAmount === 1 ? "time" : "times"}!
`;@onChange("clickAmount")
onClickAmountChanged() {
if (this.clickAmount >= 10) {
console.log("You should go play Cookie clicker instead!");
}
}
}
```This example is a bit more involved, but showcase some of the strongest parts of Fovea:
- You can declare `@prop`s which are the properties you'd like to use within your templates and styles. Here, the `prop` `clickAmount` of type `number` is declared (yes, the data type is actually used for coercion!)
- You can use complex Expressions inside your templates for everything that goes into the `${...}` parts. We call them _Live Expressions_, because they react immediately to changes to the `prop`s that are used within them. You can use _all_ Javascript language features within those.
- You can automatically sync your `props` with host attributes. Fovea takes care of mapping the names between them. In this example, the `prop` `clickAmount` will be set on the host element as the attribute `click-amount` and update each time the value changes. It also works the other way around - when the attributes change, the `prop` is updated - and coerced into the data type that it is declared with.
- You can react to changes to your props with the `@onChange` decorator.Best of all, you don't pay any cost for the features that you don't use. For example, if you never use the `@onChange` decorator, Fovea won't ship the related logic.
Naturally, Fovea components can do **so** much more, so instead we'll refer you to the [full examples section].## Contributing
Do you want to contribute? Awesome! Please follow [these recommendations](./CONTRIBUTING.md).
## Maintainers
- [Frederik Wessberg](https://github.com/wessberg): _Lead Developer_
## Backers 🏅
[Become a backer](https://www.patreon.com/bePatron?u=11315442) and get your name, logo, and link to your site listed here.
## License 📄
MIT © [Frederik Wessberg](https://github.com/wessberg)
## FAQ
#### Another UI library? Are you serious?
Yes, we're quite serious. Remember, you get Web Components out! Fovea is build on standards - we're not trying to build a new ecosystem around yet another framework. Everything
that Fovea enables you to produce is compatible with every other framework out there, including the one you might be using right now.
Fovea wants to place itself as something in-between [Stencil] and [Polymer]. Stencil is a compiler as well, but it is closer to `React` in technology (JSX, Virtual DOM) and philosophy (Functional, Reactive) than Fovea is.
Polymer is built on the same core principles, but it doesn't need a compilation step and comes with the benefits (no tooling required) and constraints (greater runtime cost) that result from it.#### Is there a way to use Fovea without the compile-step?
**No**. The reason why Fovea is so fast and so small is because it knows everything there is to know about your code before any browser ever gets involved. That enables Fovea to cool things such as convert your templates into assembly-like instructions, as well as use the data types of your props for things like coercion.
Fovea is, and always will be, a compile-time tool.[react]: https://reactjs.org/
[stencil]: https://stenciljs.com/
[polymer]: https://www.polymer-project.org/
[lit-html]: https://polymer.github.io/lit-html/