Skip to content

Commit

Permalink
feat: support hono/jsx client, add e2e, add an example
Browse files Browse the repository at this point in the history
  • Loading branch information
yusukebe committed Jan 18, 2024
1 parent 27e844f commit 4d9d523
Show file tree
Hide file tree
Showing 30 changed files with 2,910 additions and 64 deletions.
1 change: 1 addition & 0 deletions examples/basic/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
.yarn/*
3 changes: 3 additions & 0 deletions examples/basic/app/client.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
import { createClient } from 'honox/client'

createClient()
16 changes: 16 additions & 0 deletions examples/basic/app/global.d.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
// eslint-disable-next-line node/no-extraneous-import
import 'hono'

type Head = {
title?: string
}

declare module 'hono' {
interface Env {
Variables: {}
Bindings: {}
}
interface ContextRenderer {
(content: string | Promise<string>, head?: Head): Response | Promise<Response>
}
}
11 changes: 11 additions & 0 deletions examples/basic/app/islands/counter.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
import { useState } from 'hono/jsx'

export default function Counter() {
const [count, setCount] = useState(0)
return (
<div>
<p>Count: {count}</p>
<button onClick={() => setCount(count + 1)}>Increment</button>
</div>
)
}
24 changes: 24 additions & 0 deletions examples/basic/app/routes/_renderer.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
import { jsxRenderer } from 'hono/jsx-renderer'

export default jsxRenderer(
({ children, title }) => {
return (
<html lang='en'>
<head>
<meta charset='UTF-8' />
<meta name='viewport' content='width=device-width, initial-scale=1.0' />
{title ? <title>{title}</title> : <></>}
{import.meta.env.PROD ? (
<script type='module' src='/static/client.js'></script>
) : (
<script type='module' src='/app/client.ts'></script>
)}
</head>
<body>{children}</body>
</html>
)
},
{
docType: true,
}
)
15 changes: 15 additions & 0 deletions examples/basic/app/routes/index.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
import { createRoute } from 'honox/factory'
import Counter from '../islands/counter'

export default createRoute((c) => {
const name = c.req.query('name') ?? 'Hono'
return c.render(
<div>
<h1>Hello, {name}!</h1>
<Counter />
</div>,
{
title: name,
}
)
})
11 changes: 11 additions & 0 deletions examples/basic/app/server.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
import { serveStatic } from 'hono/cloudflare-pages'
import { showRoutes } from 'hono/dev'
import { createApp } from 'honox/server'

const app = createApp({
init: (app) => app.get('/static/*', serveStatic()),
})

showRoutes(app)

export default app
21 changes: 21 additions & 0 deletions examples/basic/package.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
{
"name": "basic",
"type": "module",
"scripts": {
"dev": "vite",
"build": "vite build && vite build --mode client",
"preview": "wrangler pages dev ./dist",
"deploy": "$npm_execpath build && wrangler pages deploy ./dist"
},
"private": true,
"dependencies": {
"honox": "^0.0.0"
},
"devDependencies": {
"vite": "^5.0.10",
"wrangler": "^3.22.1"
},
"resolutions": {
"honox": "portal:../.."
}
}
17 changes: 17 additions & 0 deletions examples/basic/tsconfig.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
{
"compilerOptions": {
"target": "ESNext",
"module": "ESNext",
"moduleResolution": "Bundler",
"esModuleInterop": true,
"strict": true,
"lib": [
"esnext"
],
"types": [
"vite/client"
],
"jsx": "react-jsx",
"jsxImportSource": "hono/jsx"
},
}
33 changes: 33 additions & 0 deletions examples/basic/vite.config.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
import honox from 'honox/vite'
import { defineConfig } from '../../node_modules/vite'

export default defineConfig(({ mode }) => {
if (mode === 'client') {
return {
build: {
rollupOptions: {
input: ['./app/client.ts'],
output: {
entryFileNames: 'static/client.js',
chunkFileNames: 'static/assets/[name]-[hash].js',
assetFileNames: 'static/assets/[name].[ext]',
},
},
emptyOutDir: false,
copyPublicDir: false,
},
}
} else {
return {
build: {
rollupOptions: {
output: {
entryFileNames: '_worker.js',
},
},
minify: true,
},
plugins: [honox()],
}
}
})
Loading

0 comments on commit 4d9d523

Please sign in to comment.