Skip to content

Template for a Preact project that can either be used as a standalone client or as a client + server

Notifications You must be signed in to change notification settings

nicolasventer/Preact-Project-Template

Repository files navigation

Preact Project Template

This is a template for a Preact project. It allows the client either to be standalone or to be a client for a server.

There are 4 links, each link corresponding to Preact/React Full/Light Template.

full_screenshot light_screenshot
Full Light

The React versions are using the custom hook useReact. This hook ensure the re-render of the component when the signal is changed.

There is also another custom hook called useReactSignal. It is a wrapper around useState that returns an object with the property value that is an accessor (get and set) for the state.

Note: memo is not used in React version.

The Light versions remove the dependencies with elysia, typebox, mantine, react-hot-toast, lucide-react and react-icons.

Links

Features

  • Hot reload (client)
  • File base routing (client)
  • Lazy loading (client)
  • Watch mode (server)
  • Client side rendering
  • Tests (server and client)
  • Code coverage (server and client)
  • Documentation (server and client)
  • Linting (server and client)

Installation

Requirements

npm install -g bun
npm install -g serve

On Windows:

Installation

git clone https://github.com/nicolasventer/Preact-Project-Template
cd Preact-Project-Template
all_init_on_cloned.bat

The script will create a symbolic link between the Common folder of the Client and Server folders and then install the dependencies.
If you want to install the dependencies manually, you should at least create the symbolic link:

mk_link.bat

If you only require the client, you can run the following:

copy_common.bat

On Linux

Installation

git clone https://github.com/nicolasventer/Preact-Project-Template.git
cd Preact-Project-Template
./all_init_on_cloned.sh

The script will create a symbolic link between the Common folder of the Client and Server folders and then install the dependencies.
If you want to install the dependencies manually, you should at least create the symbolic link:

mk_link.sh

If you only require the client, you can run the following:

copy_common.sh

Usage

Client only (useful for hot reload that keeps the state)

Development

In the Client folder:

bun run dev

WARNING: Be sure to be exactly in the Client folder, otherwise you will have page not found error.

Access the client at http://localhost:5173

Production

In the Client folder, run:

bun run build
bun run preview
# bun run doc # for documentation

Access the client at http://localhost:4173

Deployment

In the Client folder, run:

bun run build

Then serve index.html and dist folder (and optionally the docs folder) (for example push on GitHub pages).

Server and Client

Development

In the Client folder, run:

bun run watch

In the Server folder, run:

bun run dev

Note: The client changes will be loaded on the refresh of the page.

Production

In the Client folder:

bun run build

Client is not accessible yet.

In the Server folder, run:

bun run start

Note: You can rebuild the client at any time, the server will serve the new files.

Access the server at http://localhost:3000/status

Access the client at http://localhost:3000

Deployment

Take index.html and dist folder from the client and the server code and execute the server.
You can also take the docs folder from the client.


Project structure

project_structure

Tech stack

tech_stack

Deployment

Deployed client

In the Client folder, run:

bun run build
bun run preview

Access the client at http://localhost:4173

In the Server folder, run:

bun run start

Access the server at http://localhost:3000/status

deployed_client

Client Side Rendering

In the Client folder, run:

bun run build

Client is not accessible yet.

In the Server folder, run:

bun run start

Access the server at http://localhost:3000/status

Access the client at http://localhost:3000

client_side_rendering