Postcss Config

A Laravel-mix plugin to add the postcss-loader to the default mix webpack.config.js file.
latest v1.4.0 - released
yazeedobaid
252 downloads last week
MIT license
6 versions
postcss-loader

laravel-mix-postcss-config

GitHub Node.js Package npm npm

A Laravel-mix plugin to add the postcss-loader loader with its configuration file to the default mix webpack.config.js file in a fluent way.

mix.js('resources/js/app.js', 'public/js')
    .postCss('resources/css/app.css', 'public/css')
    .postCssConfig();

Introduction

Laravel mix has a great and fluent api to define the build steps for an application. Mix has supprt for defining postcss plugins through the postCss api. Defining these plugins along with their options in mix's config file will make the file large and difficult to read.

postcss-loader provide a way to define postcss plugins in a separate config file (postcss.config.js). This plugin extends laravel-mix api and add a method to include the loader with its config file in the build process.

Install

Install using npm:

$ npm install laravel-mix-postcss-config --save-dev

Usage

Require the pulgin in your laravel-mix config file and call the extension method on mix.

const mix = require('laravel-mix');
require('laravel-mix-postcss-config');

mix.js('resources/js/app.js', 'public/js')
    .postCss('resources/css/app.css', 'public/css')    
    .postCssConfig();

The above call will merge the postcss-loader loader to mix's generated webpack config rules with the default loader configuration options. If you wish to change the default loader options you can pass them in the call:

const mix = require('laravel-mix');
require('laravel-mix-postcss-config');

mix.js('resources/js/app.js', 'public/js')
    .postCss('resources/css/app.css', 'public/css')    
    .postCssConfig({ /* postcss-loader options */ });

You can find a list of possible postcss-loader loader options in the loader github repository

License

The MIT License (MIT). Please see License File for more information.