-
-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
I think given webreflection's decision to abandon supporting hooks in uhooks, and preact generally being more conventional in practice, switching the primary happy path over to preact would make top-bun more palatable to people. The api in uhtml is superior, and closer to the reality of the DOM, but preact has thus far been closer to react and quicker to ship support for signals and retaining local component state features. Seems like a more stable long term bet.
- Loading branch information
Showing
10 changed files
with
164 additions
and
8 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,25 @@ | ||
{ | ||
"name": "@top-bun/preact-example", | ||
"version": "0.0.0", | ||
"type": "module", | ||
"scripts": { | ||
"start": "npm run watch", | ||
"build": "npm run clean && top-bun", | ||
"clean": "rm -rf public && mkdir -p public", | ||
"watch": "npm run clean && tb --watch" | ||
}, | ||
"author": "Bret Comnes <bcomnes@gmail.com> (https://bret.io/)", | ||
"license": "MIT", | ||
"dependencies": { | ||
"@preact/signals": "^1.3.0", | ||
"highlight.js": "^11.9.0", | ||
"htm": "^3.1.1", | ||
"mine.css": "^9.0.1", | ||
"preact": "^10.24.0", | ||
"preact-render-to-string": "^6.5.11", | ||
"top-bun": "../../." | ||
}, | ||
"devDependencies": { | ||
"npm-run-all2": "^6.0.0" | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
# Preact example | ||
|
||
This is a preact example. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
// @ts-ignore | ||
import { toggleTheme } from 'mine.css' | ||
// @ts-ignore | ||
window.toggleTheme = toggleTheme |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
@import 'mine.css/dist/mine.css'; | ||
@import 'mine.css/dist/layout.css'; | ||
@import 'highlight.js/styles/github-dark-dimmed.css'; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,55 @@ | ||
import { html, Component } from 'htm/preact' | ||
import { render } from 'preact' | ||
import { useCallback } from 'preact/hooks' | ||
import { useSignal, useComputed } from '@preact/signals' | ||
|
||
const Header = ({ name }) => html`<h1>${name} List</h1>` | ||
|
||
const Footer = props => { | ||
const count = useSignal(0) | ||
const double = useComputed(() => count.value * 2) | ||
|
||
const handleClick = useCallback(() => { | ||
count.value++ | ||
}, [count]) | ||
|
||
return html`<footer ...${props}> | ||
${count} | ||
${double} | ||
${props.children} | ||
<button onClick=${handleClick}>Click</button> | ||
</footer>` | ||
} | ||
|
||
class App extends Component { | ||
addTodo () { | ||
const { todos = [] } = this.state | ||
this.setState({ todos: todos.concat(`Item ${todos.length}`) }) | ||
} | ||
|
||
render ({ page }, { todos = [] }) { | ||
return html` | ||
<div class="app"> | ||
<${Header} name="ToDo's (${page})" /> | ||
<ul> | ||
${todos.map(todo => html` | ||
<li key=${todo}>${todo}</li> | ||
`)} | ||
</ul> | ||
<button onClick=${() => this.addTodo()}>Add Todo</button> | ||
<${Footer}>footer content here<//> | ||
</div> | ||
` | ||
} | ||
} | ||
|
||
export const page = () => html` | ||
<${App}/> | ||
<${Footer}>footer content here<//> | ||
<${Footer}>footer content here<//> | ||
` | ||
|
||
if (typeof window !== 'undefined') { | ||
const renderTarget = document.querySelector('.app-main') | ||
render(page(), renderTarget) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
import { page } from './client.js' | ||
|
||
export default () => { | ||
return page() | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,58 @@ | ||
// @ts-ignore | ||
import { html } from 'htm/preact' | ||
import { render } from 'preact-render-to-string' | ||
|
||
/** | ||
* @template T extends object | ||
* @typedef {import('../build-pages/resolve-layout.js').LayoutFunction<T>} LayoutFunction | ||
*/ | ||
|
||
/** | ||
* Build all of the bundles using esbuild. | ||
* | ||
* @type {LayoutFunction<{ | ||
* title: string, | ||
* siteName: string, | ||
* defaultStyle: boolean, | ||
* basePath: string | ||
* }>} | ||
*/ | ||
export default function defaultRootLayout ({ | ||
vars: { | ||
title, | ||
siteName = 'TopBun', | ||
basePath, | ||
/* defaultStyle = true Set this to false in global or page to disable the default style in the default layout */ | ||
}, | ||
scripts, | ||
styles, | ||
children, | ||
/* pages */ | ||
/* page */ | ||
}) { | ||
return /* html */` | ||
<!DOCTYPE html> | ||
<html> | ||
${render(html` | ||
<head> | ||
<meta charset="utf-8" /> | ||
<title>${title ? `${title}` : ''}${title && siteName ? ' | ' : ''}${siteName}</title> | ||
<meta name="viewport" content="width=device-width, user-scalable=no" /> | ||
${scripts | ||
? scripts.map(script => html`<script type='module' src="${script.startsWith('/') ? `${basePath ?? ''}${script}` : script}" />`) | ||
: null} | ||
${styles | ||
? styles.map(style => html`<link rel="stylesheet" href="${style.startsWith('/') ? `${basePath ?? ''}${style}` : style}" />`) | ||
: null} | ||
</head> | ||
`)} | ||
${render(html` | ||
<body class="safe-area-inset"> | ||
<main class="mine-layout app-main"> | ||
${typeof children === 'string' ? html([children]) : children /* Support both uhtml and string children. Optional. */} | ||
</main> | ||
</body> | ||
`)} | ||
</html> | ||
` | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters