Security News
cURL Project and Go Security Teams Reject CVSS as Broken
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
vite-plugin-symfony
Advanced tools
A Vite plugin to integrate easily Vite in your Symfony application..
A Vite plugin to integrate easily Vite in your Symfony application..
entrypoints.json
file inside your build directory with your js/css/preload dependencies.This package is intended for use with the Symfony Bundle : pentatrion/vite-bundle.
npm i vite-plugin-symfony
Create this directory structure :
├──assets
│ ├──app.js
│ ├──app.css
│...
├──public
├──composer.json
├──package.json
├──vite.config.js
Vite base config with vite 3.x
// vite.config.js
import {defineConfig} from "vite";
import symfonyPlugin from "vite-plugin-symfony";
/* if you're using React */
// import reactRefresh from "@vitejs/plugin-react-refresh";
export default defineConfig({
plugins: [
/* reactRefresh(), // if you're using React */
symfonyPlugin(/* options */),
],
build: {
rollupOptions: {
input: {
app: "./assets/app.js" /* relative to the root option */
},
},
}
});
and your package.json :
{
"scripts": {
"dev": "vite",
"build": "vite build"
},
"devDependencies": {
"vite": "^4.0",
"vite-plugin-symfony": "^0.7.3"
}
}
type VitePluginSymfonyOptions = {
/**
* Web directory root
* Relative file path from project directory root.
* @default 'public'
*/
publicDirectory: string
/**
* Build directory (or path)
* Relative path from web directory root
* @default 'build'
*/
buildDirectory: string
/**
* By default vite-plugin-symfony set vite option publicDir to false.
* Because we don't want symfony entrypoint (index.php) and other files to
* be copied into the build directory.
* Related to this issue : https://github.com/lhapaipai/vite-bundle/issues/17
*
* Vite plugin Symfony use sirv to serve public directory.
*
* If you want to force vite option publicDir to true, set servePublic to false.
*
* @default true
*/
servePublic: boolean
/**
* Refresh vite dev server when your twig templates are updated.
* - array of paths to files to be watched, or glob patterns
* - true : equivalent to ["templates/**\/*.twig"]
* @default false
*
* for additional glob documentation, check out low-level library picomatch : https://github.com/micromatch/picomatch
*/
refresh: boolean | string[]
/**
* If you specify vite `server.host` option to '0.0.0.0' (usage with Docker)
* You probably need to configure your `viteDevServerHostname` to 'localhost'.
* Related to this issue : https://github.com/lhapaipai/vite-bundle/issues/26
*
* @default null
*/
viteDevServerHostname: null | string
/**
* Show vite resolved config
* @default false
*/
debug: boolean;
}
vite-plugin-symfony
use this options :
publicDirectory
buildDirectory
to determine the right configuration for vite
:
base
build.outDir
so you have to specify the configuration either from the plugin or from vite but not in both
// vite.config.js
import symfonyPlugin from "vite-plugin-symfony";
export default {
plugins: [
symfonyPlugin({
publicDirectory: 'public',
buildDirectory: 'build'
}),
],
};
or
// vite.config.js
// If you have a specific need you can still define your configuration on top.
import symfonyPlugin from "vite-plugin-symfony";
export default {
plugins: [
symfonyPlugin(),
],
base: '/build/',
build: {
outDir: './public/build'
}
};
Although it has no special dependencies, this package is intended for use with the Symfony Bundle : pentatrion/vite-bundle. This bundle provides two twig functions to load your js/css files into your templates. It also acts as a proxy by forwarding requests that are not intended for it to the Vite dev server.
If you use previous version of the plugin consult migration page.
default js entryPoint
{
"isProd": true,
"viteServer": false,
"entryPoints": {
"welcome": {
"js": [
"/build/assets/welcome-1e67239d.js"
],
"css": [],
"preload": [],
"legacy": false
}
}
}
css entry point
{
"isProd": true,
"viteServer": false,
"entryPoints": {
"theme": {
"js": [],
"css": [
"/build/assets/theme-44b5be96.css"
],
"preload": [],
"legacy": false
}
}
}
v3.3.2
FAQs
A Vite plugin to integrate easily Vite in your Symfony application
The npm package vite-plugin-symfony receives a total of 11,464 weekly downloads. As such, vite-plugin-symfony popularity was classified as popular.
We found that vite-plugin-symfony demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
Security News
Biden's executive order pushes for AI-driven cybersecurity, software supply chain transparency, and stronger protections for federal and open source systems.