Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/festify/fit-html
💪 Combining web components + lit-html + redux (3KB)
https://github.com/festify/fit-html
lit-html redux web-components
Last synced: 3 months ago
JSON representation
💪 Combining web components + lit-html + redux (3KB)
- Host: GitHub
- URL: https://github.com/festify/fit-html
- Owner: Festify
- Created: 2017-10-31T17:32:56.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2020-10-16T14:30:07.000Z (over 4 years ago)
- Last Synced: 2024-09-22T02:47:01.053Z (4 months ago)
- Topics: lit-html, redux, web-components
- Language: TypeScript
- Homepage:
- Size: 1.86 MB
- Stars: 115
- Watchers: 9
- Forks: 2
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# 💪 fit-html
[![npm](https://img.shields.io/npm/v/fit-html.svg)](https://www.npmjs.com/package/fit-html)
[![Travis](https://img.shields.io/travis/Festify/fit-html.svg)](https://travis-ci.org/Festify/fit-html)
[![Bundle Size](http://img.badgesize.io/https://unpkg.com/fit-html/.tmp/index.min.js?compression=gzip)](https://www.npmjs.com/package/fit-html)
[![Greenkeeper badge](https://badges.greenkeeper.io/Festify/fit-html.svg)](https://greenkeeper.io/)3KB web components + lit-html + redux library without bloat.
## Overview
fit-html is a combination of [lit-html](https://github.com/Polymer/lit-html), web components and [redux](http://redux.js.org/) bringing efficient rendering and a functional application architecture together. Yet, the total size of the framework is below 3KB, including dependencies.
## Small Example
You need the following:
```js
import { connect, withStore } from 'fit-html';
import { html } from 'lit-html/lib/lit-extended';
import { createStore } from 'redux';
```Set up redux store:
```js
const todos = (state = [], action) => {
switch (action.type) {
case 'ADD_TODO':
return state.concat([action.text]);
default:
return state;
}
};const store = createStore(todos, ['Use Redux']);
```Define actions and view:
```js
function addTodo() {
return {
type: 'ADD_TODO',
text: `Hello ${Math.random()}`
};
}const render = ({ addTodo, todos }) => html`
- ${text} `)}
${todos.map(text => html`
Add
`;
const TodosApp = connect(
state => ({ todos: state }),
{ addTodo }
)(render);
// Define the custom element.
//
// The withStore mixin is only required for the root element of your
// app. All other 💪-elements will get the redux store from that element.
customElements.define('todo-app', withStore(store)(TodosApp));
```
`index.html`:
```html
My cool 💪-html app
```
Please see https://github.com/Festify/fit-html-demo for more and larger examples.
## Compatibility
💪-html is written for use with evergreen browsers. Not so much for Internet Explorer (though we strive to become compatible with IE11 once lit-html itself is).
## License
MIT