A Vite integration for Rust back-ends.
This crate provides methods for parsing a Vite-generated manifest.json
file into
meaningful HTML tags, as well as utility methods for injecting these tags and other Vite
scripts into HTML templates.
To get started, add the following under your Cargo dependencies
field:
vite-rust = { version = "0.2" }
rust-vite provides a Vite
struct that is responsible for dealing with the manifest and
its chunks, and also is your interface for generating the HTML you need.
To initialize it, you need to provide a ViteConfig
struct that contains data that will
be used to manage the manifest and also generate the HTML tags according to the mode you
are running at.
There are two fields that are exclusively mandatory:
manifest_path
;entrypoints
.
If none of them is set, your application will certainly panic on Vite initialization.
use vite_rust::ViteConfig;
let vite_config: vite_rust::ViteConfig = vite_rust::ViteConfig::default()
.set_manifest_path("path/to/manifest.json")
.set_entrypoints(vec!["views/bar.js", "views/foo.js"]);
let vite = vite_rust::Vite::new(vite_config.clone()).await.unwrap();
let tags = vite.get_tags(); // get html tags from Manifest and given entrypoints
let hmr_script = vite.get_hmr_script(); // get hmr script if Mode is set to Develpment. Empty string otherwise
// inject this manually to your html somehow...
We expect you to have vite.config.ts
file created and set up by yourself. Unlike some
other plugins, such as Innocenzi's Laravel plugin, we won't generate the config file
from our ViteConfig
struct for you.
Nevertheless, here are two recommendations for getting it set up more easily:
-
laravel/vite-plugin - A robust and very popular Vite plugin for setting up Vite with Laravel applications. With a few extra settings, you can get it working with your Rust application!
-
vite-rs-plugin - A pretty simple plugin that is enough for getting your Rust application running.
At this point, vite-rust only provides a really basic HTML directives set. You can
use them by enabling the basic-directives
feature at features property inside your
Cargo file:
[dependencies]
vite-rust = { version = "0.2", features = ["basic-directives"] }
However, Vite
struct also provide many helper methods that might be useful if you want to
create your own template-engine specific helpers, directives or integration.
Our basic directives work by receiving an HTML string reference and replaces the plain text directives using Regex:
use vite_rust::{ Vite, ViteConfig, features::html_directives::ViteDefaultDirectives };
let vite = Vite::new(ViteConfig::default().set_manifest_path("path/to/manifest.json"));
let my_html = r#"
<htmL>
<head>
@vite::react
@vite
</head>
<body>
<div id="root"></div>
</body>
</html>
"#;
vite.vite_directive(&mut template);
vite.react_directive(&mut template);
We provide a little path resolver function for finding the manifest file. It is experimental and bugs might be found, though:
use vite_rust::{utils::resolve_path, ViteConfig};
// if path is invalid, or file do not exist, the function will immediatly panic
let manifest_path: String = resolve_path(file!(), "../dist/.vite/manifest.json");
let vite_config: ViteConfig = ViteConfig::default().set_manifest_path(&manifest_path);
There is an enum called ViteMode, that can be either Development
or Manifest
.
It indicates to vite-rust how to manage your assets.
If in Development
, a few things happen:
- your assets will be resolved to reference the assets served by Vite development server. Hence, it expects the server to be running or some unexpected behaviour might occur.
- some of Vite methods might return different strings.
get_resolved_vite_scripts
, for instance, returns the HMR script and a module script referencing your entrypoint.
If in Manifest
mode, other things happen:
- by using our basic directive, "@vite" will be replaced by HTML tags referencing bundled scripts needed to make your application run, as some preload links for enabling faster loading;
- some of Vite methods will conditionally return different output according to this option.
get_resolved_vite_scripts
will return, instead of HMR and client scripts, the HTML assets tags mentioned above.
It means that if you intend to make your own directives, this is the key for correctly expanding them.
The mode can be set at ViteConfig
's force_mode
property. It defaults to None
. On Vite initialization,
if there is not a required mode, it will discover what mode to run based on a few steps that includes:
- Checking for "production" value in environment variables such as "NODE_ENV", "APP_ENV" or "RUST_ENV";
- Checking if heart beat checking is enabled at the config struct (if not, Development mode will be used);
- Checking if development server is enabled (if not, Manifest mode will be used);
- Pinging Vite's development server to check whether it is running.
Every method is documented and explains what you can expect from it.
So far, there is only one really simple sample application available at /example directory.
If you find any bug with the application, please create an Issue or feel free to make a pull request. I will be working on providing templates for contributing as soon as possible.
More docs about every method available can be found at docs.rs.
Also I want to credit some amazing projects that served as references:
Warning
Unexpected bugs might occur, and vite-rust is barely newborn. Please be careful and let me know about any bug found.
This project is licensed under the MIT license.