This repository is a template repo for a single web development pipeline for creating a traditional hosted web app, desktop app with Tauri, and Android/IOS mobile app with Capacitor. This comes enabled with complex web bundling capabilities thanks to esbuild (via tinybuild) for rapid development.
It also contains some test code for linking a separate node server to the tauri application, for running nodejs in parallel with the desktop app.
frontend
- The frontend code for the appsrc-tauri
- The Tauri source filescapacitor.config.js
- The Capacitor configuration filebackend
- The backend code for the app, an example for serving a node server in a tauri webview application.
Development server: npm start
Or: bundle & serve with tinybuild
, which by default runs a hot-reloading development server for quick testing. tinybuild build
will just run the bundler step, or set server:false in tinybuild.config.js
Then in production, simply serve the index.html in this repository. and it will link the bundled file. Tinybuild includes instructions to quickly serve an https server if you don't have your own solution.
Ensure that the Tauri CLI is installed by running npm i
.
You must also ensure that both Microsoft Visual Studio C++ Build Tools, WebView2 (if below Windows 10 / 11), and Rust.
After this, you can run npm run tauri dev
to run the app in development mode. This will open a window with the app running in it.
You can also run npm run tauri build
to build the app for your current platform.
Ensure that Capacitor is installed by running npm i
.
- Install Android Studio
- Create a new project in Android Studio
npm run init:android
(will runnpx cap add android
,npx cap copy
)
- Open the project in Android Studio
npm run android
(will runnpx cap open android
)
The first run will likely need to install all of the tools in the android project necessary. Build the android project in Android Studio after running these commands by clicking the Make Project hammer icon if it doesn't start automatically. Then if you see BUILD SUCCESSFUL, run with your android device connected or the built-in android emulators active.
- Install XCode
- Install cocoapods (if required)
- Create a new project in XCode
npm run init:ios
(will runnpx cap add ios
,npx cap copy
)
- Open the project in XCode
npm run ios
(will runnpx cap open ios
)