1 | var __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 | };
|
9 | Object.defineProperty(exports, "__esModule", { value: true });
|
10 | const fs = require("mz/fs");
|
11 | const os = require("os");
|
12 | const path = require("path");
|
13 | const Helpers = require("./helpers");
|
14 | const IMPORT_PATTERN = /@import ['"](.+)['"];/g;
|
15 | const COMMENTED_IMPORT_PATTERN = /\/\/@import '(.+)';/g;
|
16 | const FILE_EXTENSION = ".scss";
|
17 | class 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 | }
|
99 | exports.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 |