Using Stylify CSS in Nette Framework

Since Nette Framework doesn't use any bundler by default. Therefore you an use onl the Bundler or configure bundler and use Stylify with Webpack or Rollup.js and etc. ´

Integration example for the Nette framework can be found in integrations examples repository.

How to integrate the Stylify into the Nette Framework

In the example bellow we will use the Bundler package on its own.

First install the @stylify/bundler package using NPM or Yarn:

npm i -D @stylify/bundler
yarn add -D @stylify/bundler

Next, create a file, for example bundles.js:

const { nativePreset } = require('@stylify/stylify');
const { Bundler } = require('@stylify/bundler');

const bundler = new Bundler({
    watchFiles: process.argv[process.argv.length - 1] === '--w',
    // Optional
    compiler: {
        variables: {},
        macros: {},
        components: {},
        // ...

    files: ['./app/Presenters/templates/**/*.latte'], outputFile: './www/static/css/index.css'

And the last step is to add scripts into the package.json:

"scripts": {
    "build": "node bundles.js",
    "watch": "node bundles.js --w"

Now you can add a link for generated css into the @layout.latte:

<link rel="stylesheet" href="/static/css/index.css">

You can customize the build above however you want.

Where to go next?