Skip to content

Commit

Permalink
+ .render()
Browse files Browse the repository at this point in the history
  • Loading branch information
Lcfvs committed Jul 7, 2021
1 parent 6eceb88 commit 7f28cae
Show file tree
Hide file tree
Showing 6 changed files with 45 additions and 11 deletions.
10 changes: 7 additions & 3 deletions lib/backend.js
Original file line number Diff line number Diff line change
@@ -1,12 +1,16 @@
import jsdom from 'jsdom'
import { serializer } from './dom.js'
import { renderer, serializer } from './dom.js'
export { template } from './template.js'

const { window } = new jsdom.JSDOM('<!DOCTYPE html>')
const { document, DOMParser, XMLSerializer } = window

export const serialize = serializer({
const context = {
document,
parser: new DOMParser(),
serializer: new XMLSerializer()
})
}

export const render = renderer(context)

export const serialize = serializer(context)
15 changes: 15 additions & 0 deletions lib/dom.js
Original file line number Diff line number Diff line change
Expand Up @@ -210,6 +210,21 @@ const resolve = (key, optional, template) => {
}, template)
}

export const renderer = ({ document, parser, policy }) => {
if (!context) {
context = { document, parser, policy }
}

return async template => {
const cloned = clone(template, any)
const { [symbols.node]: node } = cloned

fill(cloned)

return node
}
}

export const serializer = ({ document, parser, policy, serializer }) => {
if (!context) {
context = { document, parser, policy }
Expand Down
10 changes: 7 additions & 3 deletions lib/frontend.js
Original file line number Diff line number Diff line change
@@ -1,13 +1,17 @@
import { serializer } from './dom.js'
import { renderer, serializer } from './dom.js'
export { template } from './template.js'

const { document, trustedTypes, DOMParser, XMLSerializer } = window

export const serialize = serializer({
const context = {
document,
parser: new DOMParser(),
policy: trustedTypes?.createPolicy('dom-engine', {
createHTML: source => source
}),
serializer: new XMLSerializer()
})
}

export const render = renderer(context)

export const serialize = serializer(context)
4 changes: 2 additions & 2 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@lcf.vs/dom-engine",
"version": "4.0.2",
"version": "4.1.0",
"description": "A composable DOM based template engine",
"type": "module",
"scripts": {
Expand Down
15 changes: 13 additions & 2 deletions readme.md
Original file line number Diff line number Diff line change
Expand Up @@ -160,15 +160,26 @@ const template = {
```js
import { serialize } from '@lcf.vs/dom-engine/lib/backend.js'

const rendered = await serialize(template)
const htmlString = await serialize(template)
```
Or
```js
import { render } from '@lcf.vs/dom-engine/lib/backend.js'

const htmlNode = await render(template)

### Front-End

```js
import { serialize } from '@lcf.vs/dom-engine/lib/frontend.js'
const rendered = await serialize(template)
const htmlString = await serialize(template)
```
Or
```js
import { render } from '@lcf.vs/dom-engine/lib/frontend.js'
const htmlNode = await render(template)
```

### ServiceWorker
Expand Down

0 comments on commit 7f28cae

Please sign in to comment.