Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/aggre/ullr

Functional Web Components
https://github.com/aggre/ullr

Last synced: 3 days ago
JSON representation

Functional Web Components

Awesome Lists containing this project

README

        

Functional Web Components

**Building Web Components with Functional Programming.**

![CI](https://github.com/aggre/ullr/workflows/CI/badge.svg)
[![Published on npm](https://img.shields.io/npm/v/@aggre/ullr.svg)](https://www.npmjs.com/package/@aggre/ullr)

```

___ ___
/__/\ / /\
\ \:\ / /::\
\ \:\ ___ ___ ___ ___ / /:/\:\
___ \ \:\ /__/\ / /\ /__/\ / /\ / /:/~/:/
/__/\ \__\:\ \ \:\ / /:/ \ \:\ / /:/ /__/:/ /:/___
\ \:\ / /:/ \ \:\ /:/ \ \:\ /:/ \ \:\/:::::/
\ \:\ /:/ \ \:\/:/ \ \:\/:/ \ \::/~~~~
\ \:\/:/ \ \::/ \ \::/ \ \:\
\ \::/ \__\/ \__\/ \ \:\
\__\/ \__\/

```

---

# Installation

Add to a lit project:

```bash
npm i @aggre/ullr
```

When creating a new project using lit as template and RxJS as the state management:

```bash
npm i @aggre/ullr lit rxjs
```

Partially supports run on Node.js (with jsdom).

# APIs

## `shadow`

`shadow` is a lit directive.

Encapsulate the template with Shadow DOM.

```ts
import { html } from 'lit'
import { shadow } from '@aggre/ullr'

export const main = (title: string, desc: string) =>
shadow(html`

h1 {
color: blue;
}


${title}


${desc}



`)
```

| Browser | Node.js |
| ------- | --------------------------------------------------------------------------------------------------- |
| ✅ | 🚸
Shadow Dom isn't supported. An inside content of Shadow Dom is shown as just an innerHTML. |

---

## `subscribe`

`subscribe` is a lit directive.

Subscribe to `Observable` of RxJS and re-rendering with the passed callback function.

When the directive part is removed or the passed observable is changed, the unused subscription will automatically `unsubscribe`.

```ts
import { html } from 'lit'
import { subscribe } from '@aggre/ullr'
import { timer as _timer } from 'rxjs'

export const timer = (initialDelay: number, period: number) =>
subscribe(
_timer(initialDelay, period),
(x) => html`

${x}

`,
html`

Default content

`,
)
```

| Browser | Node.js |
| ------- | ------- |
| ✅ | ✅ |

---

## `createCustomElements`

`createCustomElements` creates a class that can be passed to `customElements.define`.

```ts
import { createCustomElements } from '@aggre/ullr'
import { main } from './main'

const observedAttributes = ['title', 'desc']

const template = ([title, desc]) => main(title, desc)

window.customElements.define(
'x-app',
createCustomElements(template, observedAttributes),
)
```

| Browser | Node.js |
| ------- | ------- |
| ✅ | ❌ |

---