Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/roblesdotdev/me

Personal website
https://github.com/roblesdotdev/me

remix-run website

Last synced: 2 days ago
JSON representation

Personal website

Awesome Lists containing this project

README

        

# templates/spa

This template leverages
[Remix SPA Mode](https://remix.run/docs/en/main/future/spa-mode) and the
[Remix Vite Plugin](https://remix.run/docs/en/main/future/vite) to build your
app as a Single-Page Application using
[Client Data](https://remix.run/docs/en/main/guides/client-data) for all of your
data loads and mutations.

## Setup

```shellscript
npx create-remix@latest --template remix-run/remix/templates/spa
```

## Development

You can develop your SPA app just like you would a normal Remix app, via:

```shellscript
npm run dev
```

## Production

When you are ready to build a production version of your app, `npm run build`
will generate your assets and an `index.html` for the SPA.

```shellscript
npm run build
```

### Preview

You can preview the build locally with
[vite preview](https://vitejs.dev/guide/cli#vite-preview) to serve all routes
via the single `index.html` file:

```shellscript
npm run preview
```

> [!IMPORTANT]
>
> `vite preview` is not designed for use as a production server

### Deployment

You can then serve your app from any HTTP server of your choosing. The server
should be configured to serve multiple paths from a single root `/index.html`
file (commonly called "SPA fallback"). Other steps may be required if the server
doesn't directly support this functionality.

For a simple example, you could use
[sirv-cli](https://www.npmjs.com/package/sirv-cli):

```shellscript
npx sirv-cli build/client/ --single
```