UNPKG

ng-packagr

Version:

Compile and package Angular libraries in Angular Package Format (APF)

107 lines 3.87 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.generateSearchDirectories = generateSearchDirectories; exports.findTailwindConfiguration = findTailwindConfiguration; exports.getTailwindConfig = getTailwindConfig; exports.loadPostcssConfiguration = loadPostcssConfiguration; const node_fs_1 = require("node:fs"); const node_module_1 = require("node:module"); const node_path_1 = require("node:path"); const log_1 = require("../utils/log"); const postcssConfigurationFiles = ['postcss.config.json', '.postcssrc.json']; const tailwindConfigFiles = [ 'tailwind.config.js', 'tailwind.config.cjs', 'tailwind.config.mjs', 'tailwind.config.ts', ]; function generateSearchDirectories(roots) { return roots.map(root => { return { root, files: new Set((0, node_fs_1.readdirSync)(root, { withFileTypes: true }) .filter(entry => entry.isFile()) .map(entry => entry.name)), }; }); } function findFile(searchDirectories, potentialFiles) { for (const { root, files } of searchDirectories) { for (const potential of potentialFiles) { if (files.has(potential)) { return (0, node_path_1.join)(root, potential); } } } return undefined; } function findTailwindConfiguration(searchDirectories) { return findFile(searchDirectories, tailwindConfigFiles); } function getTailwindConfig(searchDirectories, workspaceRoot) { const tailwindConfigurationPath = findTailwindConfiguration(searchDirectories); if (!tailwindConfigurationPath) { return undefined; } // Create a node resolver from the configuration file const resolver = (0, node_module_1.createRequire)(tailwindConfigurationPath); try { return { file: tailwindConfigurationPath, package: resolver.resolve('tailwindcss'), }; } catch { const relativeTailwindConfigPath = (0, node_path_1.relative)(workspaceRoot, tailwindConfigurationPath); (0, log_1.warn)(`Tailwind CSS configuration file found (${relativeTailwindConfigPath})` + ` but the 'tailwindcss' package is not installed.` + ` To enable Tailwind CSS, please install the 'tailwindcss' package.`); } return undefined; } function readPostcssConfiguration(configurationFile) { const data = (0, node_fs_1.readFileSync)(configurationFile, 'utf-8'); const config = JSON.parse(data); return config; } function loadPostcssConfiguration(searchDirectories) { const configPath = findFile(searchDirectories, postcssConfigurationFiles); if (!configPath) { return undefined; } const raw = readPostcssConfiguration(configPath); // If no plugins are defined, consider it equivalent to no configuration if (!raw.plugins || typeof raw.plugins !== 'object') { return undefined; } // Normalize plugin array form if (Array.isArray(raw.plugins)) { if (raw.plugins.length < 1) { return undefined; } const config = { plugins: [] }; for (const element of raw.plugins) { if (typeof element === 'string') { config.plugins.push([element]); } else { config.plugins.push(element); } } return config; } // Normalize plugin object map form const entries = Object.entries(raw.plugins); if (entries.length < 1) { return undefined; } const config = { plugins: [] }; for (const [name, options] of entries) { if (!options || (typeof options !== 'object' && typeof options !== 'string')) { continue; } config.plugins.push([name, options]); } return config; } //# sourceMappingURL=postcss-configuration.js.map