UNPKG

14.2 kBJavaScriptView Raw
1var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2 return new (P || (P = Promise))(function (resolve, reject) {
3 function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
4 function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
5 function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }
6 step((generator = generator.apply(thisArg, _arguments || [])).next());
7 });
8};
9Object.defineProperty(exports, "__esModule", { value: true });
10const fs = require("mz/fs");
11const os = require("os");
12const path = require("path");
13const Helpers = require("./helpers");
14const IMPORT_PATTERN = /@import ['"](.+)['"];/g;
15const COMMENTED_IMPORT_PATTERN = /\/\/@import '(.+)';/g;
16const FILE_EXTENSION = ".scss";
17class Bundle {
18 static Bundle(file) {
19 return __awaiter(this, void 0, void 0, function* () {
20 let content = yield fs.readFile(file, "utf-8");
21 return yield this.bundle(file, content);
22 });
23 }
24 static BundleAll(files) {
25 return __awaiter(this, void 0, void 0, function* () {
26 let resultsPromises = files.map(this.Bundle);
27 return yield Promise.all(resultsPromises);
28 });
29 }
30 static bundle(filePath, content, filesContents) {
31 return __awaiter(this, void 0, void 0, function* () {
32 if (filesContents == null) {
33 filesContents = {};
34 }
35 // Remove commented imports
36 content = content.replace(COMMENTED_IMPORT_PATTERN, "");
37 // Resolve path to work only with full paths
38 filePath = path.resolve(filePath);
39 let dirname = path.dirname(filePath);
40 if (filesContents[filePath] == null) {
41 filesContents[filePath] = content;
42 }
43 let importsPromises = Helpers.getAllMatches(content, IMPORT_PATTERN).map((match) => __awaiter(this, void 0, void 0, function* () {
44 let importName = match[1];
45 // Append extension if it's absent
46 if (importName.indexOf(FILE_EXTENSION) === -1) {
47 importName += FILE_EXTENSION;
48 }
49 let fullPath = path.resolve(dirname, importName);
50 let importData = {
51 importString: match[0],
52 path: importName,
53 fullPath: fullPath,
54 found: false
55 };
56 try {
57 yield fs.access(fullPath);
58 importData.found = true;
59 }
60 catch (error) {
61 let underscoredFilePath = path.join(dirname, `_${importName}`);
62 try {
63 yield fs.access(underscoredFilePath);
64 importData.fullPath = underscoredFilePath;
65 importData.found = true;
66 }
67 catch (underscoreErr) {
68 // Neither file, nor partial was found
69 }
70 }
71 return importData;
72 }));
73 let imports = yield Promise.all(importsPromises);
74 let allImports = [];
75 for (let imp of imports) {
76 // Push current import
77 allImports.push(imp);
78 let contentToReplace;
79 if (imp.found && filesContents[imp.fullPath] == null) {
80 let impContent = yield fs.readFile(imp.fullPath, "utf-8");
81 let bundledImport = yield this.bundle(imp.fullPath, impContent);
82 filesContents[imp.fullPath] = bundledImport.content;
83 allImports = allImports.concat(bundledImport.imports);
84 }
85 contentToReplace = filesContents[imp.fullPath];
86 if (contentToReplace == null) {
87 contentToReplace = `/*** IMPORTED FILE NOT FOUND ***/${os.EOL}${imp.importString}/*** --- ***/`;
88 }
89 content = content.replace(imp.importString, contentToReplace);
90 }
91 return {
92 content: content,
93 filePath: filePath,
94 imports: allImports
95 };
96 });
97 }
98}
99exports.Bundle = Bundle;
100//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bundle.js","sourceRoot":"","sources":["../src/bundle.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from \"mz/fs\";\r\nimport * as os from \"os\";\r\nimport * as path from \"path\";\r\n\r\nimport * as Helpers from \"./helpers\";\r\n\r\nconst IMPORT_PATTERN = /@import ['\"](.+)['\"];/g;\r\nconst COMMENTED_IMPORT_PATTERN = /\\/\\/@import '(.+)';/g;\r\nconst FILE_EXTENSION = \".scss\";\r\n\r\ninterface Dictionary {\r\n    [id: string]: string;\r\n}\r\n\r\ninterface ImportData {\r\n    importString: string;\r\n    path: string;\r\n    fullPath: string;\r\n    found: boolean;\r\n}\r\n\r\ninterface BundleResult {\r\n    imports: ImportData[];\r\n    filePath: string;\r\n    content: string;\r\n}\r\n\r\nexport class Bundle {\r\n    public static async Bundle(file: string): Promise<BundleResult> {\r\n        let content = await fs.readFile(file, \"utf-8\");\r\n        return await this.bundle(file, content);\r\n    }\r\n\r\n    public static async BundleAll(files: string[]): Promise<BundleResult[]> {\r\n        let resultsPromises = files.map(this.Bundle);\r\n        return await Promise.all(resultsPromises);\r\n    }\r\n\r\n    private static async bundle(filePath: string, content: string, filesContents?: Dictionary): Promise<BundleResult> {\r\n        if (filesContents == null) {\r\n            filesContents = {};\r\n        }\r\n\r\n        // Remove commented imports\r\n        content = content.replace(COMMENTED_IMPORT_PATTERN, \"\");\r\n\r\n        // Resolve path to work only with full paths\r\n        filePath = path.resolve(filePath);\r\n\r\n        let dirname = path.dirname(filePath);\r\n\r\n        if (filesContents[filePath] == null) {\r\n            filesContents[filePath] = content;\r\n        }\r\n\r\n        let importsPromises = Helpers.getAllMatches(content, IMPORT_PATTERN).map(async match => {\r\n            let importName = match[1];\r\n            // Append extension if it's absent\r\n            if (importName.indexOf(FILE_EXTENSION) === -1) {\r\n                importName += FILE_EXTENSION;\r\n            }\r\n            let fullPath = path.resolve(dirname, importName);\r\n\r\n            let importData: ImportData = {\r\n                importString: match[0],\r\n                path: importName,\r\n                fullPath: fullPath,\r\n                found: false\r\n            };\r\n\r\n            try {\r\n                await fs.access(fullPath);\r\n                importData.found = true;\r\n            } catch (error) {\r\n                let underscoredFilePath = path.join(dirname, `_${importName}`);\r\n                try {\r\n                    await fs.access(underscoredFilePath);\r\n                    importData.fullPath = underscoredFilePath;\r\n                    importData.found = true;\r\n                } catch (underscoreErr) {\r\n                    // Neither file, nor partial was found\r\n                }\r\n            }\r\n\r\n            return importData;\r\n        });\r\n\r\n        let imports = await Promise.all(importsPromises);\r\n        let allImports: ImportData[] = [];\r\n        for (let imp of imports) {\r\n            // Push current import\r\n            allImports.push(imp);\r\n\r\n            let contentToReplace;\r\n            if (imp.found && filesContents[imp.fullPath] == null) {\r\n                let impContent = await fs.readFile(imp.fullPath, \"utf-8\");\r\n                let bundledImport = await this.bundle(imp.fullPath, impContent);\r\n                filesContents[imp.fullPath] = bundledImport.content;\r\n                allImports = allImports.concat(bundledImport.imports);\r\n            }\r\n\r\n            contentToReplace = filesContents[imp.fullPath];\r\n\r\n            if (contentToReplace == null) {\r\n                contentToReplace = `/*** IMPORTED FILE NOT FOUND ***/${os.EOL}${imp.importString}/*** --- ***/`;\r\n            }\r\n\r\n            content = content.replace(imp.importString, contentToReplace);\r\n        }\r\n\r\n        return {\r\n            content: content,\r\n            filePath: filePath,\r\n            imports: allImports\r\n        };\r\n    }\r\n}\r\n"]}
\No newline at end of file