Configuration
Vite Plugin Symfony
In order to maintain maximum flexibility, I decided not to create an abstraction layer on top of the vite.config.js
configuration file.
// vite.config.js
import {defineConfig} from "vite";
import symfonyPlugin from "vite-plugin-symfony";
export default defineConfig({
plugins: [
symfonyPlugin(),
],
build: {
rollupOptions: {
input: {
/* relative to the root option */
app: "./assets/app.ts",
/* you can also provide [s]css files */
theme: "./assets/theme.scss"
},
}
},
});
// vite.config.js
import {defineConfig} from "vite";
import symfonyPlugin from "vite-plugin-symfony";
export default defineConfig({
plugins: [
symfonyPlugin(),
],
build: {
rollupOptions: {
input: {
/* relative to the root option */
app: "./assets/app.ts",
/* you can also provide [s]css files */
theme: "./assets/theme.scss"
},
}
},
});
The only required option is build.rollupOptions.input
. With vite-plugin-symfony
this option must be set as an object.
export type InputOption = {
// entryAlias will be used by our Twig functions
[entryAlias: string]: string;
};
export type InputOption = {
// entryAlias will be used by our Twig functions
[entryAlias: string]: string;
};
if you have a theme containing only css rules (no js) it may be interesting to define an entry point with a [s]css file. this will in particular prevent FOUC during development.
In order to allow use Vite without configuration, the extension preconfigures some options of Vite if these have not yet been defined. (view source code).
This is an interesting extract of the source code of the plugin where you can see how the vite options are preconfigured.
// vite-plugin-symfony/src/index.ts
config(userConfig) {
const extraConfig: UserConfig = {
base: userConfig.base ?? "/build/",
publicDir: false,
build: {
manifest: true,
outDir: userConfig.build?.outDir ?? "public/build",
},
optimizeDeps: {
//Set to true to force dependency pre-bundling.
force: true,
},
};
return extraConfig;
}
// vite-plugin-symfony/src/index.ts
config(userConfig) {
const extraConfig: UserConfig = {
base: userConfig.base ?? "/build/",
publicDir: false,
build: {
manifest: true,
outDir: userConfig.build?.outDir ?? "public/build",
},
optimizeDeps: {
//Set to true to force dependency pre-bundling.
force: true,
},
};
return extraConfig;
}
For all available options, you can check the Vite plugin Symfony Reference page.
Change the name of the build
directory.
If you want to specify another directory name to build your assets, you will need to change a few options.
// vite.config.js
export default defineConfig({
base: '/custom-build/',
plugins: [
symfonyPlugin(),
],
build: {
outDir: 'public/custom-build',
rollupOptions: {
input: {
"app": "./assets/app.js",
},
},
},
});
// vite.config.js
export default defineConfig({
base: '/custom-build/',
plugins: [
symfonyPlugin(),
],
build: {
outDir: 'public/custom-build',
rollupOptions: {
input: {
"app": "./assets/app.js",
},
},
},
});
You will then need to create a configuration file pentatrion_vite.yaml
so that pentatrion/vite-bundle
matches your js configuration.
#config/packages/pentatrion_vite.yaml
pentatrion_vite:
build_directory: custom-build
#config/packages/pentatrion_vite.yaml
pentatrion_vite:
build_directory: custom-build
To consult the list of all the available options, you can go to the page Reference: Vite Bundle.