You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
Dan Ditomaso bfe4e01c85
add tag version to footer (#725)
11 months ago
..
infra fix: updated nginx config to pass sub directories (#692) 11 months ago
public refactor: switch to using Bun (#718) 11 months ago
src add tag version to footer (#725) 11 months ago
.npmrc Add monorepo support to project (#682) 11 months ago
CONTRIBUTING_I18N_DEVELOPER_GUIDE.md Add monorepo support to project (#682) 11 months ago
CONTRIBUTING_TRANSLATIONS.md Add monorepo support to project (#682) 11 months ago
README.md Fix/add npm jsr building (#722) 11 months ago
crowdin.yml Add monorepo support to project (#682) 11 months ago
index.html refactor: switch to using Bun (#718) 11 months ago
package.json Fix/add npm jsr building (#722) 11 months ago
tsconfig.json refactor: switch to using Bun (#718) 11 months ago
vercel.json refactor: switch to using Bun (#718) 11 months ago
vite-env.d.ts add tag version to footer (#725) 11 months ago
vite.config.ts add tag version to footer (#725) 11 months ago
vitest.config.ts Fix/add npm jsr building (#722) 11 months ago

README.md

Meshtastic Web

CI CLA assistant Fiscal Contributors Vercel

Overview

Official Meshtastic web interface, that can be hosted or served from a node

Hosted version

Stats

Alt

Self-host

The client can be self hosted using the precompiled container images with an OCI compatible runtime such as Docker or Podman. The base image used is Nginx 1.27

# With Docker
docker run -d -p 8080:8080 --restart always --name Meshtastic-Web ghcr.io/meshtastic/web

#With Podman
podman run -d -p 8080:8080 --restart always --name Meshtastic-Web ghcr.io/meshtastic/web

Release Schedule

Our release process follows these guidelines:

  • Versioning: We use Semantic Versioning (Major.Minor.Patch).
  • Stable Releases: Published around the beginning of each month (e.g., v2.6.1).
  • Pre-releases: A pre-release is typically issued mid-month for testing and early adoption.
  • Nightly Builds: An experimental Docker image containing the latest cutting-edge features and fixes is automatically built nightly from the main branch.

Nightly Builds

# With Docker
docker run -d -p 8080:8080 --restart always --name Meshtastic-Web ghcr.io/meshtastic/web:nightly
#With Podman
podman run -d -p 8080:8080 --restart always --name Meshtastic-Web ghcr.io/meshtastic/web:nightly

[!WARNING]

  • Nightly builds represent the latest development state and may contain breaking changes
  • These builds undergo automated testing but may be less stable than tagged release versions
  • Not recommended for production environments unless you are actively testing new features
  • No guarantee of backward compatibility between nightly builds

Version Information

Each nightly build is tagged with:

  • The nightly tag for the latest build
  • A specific SHA for build reproducibility

Feedback

If you encounter any issues with nightly builds, please report them in our issues tracker. Your feedback helps improve the stability of future releases

Development & Building

You'll need to download the package manager used with this repo. You can install it by visiting bun.sh and following the installation instructions listed on the home page.

Development

Install the dependencies.

cd packages/web &&
bun install

Start the development server:

bun run dev

Building and Packaging

Build the project:

bun run build

GZip the output:

bun run package

Why Bun?

Meshtastic Web uses Bun as its development platform for several compelling reasons:

  • Fast Performance: Bun is built from the ground up for speed, offering significantly faster package installation and bundling compared to other JavaScript runtimes.
  • TypeScript Support: Native TypeScript support without additional configuration, enhancing code quality and developer experience.
  • Modern JavaScript: First-class support for ESM imports, top-level await, and other modern JavaScript features.
  • Node.js Compatibility: Drop-in replacement for Node.js with better performance and built-in tooling.
  • Reproducible Builds: Lockfile ensures consistent builds across all environments.

Contributing

We welcome contributions! Here’s how the deployment flow works for pull requests:

  • Preview Deployments:
    Every pull request automatically generates a preview deployment on Vercel. This allows you and reviewers to easily preview changes before merging.

  • Staging Environment (client-test):
    Once your PR is merged, your changes will be available on our staging site: client-test.meshtastic.org.
    This environment supports rapid feature iteration and testing without impacting the production site.

  • Production Releases:
    At regular intervals, stable and fully tested releases are promoted to our production site: client.meshtastic.org.
    This is the primary interface used by the public to connect with their Meshtastic nodes.

Please review our Contribution Guidelines before submitting a pull request. We appreciate your help in making the project better!