This repository has been archived by the owner on Jul 13, 2020. It is now read-only.
/
tsImports.ts
52 lines (46 loc) · 1.96 KB
/
tsImports.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
/*
* Copyright © 2019 Atomist, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { projectUtils } from "@atomist/automation-client";
import { AutofixRegistration } from "@atomist/sdm";
/**
* Sort and format TypeScipt imports in a standard way.
* @type {{name: string; pushTest: PredicatePushTest; transform: (p) => Promise<Project>}}
*/
export const TypeScriptImportsAutofix: AutofixRegistration = {
name: "TypeScript imports",
transform: async p => {
const regexp = new RegExp(`import\\s*?{([\\sa-zA-Z,-]*?)}\\s*from\\s*"([@\\S]*)";`, "gi");
const files = await projectUtils.toPromise(p.streamFiles("**/*.ts"));
for (const f of files) {
regexp.lastIndex = 0;
let file = f.getContentSync();
let match;
// tslint:disable-next-line:no-conditional-assignment
while (match = regexp.exec(file)) {
const imports = match[1].split(",").map(i => i.trim());
const module = match[2];
if (imports.length > 1) {
file = file.replace(match[0], `import {\n ${imports.filter(i => i.length > 0)
.sort((f1, f2) => f1.localeCompare(f2)).join(",\n ")},\n} from "${module}";`);
} else {
file = file.replace(match[0], `import { ${imports[0]} } from "${module}";`);
}
}
f.setContentSync(file);
}
return p;
},
};