lib-tools
Version:
The lib-tools helps you simplify the build, bundle, test and npm packaging workflows for Typescript, JavaScript, Angular library projects and assets module projects.
97 lines • 17.2 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.prepareStyles = void 0;
const path = require("path");
const fs_extra_1 = require("fs-extra");
const utils_1 = require("../utils");
const inputExtRegExp = /\.(sass|scss|css)$/i;
const outputExtRegExp = /\.css$/i;
async function prepareStyles(buildConfig) {
if (!buildConfig.style) {
return;
}
const styleOptions = buildConfig.style;
if (!styleOptions.compilations || !styleOptions.compilations.length) {
return;
}
const projectName = buildConfig._projectName;
const projectRoot = buildConfig._projectRoot;
let packageJsonStyleEntry;
for (let i = 0; i < styleOptions.compilations.length; i++) {
const styleEntry = styleOptions.compilations[i];
if (!styleEntry.input || !styleEntry.input.trim().length) {
throw new Error(`Style input file is required, please correct value in 'projects[${projectName}].tasks.build.style.compilations[${i}].input'.`);
}
if (!inputExtRegExp.test(styleEntry.input)) {
throw new Error(`Unsupported style input file '${styleEntry.input}', please correct value in 'projects[${projectName}].tasks.build.style.compilations[${i}].input'.`);
}
const inputFilePath = path.resolve(projectRoot, styleEntry.input);
const inputFileExists = await fs_extra_1.pathExists(inputFilePath);
if (!inputFileExists) {
throw new Error(`Style input file '${inputFilePath}' doesn't exist, please correct value in 'projects[${projectName}].tasks.build.style.compilations[${i}].input'.`);
}
let outputFilePath;
if (styleEntry.output) {
const extName = path.extname(styleEntry.output);
if (!extName || styleEntry.output.endsWith('/')) {
const outputFileName = path.basename(inputFilePath).replace(inputExtRegExp, '.css');
outputFilePath = path.resolve(buildConfig._outputPath, styleEntry.output, outputFileName);
}
else {
if (!outputExtRegExp.test(extName)) {
throw new Error(`Unsupported style output file '${styleEntry.input}', correct value in 'projects[${projectName}].tasks.build.style.compilations[${i}].output'.`);
}
outputFilePath = path.resolve(buildConfig._outputPath, styleEntry.output);
}
}
else {
const outputFileName = path.basename(inputFilePath).replace(inputExtRegExp, '.css');
outputFilePath = path.resolve(buildConfig._outputPath, outputFileName);
}
let includePaths = [];
if (styleEntry.includePaths) {
includePaths = styleEntry.includePaths.map((includePath) => path.resolve(projectRoot, includePath));
}
else if (styleOptions.includePaths) {
includePaths = styleOptions.includePaths.map((includePath) => path.resolve(projectRoot, includePath));
}
let sourceMap = true;
if (styleEntry.sourceMap != null) {
sourceMap = styleEntry.sourceMap;
}
else if (styleOptions.sourceMap != null) {
sourceMap = styleOptions.sourceMap;
}
let sourceMapContents = true;
if (styleEntry.sourceMapContents != null) {
sourceMapContents = styleEntry.sourceMapContents;
}
else if (styleOptions.sourceMapContents != null) {
sourceMapContents = styleOptions.sourceMapContents;
}
let vendorPrefixes = true;
if (styleEntry.vendorPrefixes != null) {
vendorPrefixes = styleEntry.vendorPrefixes;
}
else if (styleOptions.vendorPrefixes != null) {
vendorPrefixes = styleOptions.vendorPrefixes;
}
let minify = true;
if (styleEntry.minify != null) {
minify = styleEntry.minify;
}
else if (styleOptions.minify != null) {
minify = styleOptions.minify;
}
const minOutputFilePath = path.resolve(path.dirname(outputFilePath), `${path.parse(outputFilePath).name}.min.css`);
if (!packageJsonStyleEntry && styleOptions.addToPackageJson !== false) {
packageJsonStyleEntry = utils_1.normalizePath(path.relative(buildConfig._packageJsonOutDir, outputFilePath));
}
buildConfig._styleEntries.push(Object.assign(Object.assign({}, styleEntry), { _inputFilePath: inputFilePath, _outputFilePath: outputFilePath, _includePaths: includePaths, _sourceMap: sourceMap, _sourceMapContents: sourceMapContents, _vendorPrefixes: vendorPrefixes, _minify: minify, _minOutputFilePath: minOutputFilePath }));
}
if (styleOptions.addToPackageJson !== false && packageJsonStyleEntry) {
buildConfig._packageJsonEntryPoint.style = packageJsonStyleEntry;
}
}
exports.prepareStyles = prepareStyles;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"prepare-styles.js","sourceRoot":"./","sources":["helpers/prepare-styles.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\n\nimport { pathExists } from 'fs-extra';\n\nimport { AutoPrefixerOptions, BuildConfigInternal, CleanCSSOptions } from '../models';\nimport { normalizePath } from '../utils';\n\nconst inputExtRegExp = /\\.(sass|scss|css)$/i;\nconst outputExtRegExp = /\\.css$/i;\n\nexport async function prepareStyles(buildConfig: BuildConfigInternal): Promise<void> {\n    if (!buildConfig.style) {\n        return;\n    }\n\n    const styleOptions = buildConfig.style;\n\n    if (!styleOptions.compilations || !styleOptions.compilations.length) {\n        return;\n    }\n\n    const projectName = buildConfig._projectName;\n    const projectRoot = buildConfig._projectRoot;\n    let packageJsonStyleEntry: string | undefined;\n\n    for (let i = 0; i < styleOptions.compilations.length; i++) {\n        const styleEntry = styleOptions.compilations[i];\n        if (!styleEntry.input || !styleEntry.input.trim().length) {\n            throw new Error(\n                `Style input file is required, please correct value in 'projects[${projectName}].tasks.build.style.compilations[${i}].input'.`\n            );\n        }\n\n        if (!inputExtRegExp.test(styleEntry.input)) {\n            throw new Error(\n                `Unsupported style input file '${styleEntry.input}', please correct value in 'projects[${projectName}].tasks.build.style.compilations[${i}].input'.`\n            );\n        }\n\n        const inputFilePath = path.resolve(projectRoot, styleEntry.input);\n        const inputFileExists = await pathExists(inputFilePath);\n        if (!inputFileExists) {\n            throw new Error(\n                `Style input file '${inputFilePath}' doesn't exist, please correct value in 'projects[${projectName}].tasks.build.style.compilations[${i}].input'.`\n            );\n        }\n\n        let outputFilePath: string;\n\n        if (styleEntry.output) {\n            const extName = path.extname(styleEntry.output);\n\n            if (!extName || styleEntry.output.endsWith('/')) {\n                const outputFileName = path.basename(inputFilePath).replace(inputExtRegExp, '.css');\n                outputFilePath = path.resolve(buildConfig._outputPath, styleEntry.output, outputFileName);\n            } else {\n                if (!outputExtRegExp.test(extName)) {\n                    throw new Error(\n                        `Unsupported style output file '${styleEntry.input}', correct value in 'projects[${projectName}].tasks.build.style.compilations[${i}].output'.`\n                    );\n                }\n\n                outputFilePath = path.resolve(buildConfig._outputPath, styleEntry.output);\n            }\n        } else {\n            const outputFileName = path.basename(inputFilePath).replace(inputExtRegExp, '.css');\n            outputFilePath = path.resolve(buildConfig._outputPath, outputFileName);\n        }\n\n        let includePaths: string[] = [];\n        if (styleEntry.includePaths) {\n            includePaths = styleEntry.includePaths.map((includePath: string) => path.resolve(projectRoot, includePath));\n        } else if (styleOptions.includePaths) {\n            includePaths = styleOptions.includePaths.map((includePath: string) =>\n                path.resolve(projectRoot, includePath)\n            );\n        }\n\n        let sourceMap = true;\n        if (styleEntry.sourceMap != null) {\n            sourceMap = styleEntry.sourceMap;\n        } else if (styleOptions.sourceMap != null) {\n            sourceMap = styleOptions.sourceMap;\n        }\n\n        let sourceMapContents = true;\n        if (styleEntry.sourceMapContents != null) {\n            sourceMapContents = styleEntry.sourceMapContents;\n        } else if (styleOptions.sourceMapContents != null) {\n            sourceMapContents = styleOptions.sourceMapContents;\n        }\n\n        let vendorPrefixes: boolean | AutoPrefixerOptions = true;\n        if (styleEntry.vendorPrefixes != null) {\n            vendorPrefixes = styleEntry.vendorPrefixes;\n        } else if (styleOptions.vendorPrefixes != null) {\n            vendorPrefixes = styleOptions.vendorPrefixes;\n        }\n\n        let minify: boolean | CleanCSSOptions = true;\n        if (styleEntry.minify != null) {\n            minify = styleEntry.minify;\n        } else if (styleOptions.minify != null) {\n            minify = styleOptions.minify;\n        }\n\n        const minOutputFilePath = path.resolve(\n            path.dirname(outputFilePath),\n            `${path.parse(outputFilePath).name}.min.css`\n        );\n\n        if (!packageJsonStyleEntry && styleOptions.addToPackageJson !== false) {\n            packageJsonStyleEntry = normalizePath(path.relative(buildConfig._packageJsonOutDir, outputFilePath));\n        }\n\n        buildConfig._styleEntries.push({\n            ...styleEntry,\n            _inputFilePath: inputFilePath,\n            _outputFilePath: outputFilePath,\n            _includePaths: includePaths,\n            _sourceMap: sourceMap,\n            _sourceMapContents: sourceMapContents,\n            _vendorPrefixes: vendorPrefixes,\n            _minify: minify,\n            _minOutputFilePath: minOutputFilePath\n        });\n    }\n\n    if (styleOptions.addToPackageJson !== false && packageJsonStyleEntry) {\n        buildConfig._packageJsonEntryPoint.style = packageJsonStyleEntry;\n    }\n}\n"]}