Skip to content

Configuring Vite Ruby

The following section is an overview of basic configuration for Vite Ruby.

Most of the options discussed are specific to Vite Ruby, for the rest of the available configuration options please check Vite's config reference.

Configuring Vite ⚡

When running bin/vite from the command line, Vite will use your vite.config.ts.

If you followed the installation section, it should look similar to:

// vite.config.ts
import { defineConfig } from 'vite'
import RubyPlugin from 'vite-plugin-ruby'

export default defineConfig({
  plugins: [
    RubyPlugin(),
  ],
})

You can customize this file as needed, check Vite's plugins and config reference for more info.

Shared Configuration File 📄

Vite Ruby leverages a simple config/vite.json configuration file, which is read both from Ruby and JavaScript, and allows you to easily configure options such as the host and port of the Vite development server.

If you followed the installation section, it should look similar to:

{
  "all": {
    "watchAdditionalPaths": []
  },
  "development": {
    "autoBuild": true,
    "publicOutputDir": "vite-dev",
    "port": 3036
  },
  "test": {
    "autoBuild": true,
    "publicOutputDir": "vite-test",
    "port": 3037
  }
}

The all section is applied to all environments, including production. You can override specific options in an environment-specific group.

The following options can all be specified in your config/vite.json file, or overriden with environment variables.

Ruby Configuration File 💎

To set environment variables that need to be resolved at runtime, use config/vite.rb.

This will be loaded once ViteRuby.config is resolved, and you may configure ViteRuby.env as needed or call ViteRuby.configure(**options) to override the configuration.

# config/vite.rb
ViteRuby.env['ADMINISTRATOR_ASSETS_PATH'] =
  "#{ Gem.loaded_specs['administrator'].full_gem_path }/app/frontend"

Then, you can access those environment variables in process.env in the Vite config file:

// vite.config.ts
const adminAssetsPath = process.env.ADMINISTRATOR_ASSETS_PATH

Source Maps 🗺

One notable difference with Vite's defaults, is that source maps are enabled in production to be in alignment with Rails defaults.

You may skip source map generation by explicitly configuring sourcemap:

// vite.config.ts
export default defineConfig({
  build: { sourcemap: false },

Emptying the Output Dir 📦

Another difference with Vite's defaults, is that emptyOutDir is disabled in production to provide better support for deployments that don't use a CDN.

Keeping assets from previous builds helps to prevent downtime when deploying in the same host.

You may override this behavior manually:

// vite.config.ts
export default defineConfig({
  build: { emptyOutDir: true },

Development Options

autoBuild

  • Default: false in production, true in test and development

  • Env Var: VITE_RUBY_AUTO_BUILD

    When enabled, Vite Ruby will track changes to sourceCodeDir, and trigger a Vite build on demand if files have changed. Additional files can be specified with watchAdditionalPaths.

    This is very convenient when running integration tests, or when a developer does not want to start the Vite development server (although it's highly recommended).

host

  • Default: "localhost"

  • Env Var: VITE_RUBY_HOST

    Specify the hostname for the Vite development server.

port

  • Default: 3036

  • Env Var: VITE_RUBY_PORT

    Specify the port for the Vite development server.

https

  • Type: boolean

  • Env Var: VITE_RUBY_HTTPS

    Enable TLS + HTTP/2 for the Vite development server.

Build Options

The default configuration expects your code to be in app/frontend, and your entrypoint files to be in the app/frontend/entrypoints directory.

The compiled assets will be outputed to the public/vite/assets directory.

You can customize this behavior using the following options.

buildCacheDir

  • Default: tmp/cache/vite

  • Env Var: VITE_RUBY_BUILD_CACHE_DIR

    Specify the directory where the autoBuild cache should be stored, used to detect if a build is needed when the development server is not running.

publicDir

  • Default: public

  • Env Var: VITE_RUBY_PUBLIC_DIR

    Specify the public directory (relative to root).

    It's expected for this directory to be served by Apache/NGINX, or loaded into a CDN.

    Check Rails public_file_server.enabled for more information.

publicOutputDir

  • Default: vite

  • Env Var: VITE_RUBY_PUBLIC_OUTPUT_DIR

    Specify the output directory (relative to publicDir).

assetsDir

  • Default: assets

  • Env Var: VITE_RUBY_ASSETS_DIR

    Specify the directory to nest generated assets under (relative to publicOutputDir).

sourceCodeDir

  • Default: app/frontend

  • Env Var: VITE_RUBY_SOURCE_CODE_DIR

    Specify the directory where your source code will be located (relative to root).

    Vite Ruby will alias this directory as ~/ and @/, allowing you to make absolute imports which are more convenient.

    Files in this directory will be tracked for changes when using autoBuild.

entrypointsDir

  • Default: entrypoints

  • Env Var: VITE_RUBY_ENTRYPOINTS_DIR

    Specify the directory where the entrypoints will be located (relative to sourceCodeDir).

Other Options

additionalEntrypoints

  • Version Added: 3.0.0

  • Default: ["~/{assets,fonts,icons,images}/**/*"]

    Specify additional entrypoints, which can be referenced using tag helpers without having to place them inside entrypointsDir.

    ~/ is an alias for the sourceCodeDir, ["~/images/**/*"]:

    vite_asset_path 'images/logo.svg' # app/frontend/images/logo.svg
    

    Otherwise, globs are relative to root, such as ["app/components/**/*.js"].

    vite_asset_path '/app/components/header.js' # leading slash is required
    

assetHost

  • Default: Rails.application.config.action_controller.asset_host

  • Env Var: VITE_RUBY_ASSET_HOST

    Specify the asset host when using a CDN. Usually there's no need to explicitly configure it.

base

  • Default: ''

  • Env Var: VITE_RUBY_BASE

    Necessary when you are hosting your Ruby app in a nested path. Example:

    "base": "/nested_path"
    

devServerConnectTimeout

  • Default: 0.01 (seconds)

    Timeout when attempting to connect to the dev server (in seconds).

    You can increase this timeout if the fallback compilation is being triggered even though the dev server is running.

hideBuildConsoleOutput

  • Default: false

  • Env Var: VITE_RUBY_HIDE_BUILD_CONSOLE_OUTPUT

    Allows to skip Vite build output from logs, to keep the noise down.

packageManager

  • Default: auto-detected based on existing lockfiles, otherwise "npm"

  • Env Var: VITE_RUBY_PACKAGE_MANAGER

    Allows to specify which package manager to use, such as:

    • npm
    • pnpm
    • yarn
    • bun (experimental)

root

  • Default: Rails.root

  • Env Var: VITE_RUBY_ROOT

    Specify the project root.

skipCompatibilityCheck

  • Version Added: 3.0.0

  • Default: false

  • Env Var: VITE_RUBY_SKIP_COMPATIBILITY_CHECK

    The version of vite-plugin-ruby is checked on initialization to fail early if an incompatible version is suspected, as it could lead to hard-to-debug errors such as missing entrypoints in the build.

    Running bin/vite upgrade will install a compatible version, which should resolve this error.

    Otherwise, this setting allows to skip that check. Use it responsibly.

skipProxy (experimental)

  • Version Added: 3.2.12

  • Default: false

  • Env Var: VITE_RUBY_SKIP_PROXY

    Whether to skip the dev server proxy, and request assets to the Vite development server directly.

    Connecting to Vite directly allows assets to be served using HTTP2 when https is enabled.

    Don't enable this option in Rails 6 or earlier if you are using vite_stylesheet_tag with assets that don't have a .css extension, or Vite will fail to serve them.

viteBinPath

  • Default: node_modules/.bin/vite

  • Env Var: VITE_RUBY_VITE_BIN_PATH

    The path where the Vite.js binary is installed. It will be used to execute the dev and build commands.

watchAdditionalPaths

  • Default: []

    Specify which other paths should be tracked for changes when using autoBuild.

    You may provide globs such as ["app/components/**/*"], paths should be relative to root.

    The sourceCodeDir and any additionalEntrypoints are included by default.


    In order to reference these files it's highly recommended to define your own import aliases:







     




    import { resolve } from 'path'
    import { defineConfig } from 'vite'
    
    export default defineConfig({
      resolve: {
        alias: {
          '@assets': resolve(__dirname, 'app/assets'),
        },
      },
    })
    

ENV-Only Options

config_path

  • Default: config/vite.json

  • Env Var: VITE_RUBY_CONFIG_PATH

    Specify where the JSON config file is located (relative to root).

skip_assets_precompile_extension

  • Default: false

  • Env Var: VITE_RUBY_SKIP_ASSETS_PRECOMPILE_EXTENSION

    When enabled, vite:build won't be run automatically when the assets:precompile rake task is run, allowing you to fully customize your deployment.

skip_assets_precompile_install

  • Version Added: 3.6.0

  • Default: false

  • Env Var: VITE_RUBY_SKIP_ASSETS_PRECOMPILE_INSTALL

    When enabled, assets:precompile won't invoke vite:install_dependencies before invoking vite:build.

    This can be useful in CI setups where all node dependencies necessary for the Vite build have already been installed in a previous step.

skip_install_dev_dependencies

  • Version Added: 3.3.3

  • Default: false

  • Env Var: VITE_RUBY_SKIP_INSTALL_DEV_DEPENDENCIES

    When enabled, the vite:install_dependencies rake task will also install development dependencies, which is usually necessary in order to run a Vite build.

    By adding Vite and its plugins (plus other tools such as ESLint) as development dependencies, you can easily prune them after assets have been precompiled.

SSR Options (experimental)

Vite Ruby supports building your app in SSR mode, obtaining a Node.js app that can be used in combination with Rails, such as when using Inertia.js in SSR mode.

When building in SSR mode, Vite Ruby will use ssrEntrypoint as the single entrypoint, and output the resulting app in a ssrOutputDir/ssr.js script.

Running the server

The resulting Node.js script can be conveniently executed with bin/vite ssr.

Experimental

Until the API is stabilized, these options do not follow semantic versioning.

Lock vite_ruby and vite-plugin-ruby down to patch releases to prevent breaking changes.

ssrBuildEnabled

  • Default: false

  • Env Var: VITE_RUBY_SSR_BUILD_ENABLED

    When enabled, running rake assets:precompile will also run an SSR build, simplifying the deployment setup.

Manual SSR Builds

You can build the app in SSR mode using bin/vite build --ssr.

ssrEntrypoint

  • Default: ~/ssr/ssr.{js,ts,jsx,tsx}

  • Env Var: VITE_RUBY_SSR_ENTRYPOINT

    A file glob pattern that matches the entrypoint file for SSR builds, for example: app/frontend/ssr/ssr.ts.

    ~/ can be used in the glob pattern as an alias for the sourceCodeDir.

ssrOutputDir

  • Default: public/vite-ssr

  • Env Var: VITE_RUBY_SSR_OUTPUT_DIR

    Specify the output directory for the SSR build (relative to root).




















Configuring Vite Ruby has loaded