File: /var/www/vhost/disk-apps/alq-cali.bikenow.co/node_modules/laravel-mix/src/PostCssPluginsFactory.js
module.exports = class PostCssPluginsFactory {
    /**
     * Create a new instance.
     * @param {import('./Mix.js')} context
     */
    constructor(context) {
        this.context = context;
        /** @type {import('postcss').AcceptedPlugin[]} */
        this.plugins = [];
    }
    /**
     * Load all relevant PostCSS plugins.
     *
     * @param {import('postcss').AcceptedPlugin[] | undefined} plugins
     */
    load(plugins = []) {
        this.loadGlobalPlugins();
        this.loadLocalPlugins(plugins);
        this.loadAutoprefixer();
        this.loadCssNano();
        return this.plugins;
    }
    /**
     * Load the user's postcss.config.js file, if any.
     *
     * @deprecated postcss-loader already does this on its own
     */
    loadConfigFile() {
        let postcssrc = require('postcss-load-config');
        try {
            this.plugins = [...this.plugins, ...postcssrc.sync().plugins];
        } catch (e) {
            // No postcss.config.js file exists.
        }
    }
    /**
     * Load any global postcss plugins that have been passed to Mix.
     */
    loadGlobalPlugins() {
        if (this.context.config.postCss && this.context.config.postCss.length) {
            this.plugins = [...this.plugins, ...this.context.config.postCss];
        }
    }
    /**
     * Load any postcss plugins that were passed to the Mix command.
     *
     * @param {import('postcss').AcceptedPlugin[] | undefined} plugins
     */
    loadLocalPlugins(plugins) {
        if (plugins && plugins.length) {
            this.plugins = [...this.plugins, ...plugins];
        }
    }
    /**
     * Add autoprefixer to the plugins list.
     */
    loadAutoprefixer() {
        if (this.context.config.autoprefixer) {
            this.plugins.push(require('autoprefixer')(this.context.config.autoprefixer));
        }
    }
    /**
     * Add CSSNano to the plugins list.
     */
    loadCssNano() {
        if (this.context.config.production && this.context.config.cssNano !== false) {
            this.plugins.push(
                require('cssnano')({
                    preset: ['default', this.context.config.cssNano]
                })
            );
        }
    }
};